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!