Concierge repository projects management CLI.
Project description
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 (python-gitlab v2.0.0 dropped support for older Pythons). You can use Pipenv to work around this limitation:
$ pip install pipenv
$ pipenv shell --three
$ pip install concierge-cli
Preparation
You need an access token of a GitLab user to access resources through the API. For groups and group membership this needs to be an administrator user. You may also want to disable notifications of the user(s) you plan to perform bulk updates on, to avoid sending out massive amounts of emails.
Set the GitLab URI and TOKEN as environment variables (if you want to avoid using the --token and/or --uri options):
$ export CONCIERGE_GITLAB_URI=https://git.example.com/
$ export CONCIERGE_GITLAB_TOKEN=<redacted>
Usage Patterns
Manage project topics
List projects by topic
List (and merge) merge requests by project
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
Merge requests
List of all merge requests of a project, optionally matching labels:
$ concierge-cli gitlab mrs mygroup/myproject --label mylabel
Add --merge yes to trigger merging all found requests.
Group membership
List all groups where user is not yet a member of:
$ concierge-cli gitlab groups --no-member my.user.name
Add user to all those groups:
$ concierge-cli gitlab groups --no-member my.user.name \
--set-permission maintainer
List a user’s group memberships and permissions:
$ concierge-cli gitlab groups my.user.name
Remove a user from selected groups:
$ concierge-cli gitlab groups my.user.name \
--group-filter a-group-name \
--set-permission none
Found a bug? Need a new feature?
Please see our Contribution Guide if you want to help out!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file concierge-cli-1.6.0.tar.gz
.
File metadata
- Download URL: concierge-cli-1.6.0.tar.gz
- Upload date:
- Size: 10.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.6.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.7.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 120ec94f0e8f75265d85785f157c6c148e6a70694964b3b5329bdbd0b26cdd1a |
|
MD5 | 3935204e88fd3ec79bcb746070e38f77 |
|
BLAKE2b-256 | 2e686ceb9935ce607b8cf02d6280ad2f014295d6ade9242af23fe55d50de98a7 |
Provenance
File details
Details for the file concierge_cli-1.6.0-py3-none-any.whl
.
File metadata
- Download URL: concierge_cli-1.6.0-py3-none-any.whl
- Upload date:
- Size: 11.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.6.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.7.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 716d80fd1c2ff979cd1ed3c6d83301cf0ba71db53bc3935e536e292293b70672 |
|
MD5 | dcb4f04607b007efafac35304483d0e9 |
|
BLAKE2b-256 | 7825b7f9940ce5b30cdf6bb64cf9c5312141dfc167b26e336805f71c8396ffa4 |