Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/amorimjj/nestjs-redoc-try-out

NestJS-Redoc-Try-Out is an unofficial NestJS module for Redoc Try Out. It provides an easy way plugging in Redoc in a NestJS application.
https://github.com/amorimjj/nestjs-redoc-try-out

openapi swagger typescript

Last synced: 3 months ago
JSON representation

NestJS-Redoc-Try-Out is an unofficial NestJS module for Redoc Try Out. It provides an easy way plugging in Redoc in a NestJS application.

Awesome Lists containing this project

README

        


NestJS Redoc Try Out Module



An unofficial NestJS module for Redoc Try Out

[Description](#Description) |
[Features](#Features) |
[Installation](#Installation) |
[How to use](#How-to-use) |
[Available Options](#Available-options) |
[Credits](#Credits) |
[Changelog](#Changelog) |
[TODO](#TODO)

## Description
NestJS-Redoc-Try-Out is an unofficial [NestJS](https://nestjs.com) module for [Redoc Try Out](https://www.npmjs.com/package/redoc-try-it-out).
It provides an easy way plugging in [Redoc](https://github.com/Redocly/redoc) in a NestJS application.

## Features
- Provides a try out option implemented by [Redoc Try Out](https://www.npmjs.com/package/redoc-try-it-out)
- Automatic code snippet generation

## Installation

`npm i nestjs-redoc-try-out`

## How to use

Redoc it's just a fancy frontend for display [OpenApi](https://swagger.io/specification/) documentation.
In order to get your api documented, [SwaggerWrapper Module](https://github.com/nestjs/swagger) is required and the official [NestJS OpenApi Guide](https://docs.nestjs.com/openapi/introduction) must be followed.

```typescript
...

import { RedocTryOutModule, RedocModuleOptions } from 'nestjs-redoc-try-out';

async function bootstrap() {
...
const app = ... //create NestJS application
const config = new DocumentBuilder() // documenting the api
const document = SwaggerModule.createDocument(app, config);

const options: RedocOptions = { /** see: available options */ };
// Instead of using SwaggerModule.setup() you call this module
await RedocTryOutModule.setup('/docs', app, document, options);
...
}

bootstrap();
```

## Available options

### RedocTryOutModule Setup Options
| Option | Description | Type |
| ----------------------- | ------------------------------- | --------------------------------------------------------------------------------- |
| path | The path to mount the Redoc UI | string |
| app | An application instance | [INestApplication](https://docs.nestjs.com/first-steps) |
| document | URL swagger's spec file | [OpenAPIObject](https://docs.nestjs.com/openapi/introduction#document-options) |
| options (optional) | Redoc try it out config options | [RedocTryItOutOptions](#Redoc-Try-It-Out-Options) |

### Redoc Options
RedocOptions extends RedocTryItOutOptions, documented on [Redoc Try Out Documentation](https://www.npmjs.com/package/redoc-try-it-out#redoc-try-it-out-options)

```typescript
export interface RedocModuleOptions extends RedocOptions {

/**
* Web site title
* default: document.info.title || document.info.description || 'Online documentation'
*/
title?: string;

/** Web site favicon URL */
favicon?: string;

/** Name of the swagger json spec file. default: 'swagger' */
docName?: string;

/** Skip generation of code snippets: default: false */
skipSnippetsGeneration?: boolean;

/**
* Languages used on code generation snippets.
* default: ['javascript']
* Language = 'c'| 'c_libcurl'| 'clojure'| 'clojure_clj_http'| 'csharp'| 'csharp_restsharp'| 'csharp_httpclient'| 'go'| 'go_native'|'http'|'http_1.1'|'java'|'java_okhttp'|'java_unirest'|'java_asynchttp'|'java_nethttp'|'javascript'|'javascript_jquery'|'javascript_fetch'|'javascript_xhr'|'javascript_axios'|'kotlin'|'kotlin_okhttp'|'node'|'node_native'|'node_request'|'node_unirest'|'node_axios'|'node_fetch'|'objc'|'objc_nsurlsession'|'ocaml'|'ocaml_cohttp'|'php'|'php_curl'|'php_http1'|'php_http2'|'powershell'|'powershell_webrequest'|'powershell_restmethod'|'python'|'python_python3'|'python_requests'|'r'|'r_httr'|'ruby'|'ruby_native'|'shell'|'shell_curl'|'shell_httpie'|'shell_wget'|'swift'|'swift_nsurlsession'
*/
codeSnippetsLanguages?: Language[];

/** Authentication options - not implemented yet */
auth?: {
enabled: boolean;
user: string;
password: string;
};

/**
* Group tags in categories in the side menu.
* Tags not added to a group will not be displayed.
* default: document.tags
*/
tagGroups?: TagGroupOptions[];

/** Logo Options */
logo?: LogoOptions;
}

export interface LogoOptions {
/**
* The URL pointing to the spec logo
* Format: Absolute URL
*/
url?: string;

/** Background color. Format: RGB color in hexadecimal format (e.g: #0000ff) */
backgroundColor?: string;

/** Alt tag for logo */
altText?: string;

/** href tag for logo. */
href?: string;
}

export interface TagGroupOptions {
name: string;
tags: string[];
}
```

## Credits

It's based on [nestjs-redoc](https://www.npmjs.com/package/nestjs-redoc) work.

## Changelog

Bellow are a list of changes, some might go undocumented

- 1.0.0 - First release
- 1.0.1 - Fix codegen issue for authenticated spec
- 1.0.2 - Fix docName undefinded error
- 1.0.3 - Fix empty screen when option is not provided

## TODO
- Add Fastify support
- Implement authentication
- Refactoring code gen
- Add custom language