46 releases (27 stable)
| 1.0.26 | Jan 11, 2026 |
|---|---|
| 1.0.24 | Dec 29, 2025 |
| 1.0.22 | Nov 30, 2025 |
| 1.0.21 | May 26, 2025 |
| 0.1.3 | Mar 11, 2023 |
#147 in HTTP server
1MB
16K
SLoC
RustyRoad
Rails-flavored scaffolding and migrations for Rust web apps (Actix + Tera + SQLx).
RustyRoad is under active development. For day-to-day use, prefer the latest released version on crates.io.
In loving memory of Rusty (2014–2023), a wonderful loving pup. I am forever grateful for the time I had with him.
What is RustyRoad?
RustyRoad is a Rust CLI + generator toolkit inspired by Ruby on Rails.
It focuses on:
- generating a consistent project structure
- generating controllers/routes/models
- generating and running database migrations
- providing a few productivity-focused database commands
Under the hood, generated projects use Actix for HTTP, Tera for templates, and SQLx for database support.
If you're curious about the motivation, there's a short write-up here: https://rileyseaburg.com/posts/rust-needs-a-rails
Features
- Project generator (
rustyroad new) - Generators (
rustyroad generate ...) - Database migrations (
rustyroad migration ...) - Database inspection / queries (
rustyroad db ...,rustyroad query ...) - MCP Server for AI agent integration (
rustyroad-mcp) - Optional GrapesJS feature (drag-and-drop editor) via
rustyroad feature add grapesjs
Install
From crates.io
cargo install rustyroad
From source
git clone --recurse-submodules https://github.com/RustyRoad/RustyRoad
cd RustyRoad
cargo build --release
Quick start
Create a new project:
rustyroad new my_project
Generate a route/controller:
rustyroad generate route users
Configuration
How rustyroad.toml is used
RustyRoad reads your database settings from a TOML file in your project root.
- Default (dev): RustyRoad reads
./rustyroad.toml - If
ENVIRONMENTis set and notdev: RustyRoad reads./rustyroad.<ENVIRONMENT>.toml
Examples:
ENVIRONMENT=prod→ readsrustyroad.prod.tomlENVIRONMENT=test→ readsrustyroad.test.toml
There is no special rustyroad.dev.toml—dev is the plain rustyroad.toml file.
Tip: You can also use ENV=prod as a shorthand for ENVIRONMENT=prod.
If you're unsure what RustyRoad is going to read on your machine, run:
rustyroad config
(It prints ENVIRONMENT=..., the config filename, and a sanitized view of the parsed database settings.)
Migrations
RustyRoad expects migrations in this exact location (do not create a plain ./migrations/ folder):
./config/database/migrations/<timestamp>-<name>/up.sql
./config/database/migrations/<timestamp>-<name>/down.sql
Migration Commands
List migrations:
rustyroad migration list
Run all migrations (up) in order:
rustyroad migration all
Run a single migration by name (the name is the part after the timestamp in the folder name):
rustyroad migration run create_users_table
Rollback a migration:
rustyroad migration rollback create_users_table
Generate a migration (folder + files):
rustyroad migration generate create_users_table id:serial:primary_key email:string:not_null,unique
Auto-convert Rogue Migrations
If you (or an AI agent) accidentally created migrations in the wrong location (like ./migrations/), RustyRoad can detect and convert them:
# Preview what would be converted
rustyroad migration convert --dry-run
# Convert and keep source files
rustyroad migration convert
# Convert and remove source files
rustyroad migration convert --remove-source
RustyRoad will also warn you when running any migration command if it detects rogue migrations.
Database commands
Inspect schema:
rustyroad db schema
Run ad-hoc queries:
rustyroad query "SELECT * FROM users LIMIT 10;"
rustyroad query "SELECT COUNT(*) AS total_users FROM users;"
MCP Server (AI Agent Integration)
RustyRoad includes an MCP (Model Context Protocol) server that exposes database tools to AI agents like OpenCode, Claude, etc. This prevents agents from using raw psql commands or connecting to the wrong database.
Available Tools
rustyroad_query- Execute SQL queriesrustyroad_schema- Get database schemarustyroad_migrate- Run migrationsrustyroad_migration_generate- Create new migrationsrustyroad_config- View configurationrustyroad_convert_migrations- Fix rogue migrations
Setup
Register with OpenCode:
rustyroad-mcp --register
Or manually add to ~/.config/opencode/opencode.json:
{
"mcp": {
"rustyroad": {
"type": "local",
"command": ["/path/to/rustyroad-mcp"],
"enabled": true,
"environment": {
"RUSTYROAD_PROJECT_DIR": "/path/to/your/project"
}
}
}
}
Optional: GrapesJS
RustyRoad can scaffold an optional GrapesJS editor experience:
rustyroad feature add grapesjs
You can learn more about GrapesJS at https://grapesjs.com/ and see the example project at example-grapesjs/.
Examples
example/– a basic generated appexample-grapesjs/– a generated app with GrapesJS enabled
Troubleshooting
Building from source on Windows (PostgreSQL linkage)
If you build this repository from source on Windows and see errors about POSTGRES_LIB_PATH or libpq.lib:
- Install PostgreSQL from the official website
- Set
POSTGRES_LIB_PATHenvironment variable to the directory containinglibpq.lib(e.g.,C:\Program Files\PostgreSQL\13\lib) - For generated projects, create
.cargo/config.tomlin your project root:
[target.'cfg(windows)']
rustflags = ["-C", "link-arg=/LIBPATH:C:\\Program Files\\PostgreSQL\\13\\lib"]
Contributing
Contributions are welcome! Please see CONTRIBUTING.md.
License
MIT — see LICENSE.
Dependencies
~71–95MB
~1.5M SLoC