Skip to main content

synchronise GitLab repositories

Project description

PyPI version Build Status

gitlab-sync

This provides the gitlab-sync tool which clones GitLab and updates repositories.

Config

You will need to have SSH access configured for GitLab, and have created a personal access token with API access.

The config goes in ~/.config/gitlab-sync.toml or ~/.gitlab-sync.toml, which is TOML.

["~/team-x"]
access-token = "9koXpg98eAheJpvBs5tK"
# you can see the paths of groups from the URL on GitLab
paths = [ "path/to/team-x" ]
# strip the common prefix from the given path
strip-path = true
strategy = "mirror"

["~/gitlab"]
# get the gitlab access token from running a command
access-token = ["pass", "GitLab/api-access-token"]

# paths to clone from GitLab, can include slashes for groups/projects
paths = [ "mintel", "obristow" ]
strategy = "mirror"

Usage

$ gitlab-sync local-update

Strategies

You have to define a strategy for each local copy you define in config, the strategy defines what will happen when gitlab-sync runs over the given copy.

mirror

  1. delete repositories which no longer exist remotely
  2. move repositories which have been moved remotely
  3. update local repositories
  4. clean local repositories (prune+gc)
  5. clone new repositories

This is good for having a local copy which you can use to perform searches in using something like ag.

The local copies should not be modified by users.

To do

  • flesh out integration tests
  • cater for new repositories being made locally and pushed remotely
  • compare (toasted-)marshmallow as a replacement for attr+voluptious - marshmallow uses attr

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Files for gitlab-sync, version 0.2.8
Filename, size File type Python version Upload date Hashes
Filename, size gitlab_sync-0.2.8-py2-none-any.whl (10.0 kB) File type Wheel Python version py2 Upload date Hashes View
Filename, size gitlab-sync-0.2.8.tar.gz (13.7 kB) File type Source Python version None Upload date Hashes View

Supported by

Pingdom Pingdom Monitoring Google Google Object Storage and Download Analytics Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page