Skip to main content

API reference

Config options

The optional config options allow you to customize Next REST Framework. The following options can be passed as a parameter for your NextRestFramework client in an object:

NameDescription
openApiSpecOverridesAn OpenAPI Object that can be used to override and extend the auto-generated specification.
openApiJsonPathCustom path for serving openapi.json file. Defaults to /api/openapi.json.
openApiYamlPathCustom path for serving openapi.yaml file. Defaults to /api/openapi.yaml.
swaggerUiPathCustom path for service Swagger UI. Defaults to /api.
swaggerUiConfigA SwaggerUI config object for customizing the generated SwaggerUI.
exposeOpenApiSpecSetting this to false will serve none of the OpenAPI documents neither the Swagger UI. Defaults to true.
middlewareA global middleware for all of your API routes. See Global middleware for more information.
errorHandlerA Global error handler for all of your API routes. Defaults to a basic error handler logging the errors in non-production mode.
suppressInfoSetting this to true will suppress all informational logs from Next REST Framework. Defaults to false.
apiRoutesPath Absolute path to the directory where your API routes are located - defaults to pages/api.

Route config

The route config parameters define an individual route, applicable for all endpoints (methods) that are using that route:

NameDescriptionRequired
GET \| PUT \| POST \| DELETE \| OPTIONS \| HEAD \| PATCH \| TRACEA Method handler object.true
middleware A Middleware function that takes in the return values from your Global middleware.false
errorHandlerA Route error handler for this API route, overriding the Global error handler.false
openApiSpecOverridesAn OpenAPI Path Item Object that can be used to override and extend the auto-generated and higher level specifications.false

Method handlers

The method handler parameters define an individual endpoint:

NameDescriptionRequired
inputAn Input object object.false
outputAn array of Output objects. true
middlewareA Middleware function that takes in the return values from both your Global middleware and Route middleware. false
handler Your Handler function that takes in your typed request, response and Middleware parameters and contains all of your business logic.true
errorHandlerA Method error handler for this method, overriding both the Global error handler and Route error handler.false
openApiSpecOverridesAn OpenAPI Operation object that can be used to override and extend the auto-generated and higher level specifications.false

Input

The input object is used for the validation of the incoming request:

NameDescriptionRequired
contentTypeThe content type that the request must have - request with no content type or incorrect content type will get an error response.true
bodyA Zod schema describing the format of the request body.true
queryA Zod schema describing the format of the query parameters. Note that Next.js parses the query string into an object containing either strings or arrays of strings.false

Output object

The output objects define what kind of responses you are allowed to return from your API handlers:

NameDescriptionRequired
statusA possible status code that your API can return - using other status codes will lead to a TS error.true
contentTypeThe content type of the response - using other content-types will lead to a TS error.true
schemaA Zod schema describing the format of the response data. A response format not matching to the schema will lead to a TS error. true

Handler

The handler function takes care of your actual business logic, supporting both synchronous and asynchronous execution and taking in an object with three strongly typed parameters:

NameDescription
req A strongly-typed NextApiRequest object containing the typed body and query parameters of your request.
resA strongly-typed NextApiResponse object that allows you to use only pre-defined status codes, Content-Type headers and response data formats from the current method handler.
paramsAn object containing the strongly-typed combined response of your Global middleware, Route middleware and Method middleware. The parameters can also be overridden in the different middleware layers with the Method middleware taking precedence over the Route middleware and route middleware taking precedence over Global middleware

Middlewares

The middleware functions can be used for any kind of middleware logic, like adding authentication etc. for your API. In addition, they can be used to add additional typed parameters for your API route handlers. They support both asynchronous and synchronous execution.

// A global middleware, route middleware or method middleware.
middleware: () => ({
foo: 'bar'
});
// A method handler (given that the middleware above is either in the same API route or method, or is a global middleware).
handler: ({
params: {
foo // string
}
}) => {
// Your logic.
};

Global middleware

The global middleware function takes in an object with two attributes and optionally returns an object of any form:

NameDescription
req A plain NextApiRequest object.
resA plain NextApiResponse object.

Route middleware

The route middleware function takes in an object with three attributes and optionally returns an object of any form:

NameDescription
req A plain NextApiRequest object.
resA plain NextApiResponse object.
params The type of an object returned by your Global middleware.

Method middleware

The method middleware function takes in an object with three attributes and optionally returns an object of any form:

NameDescription
req A strongly-typed NextApiRequest object containing the typed body and query parameters of your request.
resA strongly-typed NextApiResponse object that allows you to use only pre-defined status codes, Content-Type headers and response data formats from the current method handler.
params The type of a combined object returned by both your Global middleware and Route middleware.

Error handlers

The error handler functions can be used for custom error handling. They support both asynchronous and synchronous execution.

// A global error handler, route error handler or method error handler.
errorHandler: ({ req, res, params }) => {
// Your error handling logic.
};

Global error handler

The global error handler takes in an object with two attributes:

NameDescription
req A plain NextApiRequest object.
resA plain NextApiResponse object.

Route error handler

Route error handler can be used to override your global error handler. The route error handler takes in an object with three attributes:

NameDescription
req A plain NextApiRequest object.
resA plain NextApiResponse object.
params The type of a combined object returned by both your Global middleware and Route middleware.

Method error handler

Method error handler can be used to override both your global error handler and route error handler. The method error handler takes in an object with three attributes and optionally returns an object of any form:

NameDescription
req A strongly-typed NextApiRequest object containing the typed body and query parameters of your request.
resA strongly-typed NextApiResponse object that allows you to use only pre-defined status codes, Content-Type headers and response data formats from the current method handler.
params The type of a combined object returned by your Global middleware, Route middleware and Method middleware.

SwaggerUI config

The SwaggerUI config object can be used to customize the generated Swagger UI:

NameDescription
titleCustom page title meta tag value.
descriptionCustom page description meta tag value.
logoHrefAn href for a custom logo.
faviconHrefAn href for a custom favicon.