You can configure one or more platforms as source to mirror the structure from the remote server onto your local system (repositories will be moved if necessary). You can use complex rules to include or exclude projects based on the namespace or other properties.
# yaml-language-server: $schema=https://raw.githubusercontent.com/cidverse/reposync/main/configschema/v1.json
servers:
- url: https://github.com
type: github
auth:
username: YourAccount
password: <readOnlyPersonalAccessToken>
password-file: /path/to/file
password-command: pass show personal/github.com/read-only-pat
mirror:
dir: /tmp/github
default-action: exclude
naming-style: slug
rules:
- rule: group == "my-org"
action: includeThe configuration is read from ~/.config/reposync/config.yaml by default, but you can also specify a custom path by setting the REPOSYNC_CONFIG environment variable.
Supported platforms:
githubgitlab
The
gitcommands will use your local git installation, so you can use ssh keys or other authentication methods. The personal access tokens are only used to query the repositories you have access to and not to clone them.
curl -L -o ~/.local/bin/reposync https://github.com/cidverse/reposync/releases/download/v0.5.0/linux_amd64
chmod +x ~/.local/bin/reposyncreposync clone will clone all repositories you have access to into the target directory, keeping the remote structure as close as possible.
Notes:
- tracked repositories might be moved to track the remote structure changes (
<namespace>/<projectName>).
reposync pull will pull the latest changes for all tracked repositories.
git fetchgit pull --ff-only
reposync list will list all tracked repositories.
Additional options:
--format(-f) -> specify the output format (table, json, csv, ...)--columns(-c) -> filter output by columns
reposync housekeeping (reposync hk) will run the following tasks for all repositories:
repack->git repack -a -d --write-bitmap-indexprune->git prune --expire nowgc->git gc --autofsck->git fsck --full --unreachable --strictcommit-graph->git commit-graph write --reachable
You can choose to only run a subset of the tasks by specifying them as arguments. For example, reposync hk --jobs repack prune.
This is work-in-progress and not yet implemented.
Before your first run, you can use reposync index /old-project-dir, to add your local projects to the known repositories.
When running reposync clone, it will then move the projects to the new location, instead of cloning them.
Rules support the following variables to match against:
| Variable | Example | Description |
|---|---|---|
uniqueId |
github-com/123456 | The unique id of the project |
id |
123456 | The id of the project |
group |
my-org | The group / namespace the project is in |
name |
my-project | The name of the project |
path |
my-org/my-project | The full path of the project |
is_fork |
false | Whether the project is a fork |
Rules follow the Common Expression Language syntax.
Released under the MIT license.