Skip to main content

Concierge repository projects management CLI.

Project description

Build status Code health Updates Python versions Software license

Companion CLI for Concierge, the Configuration management & CI solution for aligning your multitude of Git repositories. Allows you to bulk-manage properties of your Git repository projects. Currently, GitLab is supported.

Why Should I Use This Tool?

Concierge-cli helps you analyze and bulk-update the repository projects you manage (e.g. set topics on projects, generate project lists for ModuleSync).

Installation

From PyPI:

$ pip install concierge-cli

Note: You need Python >= 3.6, otherwise your installation will not succeed. (We’re doing this really just for Python’s awesome f-strings!) You can use Pipenv to work around this limitation:

$ pip install pipenv
$ pipenv shell --three
$ pip install concierge-cli

Usage Patterns

  1. Manage project topics

  2. List projects by topic

  3. Manage group membership and permissions

Manage topics

List all projects (for a private GitLab) that have no topics yet:

$ concierge-cli gitlab --uri https://git.vs.hn topics --empty

List all projects “foo” or similar in group “bar” or similar: (on GitLab.com)

$ concierge-cli gitlab topics bar/foo --empty

Set topics on all those projects:

$ concierge-cli gitlab topics bar/foo --empty --set-topic Puppet --set-topic Ansible

List all projects with topics now: (double-check)

$ concierge-cli gitlab topics bar/foo

List projects

Print a YAML list of all projects matching a topic:

$ concierge-cli gitlab projects --topic Puppet

Update the list of modules Concierge manages with a specific configuration:

$ concierge-cli gitlab projects --topic Puppet > configs/foo-bar/managed_modules.yml
$ git add -v configs/foo-bar/managed_modules.yml
$ git status && git commit -m 'Added ...' && git push

Group membership

Preparation: You need an access token of an administrator user to list all groups and make changes to any group membership.

List all groups where user is not yet a member of:

$ concierge-cli gitlab --token *s3cr3t* groups --no-member my.user.name

Add user to all those groups:

$ concierge-cli gitlab --token *s3cr3t* groups --no-member my.user.name \
                       --set-permission maintainer

List a user’s group memberships and permissions:

$ concierge-cli gitlab --token *s3cr3t* groups my.user.name

Remove a user from selected groups:

$ concierge-cli gitlab --token *s3cr3t* groups my.user.name \
                       --group-filter a-group-name \
                       --set-permission none

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

concierge-cli-1.1.0.tar.gz (7.2 kB view details)

Uploaded Source

Built Distribution

concierge_cli-1.1.0-py3-none-any.whl (9.2 kB view details)

Uploaded Python 3

File details

Details for the file concierge-cli-1.1.0.tar.gz.

File metadata

  • Download URL: concierge-cli-1.1.0.tar.gz
  • Upload date:
  • Size: 7.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/44.0.0 requests-toolbelt/0.9.1 tqdm/4.41.1 CPython/3.6.7

File hashes

Hashes for concierge-cli-1.1.0.tar.gz
Algorithm Hash digest
SHA256 92fd31245bd48ddb28b9f44d32645dc4cbedde75090612addccd5620718d123a
MD5 e4a7f438ca1e03c6eff8836473cc6a3f
BLAKE2b-256 20fc5b143fd986a5baedea11a94edb180248bdd744d740b3dce0ee26aea9a4bd

See more details on using hashes here.

File details

Details for the file concierge_cli-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: concierge_cli-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 9.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/44.0.0 requests-toolbelt/0.9.1 tqdm/4.41.1 CPython/3.6.7

File hashes

Hashes for concierge_cli-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3417937fcb19e541b54e237f9b0d94c5b4a65a90c986b96482bcfbe6974b12f6
MD5 a5a038de3379a0da72c13d72b3135ccb
BLAKE2b-256 a527b379255fe6252fc32e3fb86845910e1527545859d011cf365888609c04b5

See more details on using hashes here.

Supported by

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