apiVersion: v1
kind: Secret
metadata:
name: private-repo
namespace: openshift-operators
labels:
argocd.argoproj.io/secret-type: repository
stringData:
type: git
url: git@github.com:mbaldessari/mcg-private.git
sshPrivateKey: |
-----BEGIN OPENSSH PRIVATE KEY-----
a3...
...
...
-----END OPENSSH PRIVATE KEY-----Deploying patterns from private repositories
You can deploy patterns from git repositories that are either password-protected or secured with an SSH key.
Using an SSH key
To deploy a pattern from an SSH-secured private repository, create a secret for repository access and then reference it in your pattern’s Custom Resource.
Create a secret for repository access
Generate a secret containing the credentials for accessing your repository. This secret should be formatted according to ArgoCD’s declarative setup guidelines.
Deploy the pattern with the secret
Reference the secret you created by passing TOKEN_SECRET and TOKEN_NAMESPACE to the install command:
./pattern.sh make TOKEN_SECRET=private-repo TOKEN_NAMESPACE=openshift-operators installThis command assumes that the private-repo secret exists and that the origin remote of the repository points to git@github.com:mbaldessari/mcg-private.git as specified in the secret. The install sets the tokenSecret and tokenSecretNamespace fields on the pattern’s Custom Resource, which ensures that all Argo instances can access the private repository.
If you need to create the pattern CR manually instead, set those fields directly:
apiVersion: gitops.hybrid-cloud-patterns.io/v1alpha1
kind: Pattern
metadata:
name: pattern-sample
namespace: patterns-operator
spec:
clusterGroupName: hub
gitSpec:
targetRepo: git@github.com:mbaldessari/mcg-private.git
targetRevision: private-repo
tokenSecret: private-repo
tokenSecretNamespace: openshift-operatorsUsing a GitLab private repository with a PAT
First, make sure your PAT has at least Read and Download permissions for your private repository.
As with the SSH example above, create a secret before running the install:
apiVersion: v1
kind: Secret
metadata:
name: private-repo
namespace: openshift-operators
labels:
argocd.argoproj.io/secret-type: repository
stringData:
type: git
url: https://gitlab.com/dminnear-rh/mcg-private.git
username: oauth2
password: glpat-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxThe username must be oauth2, not your GitLab handle. |
Then reference the secret in the install:
./pattern.sh make TOKEN_SECRET=private-repo TOKEN_NAMESPACE=openshift-operators install