Nenhuma descrição

paul-the-alien[bot] 576f8aed39 Merge pull request #144 from gabibeyer/add-gcpsm-provider 4 anos atrás
.github 41d0a72fba Merge pull request #154 from external-secrets/dependabot/github_actions/helm/chart-releaser-action-1.2.1 4 anos atrás
apis c3197051cb add provider for gcp 4 anos atrás
assets e0e824967d Tidy image 5 anos atrás
deploy 53e21034d5 Fix merge conflicts to add GCP secret manager 4 anos atrás
design 8361f6d055 Move crd spec to directory 5 anos atrás
docs fe05c523d4 Add documentation for gcpsm 4 anos atrás
e2e 7beec56522 feat: add basic e2e test 5 anos atrás
hack e5d6e30d00 fix: template data should be string, fix update mechanics 4 anos atrás
pkg c610913683 Add first round of unit tests for gcpsm 4 anos atrás
.editorconfig 987d499241 cleanup: add lint and editorconfig 5 anos atrás
.gitignore 7beec56522 feat: add basic e2e test 5 anos atrás
.golangci.yaml 8c8064e0e1 Draft: feat: implement template (#69) 5 anos atrás
CNAME 90286f37a4 Create CNAME 5 anos atrás
Dockerfile b4b1f892c5 Improve primary CI pipeline and refactor Makefile 5 anos atrás
LICENSE 59a364e04d initial commit 5 anos atrás
Makefile 250f40b869 ci: print diff error on failure 4 anos atrás
PROJECT 2e0a6effbe convert to multi-api 5 anos atrás
README.md c405cfb9de Update readme for gcpsm 4 anos atrás
RELEASE.md 771334dee9 feat: helm release workflow 5 anos atrás
SECURITY.md 25b3f4dd83 feat: security policy & dependabot (#60) 5 anos atrás
changelog.json 771334dee9 feat: helm release workflow 5 anos atrás
go.mod 53e21034d5 Fix merge conflicts to add GCP secret manager 4 anos atrás
go.sum c3197051cb add provider for gcp 4 anos atrás
main.go 6318811108 Cleanup and remove kustomize manifests in favor of Helm chart 5 anos atrás
tools.go 6318811108 Cleanup and remove kustomize manifests in favor of Helm chart 5 anos atrás

README.md

External Secrets


The External Secrets Operator reads information from a third party service like AWS Secrets Manager and automatically injects the values as Kubernetes Secrets.

Multiple people and organizations are joining efforts to create a single External Secrets solution based on existing projects. If you are curious about the origins of this project, check out this issue and this PR.

Supported Backends

ESO installation with an AWS example

If you want to use Helm:

helm repo add external-secrets https://charts.external-secrets.io

helm install external-secrets \
   external-secrets/external-secrets \
    -n external-secrets \
    --create-namespace \
  # --set installCRDs=true

If you want to run it locally against the active Kubernetes cluster context:

git clone https://github.com/external-secrets/external-secrets.git
make crds.install
make run

Create a secret containing your AWS credentials:

echo -n 'KEYID' > ./access-key
echo -n 'SECRETKEY' > ./secret-access-key
kubectl create secret generic awssm-secret --from-file=./access-key  --from-file=./secret-access-key

Create a secret inside AWS Secret Manager with name my-json-secret with the following data:

{
  "name": {"first": "Tom", "last": "Anderson"},
  "friends": [
    {"first": "Dale", "last": "Murphy"},
    {"first": "Roger", "last": "Craig"},
    {"first": "Jane", "last": "Murphy"}
  ]
}

Apply the sample resources (omitting role and controller keys here, you should not omit them in production):

# secretstore.yaml
apiVersion: external-secrets.io/v1alpha1
kind: SecretStore
metadata:
  name: secretstore-sample
spec:
  provider:
    aws:
      service: SecretsManager
      region: us-east-2
      auth:
        secretRef:
          accessKeyIDSecretRef:
            name: awssm-secret
            key: access-key
          secretAccessKeySecretRef:
            name: awssm-secret
            key: secret-access-key
# externalsecret.yaml
apiVersion: external-secrets.io/v1alpha1
kind: ExternalSecret
metadata:
  name: example
spec:
  refreshInterval: 1m
  secretStoreRef:
    name: secretstore-sample
    kind: SecretStore
  target:
    name: secret-to-be-created
    creationPolicy: Owner
  data:
  - secretKey: firstname
    remoteRef:
      key: my-json-secret
      property: name.first # Tom
  - secretKey: first_friend
    remoteRef:
      key: my-json-secret
      property: friends.1.first # Roger
kubectl apply -f secretstore.yaml
kubectl apply -f externalsecret.yaml

Running kubectl get secret secret-to-be-created should return a new secret created by the operator.

You can get one of its values with jsonpath (This should return Roger):

kubectl get secret secret-to-be-created   -o jsonpath='{.data.first_friend}' | base64 -d

We will add more documentation once we have the implementation for the different providers. You can find some here: https://external-secrets.io

Contributing

We welcome and encourage contributions to this project! Please read the Developer and Contribution process guides. Also make sure to check the Code of Conduct and adhere to its guidelines.

Kicked off by