Skip to content

softwarefactory-project/python-quay-tool

Repository files navigation

Quaytool

The Quay container image registry has an API, that give possibility to maintain organization and repositories in automated way.

Features of Quaytool

The Quaytool is using only API calls to:

  • set visibility for repository
  • create organization
  • get info about organization

Future improvements

In the future, project should provide:

  • creating robot and set permissions to it

Usage

Basic usage of Quay tool

Set image to be public:

quaytool --api-url https://quay.dev/api/v1 --token <token> --organization myorganization --visibility public

Specify image repository to be public:

quaytool --api-url https://quay.dev/api/v1 --token <token> --organization myorganization --repository test --repository test2 --visibility public

Set all repository to be private, but skip some of them:

quaytool --api-url https://quay.dev/api/v1 --token <token> --organization myorganization --skip-repo test3 --skip-repo test4 --visibility private

List all robots in organization:

quay_tool --api-url https://quay.dev/api/v1 --organization test --token sometoken --insecure --list-robots

Create robot in organization:

quay_tool --api-url https://quay.dev/api/v1 --organization test --token sometoken --create-robot bender

Set write permissions for a user for repositories inside the organziation:

quaytool  --api-url https://quay.dev/api/v1 --organization test --token sometoken --user test+cirobot --set-permissions

Restore deleted tag:

quaytool --api-url https://quay.dev/api/v1 --organization test --token sometoken --tag 14ee273e8565960cf6d5b6e26ae92ade --restore-tag

Set the prototype (default permissions) in the organization. By default it creates prototype with write permissions.

For a user:

quaytool  --api-url https://quay.dev/api/v1 --organization test --token sometoken --create-prototype --user test+cirobot

For a team:

quaytool  --api-url https://quay.dev/api/v1 --organization test --token sometoken --create-prototype --team creators

Basic workflow how to setup new organziation

  • Get the admin token
grep -i admin_token /var/data/quay/config/admin_token | cut -f2 -d'='

NOTE: If you don't have such token on bootstraping the Quay service or the token expired, you need to:

  • create organization via Web interface,
  • create new application inside the organization
  • in the new application, generate a token with all available permissions
  • write the token to the file (this one will not expire). It can look like:
#!/bin/bash
ADMIN_TOKEN=<mytoken>
  • Create organization (skip if you have done via web interface):
quaytool --api-url <api url> --organization <organization name> --token <admin token> --create-organization
  • Create robot user
quaytool --api-url <api url> --organization <organization name> --token <admin token> --robot <robot_name> --create-robot
  • Create new team that will be able to create new repositories inside the organization
quaytool --api-url <api url> --organization <organization name> --token <admin token> --team <team name> --create-team
  • Create prototype for the creators team inside the organization (set default permissions for the new users like robot that are in creators team). By default it will create write permissions.
quaytool --api-url <api url> --organization <organization name> --token <admin token> --team <team name> --create-prototype
  • Add robot user to the team
quaytool --api-url <api url> --organization <organization name> --token <admin token> --team <team name> --user <robot user> --add-member

After pushing images into the new repositories, by default the repository visibility is set to private. To make all repositories public, run:

quaytool  --api-url <api url> --organization <organization name> --token <admin token> --visibility public --set-visibility

Or just for one repository:

quaytool  --api-url <api url> --organization <organization name> --token <admin token> --repository <repository> --visibility public --set-visibility

NOTE: To skip some repositories, use --skip-repo parameter.

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •  

Languages