API reference
Docs handler options
The following options can be passed to the docsRouteHandler
(App Router) and docsApiRouteHandler
(Pages Router) functions for customizing Next REST Framework:
Name | Description |
---|---|
deniedPaths | Array of paths that are denied by Next REST Framework and not included in the OpenAPI spec. Supports wildcards using asterisk * and double asterisk ** for recursive matching. Example: ['/api/disallowed-path', '/api/disallowed-path-2/*', '/api/disallowed-path-3/**'] Defaults to no paths being disallowed. |
allowedPaths | Array of paths that are allowed by Next REST Framework and included in the OpenAPI spec. Supports wildcards using asterisk * and double asterisk ** for recursive matching. Example: ['/api/allowed-path', '/api/allowed-path-2/*', '/api/allowed-path-3/**'] Defaults to all paths being allowed. |
openApiObject | An OpenAPI Object that can be used to override and extend the auto-generated specification. |
openApiJsonPath | Path that will be used for fetching the OpenAPI spec - defaults to /openapi.json . This path also determines the path where this file will be generated inside the public folder. |
autoGenerateOpenApiSpec | Setting this to false will not automatically update the generated OpenAPI spec when calling the docs handler endpoints. Defaults to true . |
docsConfig | A Docs config object for customizing the generated docs. |
suppressInfo | Setting this to true will suppress all informational logs from Next REST Framework. Defaults to false . |
Docs config
The docs config options can be used to customize the generated docs:
Name | Description |
---|---|
provider | Determines whether to render the docs using Redoc (redoc ) or SwaggerUI swagger-ui . Defaults to redoc . |
title | Custom title, used for the visible title and HTML title. |
description | Custom description, used for the visible description and HTML meta description. |
faviconUrl | Custom HTML meta favicon URL. |
logoUrl | A URL for a custom logo. |
Route handler options
The following options cam be passed to the routeHandler
(App Router) and apiRouteHandler
(Pages Router) functions to create new API endpoints:
Name | Description | Required |
---|---|---|
GET \| PUT \| POST \| DELETE \| OPTIONS \| HEAD \| PATCH | A Method handler object. | true |
openApiPath | An OpenAPI Path Item Object that can be used to override and extend the auto-generated specification. | false |
Route operations
The route operation functions routeOperation
(App Router) and apiRouteOperation
(Pages Router) allow you to define your API handlers for your endpoints. These functions accept an OpenAPI Operation object as a parameter, that can be used to override the auto-generated specification. Calling this function allows you to chain your API handler logic with the following functions.
Name | Description |
---|---|
input | An Input function for defining the validation and documentation of the request. |
output | An Output function for defining the validation and documentation of the response. |
handler | A Handler function for defining your business logic. |
Input
The input function is used for type-checking, validation and documentation of the request, taking in an object with the following properties:
Name | Description | Required |
---|---|---|
contentType | The content type header of the request. When the content type is defined, a request with an incorrect content type header will get an error response. | false |
body | A Zod schema describing the format of the request body. When the body schema is defined, a quest with an invalid request body will get an error response. | false |
query | A Zod schema describing the format of the query parameters. When the query schema is defined, a request with invalid query parameters will get an error response. | false |
Calling the input function allows you to chain your API handler logic with the Output and Handler functions.
Output
The output function is used for type-checking and documentation of the response, taking in an array of objects with the following properties:
Name | Description | Required |
---|---|---|
status | A status code that your API can return. | true |
contentType | The content type header of the response. | true |
schema | A Zod schema describing the format of the response data. | true |
Calling the input function allows you to chain your API handler logic with the Handler function.
Handler
The handler function is a strongly-typed function to implement the business logic for your API. The function takes in strongly-typed versions of the same parameters as the Next.js Route Handlers and API Routes handlers.
CLI
The Next REST Framework CLI supports generating and validating the openapi.json
file:
npx next-rest-framework generate
to generate theopenapi.json
file.npx next-rest-framework validate
to validate that theopenapi.json
file is up-to-date.
The next-rest-framework validate
command is useful to have as part of the static checks in your CI/CD pipeline. Both commands support the following options:
Name | Description |
---|---|
--skipBuild <boolean> | By default, next build is used to build your routes. If you have already created the build, you can skip this step by setting this to true . |
--distDir <string> | Path to your production build directory. Defaults to .next . |
--timeout <string> | The timeout for generating the OpenAPI spec. Defaults to 60 seconds. |
--configPath <string> | In case you have multiple docs handlers with different configurations, you can specify which configuration you want to use by providing the path to the API. Example: /api/my-configuration . |