Skip to content

Collection of utility scripts for generating CSVs of repositories from various source code management providers.

License

Notifications You must be signed in to change notification settings

moderneinc/repository-fetchers

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Repository Fetchers

This directory contains scripts that query a source code manager (SCM) to create a CSV file that contains a list of repositories and their details. This list of repositories can then be used for easy cloning with the Moderne CLI or it can be used to help you create an Organizations service.

The expected output looks similar to:

cloneUrl,branch
https://github.com/openrewrite/rewrite-spring,main
https://github.com/openrewrite/rewrite-recipe-markdown-generator,main
https://github.com/openrewrite/rewrite-docs,master
https://github.com/openrewrite/rewrite,main
https://github.com/openrewrite/rewrite-python,main
https://github.com/openrewrite/rewrite-migrate-java,main
https://github.com/openrewrite/rewrite-recommendations,main
https://github.com/openrewrite/rewrite-testing-frameworks,main
https://github.com/openrewrite/rewrite-gradle-tooling-model,main
https://github.com/openrewrite/rewrite-recipe-bom,main

Supported SCMs

Below are the details of each script along with examples of how to invoke them and their required/optional arguments.

GitHub

This script fetches all repositories from a GitHub organization.

Usage

./github.sh <organization_name>

Description

This script fetches all repositories from the specified GitHub organization.

Prerequisites:
  1. You must also have the GitHub CLI installed.
  2. You must either have run gh auth login or set the GITHUB_TOKEN environment variable for authentication.

(Note: if you use a GitHub installation rather than github.com you will have to gh auth login --hostname github.mycompany.com)

Example

To fetch all repositories from a GitHub organization:

./github.sh my-organization

Bitbucket Data Center

This script fetches all repositories from a Bitbucket Data Center instance.

Usage

./bitbucket-data-center.sh <bitbucket_url>

Description

This script fetches all repositories from the specified Bitbucket Data Center URL. If the AUTH_TOKEN environment variable is set, it will be used for authentication.

Example

To fetch all repositories from a Bitbucket Data Center instance:

AUTH_TOKEN=YOUR_TOKEN ./bitbucket-data-center.sh https://my-bitbucket.com/stash

Bitbucket Cloud

This script fetches all repositories from a Bitbucket Data Center instance.

Usage

./bitbucket-cloud.sh -u username -p password <workspace>

Description

This script fetches all repositories from the specified Bitbucket Data Center URL. If the AUTH_TOKEN environment variable is set, it will be used for authentication.

Example

To fetch all repositories from a Bitbucket Data Center instance:

./bitbucket-cloud.sh -u YOUR_USERNAME -p APP_PASSWORD myworkspace

GitLab

This script fetches all repositories from a GitLab instance or a specific group within a GitLab instance.

Usage

./gitlab.sh [-g <group>] [-h <gitlab_domain>]

Description

This script fetches all repositories from a GitLab instance or a specific group within a GitLab instance. The AUTH_TOKEN environment variable must be set for authentication. The -g option specifies a group to fetch repositories from. The -h option specifies the GitLab domain (defaults to https://gitlab.com if not provided).

Example

To fetch all repositories from a specific group on a custom GitLab domain:

AUTH_TOKEN=YOUR_TOKEN ./gitlab.sh -g my-group -h https://my-gitlab.com

About

Collection of utility scripts for generating CSVs of repositories from various source code management providers.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages