forked from asyncapi/cli
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
5e72071
commit 7943b4c
Showing
1 changed file
with
206 additions
and
0 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,206 @@ | ||
asyncapi: 3.0.0 | ||
info: | ||
title: Streetlights Kafka API | ||
version: 1.0.0 | ||
description: |- | ||
The Smartylighting Streetlights API allows you to remotely manage the city | ||
lights. | ||
### Check out its awesome features: | ||
* Turn a specific streetlight on/off 🌃 | ||
* Dim a specific streetlight 😎 | ||
* Receive real-time information about environmental lighting conditions 📈 | ||
license: | ||
name: Apache 2.0 | ||
url: 'https://www.apache.org/licenses/LICENSE-2.0' | ||
defaultContentType: application/json | ||
servers: | ||
scram-connections: | ||
host: 'test.mykafkacluster.org:18092' | ||
protocol: kafka-secure | ||
description: Test broker secured with scramSha256 | ||
security: | ||
- $ref: '#/components/securitySchemes/saslScram' | ||
tags: | ||
- name: 'env:test-scram' | ||
description: >- | ||
This environment is meant for running internal tests through | ||
scramSha256 | ||
- name: 'kind:remote' | ||
description: This server is a remote server. Not exposed by the application | ||
- name: 'visibility:private' | ||
description: This resource is private and only available to certain users | ||
mtls-connections: | ||
host: 'test.mykafkacluster.org:28092' | ||
protocol: kafka-secure | ||
description: Test broker secured with X509 | ||
security: | ||
- $ref: '#/components/securitySchemes/certs' | ||
tags: | ||
- name: 'env:test-mtls' | ||
description: This environment is meant for running internal tests through mtls | ||
- name: 'kind:remote' | ||
description: This server is a remote server. Not exposed by the application | ||
- name: 'visibility:private' | ||
description: This resource is private and only available to certain users | ||
channels: | ||
lightingMeasured: | ||
address: 'smartylighting.streetlights.1.0.event.{streetlightId}.lighting.measured' | ||
messages: | ||
lightMeasured: | ||
$ref: '#/components/messages/lightMeasured' | ||
description: The topic on which measured values may be produced and consumed. | ||
parameters: | ||
streetlightId: | ||
$ref: '#/components/parameters/streetlightId' | ||
lightTurnOn: | ||
address: 'smartylighting.streetlights.1.0.action.{streetlightId}.turn.on' | ||
messages: | ||
turnOn: | ||
$ref: '#/components/messages/turnOnOff' | ||
parameters: | ||
streetlightId: | ||
$ref: '#/components/parameters/streetlightId' | ||
lightTurnOff: | ||
address: 'smartylighting.streetlights.1.0.action.{streetlightId}.turn.off' | ||
messages: | ||
turnOff: | ||
$ref: '#/components/messages/turnOnOff' | ||
parameters: | ||
streetlightId: | ||
$ref: '#/components/parameters/streetlightId' | ||
lightsDim: | ||
address: 'smartylighting.streetlights.1.0.action.{streetlightId}.dim' | ||
messages: | ||
dimLight: | ||
$ref: '#/components/messages/dimLight' | ||
parameters: | ||
streetlightId: | ||
$ref: '#/components/parameters/streetlightId' | ||
operations: | ||
receiveLightMeasurement: | ||
action: receive | ||
channel: | ||
$ref: '#/channels/lightingMeasured' | ||
summary: >- | ||
Inform about environmental lighting conditions of a particular | ||
streetlight. | ||
traits: | ||
- $ref: '#/components/operationTraits/kafka' | ||
messages: | ||
- $ref: '#/channels/lightingMeasured/messages/lightMeasured' | ||
turnOn: | ||
action: send | ||
channel: | ||
$ref: '#/channels/lightTurnOn' | ||
traits: | ||
- $ref: '#/components/operationTraits/kafka' | ||
messages: | ||
- $ref: '#/channels/lightTurnOn/messages/turnOn' | ||
turnOff: | ||
action: send | ||
channel: | ||
$ref: '#/channels/lightTurnOff' | ||
traits: | ||
- $ref: '#/components/operationTraits/kafka' | ||
messages: | ||
- $ref: '#/channels/lightTurnOff/messages/turnOff' | ||
dimLight: | ||
action: send | ||
channel: | ||
$ref: '#/channels/lightsDim' | ||
traits: | ||
- $ref: '#/components/operationTraits/kafka' | ||
messages: | ||
- $ref: '#/channels/lightsDim/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: | ||
saslScram: | ||
type: scramSha256 | ||
description: Provide your username and password for SASL/SCRAM authentication | ||
certs: | ||
type: X509 | ||
description: Download the certificate files from service provider | ||
parameters: | ||
streetlightId: | ||
description: The ID of the streetlight. | ||
messageTraits: | ||
commonHeaders: | ||
headers: | ||
type: object | ||
properties: | ||
my-app-header: | ||
type: integer | ||
minimum: 0 | ||
maximum: 100 | ||
operationTraits: | ||
kafka: | ||
bindings: | ||
kafka: | ||
clientId: | ||
type: string | ||
enum: | ||
- my-app-id |