Skip to main content

A CLI tool to automate SIGNATE competition workflows via GitHub Actions

Project description

signate-deploy

A CLI tool to automate SIGNATE competition workflows via GitHub Actions.

git push → GitHub Actions → Download data → Train → Submit to SIGNATE

signate-deploy init-repo              # Set up GitHub Actions workflows
signate-deploy setup-token            # Get SIGNATE token & set GitHub Secret
signate-deploy competition-list       # List available competitions
signate-deploy task-list <comp_key>   # Get task_key from competition
signate-deploy file-list <task_key>   # Get file_keys from task
signate-deploy init my-comp \
  --task-key <task_key> \
  --file-key train:<key> \
  --file-key test:<key>               # Create competition directory
signate-deploy submit my-comp \
  --memo "Baseline v1"               # Trigger train & submit
signate-deploy download my-comp      # Trigger data download only

Installation

pip install signate-deploy

Prerequisites: GitHub CLI (gh) must be installed and authenticated.

Quick Start

1. Install signate CLI

pip install signate

The signate CLI is required to fetch your API token and get file keys. It is a separate package from signate-deploy.

2. Set up GitHub Actions

In your GitHub repository root:

python -m signate_deploy init-repo

Creates:

  • .github/workflows/signate-submit.yml — full pipeline (download → train → submit)
  • .github/workflows/signate-download.yml — data download only

3. Set SIGNATE token as GitHub Secret

python -m signate_deploy setup-token --email=your@email.com --set-secret

This command will:

  1. Run signate token interactively (you will be prompted for your password)
  2. Base64-encode ~/.signate/signate.json
  3. Set it as SIGNATE_TOKEN_B64 in GitHub Secrets automatically

Windows (cmd.exe): Use python -m signate_deploy instead of signate-deploy since the Scripts folder may not be on PATH.

4. Get task_key and file_keys

# Find your competition_key from the competition URL:
# https://user.competition.signate.jp/.../detail/?competition=THIS_IS_COMPETITION_KEY

# Get task_key from competition_key
python -m signate_deploy task-list <competition_key>

# Get file_keys from task_key
python -m signate_deploy file-list <task_key>

You can also browse available competitions with python -m signate_deploy competition-list.

5. Create competition directory

python -m signate_deploy init my-comp \
  --task-key abc123def456 \
  --file-key train:5f0e1ebb35af4963 \
  --file-key test:72f23ebe8f004fa0 \
  --file-key sample_submit:ad3502af26b9

Creates:

my-comp/
  signate-config.json   # task_key and file_keys
  train.py              # LightGBM 5-fold CV template
  requirements.txt      # pandas, numpy, scikit-learn, lightgbm

6. Edit train.py and push

# Edit my-comp/train.py (set TARGET column name, add preprocessing, etc.)
git add my-comp/ && git commit -m "Add my-comp baseline" && git push

7. Submit

python -m signate_deploy submit my-comp --memo "Baseline v1"
# → gh workflow run signate-submit.yml is triggered

# Check progress
gh run list --limit 1
gh run view --log

signate-config.json

{
  "task_key": "your_task_key",
  "file_keys": {
    "train": "file_key_for_train_csv",
    "test": "file_key_for_test_csv",
    "sample_submit": "file_key_for_sample_submit_csv"
  }
}

Notes

  • ⚠️ Never commit data/ or .signate/ — they are .gitignored by init-repo
  • Requires GitHub CLI (gh) to be installed and authenticated
  • Works on any OS (Windows/Mac/Linux)

Links

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

signate_deploy-0.1.6.tar.gz (10.6 kB view details)

Uploaded Source

Built Distribution

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

signate_deploy-0.1.6-py3-none-any.whl (15.6 kB view details)

Uploaded Python 3

File details

Details for the file signate_deploy-0.1.6.tar.gz.

File metadata

  • Download URL: signate_deploy-0.1.6.tar.gz
  • Upload date:
  • Size: 10.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for signate_deploy-0.1.6.tar.gz
Algorithm Hash digest
SHA256 250cae9456970dbe621af721b8a5dd82bed07b76d80c4cee13938339a53dfdb6
MD5 c8ad7599004378c3d77097079a420b61
BLAKE2b-256 f3dedeedddcebeb03862a6af89865b393d70884d1837f3aa174e6299fd3c1eb6

See more details on using hashes here.

Provenance

The following attestation bundles were made for signate_deploy-0.1.6.tar.gz:

Publisher: publish.yml on yasumorishima/signate-deploy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file signate_deploy-0.1.6-py3-none-any.whl.

File metadata

  • Download URL: signate_deploy-0.1.6-py3-none-any.whl
  • Upload date:
  • Size: 15.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for signate_deploy-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 9588148a0a648233f3f760bedac829fb82ebc2ccfb3b82eea81a4f5dfc7712fd
MD5 c7feff8ea47317f265994c6923895346
BLAKE2b-256 451e2b9f1d60994eeffc7cad8d310f82189f8988fefc2b3d5027eb81082755af

See more details on using hashes here.

Provenance

The following attestation bundles were made for signate_deploy-0.1.6-py3-none-any.whl:

Publisher: publish.yml on yasumorishima/signate-deploy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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