Skip to content

Latest commit

 

History

History
 
 

upload-docker-image

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 

upload-docker-image

The upload-docker-image action uploads a Docker image to the Rust Infrastructure team's ECR registry. Additionally it supports redeploying an ECS service. There is no stability guarantee for this action, since it's supposed to only be used in infra managed by us.

Usage

To use the action add this to your workflow:

- uses: rust-lang/simpleinfra/github-actions/upload-docker-image@master
  with:
    image: local-image-name
    repository: ecr-repository-name
    region: us-west-1
    aws_access_key_id: "${{ secrets.aws_access_key_id }}"
    aws_secret_access_key: "${{ secrets.aws_secret_access_key }}"

If you also want to redeploy an ECS service add this instead of the above to your workflow:

- uses: rust-lang/simpleinfra/github-actions/upload-docker-image@master
  with:
    image: local-image-name
    repository: ecr-repository-name
    region: us-west-1
    redeploy_ecs_cluster: cluster-name
    redeploy_ecs_service: service-name
    aws_access_key_id: "${{ secrets.aws_access_key_id }}"
    aws_secret_access_key: "${{ secrets.aws_secret_access_key }}"

Redeploying requires IAM permissions to execute the ecs:UpdateService action on that service.

Development

The action is written in NodeJS 16, and you can install the dependencies with:

npm install

GitHub Actions requires all the dependencies to be committed, so before creating a commit you need to run:

npm run build

The command will bundle everything in dist/index.js. That file will need to be committed.