A command-line tool to efficiently sync all repositories from a GitHub organization to your local machine. Perfect for developers who need to maintain local copies of multiple repositories for backup, analysis, or bulk operations.
- Bulk Repository Sync: Clone or update all repositories from a GitHub organization in one command
- Smart Updates: Automatically switches to default branch and pulls latest changes
- Dirty Repository Handling: Safely stashes uncommitted changes before updating
- Parallel Processing: Configurable concurrency for faster synchronization
- Repository Filtering: Include/exclude specific repositories by name pattern
- Archived Repository Support: Option to skip archived repositories
- Permission Aware: Automatically skips repositories without pull permissions
- Empty Repository Handling: Gracefully handles empty repositories without errors
Download the latest release for your platform from the releases page.
- 
Clone the repository: git clone [email protected]:xbglowx/github-org-repos-sync.git cd github-org-repos-sync 
- 
Build using Makefile: # Build for current platform make build # Build for all platforms (cross-compilation) make build-all # Run tests make test # Clean build artifacts make clean # Show available targets make help 
The Makefile automatically handles version detection from git tags/commits and provides convenient targets for building, testing, and cross-compilation.
- 
GitHub Personal Access Token: Create a token with reposcopeexport GITHUB_TOKEN=<your-token> 
- 
Git CLI Authentication: Ensure gitis authenticated with GitHub (SSH keys or credential helper)
./github-org-repos-sync <organization> -d <destination-path> [options]./github-org-repos-sync myorg -d ~/repos/myorg./github-org-repos-sync myorg -d ~/repos -p 5./github-org-repos-sync myorg -d ~/repos --skip-archived./github-org-repos-sync myorg -d ~/repos --include "api"./github-org-repos-sync myorg -d ~/repos --exclude "test"./github-org-repos-sync mycompany -d ~/backups/mycompany-repos./github-org-repos-sync mycompany -d ~/services --include "service"./github-org-repos-sync --help# Using version subcommand
./github-org-repos-sync version
# Using version flag
./github-org-repos-sync --version
./github-org-repos-sync -v- Repository Discovery: Fetches a list of all repositories in the specified organization that you have access to
- Local Check: Determines if each repository already exists locally
- Clone or Update:
- New repositories: Clones them to the destination path
- Existing repositories:
- Fetches latest changes from remote
- Stashes uncommitted changes if the working directory is dirty
- Switches to the repository's default branch
- Pulls latest changes with rebase
 
 
- Parallel Processing: Processes multiple repositories concurrently for improved performance
- Error Handling: Gracefully handles edge cases like empty repositories, missing branches, and permission issues
The project includes a Makefile with convenient targets for development:
| Target | Description | 
|---|---|
| make build | Build binary for current platform | 
| make build-all | Build binaries for all platforms (linux/darwin/windows × amd64/arm64) | 
| make test | Run tests with race detection | 
| make clean | Clean build artifacts | 
| make version | Show version that would be built | 
| make info | Show detailed build information | 
| make help | Show all available targets | 
Version Handling: The Makefile automatically detects versions using:
- Git tags for release builds (e.g., v1.0.0)
- Git commit SHA for development builds (e.g., a1b2c3d)
- -dirtysuffix when there are uncommitted changes
| Flag | Description | Default | 
|---|---|---|
| -d, --dest | Destination directory for repositories | Required | 
| -p, --parallelism | Number of concurrent operations | 10 | 
| --skip-archived | Skip archived repositories | false | 
| --include | Include only repositories containing this string | "" | 
| --exclude | Exclude repositories containing this string | "" | 
| -h, --help | Show help message | - | 
- Ensure your GitHub token has reposcope
- Verify you have access to the organization
- Check that git CLI is properly authenticated
- The tool will retry failed operations
- Use lower parallelism (-p 1) for unstable connections
- Consider using filters (--include/--exclude) for large organizations
- Monitor disk space when syncing many repositories
- Fork the repository
- Create a feature branch (git checkout -b feature/amazing-feature)
- Commit your changes (git commit -m 'Add amazing feature')
- Push to the branch (git push origin feature/amazing-feature)
- Open a Pull Request
This project is licensed under the Apache License 2.0 - see the LICENSE file for details.