Metadata-Version: 1.1
Name: gitlabform
Version: 0.23.0
Summary: Easy configuration as code tool for GitLab using config in plain YAML
Home-page: https://github.com/egnyte/gitlabform
Author: Egnyte
Author-email: UNKNOWN
License: UNKNOWN
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``:
        
        .. code:: yaml
        
            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
        
        3. Run ``gitlabform my_group``
        
        4. Watch GitLabForm add/reset this deploy key to all projects in
           "my\_group" group in your GitLab!
        
        Configuration syntax
        --------------------
        
        See `config.yml <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.x+
        
        Why?
        ----
        
        This tool was created as a workaround for missing GitLab features such
        as `assigning deploy keys per project
        groups <https://gitlab.com/gitlab-org/gitlab-ce/issues/3890>`__ but as
        of now we prefer to use it ever if there are appropriate web UI
        features, such as `secret variables per project
        groups <https://gitlab.com/gitlab-org/gitlab-ce/issues/12729>`__
        (released in GitLab 9.4) to keep configuration as code.
        
        GitLabForm is slightly similar to `GitLab
        provider <https://www.terraform.io/docs/providers/gitlab/index.html>`__
        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
        
        .. |PyPI version| image:: https://badge.fury.io/py/gitlabform.svg
           :target: https://badge.fury.io/py/gitlabform
        .. |Build Status| image:: https://travis-ci.org/egnyte/gitlabform.svg?branch=master
           :target: https://travis-ci.org/egnyte/gitlabform
        .. |Join the chat at https://gitter.im/egnyte/gitlabform| image:: https://badges.gitter.im/egnyte/gitlabform.svg
           :target: https://gitter.im/egnyte/gitlabform?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge
        
Keywords: gitlab,configuration-as-code
Platform: UNKNOWN
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Information Technology
Classifier: Intended Audience :: System Administrators
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Topic :: Software Development :: Version Control :: Git
