Skip to content
This repository has been archived by the owner on Jun 17, 2024. It is now read-only.

Latest commit

 

History

History
102 lines (79 loc) · 2.04 KB

README.md

File metadata and controls

102 lines (79 loc) · 2.04 KB

⚠️ Deprecated in favour of fastify-kit.

⚠️ Do not use it in produciton.

re.js

re.js is a framework built on top of Express that facilitates the development of API endpoints using the capabilities of Typescript and Zod.

Features

  • 💥 Tiny and lightweight
  • 🏆 First class support of Zod and Typescript
  • 🧠 Fully-typed routes, params and output
  • 🤓 Out of the box OpenAPI/Swagger support
  • 😎 Backward compatible with Express

Getting started

bash npm install @relab/rejs --save

Route

import { route } from '@relab/rejs'
import { z } from 'zod'

export const helloWorld = route({
    method: 'POST',
    path: '/hello/:name',
    schema: {
        route: z.object({
            name: z.coerce.string(),
        }),
        result: z.string(),
    },
})(({ route }, context) => {
    return `${route.name}, hello world!`
})

Setup routes serving

In your index.ts:

import { serve } from '@relab/rejs'

import { helloWorld } from './hello-world'

void serve(
    {
        port: Number(process.env.PORT) || 3000,
        routes: [
            helloWorld,
        ],
    },
    port => {
        logger.info(`Listening http://localhost:${port}`)
    }
)

Setup swagger

npm install @relab/rejs-swagger --save

In your index.ts:

import { serve } from '@relab/rejs'
import { swagger } from '@relab/rejs-swagger'

import { helloWorld } from './hello-world'

void serve(
    {
        port: Number(process.env.PORT) || 3000,
        middlewares: [
            swagger({
                ui: {
                    enabled: true,
                },
            }),
        ],
        routes: [
            helloWorld,
        ],
    },
    port => {
        logger.info(`Listening http://localhost:${port}`)
    }
)

Now you can access Swagger by /swagger and /swagger/swagger.json URLs.

License

Released under MIT by Sergey Zwezdin.