docs: add documentation to OpenApi decorator

Signed-off-by: Philip Molares <philip.molares@udo.edu>
This commit is contained in:
Philip Molares 2022-02-20 20:52:40 +01:00 committed by David Mehren
parent cae55e0baa
commit 86ef8f3c7f

View file

@ -39,6 +39,15 @@ export type HttpStatusCodes =
| 409 | 409
| 500; | 500;
/**
* Defines what the open api route should document.
*
* This makes it possible to document
* - description
* - return object
* - if the return object is an array
* - the mimeType of the response
*/
export interface HttpStatusCodeWithExtraInformation { export interface HttpStatusCodeWithExtraInformation {
code: HttpStatusCodes; code: HttpStatusCodes;
description?: string; description?: string;
@ -47,6 +56,17 @@ export interface HttpStatusCodeWithExtraInformation {
mimeType?: string; mimeType?: string;
} }
/**
* This decorator is used to document what an api route returns.
*
* The decorator can be used on a controller method or on a whole controller class (if one wants to document that every method of the controller returns something).
*
* @param httpStatusCodesMaybeWithExtraInformation - list of parameters can either be just the {@link HttpStatusCodes} or a {@link HttpStatusCodeWithExtraInformation}.
* If only a {@link HttpStatusCodes} is provided a default description will be used.
*
* For non-200 successful responses the appropriate {@link HttpCode} decorator is set
* @constructor
*/
// eslint-disable-next-line @typescript-eslint/naming-convention,func-style // eslint-disable-next-line @typescript-eslint/naming-convention,func-style
export const OpenApi = ( export const OpenApi = (
...httpStatusCodesMaybeWithExtraInformation: ( ...httpStatusCodesMaybeWithExtraInformation: (