CLI client for judge.nitro-ai.org
Project description
Nitro CLI
CLI client for judge.nitro-ai.org.
Features
- login using Nitro's JSON API
- list contests with page controls
- list tasks for a contest
- view full task statements
- submit solutions and wait for feedback
- list submissions
- inspect submission feedback/details
- interactive shell mode when run without arguments
Requirements
- Python 3.10+
- no third-party Python package dependencies
Login
nitro-cli login posts to Nitro's /api/auth/login endpoint and stores the returned access and refresh tokens.
Behavior:
- saves API tokens in the local CLI state file
- refreshes an expired access token when a refresh token is available
- asks you to log in again if the saved refresh token is no longer valid
Example:
nitro-cli login --username MihneaStoica --password '...'
Installation
With pipx:
pipx install .
With pip:
python3 -m pip install .
For local development:
python3 -m pip install -e .
From PyPI:
pipx install nitro-ai-judge-cli
Usage
Direct commands:
nitro-cli login
nitro-cli contests
nitro-cli contests --page 2
nitro-cli contests --all-pages
nitro-cli tasks algolymp/algolymp-preojia-ix-x
nitro-cli task algolymp/algolymp-preojia-ix-x 1
nitro-cli submissions algolymp/algolymp-preojia-ix-x 1 --mode both
nitro-cli submission 3a009d767bd5 --org algolymp --comp algolymp-preojia-ix-x --task-id 1
nitro-cli submit algolymp/algolymp-preojia-ix-x 1 --output submission.csv --source solution.py --wait
Interactive shell:
nitro-cli
Example shell session:
contest list
contest list --page 2
contest list --all-pages
select 20
tasks
select 1
show
submit submission.csv solution.py --wait
submissions
submission 1
Shell commands:
help
exit | quit
back | unselect
login [username] [password]
status
contests
contest list [--all] [--page N] [--page-size N] [--all-pages]
contest select <index|org/slug>
contest show
tasks
task list
task select <index|id>
select <index|id>
show
submit <output.csv> [source.py] [--note TEXT] [--wait]
task show
task submit <output.csv> [source.py] [--note TEXT] [--wait]
submissions [--mode partial|complete|both]
task submissions list [--mode partial|complete|both]
submission <index|short-id|full-id>
submission view <index|short-id|full-id>
task submissions show <index|short-id|full-id>
set-final <index|short-id|full-id>
unset-final <index|short-id|full-id>
Notes:
selectis context-sensitive: at top level it selects a contest; inside a contest it selects a task.back/unselectclears the current task first, then the current contest.
State
Login state is stored in:
~/.nitro-cli/state.json
Override with:
NITRO_STATE_DIR=/some/path nitro-cli login
Publishing
This repo includes a GitHub Actions workflow at .github/workflows/publish.yml.
Behavior:
- Builds the package on pushes, pull requests, and manual runs
- Runs
twine checkon built distributions - Publishes to PyPI when you push a tag matching
v*
Recommended release flow:
python3 -m pip install --upgrade build twine
python3 -m build
python3 -m twine check dist/*
# bump version in pyproject.toml before tagging a new release
git tag v0.1.3
git push origin main --tags
PyPI does not allow re-uploading the same filename for an existing release. The workflow is configured to skip already-published files on reruns, but publishing a new release still requires a new version in pyproject.toml and a matching new tag.
For PyPI trusted publishing, configure PyPI to trust this GitHub repository and the pypi environment.
Package name on PyPI: nitro-ai-judge-cli
Command name after install: nitro-cli
Before publishing publicly, choose and add a license file.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file nitro_ai_judge_cli-0.2.0.tar.gz.
File metadata
- Download URL: nitro_ai_judge_cli-0.2.0.tar.gz
- Upload date:
- Size: 15.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
efe77fd6492ac496dc01c2ae88032326096b2d915d7bf6dec35d442eb9e98ee5
|
|
| MD5 |
9fe752b6945512e360a5ad0b97e53d93
|
|
| BLAKE2b-256 |
0b8185aa9888489ef9a5a40648a43fdc95fb0d00b0228f77d8da8082c543f113
|
Provenance
The following attestation bundles were made for nitro_ai_judge_cli-0.2.0.tar.gz:
Publisher:
publish.yml on MihneaTeodorStoica/nitro-cli
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
nitro_ai_judge_cli-0.2.0.tar.gz -
Subject digest:
efe77fd6492ac496dc01c2ae88032326096b2d915d7bf6dec35d442eb9e98ee5 - Sigstore transparency entry: 1435188327
- Sigstore integration time:
-
Permalink:
MihneaTeodorStoica/nitro-cli@fa840aa0829022e101877d61a249fc9b14343cd4 -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/MihneaTeodorStoica
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@fa840aa0829022e101877d61a249fc9b14343cd4 -
Trigger Event:
push
-
Statement type:
File details
Details for the file nitro_ai_judge_cli-0.2.0-py3-none-any.whl.
File metadata
- Download URL: nitro_ai_judge_cli-0.2.0-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.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
220ba9e11d1a457a12b4bfad4a657ad0cba81f456698b8c680793ae64aa05f1d
|
|
| MD5 |
7eed29f2f770c4cb8e04a592169aba43
|
|
| BLAKE2b-256 |
f712563e385fee4f8a676ebac5efd83a4c8d412333ccf1230943f8996d63f616
|
Provenance
The following attestation bundles were made for nitro_ai_judge_cli-0.2.0-py3-none-any.whl:
Publisher:
publish.yml on MihneaTeodorStoica/nitro-cli
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
nitro_ai_judge_cli-0.2.0-py3-none-any.whl -
Subject digest:
220ba9e11d1a457a12b4bfad4a657ad0cba81f456698b8c680793ae64aa05f1d - Sigstore transparency entry: 1435188387
- Sigstore integration time:
-
Permalink:
MihneaTeodorStoica/nitro-cli@fa840aa0829022e101877d61a249fc9b14343cd4 -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/MihneaTeodorStoica
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@fa840aa0829022e101877d61a249fc9b14343cd4 -
Trigger Event:
push
-
Statement type: