Skip to main content

Tools for data wrangling in github releases

Project description

Release Tools PyPI - Latest Version GitHub Tag

Note: These tools are being used for my personal projects and are not meant for general public use.

This project provides a set of tools to manage publishing a large number of files using GitHub releases, particularly to overcome the 1000 file limit per release by creating supplementary releases. This assumes that gh (the GitHub CLI) is installed and configured on your system, as it is used to interact with GitHub releases.

Features

  • Generate file lists: Create a CSV file containing a list of all files in a GitHub release.
  • Upload files to a release: Upload files from a local directory to a GitHub release, with an option to overwrite existing files.
  • Delete files from a release: Delete specified files from a release and its supplementary releases.

Installation

This project is packaged using Hatch. To install the tools, you can run the following command:

pip install .

This will install the gh_release_tools package and make the following command-line tools available:

  • generate-lists
  • upload-to-release
  • delete-from-release
  • download-from-release

Usage

It is recommended to run the tools using uvx to avoid dependency conflicts with other installed packages.

uvx

uvx --from gh_release_tools generate-lists --release <tag> --extension <extension>
uvx --from gh_release_tools upload-to-release --release <tag> --folder <folder> --extension <extension> [--overwrite] [--create-extra-releases] [--batch-size <size>]
uvx --from gh_release_tools download-from-release --release <tag> [--file-list <file>] [--output-dir <dir>] [--skip-existing] [--batch-size <size>] [file1 file2 ...]

generate-lists

This tool generates a CSV file named listing_files.csv containing a list of assets from a specified GitHub release and its associated -extra releases. The CSV file includes the file name, size, and download URL for each asset. The generated CSV is then uploaded to the base release, overwriting any existing listing_files.csv.

Usage:

generate-lists --release <tag> --extension <ext1> [--extension <ext2> ...] [--repo <owner/repo>]

Arguments:

  • --release, -r: The base name of the GitHub release (e.g., v1.0.0).
  • --extension, -e: The file extension of the assets to include in the list (e.g., .zip). This argument can be specified multiple times for different extensions.
  • --repo, -g: (Optional) The GitHub repository in the format owner/repo. If not provided, it will be inferred from the current directory.

Example:

generate-lists --release v1.0.0 --extension .zip --extension .txt

This command will generate a listing_files.csv file with a list of all .zip and .txt files from the v1.0.0 release and any releases named v1.0.0-extra<number>.

upload-to-release

This tool uploads files from a local folder to a GitHub release. It can be configured to skip files that already exist in the release or to overwrite them. It can also create new supplementary releases if the target release is full.

Usage:

upload-to-release --release <tag> --folder <folder> --extension <ext1> [--extension <ext2> ...] [--overwrite] [--create-extra-releases] [--batch-size <size>] [--repo <owner/repo>]

Arguments:

  • --release, -r: The git tag of the release to upload to.
  • --folder, -d: The local folder containing the files to upload.
  • --extension, -e: The file extension of the files to upload (e.g., .zip). This argument can be specified multiple times.
  • --overwrite: (Optional) Overwrite existing assets in the release.
  • --create-extra-releases, -x: (Optional) Create supplementary releases if the main release is full.
  • --batch-size, -b: (Optional) The number of files to upload in a single batch. (default: 1)
  • --repo, -g: (Optional) The GitHub repository in the format owner/repo. If not provided, it will be inferred from the current directory.

Example:

upload-to-release --release v1.0.0 --folder /path/to/files --extension .zip

This command will upload all .zip files from the /path/to/files directory to the v1.0.0 release. If a file with the same name already exists in the release, it will be skipped. To overwrite existing files, use the following command:

upload-to-release --release v1.0.0 --folder /path/to/files --extension .zip --overwrite

delete-from-release

This tool deletes specified files from a GitHub release and its associated -extra releases. You can provide a list of files to delete either as command-line arguments or in a separate text file.

Usage:

delete-from-release --release <tag> [--file-list <file>] [--repo <owner/repo>] [file1 file2 ...]

Arguments:

  • --release, -r: The base name of the GitHub release (e.g., v1.0.0).
  • --file-list, -f: (Optional) Path to a text file with a list of files to delete (one file per line).
  • files: (Optional) Space-separated list of file names to delete.
  • --repo, -g: (Optional) The GitHub repository in the format owner/repo. If not provided, it will be inferred from the current directory.

Example:

delete-from-release --release v1.0.0 --file-list files_to_delete.txt my_file.zip

This command will delete the files listed in files_to_delete.txt and my_file.zip from the v1.0.0 release and any releases named v1.0.0-extra<number>.

download-from-release

This tool downloads specified files from a GitHub release and its associated -extra releases.

Usage:

download-from-release --release <tag> [--file-list <file>] [--output-dir <dir>] [--skip-existing] [--batch-size <size>] [--repo <owner/repo>] [file1 file2 ...]

Arguments:

  • --release, -r: The base name of the GitHub release (e.g., v1.0.0).
  • --file-list, -f: (Optional) Path to a text file with a list of files to download (one file per line).
  • --output-dir, -d: (Optional) The directory to save the downloaded files. If not provided, files are downloaded to the current directory.
  • --skip-existing: (Optional) Skip downloading files that already exist in the output directory.
  • --batch-size, -b: (Optional) The number of files to download in a single batch. (default: 1)
  • files: (Optional) Space-separated list of file names to download.
  • --repo, -g: (Optional) The GitHub repository in the format owner/repo. If not provided, it will be inferred from the current directory.

Example:

download-from-release --release v1.0.0 --file-list files_to_download.txt --output-dir /path/to/downloads

This command will download the files listed in files_to_download.txt from the v1.0.0 release and any releases named v1.0.0-extra<number> into the /path/to/downloads directory.

download-from-release --release v1.0.0 my_file.zip --skip-existing

This command will download my_file.zip to the current directory, but only if it doesn't already exist.

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

gh_release_tools-0.1.14.tar.gz (8.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

gh_release_tools-0.1.14-py3-none-any.whl (12.4 kB view details)

Uploaded Python 3

File details

Details for the file gh_release_tools-0.1.14.tar.gz.

File metadata

  • Download URL: gh_release_tools-0.1.14.tar.gz
  • Upload date:
  • Size: 8.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.5

File hashes

Hashes for gh_release_tools-0.1.14.tar.gz
Algorithm Hash digest
SHA256 db1c3ec045c8eee38ad66493c47dae1b2db733e1a2d2eb9a11770970bdc79059
MD5 214248b5bf18c8cc0aa19402c1bb6975
BLAKE2b-256 cce8275ff5bdb0f220b9ece56807afa0149f5faa5cbd96cde7aed8c4d0dd2467

See more details on using hashes here.

File details

Details for the file gh_release_tools-0.1.14-py3-none-any.whl.

File metadata

File hashes

Hashes for gh_release_tools-0.1.14-py3-none-any.whl
Algorithm Hash digest
SHA256 00a09d3aef34345b06e6050b0cb5330de4659be7de15ee862cd1087fd8e28846
MD5 ab03aa3bd84b3c0d29daad0d0f9dfa80
BLAKE2b-256 224df1d90f99ae0987a40aad8773a63ba77f3ecf2693ad84d9a83b0182f3d300

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page