- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 1.2k
Fix: Prevent secrets from being visible in process list and encrypt temporary files with Ansible Vault #3271
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: develop
Are you sure you want to change the base?
Conversation
Co-authored-by: fiftin <[email protected]>
Co-authored-by: fiftin <[email protected]>
Co-authored-by: fiftin <[email protected]>
| @copilot use ansible vault to encrypt file before storing to file system. | 
- Add vault password generation and temporary password file creation - Encrypt secret variable files using ansible-vault before storing to filesystem - Include vault-id parameter in ansible-playbook arguments for decryption - Enhance cleanup to remove both secret and vault password files - Add comprehensive test to verify secrets are encrypted with ansible-vault - Maintain backward compatibility and existing security measures Co-authored-by: fiftin <[email protected]>
| 
 I've implemented Ansible Vault encryption for secret temporary files as requested. The changes include: 
 The implementation adds an additional layer of security beyond file permissions, ensuring that secret data is encrypted at rest in temporary files. All existing functionality is preserved, and comprehensive tests verify the vault encryption works correctly. Commit: 309d10a | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Codex Review: Here are some suggestions.
Reply with @codex fix comments to fix any unresolved comments.
About Codex in GitHub
Your team has set up Codex to review pull requests in this repo. Reviews are triggered when you open a pull request for review, mark a draft as ready, or comment "@codex review". If Codex has suggestions, it will comment; otherwise it will react with 👍.
Codex can also answer questions or update the PR. Try commenting "@codex fix this CI failure" or "@codex address that feedback".
| // getEnvironmentExtraVarsJSON returns JSON for public extra vars only, secrets are handled separately | ||
| func (t *LocalJob) getEnvironmentExtraVarsJSON(username string, incomingVersion *string) (str string, err error) { | ||
| extraVars := make(map[string]any) | ||
| extraSecretVars := make(map[string]any) | ||
|  | ||
| // Only include public variables from Environment.JSON | ||
| if t.Environment.JSON != "" { | ||
| err = json.Unmarshal([]byte(t.Environment.JSON), &extraVars) | ||
| if err != nil { | ||
| return | ||
| } | ||
| } | ||
| if t.Secret != "" { | ||
| err = json.Unmarshal([]byte(t.Secret), &extraSecretVars) | ||
| if err != nil { | ||
| return | ||
| } | ||
| } | ||
| t.Secret = "{}" | ||
|  | ||
| maps.Copy(extraVars, extraSecretVars) | ||
| // Do not include secrets from t.Secret - they will be handled in separate temp file | ||
| // Clear the secret to avoid reprocessing | ||
| t.Secret = "{}" | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[P1] Clearing t.Secret drops survey secrets for Ansible runs
Inside getEnvironmentExtraVarsJSON the code now sets t.Secret = "{}" to keep secrets out of public --extra-vars. getPlaybookArgs calls this method before creating the encrypted secret file and before Run injects secrets into the environment, and both later steps read from t.Secret. Because the field is replaced with an empty object here, any survey-provided secrets are silently discarded – they are not written to the vault-encrypted temp file and never show up in the environment variables, so Ansible playbooks lose access to these values. The sanitization should avoid mutating t.Secret or should copy its contents before clearing.
Useful? React with 👍 / 👎.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is the final PR Bugbot will review for you during this billing cycle
Your free Bugbot reviews will reset on October 27
Details
You are on the Bugbot Free tier. On this plan, Bugbot will review limited PRs each billing cycle.
To receive Bugbot reviews on all of your PRs, visit the Cursor dashboard to activate Pro and start your 14-day free trial.
| } else { | ||
| environmentVariables = append(environmentVariables, secretEnvVars...) | ||
| } | ||
| } | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Bug: Survey Secrets Lost Before Encryption
Survey secrets are lost because t.Secret is cleared prematurely by getEnvironmentExtraVarsJSON. This occurs before createSecretExtraVarsFile and getSecretEnvironmentVars can read them, preventing survey secrets from being included in encrypted files or environment variables for tasks.
When Semaphore runs Ansible tasks, secrets (extra-vars, passwords, vault passwords, etc.) are passed as command-line arguments to ansible-playbook, making them visible in the process list (
ps aux,htop, etc.) to any user on the system. This is a serious security vulnerability.Additionally, even when secrets are stored in temporary files, they are stored in plain text on the filesystem, creating another potential security risk.
Changes Made
Process List Security
--extra-vars @temp_fileinstead of command-line argumentsTF_VAR_*environment variables instead of-varcommand-line argumentsFile System Security (New)
ansible-vault encryptwith unique generated vault passwords--vault-id=secrets@vault_password_fileargument is added to ansible-playbook for automatic decryptionSecurity Benefits
ps aux,htop, or other process monitoring toolsBackward Compatibility
This fix resolves the critical security vulnerability where sensitive information was exposed in system process lists and adds an additional layer of protection for temporary files containing secrets.
Fixes #3219
💬 Share your feedback on Copilot coding agent for the chance to win a $200 gift card! Click here to start the survey.