with one click
Create backend with ElysiaJS, a type-safe, high-performance framework.
npx skills add https://github.com/midudev/autoskills --skill elysiajsCopy and paste this command into Claude Code to install the skill
Create backend with ElysiaJS, a type-safe, high-performance framework.
npx skills add https://github.com/midudev/autoskills --skill elysiajsCopy and paste this command into Claude Code to install the skill
Turborepo monorepo build system guidance. Triggers on: turbo.json, task pipelines, dependsOn, caching, remote cache, the "turbo" CLI, --filter, --affected, CI optimization, environment variables, internal packages, monorepo structure/best practices, and boundaries. Use when user: configures tasks/workflows/pipelines, creates packages, sets up monorepo, shares code between apps, runs changed/affected packages, debugs cache, or has apps/packages directories.
Reviews Rails pull requests, focusing on controller/model conventions, migration safety, query performance, and Rails Way compliance. Covers routing, ActiveRecord, security, caching, and background jobs. Use when reviewing existing Rails code for quality, conducting a PR review, or doing a code review on Ruby on Rails (RoR) code.
Use when writing new Rails code for a project using the PostgreSQL + Hotwire + Tailwind CSS stack. Covers stack-specific patterns only: MVC structure, ActiveRecord query conventions, Turbo Frames/Streams wiring, Stimulus controllers, and Tailwind component patterns. Not for general Rails design principles ā this skill is scoped to what changes based on this specific technology stack.
Analyzes Rails applications and generates comprehensive upgrade reports with breaking changes, deprecations, and step-by-step migration guides for Rails 2.3 through 8.1. Use when upgrading Rails applications, planning multi-hop upgrades, or querying version-specific changes. Based on FastRuby.io methodology and "The Complete Guide to Upgrade Rails" ebook.
Use when writing RSpec tests for service objects, API clients, orchestrators, or business logic in spec/services/. Covers instance_double, FactoryBot hash factories, shared_examples, subject/let blocks, context/describe structure, aggregate_failures, change matchers, travel_to, and error scenario testing.
Best practices for Remotion - Video creation in React
| name | elysiajs |
| description | Create backend with ElysiaJS, a type-safe, high-performance framework. |
Always consult elysiajs.com/llms.txt for code examples and latest API.
ElysiaJS is a TypeScript framework for building Bun-first (but not limited to Bun) type-safe, high-performance backend servers. This skill provides comprehensive guidance for developing with Elysia, including routing, validation, authentication, plugins, integrations, and deployment.
Trigger this skill when the user asks to:
Quick scaffold:
bun create elysia app
import { Elysia, t, status } from 'elysia'
const app = new Elysia()
.get('/', () => 'Hello World')
.post('/user', ({ body }) => body, {
body: t.Object({
name: t.String(),
age: t.Number()
})
})
.get('/id/:id', ({ params: { id } }) => {
if(id > 1_000_000) return status(404, 'Not Found')
return id
}, {
params: t.Object({
id: t.Number({
minimum: 1
})
}),
response: {
200: t.Number(),
404: t.Literal('Not Found')
}
})
.listen(3000)
import { Elysia } from 'elysia'
new Elysia()
.get('/', 'GET')
.post('/', 'POST')
.put('/', 'PUT')
.patch('/', 'PATCH')
.delete('/', 'DELETE')
.options('/', 'OPTIONS')
.head('/', 'HEAD')
.get('/user/:id', ({ params: { id } }) => id)
.get('/post/:id/:slug', ({ params }) => params)
.get('/search', ({ query }) => query.q)
// GET /search?q=elysia ā "elysia"
.post('/user', ({ body }) => body)
.get('/', ({ headers }) => headers.authorization)
import { Elysia, t } from 'elysia'
.post('/user', ({ body }) => body, {
body: t.Object({
name: t.String(),
age: t.Number(),
email: t.String({ format: 'email' }),
website: t.Optional(t.String({ format: 'uri' }))
})
})
body: t.Object({
user: t.Object({
name: t.String(),
address: t.Object({
street: t.String(),
city: t.String()
})
})
})
body: t.Object({
tags: t.Array(t.String()),
users: t.Array(t.Object({
id: t.String(),
name: t.String()
}))
})
.post('/upload', ({ body }) => body.file, {
body: t.Object({
file: t.File({
type: 'image', // image/* mime types
maxSize: '5m' // 5 megabytes
}),
files: t.Files({ // Multiple files
type: ['image/png', 'image/jpeg']
})
})
})
.get('/user/:id', ({ params: { id } }) => ({
id,
name: 'John',
email: 'john@example.com'
}), {
params: t.Object({
id: t.Number()
}),
response: {
200: t.Object({
id: t.Number(),
name: t.String(),
email: t.String()
}),
404: t.String()
}
})
import { z } from 'zod'
.post('/user', ({ body }) => body, {
body: z.object({
name: z.string(),
age: z.number().min(0),
email: z.string().email()
})
})
.get('/user/:id', ({ params: { id }, status }) => {
const user = findUser(id)
if (!user) {
return status(404, 'User not found')
}
return user
})
.guard({
params: t.Object({
id: t.Number()
})
}, app => app
.get('/user/:id', ({ params: { id } }) => id)
.delete('/user/:id', ({ params: { id } }) => id)
)
.macro({
hi: (word: string) => ({
beforeHandle() { console.log(word) }
})
})
.get('/', () => 'hi', { hi: 'Elysia' })
Elysia takes an unopinionated approach but based on user request. But without any specific preference, we recommend a feature-based and domain driven folder structure where each feature has its own folder containing controllers, services, and models.
src/
āāā index.ts # Main server entry
āāā modules/
ā āāā auth/
ā ā āāā index.ts # Auth routes (Elysia instance)
ā ā āāā service.ts # Business logic
ā ā āāā model.ts # TypeBox schemas/DTOs
ā āāā user/
ā āāā index.ts
ā āāā service.ts
ā āāā model.ts
āāā plugins/
āāā custom.ts
public/ # Static files (if using static plugin)
test/ # Unit tests
Each file has its own responsibility as follows:
Elysia is unopinionated on design pattern, but if not provided, we can relies on MVC pattern pair with feature based folder structure.
onError to handle local custom errorsElysia.models({ ...models }) and prefix model by namespace Elysia.prefix('model', 'Namespace.')Model.nameModelstatus (import { status } from 'elysia') for errorreturn Error instead of throw ErrorElysia has a every important concepts/rules to understand before use.
Lifecycles (hooks, middleware) don't leak between instances unless scoped.
Scope levels:
local (default) - current instance + descendantsscoped - parent + current + descendantsglobal - all instances.onBeforeHandle(() => {}) // only local instance
.onBeforeHandle({ as: 'global' }, () => {}) // exports to all
Must chain. Each method returns new type reference.
ā Don't:
const app = new Elysia()
app.state('build', 1) // loses type
app.get('/', ({ store }) => store.build) // build doesn't exists
ā Do:
new Elysia()
.state('build', 1)
.get('/', ({ store }) => store.build)
Each instance independent. Declare what you use.
const auth = new Elysia()
.decorate('Auth', Auth)
.model(Auth.models)
new Elysia()
.get('/', ({ Auth }) => Auth.getProfile()) // Auth doesn't exists
new Elysia()
.use(auth) // must declare
.get('/', ({ Auth }) => Auth.getProfile())
Global scope when:
Explicit when:
Plugins re-execute unless named:
new Elysia() // rerun on `.use`
new Elysia({ name: 'ip' }) // runs once across all instances
Events apply to routes registered after them.
.onBeforeHandle(() => console.log('1'))
.get('/', () => 'hi') // has hook
.onBeforeHandle(() => console.log('2')) // doesn't affect '/'
Inline functions only for accurate types.
For controllers, destructure in inline wrapper:
.post('/', ({ body }) => Controller.greet(body), {
body: t.Object({ name: t.String() })
})
Get type from schema:
type MyType = typeof MyType.static
Model can be reference by name, especially great for documenting an API
new Elysia()
.model({
book: t.Object({
name: t.String()
})
})
.post('/', ({ body }) => body.name, {
body: 'book'
})
Model can be renamed by using .prefix / .suffix
new Elysia()
.model({
book: t.Object({
name: t.String()
})
})
.prefix('model', 'Namespace')
.post('/', ({ body }) => body.name, {
body: 'Namespace.Book'
})
Once prefix, model name will be capitalized by default.
The following are technical terms that is use for Elysia:
OpenAPI Type Gen - function name fromTypes from @elysiajs/openapi for generating OpenAPI from types, see plugins/openapi.mdEden, Eden Treaty - e2e type safe RPC client for share type from backend to frontendUse the following references as needed.
It's recommended to checkout route.md for as it contains the most important foundation building blocks with examples.
plugin.md and validation.md is important as well but can be check as needed.
Detailed documentation split by topic:
bun-fullstack-dev-server.md - Bun Fullstack Dev Server with HMR. React without bundler.cookie.md - Detailed documentation on cookiedeployment.md - Production deployment guide / Dockereden.md - e2e type safe RPC client for share type from backend to frontendguard.md - Setting validation/lifecycle all at oncemacro.md - Compose multiple schema/lifecycle as a reusable Elysia via key-value (recommended for complex setup, eg. authentication, authorization, Role-based Access Check)plugin.md - Decouple part of Elysia into a standalone componentroute.md - Elysia foundation building block: Routing, Handler and Contexttesting.md - Unit tests with examplesvalidation.md - Setup input/output validation and list of all custom validation ruleswebsocket.md - Real-time featuresDetailed documentation, usage and configuration reference for official Elysia plugin:
bearer.md - Add bearer capability to Elysia (@elysiajs/bearer)cors.md - Out of box configuration for CORS (@elysiajs/cors)cron.md - Run cron job with access to Elysia context (@elysiajs/cron)graphql-apollo.md - Integration GraphQL Apollo (@elysiajs/graphql-apollo)graphql-yoga.md - Integration with GraphQL Yoga (@elysiajs/graphql-yoga)html.md - HTML and JSX plugin setup and usage (@elysiajs/html)jwt.md - JWT / JWK plugin (@elysiajs/jwt)openapi.md - OpenAPI documentation and OpenAPI Type Gen / OpenAPI from types (@elysiajs/openapi)opentelemetry.md - OpenTelemetry, instrumentation, and record span utilities (@elysiajs/opentelemetry)server-timing.md - Server Timing metric for debug (@elysiajs/server-timing)static.md - Serve static files/folders for Elysia Server (@elysiajs/static)Guide to integrate Elysia with external library/runtime:
ai-sdk.md - Using Vercel AI SDK with Elysiaastro.md - Elysia in Astro API routebetter-auth.md - Integrate Elysia with better-authcloudflare-worker.md - Elysia on Cloudflare Worker adapterdeno.md - Elysia on Denodrizzle.md - Integrate Elysia with Drizzle ORMexpo.md - Elysia in Expo API routenextjs.md - Elysia in Nextjs API routenodejs.md - Run Elysia on Node.jsnuxt.md - Elysia on API routeprisma.md - Integrate Elysia with Prismareact-email.d - Create and Send Email with React and Elysiasveltekit.md - Run Elysia on Svelte Kit API routetanstack-start.md - Run Elysia on Tanstack Start / React Queryvercel.md - Deploy Elysia to Vercelbasic.ts - Basic Elysia examplebody-parser.ts - Custom body parser example via .onParsecomplex.ts - Comprehensive usage of Elysia servercookie.ts - Setting cookieerror.ts - Error handlingfile.ts - Returning local file from serverguard.ts - Setting mulitple validation schema and lifecyclemap-response.ts - Custom response mapperredirect.ts - Redirect responserename.ts - Rename context's propertyschema.ts - Setup validationstate.ts - Setup global stateupload-file.ts - File upload with validationwebsocket.ts - Web Socket for realtime communicationpatterns/mvc.md - Detail guideline for using Elysia with MVC patterns