CLI for downloading all repositories from a specified user.
Project description
git-neko
CLI for downloading all repositories from a specified user.
Requirements
requests
is used to get information from the Github API and download the repositories (if you don't use -g/--git to download using git).
Note that requests
will not download submodules but git will.
If you want to build this on your own, you can install the requirements with
pip install -r requirements.txt
or install the package by running
pip install git-neko
Python's native os
(used to check for whether a folder exists or not), argparse
(parse return request and set command argument), subprocess
(call git clone
and git pull
on repositories) and setuptools
(used to build the script) packages are also used.
How it works
I send requests to https://api.github.com/users/{username}/repos
or https://api.github.com/user/repos
, depending on the arguments passed to the script, I either download all the repositories in specified user's account with either requests
or git
.
You can run the script with
git-neko
-u <github-username>
-t <github-personal-access-token> (optional - you will just download the public repositories instead of all repositories)
-e (optional - means you will be using environment variables. This overrides -u and -t)
-g (optional - means you will be downloading using git)
-gu <github-username> (this will set <github-username> as environment variable)
-gpat <github-personal-access-token> (this will set <github-personal-access-token> as environment variable)
Examples
Setting Environment Variables
This will set the specified Github username and personal access token as your GITHUB_USERNAME
and GITHUB_PERSONAL_ACCESS_TOKEN
environment variable respectively. On Linux this is a bit buggy.
git-neko -gu <github-username> -gpat <github-personal-access-token>
This will set the specified Github username as your GITHUB_USERNAME
environment variable. On Linux this is a bit buggy.
git-neko -gu <github-username>
This will set the specified personal access token as your GITHUB_PERSONAL_ACCESS_TOKEN
environment variable. On Linux this is a bit buggy.
git-neko -gpat <github-personal-access-token>
Public Repositories without Environment Variables
This will use the specified Github username and download all public repositories using requests
.
git-neko -u <github-username> -t <github-personal-access-token>
This will use the specified Github username and download all public repositories using git
.
git-neko -u <github-username> -t <github-personal-access-token> -g <anything>
Public and Private Repositories without Environment Variables
This will use the specified Github username and personal access token and download all public and private repositories using requests
.
git-neko -u <github-username> -t <github-personal-access-token>
This will use the specified Github username and personal access token and download all public and private repositories using git
.
git-neko -u <github-username> -t <github-personal-access-token> -g <anything>
Public and Private Repositories with Environment Variables
This will use the Github username and personal access token in the environment variables and download all public and private repositories using requests
.
git-neko -e <anything>
This will use the Github username and personal access token in the environment variables and download all public and private repositories using git
.
git-neko -e <anything> -g <anything>
Public and Private Repositories with Environment Variables (Overriding passed Username and Personal Access Token)
This will ignore the passed Github username and personal access token instead using environment variables and download all public and private repositories using requests
.
git-neko -u <github-username> -t <github-personal-access-token> -e <anything>
This will ignore the passed Github username and personal access token instead using environment variables and download all public and private repositories using git
.
git-neko -u <github-username> -t <github-personal-access-token> -e <anything> -g <anything>
Simplified Examples
If you want to only download your repositories (public), you can do
git-neko -u <your-username>
If you want to only download your repositories (public and private), you can either do
git-neko -u <your-username> -t <your-personal-access-token>
or you can put your information on environment variables and do
git-neko -e <anything>
If you want to download other people's repositories (public), you can do
git-neko -u <their-username>
If you want to download other people's repositories (public and private), you can do
git-neko -u <their-username> -t <their-personal-access-token>
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file git_neko-1.18.tar.gz
.
File metadata
- Download URL: git_neko-1.18.tar.gz
- Upload date:
- Size: 7.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2430a2ccd98b1a07d40dfc194e0bdc4909e52359ad3d3fcba822ff44a29f0556 |
|
MD5 | de1b53fba9980d89261af642bdd7eab0 |
|
BLAKE2b-256 | 4d938a1c3d59af39629f5a84867c777cf52dd7a6a88599709333d428a2083353 |
File details
Details for the file git_neko-1.18-py3-none-any.whl
.
File metadata
- Download URL: git_neko-1.18-py3-none-any.whl
- Upload date:
- Size: 7.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a2bca360a39f16e9b2b1bd0217a5829ac80f3baa83de468172fdace6362ab10b |
|
MD5 | 09164860d813d85e914f38ecfc6ca489 |
|
BLAKE2b-256 | 48873456b9cb2ccdf67d91fd01a3bac199036d06f6786c11f284df31b235f4a6 |