-
Notifications
You must be signed in to change notification settings - Fork 4
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
overlay: keep comments and linewidth when dumping to YAML
If the original file is YAML and the target overlayed definition is YAML, we now preserve comments from the original document and also keep the same line width as the original file.
- Loading branch information
Showing
6 changed files
with
216 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,177 @@ | ||
# Some comments in the API definition | ||
asyncapi: 2.2.0 | ||
info: | ||
title: Streetlights API | ||
version: 1.0.0 | ||
description: | | ||
Turn lights on or off. And get notified when lights are dimmed or switched. | ||
license: | ||
name: Apache 2.0 | ||
url: 'https://www.apache.org/licenses/LICENSE-2.0' | ||
servers: | ||
# This is a Production MQTT server | ||
production: | ||
url: 'test.mosquitto.org:{port}' | ||
protocol: mqtt | ||
description: Test broker | ||
variables: | ||
port: | ||
description: Secure connection (TLS) is available through port 8883. | ||
default: '1883' | ||
enum: | ||
- '1883' | ||
- '8883' | ||
security: | ||
- apiKey: [] | ||
- supportedOauthFlows: | ||
- 'streetlights:on' | ||
- 'streetlights:off' | ||
- 'streetlights:dim' | ||
- openIdConnectWellKnown: [] | ||
defaultContentType: application/json | ||
channels: | ||
'smartylighting/streetlights/1/0/event/{streetlightId}/lighting/measured': | ||
description: The topic on which measured values may be produced and consumed. | ||
parameters: | ||
streetlightId: | ||
$ref: 'http://example.org/param-lights.json' | ||
publish: | ||
summary: Inform about environmental lighting conditions of a particular streetlight. | ||
operationId: receiveLightMeasurement | ||
traits: | ||
- $ref: ./traits/kafka.yml | ||
message: | ||
$ref: '#/components/messages/lightMeasured' | ||
'smartylighting/streetlights/1/0/action/{streetlightId}/turn/on': | ||
parameters: | ||
streetlightId: | ||
$ref: ./params/streetlightId.json | ||
subscribe: | ||
operationId: turnOn | ||
traits: | ||
- $ref: ./traits/kafka.yml | ||
message: | ||
$ref: '#/components/messages/turnOnOff' | ||
'smartylighting/streetlights/1/0/action/{streetlightId}/turn/off': | ||
parameters: | ||
streetlightId: | ||
$ref: ./params/streetlightId.json | ||
'smartylighting/streetlights/1/0/action/{streetlightId}/dim': | ||
parameters: | ||
streetlightId: | ||
$ref: params/streetlightId.json | ||
subscribe: | ||
operationId: dimLight | ||
traits: | ||
- $ref: ./traits/kafka.yml | ||
message: | ||
$ref: '#/components/messages/dimLight' | ||
components: | ||
messages: | ||
lightMeasured: | ||
name: lightMeasured | ||
title: Light measured | ||
summary: Inform about environmental lighting conditions of a particular streetlight. | ||
contentType: application/json | ||
traits: | ||
- $ref: '#/components/messageTraits/commonHeaders' | ||
payload: | ||
$ref: '#/components/schemas/lightMeasuredPayload' | ||
turnOnOff: | ||
name: turnOnOff | ||
title: Turn on/off | ||
summary: Command a particular streetlight to turn the lights on or off. | ||
traits: | ||
- $ref: '#/components/messageTraits/commonHeaders' | ||
payload: | ||
$ref: '#/components/schemas/turnOnOffPayload' | ||
dimLight: | ||
name: dimLight | ||
title: Dim light | ||
summary: Command a particular streetlight to dim the lights. | ||
traits: | ||
- $ref: '#/components/messageTraits/commonHeaders' | ||
payload: | ||
$ref: '#/components/schemas/dimLightPayload' | ||
schemas: | ||
lightMeasuredPayload: | ||
type: object | ||
properties: | ||
lumens: | ||
type: integer | ||
minimum: 0 | ||
description: Light intensity measured in lumens. | ||
sentAt: | ||
$ref: '#/components/schemas/sentAt' | ||
turnOnOffPayload: | ||
type: object | ||
properties: | ||
command: | ||
type: string | ||
enum: | ||
- 'on' | ||
- 'off' | ||
description: Whether to turn on or off the light. | ||
sentAt: | ||
$ref: '#/components/schemas/sentAt' | ||
dimLightPayload: | ||
type: object | ||
properties: | ||
percentage: | ||
type: integer | ||
description: Percentage to which the light should be dimmed to. | ||
minimum: 0 | ||
maximum: 100 | ||
sentAt: | ||
$ref: '#/components/schemas/sentAt' | ||
sentAt: | ||
type: string | ||
format: date-time | ||
description: Date and time when the message was sent. | ||
securitySchemes: | ||
apiKey: | ||
type: apiKey | ||
in: user | ||
description: Provide your API key as the user and leave the password empty. | ||
supportedOauthFlows: | ||
type: oauth2 | ||
description: Flows to support OAuth 2.0 | ||
flows: | ||
implicit: | ||
authorizationUrl: 'https://authserver.example/auth' | ||
scopes: | ||
'streetlights:on': Ability to switch lights on | ||
'streetlights:off': Ability to switch lights off | ||
'streetlights:dim': Ability to dim the lights | ||
password: | ||
tokenUrl: 'https://authserver.example/token' | ||
scopes: | ||
'streetlights:on': Ability to switch lights on | ||
'streetlights:off': Ability to switch lights off | ||
'streetlights:dim': Ability to dim the lights | ||
clientCredentials: | ||
tokenUrl: 'https://authserver.example/token' | ||
scopes: | ||
'streetlights:on': Ability to switch lights on | ||
'streetlights:off': Ability to switch lights off | ||
'streetlights:dim': Ability to dim the lights | ||
authorizationCode: | ||
authorizationUrl: 'https://authserver.example/auth' | ||
tokenUrl: 'https://authserver.example/token' | ||
refreshUrl: 'https://authserver.example/refresh' | ||
scopes: | ||
'streetlights:on': Ability to switch lights on | ||
'streetlights:off': Ability to switch lights off | ||
'streetlights:dim': Ability to dim the lights | ||
openIdConnectWellKnown: | ||
type: openIdConnect | ||
openIdConnectUrl: 'https://authserver.example/.well-known' | ||
messageTraits: | ||
commonHeaders: | ||
headers: | ||
type: object | ||
properties: | ||
my-app-header: | ||
type: integer | ||
minimum: 0 | ||
maximum: 100 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
overlay: 1.0.0 | ||
info: | ||
title: Overlay to customise API for Streetlights | ||
version: 0.0.1 | ||
actions: | ||
- target: '$.info.description' | ||
description: Provide a better introduction for our end users than this techno babble. | ||
update: | | ||
Turn lights on or off. And get notified when lights are dimmed or switched. | ||
- target: '$..[?(@["x-beta"]==true)]' | ||
description: Remove all beta operations | ||
remove: true |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters