Adds some magic to GitLab
Project description
Gitlabracadabra
🧹 GitLabracadabra 🧙
⚗ Adds some magic to GitLab 🔮
GitLab'racadabra is a GitOps way to configure a GitLab instance from a YAML configuration, using the API.
It is able to create GitLab's groups, projects, users and application settings.
👍 It's also able to mirror :
- Git repositories, using the
mirrorsparameter in Mirroring repositories. - container (Docker) images, using the
image_mirrorsparameter. See Mirroring container images. - packages, using the
package_mirrorsparameter. See Mirroring packages.
It is based on Python GitLab.
Table of Contents
Installation
Using Debian packages
Debian package is available from artifacts and can be installed with:
apt install gitlabracadabra_*.deb
gitlabracadabra --verbose --dry-run
Note: Debian 12 bookworm or later is required.
Using pip
pip install gitlabracadabra
Using docker image
There are also Docker/OCI images.
Example usage:
sudo docker run -ti \
-v "$HOME/.python-gitlab.cfg:/home/gitlabracadabra/.python-gitlab.cfg:ro" \
-v "$PWD/gitlabracadabra.yml:/app/gitlabracadabra.yml:ro" \
'registry.gitlab.com/gitlabracadabra/gitlabracadabra:v2.8.0' \
--verbose --dry-run
Other images are available. Examples:
registry.gitlab.com/gitlabracadabra/gitlabracadabra/main: Currentmainregistry.gitlab.com/gitlabracadabra/gitlabracadabra/main:b1cd3482bf9583c5db863c359e12cafcdb7119bf: A specific commit ofmain
From source
Local installation (in $HOME/.local):
# On Debian or Ubuntu
sudo apt install -y --no-install-recommends \
python3-build \
python3-github \
python3-gitlab \
python3-html5lib \
python3-jsonschema \
python3-packaging \
python3-pygit2 \
python3-semantic-version \
python3-vcr \
python3-venv \
python3-yaml \
python3-pip \
python3-coverage \
python3-pytest
# On Alpine
sudo apk add \
py3-build \
py3-pygithub \
py3-requests-toolbelt \
py3-html5lib \
py3-jsonschema \
py3-packaging \
py3-pygit2 \
py3-semantic-version \
py3-vcrpy \
py3-yaml \
py3-pip \
py3-coverage \
py3-pytest
# On others
pip install build
# Build and install
python3 -m build
version="$(grep __version__ gitlabracadabra/__init__.py | awk -F "'" '{print $2}')"
pip install --user "dist/gitlabracadabra-$version"*.whl
# Test
pytest-3 # or pytest
~/.local/bin/gitlabracadabra --verbose --dry-run
Configuration
GitLabracadabra uses the same configuration file as Python GitLab CLI to store connection parameters.
Example ~/.python-gitlab.cfg:
[global]
default = gitlab
[gitlab]
url = https://gitlab.com
private_token = T0K3N
More information in Python GitLab documentation.
Alternatively, you can use the following environment variables:
GITLAB_URL: GitLab URLGITLAB_PRIVATE_TOKENorGITLAB_OAUTH_TOKEN: authenticationGITLAB_TLS_VERIFY: eithertrueorfalse, or a CA path. Ignored when emty.
Action file(s)
GitLabracadabra actions are configured with a YAML file.
See GitLabracadabra's own action file or read:
- Action file syntax
- list of parameters:
Using gitlabracadabra in GitLab CI
Since job token probably won't have enough permissions, you'll need to use a personal access token:
- create a personal access token
- Define the
GITLAB_PRIVATE_TOKENprotected variable - Use it in your jobs to configure
python-gitlab. Example.gitlab-ci.yml:
default:
image:
name: 'registry.gitlab.com/gitlabracadabra/gitlabracadabra:v2.8.0'
entrypoint: [""]
before_script:
- |
cat << EOF > ~/.python-gitlab.cfg
[global]
default = gitlab
[gitlab]
url = ${CI_SERVER_URL:-https://gitlab.com}
private_token = ${GITLAB_PRIVATE_TOKEN}
# job_token = ${GITLAB_JOB_TOKEN}
EOF
stages:
- test
- deploy
test:
stage: test
script:
- gitlabracadabra --verbose --dry-run
rules:
- if: '$CI_COMMIT_BRANCH != "main"'
apply:
stage: deploy
script:
- gitlabracadabra --verbose
rules:
- if: '$CI_COMMIT_BRANCH == "main"'
Contributing
-
File bugs and feature requests in GitLab issues. Security issues should be marked as confidential.
-
Propose documentation or code improvements in GitLab merge requests.
This repository enforces commit message convention, to check this locally install the commitlint hook:
npm install @commitlint/{config-conventional,cli} echo 'npx commitlint --edit' >> .git/hooks/commit-msg chmod +x .git/hooks/commit-msg
See also:
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gitlabracadabra-2.8.0.tar.gz.
File metadata
- Download URL: gitlabracadabra-2.8.0.tar.gz
- Upload date:
- Size: 566.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: python-httpx/0.28.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
65f26b4e4bb8f77a942c0ce46b49ed448b14a3345cd0617409a75a4e133e06b4
|
|
| MD5 |
08f06f90d8e4518425396d7ac4b16630
|
|
| BLAKE2b-256 |
986fefa6eaa7f73454844100e065ec58a0be85a72ac8df3da333b3447c787eb6
|
File details
Details for the file gitlabracadabra-2.8.0-py3-none-any.whl.
File metadata
- Download URL: gitlabracadabra-2.8.0-py3-none-any.whl
- Upload date:
- Size: 131.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: python-httpx/0.28.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ab40acf379a8a28f04aaa197562334920d7ebaebe370d70efa03cdf22cf5c78b
|
|
| MD5 |
be0146ce5ccc91fb218c681e48d50606
|
|
| BLAKE2b-256 |
5f5f4e0a815a534e61635d9f943ad6c97e8455aafd9d166f451ece77b0db84e5
|