Skip to content

Step to perform a Sync operation on an Argo CD App when using the Codefresh's GitOps Runtimes

License

Notifications You must be signed in to change notification settings

codefresh-contrib/argo-cd-sync

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Argo CD Sync for Codefresh's GitOps Runtimes

Step to perform a Sync operation on an Argo CD App when using the Codefresh's GitOps Runtimes

Development

  • To activate venv
cd /to/root/dir
python3 -m venv venv --clear
source venv/bin/activate
  • Download all dependencies
pip install --upgrade pip
pip install -r requirements.txt
  • Update list of requirements:
pip freeze > requirements.txt

Running it

Create a variables.env file with the following content:

ENDPOINT=https://g.codefresh.io/2.0/api/graphql
CF_API_KEY=XYZ
RUNTIME=<the_runtime_name>
NAMESPACE=<the_namespace>
APPLICATION=<the_app_name>
  • Running in shell:
export $( cat variables.env | xargs ) && python argocd_sync.py
  • Running as a container:
export image_name="`yq .name service.yaml`"
export image_tag="`yq .version service.yaml`"
export registry="franciscocodefresh" ## e.g., the Docker Hub account
docker build -t ${image_name} .
docker run --rm --env-file variables.env ${image_name}
docker tag ${image_name} ${registry}/${image_name}:${image_tag}
docker push ${registry}/${image_name}:${image_tag}

When using ARM:

docker build \
    --tag ${registry}/${image_name}:${image_tag} \
    --platform linux/arm64/v8,linux/amd64 \
    --builder container \
    --push \
    .

If you don't have a builder using the docker-container driver:

docker buildx create --name container --driver=docker-container

About

Step to perform a Sync operation on an Argo CD App when using the Codefresh's GitOps Runtimes

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published