Skip to main content

A restful web service for querying the image sizes of a GitLab registry.

Project description

Introduction

GitLab-Registry-Usage-REST is a package that periodically collects image information (name, tags, sizes) of a GitLab registry server and offers the data via a secured RESTful HAL api. For the initial authentication a LDAP server is needed. Subsequent queries are secured by JSON Web Tokens (JWT).

Installation

The latest version can be obtained from PyPI:

pip install gitlab-registry-usage-rest
gitlab-registry-usage-rest --help

or from DockerHub:

docker run sciapp/gitlab-registry-usage-rest:latest --help

Usage

Gitlab-Registry-Usage-REST needs a configuration file in order to run. The default path is /etc/gitlab_registry_usage_rest.conf but can be altered with the -c command line switch. To get started, you can run

gitlab-registry-usage-rest --print-default-config

and edit this default configuration to fit your environment.

If you would like to use the docker image, you can bind mount a local configuration file with the -v switch:

docker run -v "$(pwd)/gitlab_registry_usage_rest.conf:/etc/gitlab_registry_usage_rest.conf" sciapp/gitlab-registry-usage-rest:latest

Note: Docker expects an absolute path for the local configuration file.

The server offers these api endpoints:

  • /auth_token: Accepts a request with basic auth (and valid LDAP credentials) and returns an auth token for further api usage. All other endpoints only accept requests with a valid Bearer authorization header:

    Authorization: Bearer <token>
  • /images: Lists attributes of the images collection. Currently, only the timestamp of the last data refresh is contained:

    {
        "timestamp": 1521796487.7021387
    }
  • /images/<image_name>: Queries attributes of a specific image:

    {
        "name": "scientific-it-systems/administration/gitlab-registry-usage-rest",
        "size": 39899199,
        "disk_size": 39898911
    }
  • /images/<image_name>/tags: Endpoint for the collection of image tags, currently without any content.

  • /images/<image_name>/tags/<tag_name>: Lists attributes of an image tag:

    {
        "name": "latest",
        "size": 39899199,
        "disk_size": 39898911
    }

Additionally, all api endpoints (except /auth_token) offer an _embedded and a _links attribute if requested with the query string:

?embed=true&links=true

Instead of a boolean value, the embed key can also take an integer number to only request a specific level of embedded resources.

Links can be used to easily navigate between related resources. Embedded resources are convenient to query a complete hierarchy of resources with one GET request. Accordingly, the request

/images?embed=true

returns all resources at once.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gitlab-registry-usage-rest-0.1.12.tar.gz (10.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

gitlab_registry_usage_rest-0.1.12-py3-none-any.whl (13.1 kB view details)

Uploaded Python 3

File details

Details for the file gitlab-registry-usage-rest-0.1.12.tar.gz.

File metadata

File hashes

Hashes for gitlab-registry-usage-rest-0.1.12.tar.gz
Algorithm Hash digest
SHA256 7e53eabc036e689b3516c7ccd918b70e983cb7805901e830dddbadc2017e59a0
MD5 12c960e2fcd858721ecd95e3575d9203
BLAKE2b-256 3388230decf771250288064e5f9dbef7b47c93a7830e53673ca476dc0afa40b6

See more details on using hashes here.

File details

Details for the file gitlab_registry_usage_rest-0.1.12-py3-none-any.whl.

File metadata

File hashes

Hashes for gitlab_registry_usage_rest-0.1.12-py3-none-any.whl
Algorithm Hash digest
SHA256 92e046349d9c364b010c2c4c0301bed760393f88e6b7bae3cea9be687fde4fef
MD5 db88fc456895608d2f8a79d6d2d02bda
BLAKE2b-256 2cdedc0f8a43ca52689c3f79f86f38d4a1c00bfc23060b831e55698c47dcad40

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page