freerouting API CLI
A CLI tool for interacting with the freerouting API, maintained by tscircuit.
npm install -g freerouting
Initial Setup
Before using the CLI, you need to configure your profile ID. The easiest way is to generate a new one:
freerouting config create-profile
Alternatively, you can set a specific UUID as your profile ID:
freerouting config set-profile <uuid>
You can also optionally set a custom API base URL (defaults to https://api.freerouting.app):
freerouting config set-api-url <api-url>
Usage
The CLI follows a typical workflow for PCB autorouting:
- Create a session
- Create a job within that session
- Upload your design file
- Start the routing job
- Retrieve the output
Basic Workflow Example
freerouting session create
freerouting job create --name "my-board"
freerouting job upload --file my-board.dsn
freerouting job start
freerouting job output
Available Commands
Session Management
session create
- Create a new routing sessionsession list
- List all your sessionssession get [sessionId]
- Get details of a specific session
Job Management
job create
- Create a new routing job
- Options:
-s, --session-id <sessionId>
- Session ID (uses last session by default)-n, --name <name>
- Job name (default: "untitled")-p, --priority <priority>
- Job priority (default: "NORMAL")
job list <sessionId>
- List all jobs in a sessionjob get <jobId>
- Get details of a specific jobjob upload
- Upload a design file
- Required:
-f, --file <file>
- Path to your DSN file - Optional:
-j, --job-id <jobId>
- Job ID (uses last job by default)
job start [jobId]
- Start the routing processjob output [jobId]
- Get the routed output
- Optional:
-o, --output <file>
- Custom output file path
System Commands
system status
- Check the API system status
Configuration
config set-profile <profileId>
- Set your profile IDconfig set-api-url <apiBaseUrl>
- Set custom API base URL
Acknowledgements
- Andras Fuchs is an incredible maintainer and
none of this would have been possible without his work on the freerouting api.
THANK YOU ANDRAS!
- Freerouting is the defacto
open-source pcb routing tool. Thank you to everyone who has contributed!
We are not affiliated with the freerouting project beyond sponsoring it! If
the freerouting project wants us to give the npm handle for a more official
cli just reach out to @seveibar!