Skip to content

Latest commit

 

History

History
122 lines (94 loc) · 3.67 KB

README.md

File metadata and controls

122 lines (94 loc) · 3.67 KB

Torrent Action

This GitHub action allows you to generate and publish torrent files for your release assets, which is useful when the files are large. Initial seeding is performed using the corresponding GitHub release assets as webseeds.

Usage

There are two modes, local and remote.

  • In local mode, you will specify which files need torrents generated. This works faster as there's less upload/download involved.
  • In remote mode, every generated asset gets a corresponding torrent file. Parameters files and onefile are ignored.

Parameters

name default description
token required Set to ${{ secrets.GITHUB_TOKEN }}
local true Search files locally or download existing release assets.
files required, if local List of files to create torrents for. One per line, globs allowed.
onefile false Create a single torrent containing all listed files.

Local

Files are searched locally, torrents are generated for them, and then everything is released together.

Example

name: Release

on:
  push:
    tags:
      - "v*"

jobs:
  release:
    runs-on: ubuntu-latest
    permissions:
      contents: write
    steps:
      - name: Checkout repository
        uses: actions/checkout@v4

        # Create torrents first
      - name: Create torrents
        if: startsWith(github.ref, 'refs/tags/')
        uses: devopsx/action-torrent@v1
        with:
          token: ${{ secrets.GITHUB_TOKEN }}
          files: |
            dist/index.js
            src/*

        # And then upload torrents together with corresponding assets
      - name: Release
        if: startsWith(github.ref, 'refs/tags/')
        uses: softprops/action-gh-release@v2
        with:
          token: ${{ secrets.GITHUB_TOKEN }}
          name: ${{ github.ref_name }}
          fail_on_unmatched_files: true
          files: | # same as above, but with addition of torrents/* directory
            dist/index.js
            src/*
            torrents/*

Make sure to include all the same files into the actual release, this is required for the initial web seeding.

Remote

The release is generated first, then every asset is downloaded, a corresponding torrent file is created and uploaded. Parameters files and onefile are ignored.

This is a bit slower, as there's an extra download cycle, but may be preferable in some use cases.

Example

name: Release

on:
  push:
    tags:
      - "v*"

jobs:
  release:
    runs-on: ubuntu-latest
    permissions:
      contents: write
    steps:
      - name: Checkout repository
        uses: actions/checkout@v4

        # Create a release first
      - name: Release
        if: startsWith(github.ref, 'refs/tags/')
        uses: softprops/action-gh-release@v2
        with:
          token: ${{ secrets.GITHUB_TOKEN }}
          name: ${{ github.ref_name }}
          fail_on_unmatched_files: true
          files: |
            dist/index.js
            src/*

        # Download release assets, create and upload a torrent file for each one
      - name: Release torrents
        if: startsWith(github.ref, 'refs/tags/')
        uses: devopsx/action-torrent@v1
        with:
          token: ${{ secrets.GITHUB_TOKEN }}
          local: false

P.S.

I would add magnet links, but GitHub doesn't render them.

P.P.S.

GitHub/Microsoft, if you'd like to thank me for the gazillibytes of traffic saved, you have my contact info :).