Skip to main content

Easy configuration as code tool for GitLab using config in plain YAML

Project description

PyPI version Build Status

GitLabForm

Join the chat at https://gitter.im/egnyte/gitlabform

GitLabForm is an easy configuration as code tool for GitLab using config in plain YAML.

Features

GitLabForm enables you to manage:

  • Project settings,

  • Deployment keys,

  • Secret variables,

  • Branches (protect/unprotect),

  • Services,

  • (Project) Hooks,

  • (Add/edit or delete) Files, with simple templating,

  • Merge Requests approvals settings and approvers (EE 10.6+ only),

…for:

  • all projects you have access to,

  • a group of projects,

  • a single project,

…and a combination of them (default config for all projects + more specific for some groups + even more specific for particular projects).

Quick start

  1. Install with: pip3 install gitlabform

  2. Create example config.yml:

gitlab:
  url: https://gitlab.yourcompany.com
  token: "<private token of an admin user>"

group_settings:
  'my_group':
    deploy_keys:
      a_friendly_deploy_key_name:
        key: ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQC3WiHAsm2UTz2dU1vKFYUGfHI1p5fIv84BbtV/9jAKvZhVHDqMa07PgVtkttjvDC8bA1kezhOBKcO0KNzVoDp0ENq7WLxFyLFMQ9USf8LmOY70uV/l8Gpcn1ZT7zRBdEzUUgF/PjZukqVtuHqf9TCO8Ekvjag9XRfVNadKs25rbL60oqpIpEUqAbmQ4j6GFcfBBBPuVlKfidI6O039dAnDUsmeafwCOhEvQmF+N5Diauw3Mk+9TMKNlOWM+pO2DKxX9LLLWGVA9Dqr6dWY0eHjWKUmk2B1h1HYW+aUyoWX2TGsVX9DlNY7CKiQGsL5MRH9IXKMQ8cfMweKoEcwSSXJ
        title: ssh_key_name_that_is_shown_in_gitlab
        can_push: false
  1. Run gitlabform my_group

  2. Watch GitLabForm add/reset this deploy key to all projects in “my_group” group in your GitLab!

Configuration syntax

See config.yml in this repo as a well documented example of configuring all projects in all groups, projects in “my_group” group and specifically project “my_group/my_project1”.

More usage examples

To apply settings for a single project, run:

gitlabform my_group/my_project1

To apply settings for a group of projects, run:

gitlabform my_group

To apply settings for all groups of projects and projects explicitly defined in the config, run:

gitlabform ALL_DEFINED

To apply settings for all projects, run:

gitlabform ALL

If you are satisfied with results consider running it with cron on a regular basis to ensure that your GitLab configuration stays the way defined in your config (for example in case of some admin changes some project settings temporarily by (yuck!) clicking).

All command line parameters

Run:

gitlabform -h

…to see the current set of supported command line parameters.

Requirements

  • Python 3.5+

  • GitLab 9.1+ (EE 10.6+ for merge_requests section)

Why?

This tool was created as a workaround for missing GitLab features such as assigning deploy keys per project groups but as of now we prefer to use it ever if there are appropriate web UI features, such as secret variables per project groups (released in GitLab 9.4) to keep configuration as code.

GitLabForm is slightly similar to GitLab provider for Terraform (which we love, btw!), but it has much more features and uses simpler configuration format.

How does it work?

It just goes through a loop of projects list and make a series of GitLab API requests. Where possible it corresponds to GitLab API 1-to-1, so for example it just PUTs or POSTs the hash set at given place in its config transformed into JSON, so that it’s not necessary to modify the app in case of some GitLab API changes.

Ideas for improvement

See https://github.com/egnyte/gitlabform/issues

License

MIT

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

gitlabform-0.23.0.1.tar.gz (15.2 kB view details)

Uploaded Source

File details

Details for the file gitlabform-0.23.0.1.tar.gz.

File metadata

File hashes

Hashes for gitlabform-0.23.0.1.tar.gz
Algorithm Hash digest
SHA256 67917f367e70f033ad23449b427d9f73cc7abf7d2a6e2b6f3b3e32ccb7d485b0
MD5 2315dc47e5c03073819a7275671ff2e9
BLAKE2b-256 7fcca512fa6d977d7c8935f0928c318fde605a5c17ddfd9b22435b9ffc8f75a2

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 Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page