Skip to content

Commit

Permalink
feat(rest): make servers configurable for openapi specs
Browse files Browse the repository at this point in the history
  • Loading branch information
raymondfeng committed Sep 10, 2018
1 parent 9c882d9 commit 99b80a9
Show file tree
Hide file tree
Showing 5 changed files with 368 additions and 120 deletions.
81 changes: 80 additions & 1 deletion docs/site/Server.md
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,73 @@ export class HelloWorldApp extends RestApplication {

## Configuration

The REST server can be configured by passing a `rest` property inside your
RestApplication options. For example, the following code customizes the port
number that a REST server listens on.

```ts
const app = new RestApplication({
rest: {
port: 3001,
},
});
```

### Customize How OpenAPI Spec is Served

There are a few options under `rest.openApiSpec` to configure how OpenAPI spec
is served by the given REST server.

- servers: Configure servers for OpenAPI spec
- setServersFromRequest: Set `servers` based on HTTP request headers, default to
`false`
- endpointMapping: Maps urls for various forms of the spec. Default to:

```js
{
'/openapi.json': {version: '3.0.0', format: 'json'},
'/openapi.yaml': {version: '3.0.0', format: 'yaml'},
}
```

```ts
const app = new RestApplication({
rest: {
openApiSpec: {
servers: [{url: 'http://127.0.0.1:8080'}],
setServersFromRequest: false,
endpointMapping: {
'/openapi.json': {version: '3.0.0', format: 'json'},
'/openapi.yaml': {version: '3.0.0', format: 'yaml'},
},
},
},
});
```

### Configure the API Explorer

LoopBack allows externally hosted API Explorer UI to render the OpenAPI
endpoints for a REST server. Such URLs can be specified with `rest.apiExplorer`:

- url: URL for the hosted API Explorer UI, default to
`https://loopback.io/api-explorer`.
- httpUrl: URL for the API explorer served over plain http to deal with mixed
content security imposed by browsers as the spec is exposed over `http` by
default. See https://github.com/strongloop/loopback-next/issues/1603. Default
to the value of `url`.

```ts
const app = new RestApplication({
rest: {
apiExplorer: {
url: 'https://petstore.swagger.io',
httpUrl: 'http://petstore.swagger.io',
},
},
});
```

### Enable HTTPS

Enabling HTTPS for the LoopBack REST server is just a matter of specifying the
Expand Down Expand Up @@ -89,7 +156,19 @@ export async function main() {
}
```

### Add servers to application instance
### `rest` options

| Property | Type | Purpose |
| ----------- | ------------------- | --------------------------------------------------------------------------------------------------------- |
| port | number | Specify the port on which the RestServer will listen for traffic. |
| protocol | string (http/https) | Specify the protocol on which the RestServer will listen for traffic. |
| key | string | Specify the SSL private key for https. |
| cert | string | Specify the SSL certificate for https. |
| sequence | SequenceHandler | Use a custom SequenceHandler to change the behavior of the RestServer for the request-response lifecycle. |
| openApiSpec | OpenApiSpecOptions | Customize how OpenAPI spec is served |
| apiExplorer | ApiExplorerOptions | Customize how API explorer is served |

## Add servers to application instance

You can add server instances to your application via the `app.server()` method
individually or as an array using `app.servers()` method. Using `app.server()`
Expand Down
18 changes: 1 addition & 17 deletions packages/rest/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -45,23 +45,7 @@ app.handler(({request, response}, sequence) => {

## Configuration

The rest package is configured by passing a `rest` property inside of your
Application options.

```ts
const app = new RestApplication({
rest: {
port: 3001,
},
});
```

### `rest` options

| Property | Type | Purpose |
| -------- | --------------- | --------------------------------------------------------------------------------------------------------- |
| port | number | Specify the port on which the RestServer will listen for traffic. |
| sequence | SequenceHandler | Use a custom SequenceHandler to change the behavior of the RestServer for the request-response lifecycle. |
See https://loopback.io/doc/en/lb4/Server.html#configuration.

## Contributions

Expand Down
7 changes: 6 additions & 1 deletion packages/rest/src/rest.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,12 @@ export class RestComponent implements Component {
@inject(RestBindings.CONFIG) config?: RestComponentConfig,
) {
app.bind(RestBindings.SEQUENCE).toClass(DefaultSequence);
app.bind(RestBindings.API_SPEC).to(createEmptyApiSpec());
const apiSpec = createEmptyApiSpec();
// Merge the OpenAPI `servers` spec from the config into the empty one
if (config && config.openApiSpec && config.openApiSpec.servers) {
Object.assign(apiSpec, {servers: config.openApiSpec.servers});
}
app.bind(RestBindings.API_SPEC).to(apiSpec);
}
}

Expand Down
Loading

0 comments on commit 99b80a9

Please sign in to comment.