salt@0.15.3 vulnerabilities

Portable, distributed, remote execution and configuration management system

Direct Vulnerabilities

Known vulnerabilities in the salt package. This does not include vulnerabilities belonging to this package’s dependencies.

How to fix?

Automatically find and fix vulnerabilities affecting your projects. Snyk scans for vulnerabilities and provides fixes for free.

Fix for free
VulnerabilityVulnerable Version
  • H
Directory Traversal

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Directory Traversal via the serve_file method, due to insufficient checks in the salt/fileserver/roots.py file.

How to fix Directory Traversal?

Upgrade salt to version 3005.5 or higher.

[,3005.5)
  • H
Directory Traversal

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Directory Traversal when establishing the syndic cache directory on the master.

How to fix Directory Traversal?

Upgrade salt to version 3005.5 or higher.

[,3005.5)
  • M
Improper Access Control

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Improper Access Control. The Salt-SSH pre-flight option copies the script to the target at a predictable path, which allows an attacker to force Salt-SSH to run their script. If an attacker has access to the target VM and knows the path to the pre-flight script before it runs they can ensure Salt-SSH runs their script with the privileges of the user running Salt-SSH.

How to fix Improper Access Control?

Upgrade salt to version 3005.4, 3006.4 or higher.

[,3005.4)[3006.0rc1,3006.4)
  • M
Information Exposure

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Information Exposure and other possible impacts, due to a hash collision when using Git Providers reading from different environments. If Git Providers read from the wrong environment because they get the same cache directory base name, they could get bad data or unintended data. This could also lead to wrongful executions, data corruption or a crash.

How to fix Information Exposure?

Upgrade salt to version 3005.2, 3006.2 or higher.

[,3005.2)[3006.0rc1,3006.2)
  • H
Denial of Service (DoS)

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Denial of Service (DoS) in the error message decoding mechanism in minion return. If the request server receives a number of requests equal to the number of worker threads, the master will become unresponsive to return requests until it is restarted.

How to fix Denial of Service (DoS)?

Upgrade salt to version 3005.2, 3006.2 or higher.

[,3005.2)[3006.0rc1,3006.2)
  • H
Buffer Overflow

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Buffer Overflow via the status function.

How to fix Buffer Overflow?

There is no fixed version for salt.

[0,)
  • H
Denial of Service (DoS)

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Denial of Service (DoS) in junos ifconfig output parsing.

How to fix Denial of Service (DoS)?

Upgrade salt to version 3004.1 or higher.

[,3004.1)
  • H
Access Restriction Bypass

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Access Restriction Bypass where a previously authorized user whose account is locked can still run Salt commands. This affects both local shell accounts with an active session and salt-api users that authenticate via PAM eauth.

Workaround: If the user can not upgrade to the fixed version, it is possible to:

  1. remove locked accounts rather than rely on Salt’s PAM eauth functionality.

  2. change to a different eauth module.

How to fix Access Restriction Bypass?

Upgrade salt to version 3002.9, 3003.5, 3004.2 or higher.

[,3002.9)[3003,3003.5)[3004,3004.2)
  • H
Improper Access Control

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Improper Access Control which allows users specified in the publisher_acl to publish authorized commands to any configured minion. Note: This requires a syndic master combined with publisher_acl configured on the Master-of-Masters.

How to fix Improper Access Control?

Upgrade salt to version 3002.8, 3003.4, 3004.1 or higher.

[,3002.8)[3003,3003.4)[3004,3004.1)
  • M
Denial of Service (DoS)

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Denial of Service (DoS). A MiTM attacker to force a minion process to stop by impersonating a master.

How to fix Denial of Service (DoS)?

Upgrade salt to version 3002.8, 3003.4, 3004.1 or higher.

[,3002.8)[3003,3003.4)[3004,3004.1)
  • H
Access Restriction Bypass

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Access Restriction Bypass which can allow attackers to substitute arbitrary pillar data, because Salt Masters do not sign pillar data with the minion’s public key.

How to fix Access Restriction Bypass?

Upgrade salt to version 3002.8, 3003.4, 3004.1 or higher.

[,3002.8)[3003,3003.4)[3004,3004.1)
  • M
Authentication Bypass

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Authentication Bypass which can result in an attacker replaying job publishes causing minions to run old jobs. File server replies can also be re-played. A sufficient craft attacker could gain root access to minion under certain scenarios.

How to fix Authentication Bypass?

Upgrade salt to version 3002.8, 3003.4, 3004.1 or higher.

[,3002.8)[3003,3003.4)[3004,3004.1)
  • C
SQL Injection

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to SQL Injection via the mysql.user_chpass function in the MySQL module of the package. It can lead to RCE.

How to fix SQL Injection?

Upgrade salt to version 2018.3.4, 2019.2.1 or higher.

[,2018.3.4)[2019.2.0,2019.2.1)
  • H
Privilege Escalation

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Privilege Escalation. A user who has control of the source and source_hash URLs, can gain full file system access as root on a salt minion.

How to fix Privilege Escalation?

Upgrade salt to version 3001.8, 3002.7, 3003.3 or higher.

[,3001.8)[3002rc1,3002.7)[3003rc1,3003.3)
  • M
Privilege Escalation

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Privilege Escalation. The salt minion installer will accept and use a minion config file at C:\salt\conf if that file is in place before the installer is run. This allows for a malicious actor to subvert the proper behavior of the given minion software.

The malicious actor must have access to a Windows system, permission to create directories and files on the root of the system drive, and create a malicious minion config at C:\salt\conf.

How to fix Privilege Escalation?

Upgrade salt to version 3001.8, 3002.7, 3003.3 or higher.

[,3001.8)[3002rc1,3002.7)[3003rc1,3003.3)
  • H
Command Injection

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Command Injection. The Salt-API’s SSH client is vulnerable to a shell injection by including ProxyCommand in an argument, or via ssh_options provided in an API request.

How to fix Command Injection?

Upgrade salt to version 3002.5, 3001.6, 3000.8 or higher.

[3002rc1,3002.5)[3001rc1,3001.6)[,3000.8)
  • H
Improper Authorization

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Improper Authorization. The SaltAPI does not honor eauth credentials for the wheel_async client. Thus, an attacker can remotely run any wheel modules on the master.

How to fix Improper Authorization?

Upgrade salt to version 3002.5, 3001.6, 3000.8 or higher.

[3002rc1,3002.5)[3001rc1,3001.6)[,3000.8)
  • M
Directory Traversal

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Directory Traversal. The salt.wheel.pillar_roots.write method is vulnerable to directory traversal. Unauthorized access to wheel_async through salt-api can execute arbitrarily code/command.

How to fix Directory Traversal?

Upgrade salt to version 3002.5, 3001.6, 3000.8 or higher.

[3002rc1,3002.5)[3001rc1,3001.6)[,3000.8)
  • H
Server-side Template Injection (SSTI)

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Server-side Template Injection (SSTI). The jinja renderer does not protect against server-side template injection attacks. This could be abused via the SaltAPI fix directory traversal in wheel.pillar_roots.write.

How to fix Server-side Template Injection (SSTI)?

Upgrade salt to version 3002.5, 3001.6, 3000.8 or higher.

[3002rc1,3002.5)[3001rc1,3001.6)[,3000.8)
  • M
Command Injection

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Command Injection. A command injection in salt.utils.thin.gen_thin() exists

How to fix Command Injection?

Upgrade salt to version 3002.5, 3001.6, 3000.8 or higher.

[3002rc1,3002.5)[3001rc1,3001.6)[,3000.8)
  • M
Sensitive Data Exposure

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Sensitive Data Exposure webutils write passwords in cleartext to /var/log/salt/minion.

How to fix Sensitive Data Exposure?

Upgrade salt to version 3002.5, 3001.6, 3000.8 or higher.

[3002rc1,3002.5)[3001rc1,3001.6)[,3000.8)
  • H
Man-in-the-Middle (MitM)

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Man-in-the-Middle (MitM). The SaltStack Code base not validating SSL/TLS certificate of the server, which might allow attackers to obtain sensitive information via a man-in-the-middle attack

How to fix Man-in-the-Middle (MitM)?

Upgrade salt to version 3002.5, 3001.6, 3000.8 or higher.

[3002rc1,3002.5)[3001rc1,3001.6)[,3000.8)
  • M
Sensitive Data Exposure

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Sensitive Data Exposure eauth tokens can be used once after expiration.

How to fix Sensitive Data Exposure?

Upgrade salt to version 3002.5, 3001.6, 3000.8 or higher.

[3002rc1,3002.5)[3001rc1,3001.6)[,3000.8)
  • M
Local Privilege Escalation

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Local Privilege Escalation. A privilege escalation is possible on a SaltStack minion when an unprivileged user is able to create files in any non-blacklisted directory via a command injection in a process name.

How to fix Local Privilege Escalation?

Upgrade salt to version 3002.5, 3001.6, 3000.8 or higher.

[3002rc1,3002.5)[3001rc1,3001.6)[,3000.8)
  • H
Improper Certificate Validation

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Improper Certificate Validation. Several places where Salt was not verifying the SSL cert by default. This has now been remediated.

How to fix Improper Certificate Validation?

Upgrade salt to version 3002.5, 3001.6, 3000.8 or higher.

[3002rc1,3002.5)[3001rc1,3001.6)[,3000.8)
  • H
Remote Code Execution (RCE)

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Remote Code Execution (RCE). Sending crafted web requests to the Salt API, with the SSH client enabled, can result in shell injection.

How to fix Remote Code Execution (RCE)?

Upgrade salt to version 3000.4, 3001.2 or higher.

[,3000.4)[3001,3001.2)
  • M
Improper Access Control

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Improper Access Control. When using the functions create_ca, create_csr, and create_self_signed_cert in the tls execution module, it does not ensure the key was created with the correct permissions, creating keys with world-readable permissions.

How to fix Improper Access Control?

Upgrade salt to version 3000.4, 3001.2, 3002.1 or higher.

[,3000.4)[3001,3001.2)[3002,3002.1)
  • H
Directory Traversal

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Directory Traversal. The wheel module contains commands used to read and write files under specific directory paths. The inputs to these functions are concatenated with the target directory and the resulting path is not canonicalized, leading to an escape of the intended path restriction.

The get_token() method of the salt.tokens.localfs class (which is exposed to unauthenticated requests by the ClearFuncs class) fails to sanitize the token input parameter which is then used as a filename, allowing insertion of ".." path elements and thus reading of files outside of the intended directory. The only restriction is that the file has to be deserializable by salt.payload.Serial.loads().

How to fix Directory Traversal?

Upgrade salt to version 2019.2.4, 3000.2 or higher.

[,2019.2.4)[3000,3000.2)
  • C
Arbitrary Code Execution

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Arbitrary Code Execution. The salt-master process ClearFuncs class does not properly validate method calls. This allows a remote user to access some methods without authentication. These methods can be used to retrieve user tokens from the salt master and/or run arbitrary commands on salt minions.

How to fix Arbitrary Code Execution?

Upgrade salt to version 2019.2.4, 3000.2 or higher.

[,2019.2.4)[3000,3000.2)
  • H
Arbitrary Code Execution

salt is a new approach to infrastructure management built on a dynamic communication bus. Salt can be used for data-driven orchestration, remote execution for any infrastructure, configuration management for any app stack, and much more.

Affected versions of this package are vulnerable to Arbitrary Code Execution. Insecure usage of a predictable directory in /tmp and on minion allows any minion with an accepted key to send commands to the master as any other minion.

How to fix Arbitrary Code Execution?

Upgrade salt to version 0.17.1 or higher.

[,0.17.1)
  • M
Directory Traversal

salt is a Software to automate the management and configuration of any infrastructure or application at scale.

Affected versions of this package are vulnerable to Directory Traversal via the salt-api, An attacker could determine what files exist on a server when querying /run or /events.

How to fix Directory Traversal?

Upgrade salt to versions 2017.7.8, 2018.3.3 or higher.

[,2017.7.8)[2018.0,2018.3.3)
  • H
Arbitrary Command Execution

salt is a software to automate the management and configuration of any infrastructure or application at scale.

Affected versions of this package are vulnerable to Arbitrary Command Execution and Authentication Bypass via the salt-api.

How to fix Arbitrary Command Execution?

Upgrade salt to version 2017.7.8, 2018.3.3 or higher.

[,2017.7.8)[2018.0.0,2018.3.3)
  • H
Arbitrary YAML Code Execution

salt is a Portable, distributed, remote execution and configuration management system.

Affected versions of this package are vulnerable to Arbitrary YAML Code Execution.

How to fix Arbitrary YAML Code Execution?

Upgrade salt to version 0.17.1 or higher.

[,0.17.1)
  • C
Directory Traversal

salt is a Portable, distributed, remote execution and configuration management system.

Affected versions of this package are vulnerable to Directory Traversal attacks. A remote attacker with incorrect credentials could authenticate to a master via a crafted minion ID.

How to fix Directory Traversal?

Upgrade salt to version 2016.11.7, 2017.7.1 or higher.

[,2016.11.7)[2017.7.0,2017.7.1)
  • H
Credential Exposure

salt is a Portable, distributed, remote execution and configuration management system.

Affected versions of this package are vulnerable to Credential Exposure. It copied permissions over configuration from the Salt Master without adjusting, which might leak credentials to local attackers on configured clients.

How to fix Credential Exposure?

Upgrade salt to version 2016.11.4 or higher.

[,2016.11.4)
  • C
Privilege Escalation

salt is a Portable, distributed, remote execution and configuration management system.

Affected versions of this package are vulnerable to Privilege Escalation. It does not properly drop group privileges, which makes it easier for remote attackers to gain privileges.

How to fix Privilege Escalation?

Upgrade salt to version 0.17.1 or higher.

[,0.17.1)
  • M
Client Impersonation

salt is a Portable, distributed, remote execution and configuration management system.

Affected versions of this package are vulnerable to Client Impersonation. Remote authenticated minions could impersonate arbitrary minions via a crafted minion with a valid key.

How to fix Client Impersonation?

Upgrade salt to version 0.17.1 or higher.

[0.15,0.17.1)
  • M
Arbitrary Routine Execution

salt is a Portable, distributed, remote execution and configuration management system

Affected versions of this package are vulnerable to Arbitrary Routine Execution. Remote authenticated users who are using external authentication or client ACL could execute restricted routines by embedding the routine in another routine.

How to fix Arbitrary Routine Execution?

Upgrade salt to version 0.17.1 or higher.

[,0.17.1)
  • M
Authentication Bypass

salt is a Portable, distributed, remote execution and configuration management system.

Affected versions of this package are vulnerable to Authentication Bypass. When PAM external authentication is enabled, An attacker could bypass the configured authentication service by passing an alternate service with a command sent to LocalClient.

How to fix Authentication Bypass?

Upgrade salt to versions 2015.5.10, 2015.8.8 or higher.

[,2015.5.10)[2015.8.0,2015.8.8)
  • C
Client Impersonation

salt is a Software to automate the management and configuration of any infrastructure or application at scale.

Affected versions of this package are vulnerable to Client Impersonation. Compromised salt-minions can impersonate the salt-master.

How to fix Client Impersonation?

Upgrade salt to version 2016.3.6 or higher.

[,2016.3.6)
  • H
Arbitrary File Creation

salt is a new approach to infrastructure management built on a dynamic communication bus.

Affected versions of this package are vulnerable to Arbitrary File Creation. It allows local users to have an unspecified impact via vectors related to temporary file creation in (1) seed.py, (2) salt-ssh, or (3) salt-cloud.

How to fix Arbitrary File Creation?

Upgrade salt to version 2014.1.10 or higher.

[,2014.1.10)
  • M
Insecure use of /tmp folder

salt is a new approach to infrastructure management built on a dynamic communication bus.

Affected versions of this package are vulnerable to Insecure use of /tmp folder.

How to fix Insecure use of /tmp folder?

Upgrade salt to version 2014.7.4 or higher.

[,2014.7.4)
  • M
Information Exposure

salt is a Portable, distributed, remote execution and configuration management system.

Affected versions of the package are vulnerable to Information Disclosure. salt before 2015.5.5 leaks git usernames and passwords to the log.

How to fix Information Exposure?

Upgrade salt to version 2015.5.5 or higher.

[,2015.5.5)
  • H
Arbitrary Code Execution

salt is a Portable, distributed, remote execution and configuration management system.

Affected versions of this package are vulnerable to Arbitrary Code Execution. When using the local_batch client from salt-api in SaltStack Salt before 2015.8.13, 2016.3.x before 2016.3.5, and 2016.11.x before 2016.11.2, external authentication is not respected, enabling all authentication to be bypassed.

[,2015.8.13)[2016.3,2016.3.5)[2016.11,2016.11.2)
  • H
Arbitrary Code Execution

salt is a Portable, distributed, remote execution and configuration management system.

Affected versions of this package are vulnerable to Arbitrary Code Execution. When using the local_batch client from salt-api in SaltStack Salt before 2015.8.13, 2016.3.x before 2016.3.5, and 2016.11.x before 2016.11.2, external authentication is not respected, enabling all authentication to be bypassed.

[,2015.8.12)[2016.3,2016.3.5)[2016.11,2016.11.2)
  • C
Information Exposure

salt is a Portable, distributed, remote execution and configuration management system.

Affected versions of this package are vulnerable to information Exposure. It allows deleted minions to read or write to minions with the same id, related to caching.

[,2015.8.11)
  • L
Information Exposure

salt is a Portable, distributed, remote execution and configuration management system.

Affected versions of this package are vulnerable to Information Exposure. The state.sls function in Salt before 2015.8.3 uses weak permissions on the cache data, which allows local users to obtain sensitive information by reading the file.

[,2015.8.3)
  • M
Insecure Temporary File

salt is a Portable, distributed, remote execution and configuration management system.

Affected versions of this package are vulnerable to Insecure Temporary File.

modules/serverdensity_device.py in SaltStack before 2014.7.4 does not properly handle files in /tmp.

[,2014.7.4)