diff --git a/ci/spelling-config.json b/ci/spelling-config.json index a08a7b472..0ff8f65cf 100644 --- a/ci/spelling-config.json +++ b/ci/spelling-config.json @@ -7,30 +7,19 @@ ], "words": [ "ABAC", - "addfetnetgrent", "AEST", - "Anca", - "Aniszczyk", - "antifragile", "APAC", - "architecting", - "archives", - "Archivista", "ARMO", "ATT&CK", - "backdoors", + "Anca", + "Aniszczyk", + "Archivista", + "BYOK", "Benedictis", "Bottlerocket", - "buildinfo", "Buildpacks", - "BYOK", - "Cappos", - "cgroups", - "chainguard", - "cisecurity", "CISA", "CISO", - "cloudcustodian", "CLOMonitor", "CMMC", "CNCF", @@ -38,71 +27,132 @@ "CNSMAP", "CNSWP", "CNSWP's", - "codecov", + "COBIT", "CODEOWNERS", + "CVE", + "Cappos", "Configu", - "conftest", "Conjur", - "coreutils", - "containerd", "CrowdStrike", - "cryptomining", - "CVE", "Cyberattack", - "cybercriminals", "DAAS", "DAST", "DBIR", - "ddos", "DFIR", "Diffoscope", "Dockerfiles", - "dynatrace", "EIOPA", "EMEA", "EPSS", "ESMA", - "exfiltrate", - "exfiltration", - "explainability", - "exploitability", "Expressibility", + "FIPS", "Fianu", "Ficcaglia", - "FIPS", "Flannery", "Flibble", - "frontmatter", + "GUAC", "Gamal", - "gconv", - "gitsign", - "gittuf", "Grafeas", - "GUAC", - "helm", "HIPAA", - "Hirschberg", "HITRUST", - "hotspots", - "hyperconverged", + "Hirschberg", "Inclusivity", - "intercompatible", - "iscsi", "Istio", "Italarchivi", - "jwks", - "Kamus", - "kata", "KETRMAX", - "keycloak", + "Kamus", "Kjell", "Kritis", "Kube", - "kubecon", - "kubelet", "Kubernetes", "Kubescape", "Kyverno", + "MSSP", + "MTTR", + "Microbusiness", + "Microservices", + "NACLs", + "OSCAL", + "OSSF", + "OWASP", + "Oxley", + "PEAR", + "PHP", + "Packagist", + "Peribolos", + "Petya", + "Pronin", + "RBAC", + "RCOS", + "RSTUF", + "Ragashree", + "Razzak", + "Rebuilderd", + "Rego", + "Rensselaer", + "Roadmap", + "SAST", + "SBOM", + "SIEM", + "SLSA", + "SSCP", + "SSCSP", + "SSDF", + "SWID", + "Sarbanes", + "Sergey", + "Shlomo", + "Sigstore", + "SonarCloud", + "Syft", + "TAR", + "TOCTOU", + "TSSA", + "TTPS", + "Tekton", + "Twintag", + "Virtool", + "Wolt", + "Yubi", + "Zalman", + "Zeolla" + "addfetnetgrent", + "antifragile", + "architecting", + "archives", + "backdoors", + "buildinfo", + "cgroups", + "chainguard", + "cisecurity", + "cloudcustodian", + "codecov", + "conftest", + "containerd", + "coreutils", + "cryptomining", + "cybercriminals", + "ddos", + "dynatrace", + "exfiltrate", + "exfiltration", + "explainability", + "exploitability", + "frontmatter", + "gconv", + "gitsign", + "gittuf", + "helm", + "hotspots", + "hyperconverged", + "intercompatible", + "iscsi", + "jwks", + "kata", + "keycloak", + "kubecon", + "kubelet", "libc", "libgcrypt", "libpcre", @@ -113,90 +163,47 @@ "markdownlint", "memcpy", "microbusiness", - "Microbusiness", "microservices", - "Microservices", "minimalistic", "mitigations", - "MSSP", - "MTTR", - "NACLs", "netgroupcache", "oidc", "openfga", "opentelemetry", "operationalize", - "OSCAL", - "OSSF", - "OWASP", - "Oxley", - "Packagist", "pagefind", "pcre", - "PEAR", "pearweb", - "Peribolos", - "Petya", - "PHP", - "Pronin", "protobuf", "ptree", "pyproject", - "Ragashree", - "Razzak", - "RBAC", - "RCOS", "rebuilder", - "Rebuilderd", "refreshable", - "Rego", "relatability", "renovatebot", - "Rensselaer", - "Roadmap", "rootfs", - "RSTUF", "runtimes", "sandboxed", "sandboxing", - "Sarbanes", - "SAST", - "SBOM", "sdlc", "seccomp", "semgrep", - "Sergey", - "Shlomo", - "SIEM", - "Sigstore", - "SLSA", "snapshotters", "snyk", "spearphishing", "spiffe", - "SSCP", "sscsp", - "SSCSP", - "SSDF", "stdlib", "superseded", "supplychain", - "SWID", - "Syft", "syscall", - "TAR", - "Tekton", "timeframe", - "TOCTOU", "toolset", "triage", "triaged", "triaging", "trojanized", "trufflehog", - "TSSA", - "TTPS", - "Twintag", "unencrypted", "unpatched", "untampered", @@ -207,10 +214,5 @@ "venv", "vexy", "virtiofs", - "Virtool", - "Wolt", - "Yubi", - "Zalman", - "Zeolla" ] } diff --git a/community/assessments/projects/external-secrets/self-assessment.md b/community/assessments/projects/external-secrets/self-assessment.md index 5b4bafaef..75b111d56 100644 --- a/community/assessments/projects/external-secrets/self-assessment.md +++ b/community/assessments/projects/external-secrets/self-assessment.md @@ -1,4 +1,5 @@ # Self-assessment for External Secrets Operator (ESO) + This assessment was created by community members as part of the [Security Pals](https://github.com/cncf/tag-security/issues/1102) process, and is currently pending changes from the maintainer team. ## Table of contents @@ -35,25 +36,30 @@ This assessment was created by community members as part of the [Security Pals]( | Doc | url | | -- | -- | | Security file | [Security.md](https://github.com/external-secrets/external-secrets/blob/main/SECURITY.md) | -| Default and optional configs | https://external-secrets.io/latest/guides/security-best-practices| +| Default and optional configs | [Security Best Practices](https://external-secrets.io/latest/guides/security-best-practices)| ## Overview -External Secrets Operator (ESO) is a Kubernetes operator that integrates external secret management systems like AWS Secrets Manager, HashiCorp Vault, Google Secrets Manager, Azure Key Vault, IBM Cloud Secrets Manager, CyberArk Conjur and many more. The operator reads information from external APIs and automatically injects the values into a Kubernetes Secret. -
+External Secrets Operator (ESO) is a Kubernetes operator that integrates external secret management systems like AWS Secrets Manager, HashiCorp Vault, Google Secrets Manager, Azure Key Vault, IBM Cloud Secrets Manager, CyberArk Conjur and many more. The operator reads information from external APIs and automatically injects the values into a Kubernetes Secret. +![overview](assets/overview.png) ### Background -The External Secrets Operator (ESO) is a tool designed for Kubernetes, a widely-used system for automating the deployment, scaling, and management of containerized applications. ESO addresses a key challenge in this domain: secure and efficient management of sensitive configuration data, known as "secrets" (like passwords, API keys, etc.). Typically, managing these secrets within Kubernetes can be complex and risky if not handled properly. ESO simplifies this by integrating Kubernetes with external secret management services (such as AWS Secrets Manager or HashiCorp Vault), which specialize in securely storing and managing these secrets. This integration not only enhances security but also streamlines the process of injecting these secrets into Kubernetes applications. + +The External Secrets Operator (ESO) is a tool designed for Kubernetes, a widely-used system for automating the deployment, scaling, and management of containerized applications. ESO addresses a key challenge in this domain: secure and efficient management of sensitive configuration data, known as "secrets" (like passwords, API keys, etc.). + +Typically, managing these secrets within Kubernetes can be complex and risky if not handled properly. ESO simplifies this by integrating Kubernetes with external secret management services (such as AWS Secrets Manager or HashiCorp Vault), which specialize in securely storing and managing these secrets. This integration not only enhances security but also streamlines the process of injecting these secrets into Kubernetes applications. ### Actors #### 1. External Secret Management Systems + * Examples: AWS Secrets Manager, HashiCorp Vault. * Technical Details: These systems often employ hardware security modules (HSMs) for hardware-level encryption and secure key management. Utilize OAuth, JWT, or similar token-based authentication mechanisms, which provide robust and revocable access credentials. Feature dynamic secret creation, allowing secrets to be generated on-the-fly and automatically rotated, reducing the lifespan of any single secret. * Isolation: Network boundaries and authentication mechanisms separate these from the Kubernetes cluster. #### 2. Kubernetes Cluster (including ESO) + * Role: ESO bridges Kubernetes and external secret systems. * Integration and Communication: ESO uses the Kubernetes API to interact with the cluster, making use of client certificates for authentication or leveraging service account tokens for more granular control. * Employs custom resource definitions (CRDs) like ExternalSecret to define how external secrets should be fetched and synchronized. @@ -63,92 +69,108 @@ The External Secrets Operator (ESO) is a tool designed for Kubernetes, a widely- * Cert Controller: The Cert Controller is responsible for managing the TLS certificates that are used for secure communication within the Kubernetes cluster, particularly for the webhook service. * Webhook: The Webhook in ESO is used for various purposes, including mutating or validating `ExternalSecrets` and other related custom resources. It plays a critical role in ensuring the integrity and correctness of the `ExternalSecret` resources. - #### 3. Kubernetes Secrets + * Function: Store synchronized secrets within the cluster via ESO. * Isolation: Kubernetes namespaces and access policies provide compartmentalization. * Storage and Encryption: Kubernetes Secrets are, by default, stored in etcd, a distributed key-value store. Starting from Kubernetes v1.13, etcd data can be encrypted at rest. Integration with external KMS (Key Management Service) for enhanced encryption management of Secrets. * Access Control:Secrets are often accessed via environment variables or volume mounts in Kubernetes pods, with access strictly controlled based on the pod's service account permissions. - - +![component-overview](assets/component-overview.png) ### Actions + The actions performed by ESO to synchronize secrets from/to external sources from/into Kubernetes can be outlined focusing on security checks, data handling, and interactions: #### 1. Client Request to External Secret Management System + ESO, acting as a client, sends a request to an external secret management system (like AWS Secrets Manager). This request includes authentication and authorization checks to ensure that ESO is permitted to access the requested secrets. #### 2. Retrieval of Secrets + Upon successful authentication and authorization, the external system sends the requested secrets to ESO. These secrets are transmitted over secure, encrypted channels to ensure their confidentiality and integrity. #### 3. Validation and Transformation + ESO validates the format and integrity of the received secrets. If necessary, it transforms the data to a format compatible with Kubernetes Secrets. #### 4. Synchronization to Kubernetes Secrets + ESO then creates or updates Kubernetes Secret objects with the retrieved data. This step involves interacting with the Kubernetes API server, which includes RBAC checks to ensure that ESO has the necessary permissions to perform these operations. #### 5. Synchronization to Remote Provider + ESO can synchronize secrets back to the provider using PushSecrets. It will keep the remote secret updated based on metadata provided by the user and information about the provider. Based on policy, if the local secret is deleted, remote secrets can either be orphaned or deleted completely. #### 6. Use by Kubernetes Workloads + Applications or workloads running in Kubernetes can then access these secrets. Access to these secrets within Kubernetes is controlled by namespace-specific policies and RBAC, ensuring that only authorized workloads can retrieve them. To outline the actions performed by different components of the External Secrets Operator (ESO) that enable its proper functioning, we can break it down as follows: -#### 1. Core Controller Actions: +#### 1. Core Controller Actions + * Monitoring: Continuously watches for ExternalSecret objects within the Kubernetes cluster. * Secret Retrieval: Fetches secrets from external secret management systems (like AWS Secrets Manager, HashiCorp Vault) based on the details specified in ExternalSecret objects. * Data Transformation: Converts the fetched secrets into a format compatible with Kubernetes Secrets, if necessary. * Secret Synchronization: Creates or updates corresponding Kubernetes Secret objects with the fetched data, ensuring they are in sync with the external source. * Secret Push: Updates remote secrets at the provider based on the provided secret, transforming the secret if template data is provided by the user. -#### 2. Cert Controller Actions: +#### 2. Cert Controller Actions + * Certificate Generation: Automatically generates and renews TLS certificates needed for the secure functioning of webhooks. * Certificate Management: Ensures the validity of certificates and manages their lifecycle, including storage, renewal, and revocation as required. -#### 3. Webhook Actions: +#### 3. Webhook Actions + * Request Interception: Intercepts requests related to ExternalSecret and other custom resources for validation or mutation before they are processed by the Kubernetes API server. * Validation: Checks the integrity and correctness of ExternalSecret objects, ensuring they conform to the expected schema and standards. * Mutation: Optionally modifies ExternalSecret objects as per predefined rules or logic to ensure they meet certain criteria or standards before processing. - ### Goals #### 1. Secure Secret Management + ESO's primary goal is to securely manage secrets within Kubernetes by leveraging external secret management systems. It ensures that sensitive information like API keys, passwords, and tokens are stored and managed in systems specifically designed for this purpose, offering robust security features. #### 2. Automated Synchronization + ESO automates the synchronization of secrets from these external systems into Kubernetes, ensuring that applications always have access to the latest version of each secret. #### 3. Automated Synchronization Back to the Provider + Using PushSecrets, ESO can synchronize secrets FROM the Kubernetes cluster TO the remote provider. This is useful for backing up keys, sharing secrets between multiple clusters, maintaining a central secret manager that operates as a single source of truth. #### 4. Generate Temporary Secrets for Ephemeral usage -With Generators it's possible to create temporary credentials for various puroses such as: STS token for AWS, Random Password, ECR access token, vault token, various webhook and more. These can easily be regenerated on a timer or manually. +With Generators it's possible to create temporary credentials for various purposes such as: STS token for AWS, Random Password, ECR access token, vault token, various webhook and more. These can easily be regenerated on a timer or manually. #### 5. Access Control + By integrating with external secret managers, ESO inherits and enforces their access control mechanisms. It guarantees that only authorized parties can retrieve or modify the secrets, both in the external systems and when they are injected into Kubernetes. #### 6. Encryption and Integrity -ESO ensures that the transmission of secrets from external systems to Kubernetes is secure, maintaining the confidentiality and integrity of the data throughout the process. +ESO ensures that the transmission of secrets from external systems to Kubernetes is secure, maintaining the confidentiality and integrity of the data throughout the process. ### Non-goals #### 1. Secret Data Encryption + While ESO manages encrypted secrets, it does not provide encryption services itself. The actual encryption and decryption are handled by the external secret management systems. #### 2. Intrusion Detection or Prevention + ESO does not function as an intrusion detection or prevention system. It does not monitor or protect against unauthorized access within the Kubernetes cluster or the external secret systems. #### 3. Full Lifecycle Management of Secrets + The primary role of ESO is to synchronize secrets from external systems to Kubernetes. It does not manage the full lifecycle (like creation, rotation, and deletion) of secrets within the external systems. Caveat: With generators and PushSecrets managing the full lifecycle is possible, given that the external provider allows a mechanism to do that (like with vault dynamic secrets). Example: [True Secrets Auto Rotation with ESO and Vault](https://dev.to/canelasevero/true-secrets-auto-rotation-with-eso-and-vault-1g4o). #### 4. Direct Security Auditing or Compliance Assurance + ESO does not perform security auditing or provide direct compliance assurance. It relies on the security and compliance features of the external secret management systems it integrates with. ## Self-assessment use @@ -159,15 +181,16 @@ This document serves to provide ESO users with an initial understanding of ESO's This document provides the CNCF TAG-Security with an initial understanding of ESO to assist in a joint-assessment, necessary for projects under incubation. Taken together, this document and the joint-assessment serve as a cornerstone for if and when ESO seeks graduation and is preparing for a security audit. - ## Security Functions and Features ### Critical Components + * Authentication and Authorization Interface: Connects with external secret management systems; ensures only authenticated and authorized access to secrets. * Secret Synchronization Mechanism: Securely transfers secrets from/to external systems to/from Kubernetes, critical for maintaining the confidentiality and integrity of secret data. * Kubernetes Secrets Management: Handles the creation and updating of Kubernetes Secrets, a fundamental aspect of ensuring that only authorized Kubernetes workloads can access the synchronized secrets. -### Security Relevant Components. +### Security Relevant Components + * Configuration of Secret Stores: Involves setting up SecretStore and ClusterSecretStore resources, impacting how securely ESO interacts with external systems. * Role-Based Access Control (RBAC) Configuration: Determines what resources within Kubernetes the ESO can access, significantly affecting the isolation and security of the secrets. * Network Policies: Governs the network traffic to and from ESO, relevant for preventing unauthorized network access. @@ -185,7 +208,7 @@ This document provides the CNCF TAG-Security with an initial understanding of ES * Commits to the `main` branch are merged only when a PR is approved and passes all checks. * Once a pull request has been opened it will be assigned to a reviewer from external-secrets/maintainers. * Raising a PR triggers a series of GitHub actions and workflows whose component checks are broken down below: - * [Sonar Cloud Quality Gate](https://sonarcloud.io/project/issues?id=external-secrets_external-secrets) check initiated by the sonarcloud bot which checks for bugs, vulnerabilities, security hotspots, code smells, code coverage and duplication + * [Sonar Cloud Quality Gate](https://sonarcloud.io/project/issues?id=external-secrets_external-secrets) check initiated by the SonarCloud bot which checks for bugs, vulnerabilities, security hotspots, code smells, code coverage and duplication * Developer Certificate of Origin (DCO) check to verify commits are signed correctly * Detect noop ([skip-duplicate-actions](https://github.com/fkirc/skip-duplicate-actions)) * Linting check @@ -196,9 +219,10 @@ This document provides the CNCF TAG-Security with an initial understanding of ES * Building the image * Image scanning for vulnerabilities using Trivy * Create SBOM & provenance files and sign the image - * Publish signed artifacts to Dockerhub + * Publish signed artifacts to Docker Hub ### Communication Channels + * Referenced in docs under [How to Get Involved](https://external-secrets.io/latest/#how-to-get-involved) and described below: * Internal: * Bi-weekly Development Meeting every odd week at 8:00 PM Berlin Time on Wednesday ([agenda](https://hackmd.io/GSGEpTVdRZCP6LDxV3FHJA), [jitsi call](https://meet.jit.si/eso-community-meeting)) @@ -209,42 +233,53 @@ This document provides the CNCF TAG-Security with an initial understanding of ES * [Github Issues](https://github.com/external-secrets/external-secrets/issues) * [Github Discussions](https://github.com/external-secrets/external-secrets/discussions) * [Contributing Process](https://external-secrets.io/latest/contributing/process/) - * Contact Email: cncf-externalsecretsop-maintainers@lists.cncf.io + * Contact Email: