Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/loganintech/gitpub
A small program to create remote repos from the command line. https://crates.io/crates/gitpub
https://github.com/loganintech/gitpub
cli git rust
Last synced: 2 months ago
JSON representation
A small program to create remote repos from the command line. https://crates.io/crates/gitpub
- Host: GitHub
- URL: https://github.com/loganintech/gitpub
- Owner: loganintech
- License: gpl-3.0
- Created: 2019-04-11T02:08:34.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2019-06-25T23:30:30.000Z (over 5 years ago)
- Last Synced: 2024-10-18T06:53:39.856Z (3 months ago)
- Topics: cli, git, rust
- Language: Rust
- Homepage:
- Size: 141 KB
- Stars: 20
- Watchers: 3
- Forks: 4
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# Gitpub
A small program to create remote git repositories from the command line.
_Note:_ Environment variables can also be passed directly via CLI parameters, therefore setting said variables are always optional.
_Note:_ API Versions in this README are based on the last time the CLI changed.
Usage:
```
Git Publish 0.4.1
Logan Saso
A small program to create remote git repositories from the command line.USAGE:
gitpub [FLAGS] [OPTIONS]FLAGS:
-h, --help Prints help information
--set_remote Sets the remote of the local dir after successful creation.
--ssh_remote_format Attempts to convert the git remote url into ssh format. If it fails (the provider doesn't support ssh format), the remote isn't set.
-V, --version Prints version informationOPTIONS:
--endpoint Sets a custom endpoint to POST to, useful if you want a private instance and know the api matches one gitpub supports.
--remote_name Designates a custom name for setting remote. Defaults to origin.SUBCOMMANDS:
bitbucket Create a repo on bitbucket.
github Create a repo on github.
gitlab Create a repo on gitlab.
help Prints this message or the help of the given subcommand(s)
```## Github Setup
1. Create a personal access token with repo scope from https://github.com/settings/tokens
2. Set the environment variable `GITHUB_REPO_TOKEN` to the generated personal access token._Note:_ If you want to create org repositories the token also requires `org` scope.
### Github
```
gitpub-github 0.4.1
Create a repo on github.USAGE:
gitpub github [FLAGS] [OPTIONS] --name --tokenFLAGS:
-i, --disable_issues Disables issues for this repo. Defaults to false.
--merge Enables or disables merging with a merge commit. Defaults to false.
--disable_projects Disables projects for this repo. Defaults to false.
--rebase Enables or disables rebase-merging for this repo. Defaults to false.
--squash Enables or disables squash-merging for this repo. Defaults to false.
-w, --disable_wiki Disables wikis for this repo. Defaults to false.
-h, --help Prints help information
--org Creates the repo under an organization. Requires you have CREATE REPO permissions in that org.
-p, --private Sets the repository to private. Required 'repo' scope on your personal access token.
-r, --initialize_with_readme Creates an initial commit with empty README.md. Defaults to false.
--team ID of the team that has access to this repo. Only valid when using --org
-V, --version Prints version informationOPTIONS:
-d, --description A short description of the repository.
--gitignore Language template: ex 'Rust'. View more templates at https://github.com/github/gitignore/
--homepage A URL with more information about the repository.
--license License template: ex 'mit' or 'mpl-2.0'. View more at https://choosealicense.com/
-n, --name The name of the new repository.
-t, --token A personal access token. Alternatively read from GITHUB_REPO_TOKEN env variable. [env: GITHUB_REPO_TOKEN=]```
## Gitlab Setup
1. Create a personal access token with api scope from https://gitlab.com/profile/personal_access_tokens
2. Set the environment variable `GITLAB_REPO_TOKEN` to the generated personal access token._Note_: Optionally set the `GITLAB_USERNAME` environment variable to enable printing a link to the repo.
### Gitlab
```
gitpub-gitlab 0.4.1
Create a repo on gitlab.USAGE:
gitpub gitlab [FLAGS] [OPTIONS] --name --path --tokenFLAGS:
--disable_container_registry Disables container registry for this repo.
-i, --disable_issues Disables issues for this repo.
--disable_jobs Disables jobs for this repo.
--disable_merge Disables merging with a merge commit.
--disable_shared_runners Disables shared runners for this repo.
--disable_snippets Disables snippets for this repo.
-w, --disable_wiki Disables wikis for this repo.
--discussion_resolution_required Requires discussions are resolved before a merge.
-h, --help Prints help information
-r, --initialize_with_readme Create a blank README for the project.
--large_file_support Enables git large file support.
--merge_request_link_on_commit Print the merge request link when committing to the repository.
--mirror Enables pull mirroring in a project.
--mirror_triggers_builds Enables builds on pull mirroring.
--pipeline_success_required Requires pipelines to succeed before a merge.
--public_builds Lets jobs be viewed by non-project members.
--request_access_enabled Allow users to request member access.
-V, --version Prints version informationOPTIONS:
--approvals_before_merge Number of approvals required before a merge.
--ci_config_path Path to CI config file.
--default_branch Set default branch. Defaults to master.
-d, --description A short description of the repository.
--import_url Supply a URL to import a repo from.
--merge_method Sets the merge method. [possible values: merge, rebase_merge, ff]
-n, --name The name of the new repository.
--namespace_id Namespace for the new project (defaults to the current user’s namespace)
--path The path for the new repo. Generated based on name if not provided (generated lowercased with dashes).
--repository_storage An advanced parameter to designate which shard the repo is on, available only to admins.
--tag_list ... A list of tags for a repo. Takes up to four params. `--tag_list first second third tag`
-t, --token A personal access token. Alternatively read from GITLAB_REPO_TOKEN env variable. [env: GITLAB_REPO_TOKEN=]
--visibility The visibility of the project [possible values: public, internal, private]
```## BitBucket Setup
1. Create an app password with repo scope from https://bitbucket.org/account/user//app-passwords
2. Set the environment variable `BITBUCKET_REPO_TOKEN` to the generated personal access token.
3. Set the environment variable `BITBUCKET_USERNAME` to your bitbucket username.### Bitbucket
```
gitpub-bitbucket 0.4.3
Create a repo on bitbucket.USAGE:
gitpub bitbucket [FLAGS] [OPTIONS] --name --token --usernameFLAGS:
-i, --disable_issues Disables issues for this repo. Defaults to false.
-w, --disable_wiki Disables wikis for this repo. Defaults to false.
-h, --help Prints help information
-p, --private Sets the repository to private.
-V, --version Prints version informationOPTIONS:
-d, --description A short description of the repository.
--fork_policy Changes the allowed forking method for this repo. [possible values: allow_forks, no_public_forks, no_forks]
--language Give bitbucket a hint about the programming language.
-n, --name The name of the new repository.
--scm Control underlying source control method. [possible values: git, hg]
-t, --token A personal access token. Alternatively read from BITBUCKET_REPO_TOKEN env variable. [env: BITBUCKET_REPO_TOKEN=]
--username Your bitbucket username. Alternatively read from BITBUCKET_USERNAME env variable. [env: BITBUCKET_USERNAME=]
```