From dc87f0cb305a8fdc37d8c33ce0f8b0508ea49e5e Mon Sep 17 00:00:00 2001 From: Santiago Troncoso Date: Fri, 8 Nov 2024 19:09:25 +0100 Subject: [PATCH 01/10] feat(api): Included new webrtc-events explicit subscription --- code/API_definitions/BYON-Webrtc-Events.yaml | 1505 ++++++++++++++++++ 1 file changed, 1505 insertions(+) create mode 100644 code/API_definitions/BYON-Webrtc-Events.yaml diff --git a/code/API_definitions/BYON-Webrtc-Events.yaml b/code/API_definitions/BYON-Webrtc-Events.yaml new file mode 100644 index 0000000..bf21963 --- /dev/null +++ b/code/API_definitions/BYON-Webrtc-Events.yaml @@ -0,0 +1,1505 @@ +openapi: 3.0.3 +info: + title: BYON WebRTC Event Subscription + description: |- + ## 1. Introduction + + This API provide REST API for a client, browser or native application, to + receive events about state of the call or updated of th registration status. + Any device can check for its own active registrations and calls, allowing + them to receive updates about the status of its registrations and calls and + progress them to the UI. + + A classic use case is the negotiation of a live WebRTC session (call), that + requires multiple asynchronous events from server side. Other classic + example, is to notify that a subscriber is not logged into the network + anymore, for example, when the IMS expires the registration. + + In adition, this API, allows to an external service to create "notification + channels" for other systems that does no support the async event mechanisms. + For instance, a classic browser using websockets to receive server-side + events. + + **Use cases to cover:** + - Functional: + - A push notitification service based on an external webhook + - A browser that requires a WS to receive events from the server side. + - This will require to create a dedicated endpoint using the + NotificationChannel API + - Observability: + - A monitoring system that wants to monitor registration status of + endpoints + - A call audit application that requires to remotly monitor call status + + ## 2. Relevant terms and definitions + + - **BYON**: Bring Your Own Number. A commercial name for the functionality + to use your telco credentials and phone number identity to no-SIM devices + using WebRTC sessions. + - **session**: A media session, an exchange of media between endpoints, + usually knonw as a "single one-to-one call". + - **registration**: An endpoint status were it is properly identified to be + reachable by the server side of the WebRTC gateway. + + ## 3. API functionality + + The CAMARA subscription model is detailed in the CAMARA API design guideline + document and follows CloudEvents specification. + + This API allows to create an explicit notification channel for two types of + events. It is mandatory in the subscription to provide the event type for + which the client would like to subscribe. Per CAMARA Commonalities v0.4, + **each subscription only can be dedicated to a single event type**. You + usually will need one per endpoint registration and one per session in + progress. + + Following event types are managed for this API: + + - `org.camaraproject.webrtc-events.session` + + - Events triggered for any media session related event (e.g. far end new media endpoints) + + - `org.camaraproject.webrtc-events.registration` + + - Events triggered for any media endpoint registration event (e.g. incomming session) + + Note: Additionally to these list, ``org.camaraproject.webrtc-events.subscription-ends`` + notification `type` is sent when the subscription ends. + This notification does not require dedicated subscription. + + It is used when: + - the subscription expire time (optionally set by the requester) has been reached + - the maximum number of subscription events (optionally set by the requester) has been reached + - the subscription was deleted by the requester + - the Access Token `sinkCredential` (optionally set by the requester) expiration time has been reached + - the API server has to stop sending notification prematurely + + ### 3.1. Session events + + Find more information at the Schema description. + + A `org.camaraproject.webrtc-events.session` event includes the same session information received using the WebRTC BOYN CallHandling API, when retrieving information from the GET /vvoip/session/{vvoipSessionID} endpoint. + + In general lines, it is receive each time that an event happens with the session. This might happen when a call is received, when SDP updates are included for any party or when the call is finished due an ordered cleanup or a service outage. + + Regarding the SDP descriptions for offer and answer: + - The offer, which MUST be present in a request from the application to the server to create a session. Note that the offer can be absent in a session created by the server as part of an offerless INVITE [RFC3261]. + - For the answer. This type represents an answer in WebRTC Signaling. This element is not present in case there is no answer yet, or the session invitation has been declined by the Terminating Participant. This element MUST NOT be present in a request from the application to the server to create a session. + + ### 3.2. Registration events + + Find more information at the Schema description. + + A `org.camaraproject.webrtc-events.registration` event includes two main use cases: update about netowrk status of the registration **and** provide notification about requested sessions (incoming calls). + + On one hand, it provides the same session information received using the WebRTC BYON RACM API, when retrieving information from the GET /racm/sessions/{racmSessionId} endpoint. Mainly it includes a unique registration ID, and the registration status. A valid `Registered` registration status grants that endpoint is visible for the network, since an invalid `Unregistered` status value means that network considers your endpoint unreachable. + + When a new session is requested, it includes the context information: caller and possible carrier data to contextualize (call subject, branding info, etc) and a unique SessionId, with this SessionId is possible to create a subscription and receive events about the call itself and its status progressing on the telco network. + + **NOTE**: The `Unregistered` status will be only provided by the notification service, a GET /racm/sessions/ for an unregistered endpoint will produce an 404 response. + + ## 4. Authorization and authentication + + The "Camara Security and Interoperability Profile" provides details on how a client requests + an access token. Please refer to Identify and Consent Management + (https://github.com/camaraproject/IdentityAndConsentManagement/) for the released version of + the Profile. + + Which specific authorization flows are to be used will be determined during onboarding process, + happening between the API Client and the API Provider, taking into account the declared purpose + for accessing the API, while also being subject to the prevailing legal framework dictated by + local legislation. + + It is important to remark that in cases where personal user data is processed by the API, and + users can exercise their rights through mechanisms such as opt-in and/or opt-out, the use of + 3-legged access tokens becomes mandatory. This measure ensures that the API remains in strict + compliance with user privacy preferences and regulatory obligations, upholding the principles + of transparency and user-centric data control. + + ## 5. Further info and support + (Will be added in a later version of the documentation) + + license: + name: Apache 2.0 + url: https://www.apache.org/licenses/LICENSE-2.0.html + version: 0.1.0 + x-camara-commonalities: 0.4.0 + +externalDocs: + description: Product documentation at CAMARA + url: https://github.com/camaraproject/ +servers: + - url: "{apiRoot}/webrtc-events/v1" + variables: + apiRoot: + default: http://localhost:9091 + description: API root + deviceId: + description: >- + The notification channel creation is specific to a device instance, + the device-id in the uuid format (rfc4412) shall be included in the + request + default: deviceId +tags: + - name: webrtc-events Subscription + description: Operations to manage event subscriptions for WebRTC APIs (BYON and RACM) + +paths: + /subscriptions: + post: + tags: + - webrtc-events Subscription + summary: "Create a webrtc-events event subscription" + description: Create a webrtc-events event subscription. For the correspoding type, `session` or `registration`. + operationId: createNotificationChannelSubscription + parameters: + - $ref: "#/components/parameters/x-correlator" + security: + - openId: + - webrtc-events:org.camaraproject.webrtc-events.session:create + - webrtc-events:org.camaraproject.webrtc-events.registration:create + requestBody: + content: + application/json: + schema: + $ref: "#/components/schemas/SubscriptionRequest" + examples: + REGISTRATION_SUBSCRIPTION: + $ref: "#/components/examples/REGISTRATION_SUBSCRIPTION" + SESSION_SUBSCRIPTION: + $ref: "#/components/examples/SESSION_SUBSCRIPTION" + required: true + callbacks: + notifications: + "{$request.body#/sink}": + post: + summary: "notifications callback" + description: |- + Important: this endpoint is to be implemented by the API + consumer. The webrtc-events server will call this endpoint + whenever a webrtc-events event occurs. `operationId` value will + have to be replaced accordingly with WG API specific semantic. + operationId: postNotification + parameters: + - $ref: "#/components/parameters/x-correlator" + requestBody: + required: true + content: + application/cloudevents+json: + schema: + $ref: "#/components/schemas/CloudEvent" + examples: + NEW_SESSION_INCOMING: + $ref: "#/components/examples/NEW_SESSION_INCOMING" + REGISTRATION_REVOKED: + $ref: "#/components/examples/REGISTRATION_REVOKED" + SESSION_UPDATE: + $ref: "#/components/examples/SESSION_UPDATE" + responses: + "204": + description: Successful notification + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + "400": + $ref: "#/components/responses/Generic400" + "401": + $ref: "#/components/responses/Generic401" + "403": + $ref: "#/components/responses/Generic403" + "410": + $ref: "#/components/responses/Generic410" + "429": + $ref: "#/components/responses/Generic429" + "500": + $ref: "#/components/responses/Generic500" + "503": + $ref: "#/components/responses/Generic503" + security: + - {} + - notificationsBearerAuth: [] + + responses: + "201": + description: Created + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/Subscription" + "202": + description: Request accepted to be processed. It applies for async creation process. + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/SubscriptionAsync" + "400": + $ref: "#/components/responses/CreateSubscriptionBadRequest400" + "401": + $ref: "#/components/responses/Generic401" + "403": + $ref: "#/components/responses/SubscriptionPermissionDenied403" + "409": + $ref: "#/components/responses/Generic409" + "415": + $ref: "#/components/responses/Generic415" + "422": + $ref: "#/components/responses/CreateSubscriptionUnprocessableEntity422" + "429": + $ref: "#/components/responses/Generic429" + "500": + $ref: "#/components/responses/Generic500" + "503": + $ref: "#/components/responses/Generic503" + get: + tags: + - webrtc-events Subscription + summary: "Retrieve a list of webrtc-events event subscription" + description: Retrieve a list of webrtc-events event subscription(s) + operationId: retrieveNotificationChannelSubscriptionList + parameters: + - $ref: "#/components/parameters/x-correlator" + security: + - openId: + - api-name:read + responses: + "200": + description: List of event subscription details + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + type: array + minItems: 0 + items: + $ref: '#/components/schemas/Subscription' + "400": + $ref: "#/components/responses/Generic400" + "401": + $ref: "#/components/responses/Generic401" + "403": + $ref: "#/components/responses/Generic403" + "500": + $ref: "#/components/responses/Generic500" + "503": + $ref: "#/components/responses/Generic503" + /subscriptions/{subscriptionId}: + get: + tags: + - webrtc-events Subscription + summary: "Retrieve a webrtc-events event subscription" + description: retrieve webrtc-events subscription information for a given subscription. + operationId: retrieveNotificationChannelSubscription + security: + - openId: + - api-name:read + parameters: + - $ref: "#/components/parameters/SubscriptionId" + - $ref: "#/components/parameters/x-correlator" + responses: + "200": + description: OK + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/Subscription" + "400": + $ref: "#/components/responses/SubscriptionIdRequired" + "401": + $ref: "#/components/responses/Generic401" + "403": + $ref: "#/components/responses/Generic403" + "404": + $ref: "#/components/responses/Generic404" + "500": + $ref: "#/components/responses/Generic500" + "503": + $ref: "#/components/responses/Generic503" + delete: + tags: + - webrtc-events Subscription + summary: "Delete a webrtc-events event subscription" + operationId: deleteNotificationChannelSubscription + description: delete a given webrtc-events subscription. + security: + - openId: + - api-name:delete + parameters: + - $ref: "#/components/parameters/SubscriptionId" + - $ref: "#/components/parameters/x-correlator" + responses: + "204": + description: webrtc-events subscription deleted + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + "202": + description: Request accepted to be processed. It applies for async deletion process. + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/SubscriptionAsync" + "400": + $ref: "#/components/responses/SubscriptionIdRequired" + "401": + $ref: "#/components/responses/Generic401" + "403": + $ref: "#/components/responses/Generic403" + "404": + $ref: "#/components/responses/Generic404" + "500": + $ref: "#/components/responses/Generic500" + "503": + $ref: "#/components/responses/Generic503" +components: + securitySchemes: + openId: + type: openIdConnect + openIdConnectUrl: https://example.com/.well-known/openid-configuration + notificationsBearerAuth: + type: http + scheme: bearer + bearerFormat: "{$request.body#/sinkCredential.credentialType}" + parameters: + SubscriptionId: + name: subscriptionId + in: path + description: Subscription identifier that was obtained from the create event subscription operation + required: true + schema: + $ref: "#/components/schemas/SubscriptionId" + x-correlator: + name: x-correlator + in: header + description: Correlation id for the different services + schema: + type: string + headers: + x-correlator: + description: Correlation id for the different services + schema: + type: string + schemas: + ErrorInfo: + type: object + required: + - status + - code + - message + properties: + status: + type: integer + description: HTTP response status code + code: + type: string + description: Code given to this error + message: + type: string + description: Detailed error description + + SubscriptionRequest: + description: The request for creating a event-type event subscription + type: object + required: + - sink + - protocol + - config + - types + properties: + protocol: + $ref: "#/components/schemas/Protocol" + sink: + type: string + format: url + description: The address to which events shall be delivered using the selected protocol. + example: "https://endpoint.example.com/sink" + sinkCredential: + $ref: "#/components/schemas/SinkCredential" + types: + description: |- + Camara Event types eligible to be delivered by this subscription. + Note: for the Commonalities meta-release v0.4 we enforce to have only event type per subscription then for following meta-release use of array MUST be decided + at API project level. + type: array + minItems: 1 + maxItems: 1 + items: + $ref: "#/components/schemas/SubscriptionEventTypeNotification" + config: + $ref: "#/components/schemas/Config" + discriminator: + propertyName: protocol + mapping: + HTTP: "#/components/schemas/HTTPSubscriptionRequest" + MQTT3: "#/components/schemas/MQTTSubscriptionRequest" + MQTT5: "#/components/schemas/MQTTSubscriptionRequest" + AMQP: "#/components/schemas/AMQPSubscriptionRequest" + NATS: "#/components/schemas/NATSSubscriptionRequest" + KAFKA: "#/components/schemas/ApacheKafkaSubscriptionRequest" + + Protocol: + type: string + enum: ["HTTP", "MQTT3", "MQTT5", "AMQP", "NATS", "KAFKA"] + description: Identifier of a delivery protocol. Only HTTP is allowed for now + example: "HTTP" + + Config: + description: |- + Implementation-specific configuration parameters needed by the subscription manager for acquiring events. `subscriptionExpireTime`, `subscriptionMaxEvents`, `initialEvent` are predefined for CAMARA specifications. + + WebRTC specific event type attributes are included into `subscriptionDetail` + + Note: if a request is performed for several event type, all subscribed event will use same `config` parameters. + type: object + required: + - subscriptionDetail + properties: + subscriptionDetail: + $ref: "#/components/schemas/SubscriptionDetail" + subscriptionExpireTime: + type: string + format: date-time + example: 2023-01-17T13:18:23.682Z + description: The subscription expiration time (in date-time format) requested by the API consumer. Up to API project decision to keep it. + subscriptionMaxEvents: + type: integer + description: Identifies the maximum number of event reports to be generated (>=1) requested by the API consumer - Once this number is reached, the subscription ends. Up to API project decision to keep it. + minimum: 1 + example: 5 + initialEvent: + type: boolean + description: |- + Set to `true` by API consumer if consumer wants to get an event as soon as the subscription is created and current situation reflects event request. + Example: Consumer request Roaming event. If consumer sets initialEvent to true and device is in roaming situation, an event is triggered + Up to API project decision to keep it. + + SinkCredential: + description: A sink credential provides authentication or authorization information necessary to enable delivery of events to a target. + type: object + properties: + credentialType: + type: string + enum: + - PLAIN + - ACCESSTOKEN + - REFRESHTOKEN + description: "The type of the credential." + discriminator: + propertyName: credentialType + mapping: + PLAIN: "#/components/schemas/PlainCredential" + ACCESSTOKEN: "#/components/schemas/AccessTokenCredential" + REFRESHTOKEN: "#/components/schemas/RefreshTokenCredential" + required: + - credentialType + PlainCredential: + type: object + description: A plain credential as a combination of an identifier and a secret. + allOf: + - $ref: "#/components/schemas/SinkCredential" + - type: object + required: + - identifier + - secret + properties: + identifier: + description: The identifier might be an account or username. + type: string + secret: + description: The secret might be a password or passphrase. + type: string + AccessTokenCredential: + type: object + description: An access token credential. + allOf: + - $ref: "#/components/schemas/SinkCredential" + - type: object + properties: + accessToken: + description: REQUIRED. An access token is a previously acquired token granting access to the target resource. + type: string + accessTokenExpiresUtc: + type: string + format: date-time + description: REQUIRED. An absolute UTC instant at which the token shall be considered expired. + accessTokenType: + description: REQUIRED. Type of the access token (See [OAuth 2.0](https://tools.ietf.org/html/rfc6749#section-7.1)). + type: string + enum: + - bearer + required: + - accessToken + - accessTokenExpiresUtc + - accessTokenType + RefreshTokenCredential: + type: object + description: An access token credential with a refresh token. + allOf: + - $ref: "#/components/schemas/SinkCredential" + - type: object + properties: + accessToken: + description: REQUIRED. An access token is a previously acquired token granting access to the target resource. + type: string + accessTokenExpiresUtc: + type: string + format: date-time + description: REQUIRED. An absolute UTC instant at which the token shall be considered expired. + accessTokenType: + description: REQUIRED. Type of the access token (See [OAuth 2.0](https://tools.ietf.org/html/rfc6749#section-7.1)). + type: string + enum: + - bearer + refreshToken: + description: REQUIRED. An refresh token credential used to acquire access tokens. + type: string + refreshTokenEndpoint: + type: string + format: uri + description: REQUIRED. A URL at which the refresh token can be traded for an access token. + required: + - accessToken + - accessTokenExpiresUtc + - accessTokenType + - refreshToken + - refreshTokenEndpoint + + SubscriptionDetail: + description: |- + The detail of the requested event subscription. `registration` event subscription requires a the subscriber information, while `session` event subscription requires both, the user information and the sessionId to subscribe to. + type: object + required: + - deviceId + properties: + deviceId: + type: string + example: 1qazxsw23edc + sessionId: + type: string + example: xsmcaum3z4zw4l0cu4w115m0 + subscriber: + $ref: "#/components/schemas/SubscriberUser" + + SubscriptionEventTypeNotification: + type: string + description: |- + event-type - Event triggered when an event-type event occurred + - `org.camaraproject.webrtc-events.session` + - Events triggered for any media session related event (e.g. far end new media endpoints) + - `org.camaraproject.webrtc-events.registration` + - Events triggered for any media endpoint registration event (e.g. incomming session) + + `subscription-ends` is not supported for subscription. Sent by defatult + enum: + - org.camaraproject.webrtc-events.session + - org.camaraproject.webrtc-events.registration + + EventTypeNotification: + type: string + description: |- + event-type - Event triggered when an event-type event occurred + - `org.camaraproject.webrtc-events.session` + - Events triggered for any media session related event (e.g. far end new media endpoints) + - `org.camaraproject.webrtc-events.registration` + - Events triggered for any media endpoint registration event (e.g. incomming session) + - `org.camaraproject.webrtc-events.subscription-ends` + - Event triggered when the subscription ends + enum: + - org.camaraproject.webrtc-events.session + - org.camaraproject.webrtc-events.registration + - org.camaraproject.webrtc-events.subscription-ends + + Subscription: + description: Represents a event-type subscription. + type: object + required: + - sink + - protocol + - config + - types + - id + properties: + protocol: + $ref: "#/components/schemas/Protocol" + sink: + type: string + format: url + description: The address to which events shall be delivered using the selected protocol. + example: "https://endpoint.example.com/sink" + sinkCredential: + $ref: '#/components/schemas/SinkCredential' + types: + description: |- + Camara Event types eligible to be delivered by this subscription. + Note: for the Commonalities meta-release v0.4 we enforce to have only event type per subscription then for following meta-release use of array MUST be decided + at API project level. + type: array + minItems: 1 + maxItems: 1 + items: + type: string + config: + $ref: '#/components/schemas/Config' + id: + $ref: '#/components/schemas/SubscriptionId' + startsAt: + type: string + format: date-time + description: Date when the event subscription will begin/began + expiresAt: + type: string + format: date-time + description: Date when the event subscription will expire. Only provided when `subscriptionExpireTime` is indicated by API client or Telco Operator has specific policy about that. + status: + type: string + description: |- + Current status of the subscription - Management of Subscription State engine is not mandatory for now. Note not all statuses may be considered to be implemented. Details: + - `ACTIVATION_REQUESTED`: Subscription creation (POST) is triggered but subscription creation process is not finished yet. + - `ACTIVE`: Subscription creation process is completed. Subscription is fully operative. + - `INACTIVE`: Subscription is temporarily inactive, but its workflow logic is not deleted. + - `EXPIRED`: Subscription is ended (no longer active). This status applies when subscription is ended due to `SUBSCRIPTION_EXPIRED` or `ACCESS_TOKEN_EXPIRED` event. + - `DELETED`: Subscription is ended as deleted (no longer active). This status applies when subscription information is kept (i.e. subscription workflow is no longer active but its meta-information is kept). + enum: + - ACTIVATION_REQUESTED + - ACTIVE + - EXPIRED + - INACTIVE + - DELETED + discriminator: + propertyName: protocol + mapping: + HTTP: '#/components/schemas/HTTPSubscriptionResponse' + MQTT3: '#/components/schemas/MQTTSubscriptionResponse' + MQTT5: '#/components/schemas/MQTTSubscriptionResponse' + AMQP: '#/components/schemas/AMQPSubscriptionResponse' + NATS: '#/components/schemas/NATSSubscriptionResponse' + KAFKA: '#/components/schemas/ApacheKafkaSubscriptionResponse' + + SubscriptionAsync: + description: Response for a event-type subscription request managed asynchronously (Creation or Deletion) + type: object + properties: + id: + $ref: "#/components/schemas/SubscriptionId" + + SubscriptionId: + type: string + description: The unique identifier of the subscription in the scope of the subscription manager. When this information is contained within an event notification, this concept SHALL be referred as `subscriptionId` as per [Commonalities Event Notification Model](https://github.com/camaraproject/Commonalities/blob/main/documentation/API-design-guidelines.md#122-event-notification). + example: qs15-h556-rt89-1298 + + CloudEvent: + description: The notification callback + required: + - id + - source + - specversion + - type + - time + properties: + id: + type: string + description: identifier of this event, that must be unique in the source context. + source: + $ref: "#/components/schemas/Source" + type: + $ref: "#/components/schemas/EventTypeNotification" + specversion: + type: string + description: Version of the specification to which this event conforms (must be 1.0 if it conforms to cloudevents 1.0.2 version) + enum: + - "1.0" + datacontenttype: + type: string + description: 'media-type that describes the event payload encoding, must be "application/json" for CAMARA APIs' + enum: + - application/json + data: + type: object + oneOf: + - $ref: "#/components/schemas/EventRegistration" + - $ref: "#/components/schemas/EventSession" + - $ref: "#/components/schemas/SubscriptionEnds" + description: |- + Event details payload. Depending of the event type, it will will include one of the data structures defined on this specification. Along with the subscription-ends, that is an authomatic event. + + Check the introduction documentation and the CAMARA WebRTC BYON APIs for extra info about data structures included on the events. + time: + $ref: "#/components/schemas/DateTime" + discriminator: + propertyName: "type" + mapping: + org.camaraproject.api-name.v0.resgistration: "#/components/schemas/EventRegistration" + org.camaraproject.api-name.v0.session: "#/components/schemas/EventSession" + org.camaraproject.api-name.v0.subscription-ends: "#/components/schemas/EventSubscriptionEnds" + + Source: + type: string + format: uri-reference + minLength: 1 + description: |- + Identifies the context in which an event happened - be a non-empty `URI-reference` like: + - URI with a DNS authority: + * https://github.com/cloudevents + * mailto:cncf-wg-serverless@lists.cncf.io + - Universally-unique URN with a UUID: + * urn:uuid:6e8bc430-9c3a-11d9-9669-0800200c9a66 + - Application-specific identifier: + * /cloudevents/spec/pull/123 + * 1-555-123-4567 + example: "https://notificationSendServer12.supertelco.com" + + DateTime: + type: string + format: date-time + description: Timestamp of when the occurrence happened. Must adhere to RFC 3339. + example: "2018-04-05T17:31:00Z" + + EventRegistration: + description: Event detail structure for REGISTRATION events + allOf: + - $ref: "#/components/schemas/CloudEvent" + - type: object + properties: + data: + $ref: "#/components/schemas/RegistrationEvent" + + RegistrationEvent: + description: |- + A `org.camaraproject.webrtc-events.registration` event includes two main use cases: update about netowrk status of the registration **and** provide notification about requested sessions (incoming calls). + + On one hand, it provides the same session information received using the WebRTC BYON RACM API, when retrieving information from the GET /racm/sessions/{racmSessionId} endpoint. Mainly it includes a unique registration ID, and the registration status. A valid `Registered` registration status grants that endpoint is visible for the network, since an invalid `Unregistered` status value means that network considers your endpoint unreachable. + + When a new session is requested, it includes the context information: caller and possible carrier data to contextualize (call subject, branding info, etc) and a unique SessionId, with this SessionId is possible to create a subscription and receive events about the call itself and its status progressing on the telco network. + + **NOTE**: The `Unregistered` status will be only provided by the notification service, a GET /racm/sessions/ for an unregistered endpoint will produce an 404 response. + type: object + properties: + subscriptionId: + $ref: "#/components/schemas/SubscriptionId" + msisdn: + type: string + description: The MSISDN is the mapping of the telephone number to the subscriber identity module in a mobile or cellular phone system. A unique identifier on the network to this subscriber. + regStatus: + $ref: '#/components/schemas/RegistrationStatus' + sessionRequest: + description: Object present only when receiving a new session request + type: object + properties: + originator: + $ref: "#/components/schemas/SubscriberUser" + receiver: + $ref: "#/components/schemas/SubscriberUser" + subject: + type: string + description: Subject of the call + + RegistrationStatus: + type: string + enum: + - Registered + - Unregistered + + EventSession: + description: event structure for session events + allOf: + - $ref: "#/components/schemas/CloudEvent" + - type: object + properties: + data: + $ref: "#/components/schemas/SessionInformation" + + SessionInformation: + description: |- + A `org.camaraproject.webrtc-events.registration` event includes the same session information received using the WebRTC BOYN CallHandling API, when retrieving information from the GET /vvoip/session/{vvoipSessionID} endpoint. + + In general lines, it is receive each time that an event happens with the session. This might happen when a call is received, when SDP updates are included for any party or when the call is finished due an ordered cleanup or a service outage. + + Regarding the SDP descriptions for offer and answer: + - The offer, which MUST be present in a request from the application to the server to create a session. Note that the offer can be absent in a session created by the server as part of an offerless INVITE [RFC3261]. + - For the answer. This type represents an answer in WebRTC Signaling. This element is not present in case there is no answer yet, or the session invitation has been declined by the Terminating Participant. This element MUST NOT be present in a request from the application to the server to create a session. + required: + - vvoipSessionID + type: object + properties: + originator: + $ref: '#/components/schemas/SubscriberUser' + receiver: + $ref: '#/components/schemas/SubscriberUser' + status: + $ref: '#/components/schemas/SessionStatus' + offer: + $ref: '#/components/schemas/WrtcSDPDescriptor' + answer: + $ref: '#/components/schemas/WrtcSDPDescriptor' + clientCorrelator: + type: string + description: A correlator that the client can use to tag this particular resource representation during a request to create a resource on the server. Note - This allows the client to recover from communication failures during resource creation and therefore avoids re-sending the message in such situations. In case the element is present, the WebRTC GW shall not alter its value, and shall provide it as part of the representation of this resource. + vvoipSessionId: + type: string + description: The VVOIP session ID created by WebRTC Gateway. The vvoipSessionID shall not be included in POST requests by the client, but must be included in the notifications from the WebRTC GW to client. + example: 0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EF + + SubscriberUser: + type: object + description: |- + Information about one of the participants on the WebRTC session. It can + be used to describe a caller or callee (source or destination). It can + be expanded to include any extra information for authentication out of + dialog. + properties: + address: + type: string + description: Sender or Receiver address + pattern: '^(tel:+[0-9]{5,15}|sip:.+@.+|.+)$' + example: 'tel:+11234567899' + name: + type: string + description: Friendly name of the originator + example: 'Jonh Doe' + + SessionStatus: + type: string + description: |- + Provides the status of the VVOIP session. During the session creation, + this attribute contains 'Initial' value + enum: + - Initial + - InProgress + - Ringing + - Proceeding + - Connected + - Terminated + - Hold + - Resume + - SessionCancelled + - Declined + - Failed + - Waiting + - NoAnswer + - NotReachable + - Busy + + WrtcSDPDescriptor: + type: object + properties: + sdp: + type: string + description: |- + An inlined session description in SDP format [RFC4566].If XML syntax is used, the content of this element SHALL be embedded in a CDATA section + + # CloudEvent and CAMARA standard + EventSubscriptionEnds: + description: event structure for event subscription ends + allOf: + - $ref: "#/components/schemas/CloudEvent" + - type: object + properties: + data: + $ref: "#/components/schemas/SubscriptionEnds" + + SubscriptionEnds: + description: Event detail structure for SUBSCRIPTION_ENDS event + type: object + required: + - subscriptionId + - terminationReason + properties: + subscriptionId: + $ref: "#/components/schemas/SubscriptionId" + terminationReason: + $ref: "#/components/schemas/TerminationReason" + terminationDescription: + type: string + + TerminationReason: + type: string + description: |- + - NETWORK_TERMINATED - API server stopped sending notification + - SUBSCRIPTION_EXPIRED - Subscription expire time (optionally set by the requester) has been reached + - MAX_EVENTS_REACHED - Maximum number of events (optionally set by the requester) has been reached + - ACCESS_TOKEN_EXPIRED - Access Token sinkCredential (optionally set by the requester) expiration time has been reached + - SUBSCRIPTION_DELETED - Subscription was deleted by the requester + enum: + - MAX_EVENTS_REACHED + - NETWORK_TERMINATED + - SUBSCRIPTION_EXPIRED + - ACCESS_TOKEN_EXPIRED + - SUBSCRIPTION_DELETED + + HTTPSubscriptionRequest: + allOf: + - $ref: "#/components/schemas/SubscriptionRequest" + - type: object + properties: + protocolSettings: + $ref: "#/components/schemas/HTTPSettings" + + HTTPSubscriptionResponse: + allOf: + - $ref: "#/components/schemas/Subscription" + - type: object + properties: + protocolSettings: + $ref: "#/components/schemas/HTTPSettings" + + HTTPSettings: + type: object + properties: + headers: + type: object + description: |- + A set of key/value pairs that is copied into the HTTP request as custom headers. + + NOTE: Use/Applicability of this concept has not been discussed in Commonalities under the scope of Meta Release v0.4. When required by an API project as an option to meet a UC/Requirement, please generate an issue for Commonalities discussion about it. + additionalProperties: + type: string + method: + type: string + description: The HTTP method to use for sending the message. + enum: + - POST + + MQTTSubscriptionRequest: + allOf: + - $ref: "#/components/schemas/SubscriptionRequest" + - type: object + properties: + protocolSettings: + $ref: "#/components/schemas/MQTTSettings" + + MQTTSubscriptionResponse: + allOf: + - $ref: "#/components/schemas/Subscription" + - type: object + properties: + protocolSettings: + $ref: "#/components/schemas/MQTTSettings" + + MQTTSettings: + type: object + properties: + topicName: + type: string + qos: + type: integer + format: int32 + retain: + type: boolean + expiry: + type: integer + format: int32 + userProperties: + type: object + required: + - topicName + + AMQPSubscriptionRequest: + allOf: + - $ref: "#/components/schemas/SubscriptionRequest" + - type: object + properties: + protocolSettings: + $ref: "#/components/schemas/AMQPSettings" + + AMQPSubscriptionResponse: + allOf: + - $ref: "#/components/schemas/Subscription" + - type: object + properties: + protocolSettings: + $ref: "#/components/schemas/AMQPSettings" + + AMQPSettings: + type: object + properties: + address: + type: string + linkName: + type: string + senderSettlementMode: + type: string + enum: ["settled", "unsettled"] + linkProperties: + type: object + additionalProperties: + type: string + + ApacheKafkaSubscriptionRequest: + allOf: + - $ref: "#/components/schemas/SubscriptionRequest" + - type: object + properties: + protocolSettings: + $ref: "#/components/schemas/ApacheKafkaSettings" + + ApacheKafkaSubscriptionResponse: + allOf: + - $ref: "#/components/schemas/Subscription" + - type: object + properties: + protocolSettings: + $ref: "#/components/schemas/ApacheKafkaSettings" + + ApacheKafkaSettings: + type: object + properties: + topicName: + type: string + partitionKeyExtractor: + type: string + clientId: + type: string + ackMode: + type: integer + required: + - topicName + + NATSSubscriptionRequest: + allOf: + - $ref: "#/components/schemas/SubscriptionRequest" + - type: object + properties: + protocolSettings: + $ref: "#/components/schemas/NATSSettings" + + NATSSubscriptionResponse: + allOf: + - $ref: "#/components/schemas/Subscription" + - type: object + properties: + protocolSettings: + $ref: "#/components/schemas/NATSSettings" + + NATSSettings: + type: object + properties: + subject: + type: string + required: + - subject + responses: + CreateSubscriptionBadRequest400: + description: Problem with the client request + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/ErrorInfo" + examples: + GENERIC_400_INVALID_ARGUMENT: + description: Invalid Argument. Generic Syntax Exception + value: + status: 400 + code: INVALID_ARGUMENT + message: Client specified an invalid argument, request body or query param. + GENERIC_400_OUT_OF_RANGE: + description: Out of Range. Specific Syntax Exception used when a given field has a pre-defined range or a invalid filter criteria combination is requested + value: + status: 400 + code: OUT_OF_RANGE + message: Client specified an invalid range. + GENERIC_400_INVALID_PROTOCOL: + value: + status: 400 + code: "INVALID_PROTOCOL" + message: "Only HTTP is supported" + GENERIC_400_INVALID_CREDENTIAL: + value: + status: 400 + code: "INVALID_CREDENTIAL" + message: "Only Access token is supported" + GENERIC_400_INVALID_TOKEN: + value: + status: 400 + code: "INVALID_TOKEN" + message: "Only bearer token is supported" + Generic400: + description: Problem with the client request + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/ErrorInfo" + examples: + GENERIC_400_INVALID_ARGUMENT: + description: Invalid Argument. Generic Syntax Exception + value: + status: 400 + code: INVALID_ARGUMENT + message: Client specified an invalid argument, request body or query param. + Generic401: + description: Authentication problem with the client request + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/ErrorInfo" + examples: + GENERIC_401_UNAUTHENTICATED: + description: Request cannot be authenticated + value: + status: 401 + code: UNAUTHENTICATED + message: Request not authenticated due to missing, invalid, or expired credentials. + GENERIC_401_AUTHENTICATION_REQUIRED: + description: New authentication is needed, authentication is no longer valid + value: + status: 401 + code: AUTHENTICATION_REQUIRED + message: New authentication is required. + Generic403: + description: Client does not have sufficient permission + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/ErrorInfo" + examples: + GENERIC_403_PERMISSION_DENIED: + description: Permission denied. OAuth2 token access does not have the required scope or when the user fails operational security + value: + status: 403 + code: PERMISSION_DENIED + message: Client does not have sufficient permissions to perform this action. + SubscriptionPermissionDenied403: + description: Client does not have sufficient permission + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/ErrorInfo" + examples: + GENERIC_403_PERMISSION_DENIED: + description: Permission denied. OAuth2 token access does not have the required scope or when the user fails operational security + value: + status: 403 + code: PERMISSION_DENIED + message: Client does not have sufficient permissions to perform this action. + GENERIC_403_INVALID_TOKEN_CONTEXT: + description: Reflect some inconsistency between information in some field of the API and the related OAuth2 Token + value: + status: 403 + code: INVALID_TOKEN_CONTEXT + message: "{{field}} is not consistent with access token." + GENERIC_403_SUBSCRIPTION_MISMATCH: + value: + status: 403 + code: "SUBSCRIPTION_MISMATCH" + message: "Inconsistent access token for requested events subscription" + Generic404: + description: Resource Not Found + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/ErrorInfo" + examples: + GENERIC_404_NOT_FOUND: + description: Resource is not found + value: + status: 404 + code: NOT_FOUND + message: The specified resource is not found. + Generic409: + description: Conflict + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/ErrorInfo" + examples: + GENERIC_409_ABORTED: + description: Concurreny of processes of the same nature/scope + value: + status: 409 + code: ABORTED + message: Concurrency conflict. + GENERIC_409_ALREADY_EXISTS: + description: Trying to create an existing resource + value: + status: 409 + code: ALREADY_EXISTS + message: The resource that a client tried to create already exists. + Generic410: + description: Gone + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/ErrorInfo" + examples: + GENERIC_410_GONE: + description: Use in notifications flow to allow API Consumer to indicate that its callback is no longer available + value: + status: 410 + code: GONE + message: Access to the target resource is no longer available. + Generic415: + description: Unsupported Media Type + headers: + X-Correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/ErrorInfo" + examples: + GENERIC_415_UNSUPPORTED_MEDIA_TYPE: + description: Payload format of the request is in an unsupported format by the Server. Should not happen + value: + status: 415 + code: UNSUPPORTED_MEDIA_TYPE + message: The server refuses to accept the request because the payload format is in an unsupported format + CreateSubscriptionUnprocessableEntity422: + description: Unprocessable Entity + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/ErrorInfo" + examples: + GENERIC_422_MULTIEVENT_SUBSCRIPTION_NOT_SUPPORTED: + value: + status: 422 + code: "MULTIEVENT_SUBSCRIPTION_NOT_SUPPORTED" + message: "Multi event types subscription not managed" + GENERIC_422_DEVICE_IDENTIFIERS_MISMATCH: + description: Inconsistency between device identifiers not pointing to the same device + value: + status: 422 + code: DEVICE_IDENTIFIERS_MISMATCH + message: Provided device identifiers are not consistent. + GENERIC_422_DEVICE_NOT_APPLICABLE: + description: Service is not available for the provided device + value: + status: 422 + code: DEVICE_NOT_APPLICABLE + message: The service is not available for the provided device. + Generic429: + description: Too Many Requests + headers: + X-Correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/ErrorInfo" + examples: + GENERIC_429_QUOTA_EXCEEDED: + description: Request is rejected due to exceeding a business quota limit + value: + status: 429 + code: QUOTA_EXCEEDED + message: Either out of resource quota or reaching rate limiting. + GENERIC_429_TOO_MANY_REQUESTS: + description: API Server request limit is overpassed + value: + status: 429 + code: TOO_MANY_REQUESTS + message: Either out of resource quota or reaching rate limiting. + Generic500: + description: Server error + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/ErrorInfo" + examples: + GENERIC_500_INTERNAL: + description: Problem in Server side. Regular Server Exception + value: + status: 500 + code: INTERNAL + message: Unknown server error. Typically a server bug. + Generic503: + description: Service unavailable. Typically the server is down. + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/ErrorInfo" + examples: + GENERIC_503_UNAVAILABLE: + description: Service is not available. Temporary situation usually related to maintenance process in the server side + value: + status: 503 + code: UNAVAILABLE + message: Service Unavailable. + SubscriptionIdRequired: + description: Problem with the client request + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + content: + application/json: + schema: + $ref: "#/components/schemas/ErrorInfo" + examples: + Generic400: + summary: Schema validation failed + value: + status: 400 + code: INVALID_ARGUMENT + message: "Client specified an invalid argument, request body or query param" + subscriptionIdRequired: + summary: subscription id is required + value: + status: 400 + code: INVALID_ARGUMENT + message: "Expected property is missing: subscriptionId" + examples: + # Subscription examples + REGISTRATION_SUBSCRIPTION: + description: |- + A sample of WebRTC **registration** subscription for phone number + `+1234567890` at `acme.opentelco.com`. + + This will be used to receive incoming sessions (incoming + calls) and to be aware of registration status updates from the server. + (i.e. when a REGISTRATION expires). + + The provided example will be able to receive up to 50 calls until + subscription is cancelled via server or by configuration timeout. Check + callback examples to check some possible events received: + + - New incoming call + - Registration revoked + value: + protocol: HTTP + sink: https://notificationServer.opentelco.com + types: + - org.camaraproject.webrtc-events.registration + config: + subscriptionDetail: + deviceId: "1qazxsw23edc" + subscriber: + address: "tel:+447911123456" + name: Jonh Doe + initialEvent: true + subscriptionMaxEvents: 50 + subscriptionExpireTime: "2024-11-17T13:18:23.682Z" + SESSION_SUBSCRIPTION: + description: |- + A sample of WebRTC **session** subscription for transactionId + `gnCGil25Wg7cm2vi` where phone number + `+1234567890` at `acme.opentelco.com` domain is involved. + + Identified by for phone number, domain and transactionId, the endpoint + is able to interact with its own live session. This could be used to + remotely control de call or to handle the async session establishment + procedure by the endpoint itself. + value: + protocol: HTTP + sink: https://notificationServer.opentelco.com + types: + - org.camaraproject.webrtc-events.session + config: + subscriptionDetail: + deviceId: "1qazxsw23edc" + subscriber: + address: "tel:+447911123456" + name: Jonh Doe + sessionId: 0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EF + initialEvent: true + subscriptionMaxEvents: 50 + subscriptionExpireTime: "2024-11-17T13:18:23.682Z" + # Event examples + NEW_SESSION_INCOMING: + description: |- + Example of `resgitration` events. + + A new WebRTC session is requested (i.e. incoming call). This event + starts a session negotiation. All other eventes related with this + webrtc session will be shared via the session events. + + Check example SESSION_UPDATE + value: + id: "VzYQCOClM6Kc7Xmyq7mP58Jx" + source: https://notificationServer.opentelco.com + type: org.camaraproject.webrtc-events.registration + specversion: "1.0" + datacontenttype: application/json + time: 2024-11-05T05:40:23.682Z + data: + subscriptionId: 987654321 + subscriber: + username: "tel:+447911123456" + domain: acme.opentelco.com + registration: + status: active + session: + to: + username: "+1987654320" + domain: opentelco.com + from: + username: "+1987654320" + domain: opentelco.com + status: initial + remoteSdp: "" + webrtcSessionId: 1f14dc636262b319-22@0.0.0.0 + REGISTRATION_REVOKED: + description: |- + Example of `resgitration` events. + + When a re-registration is requested from server, maybe due + administrative token revocation or due any other technical reason. It + is expected from the endpoint to re-register. No new sessions will be + delivered to the user endpoint, as the subscrition is not valid anymore. + value: + id: "VzYQCOClM6Kc7Xmyq7mP58Jx" + source: https://notificationServer.opentelco.com + type: org.camaraproject.webrtc-events.registration + specversion: "1.0" + datacontenttype: application/json + time: 2024-11-05T05:40:23.682Z + data: + subscriptionId: 987654321 + subscriber: + username: "tel:+447911123456" + domain: acme.opentelco.com + registration: + status: inactive + SESSION_UPDATE: + description: |- + Example of `session` events. + + Session envents are produced when there is an update on the session + status, due changes on the SDP of both parties and / or on the SIP + session established on the other side of the gateway. + value: + From a05ca6d37bcaed675bc01a168843ccba1809eed2 Mon Sep 17 00:00:00 2001 From: Santiago Troncoso Date: Fri, 8 Nov 2024 19:43:22 +0100 Subject: [PATCH 02/10] fix(api): Review trailing spaces for webrtc-events API --- code/API_definitions/BYON-Webrtc-Events.yaml | 34 ++++++++++---------- 1 file changed, 17 insertions(+), 17 deletions(-) diff --git a/code/API_definitions/BYON-Webrtc-Events.yaml b/code/API_definitions/BYON-Webrtc-Events.yaml index bf21963..3de608d 100644 --- a/code/API_definitions/BYON-Webrtc-Events.yaml +++ b/code/API_definitions/BYON-Webrtc-Events.yaml @@ -91,8 +91,8 @@ info: Find more information at the Schema description. A `org.camaraproject.webrtc-events.registration` event includes two main use cases: update about netowrk status of the registration **and** provide notification about requested sessions (incoming calls). - - On one hand, it provides the same session information received using the WebRTC BYON RACM API, when retrieving information from the GET /racm/sessions/{racmSessionId} endpoint. Mainly it includes a unique registration ID, and the registration status. A valid `Registered` registration status grants that endpoint is visible for the network, since an invalid `Unregistered` status value means that network considers your endpoint unreachable. + + On one hand, it provides the same session information received using the WebRTC BYON RACM API, when retrieving information from the GET /racm/sessions/{racmSessionId} endpoint. Mainly it includes a unique registration ID, and the registration status. A valid `Registered` registration status grants that endpoint is visible for the network, since an invalid `Unregistered` status value means that network considers your endpoint unreachable. When a new session is requested, it includes the context information: caller and possible carrier data to contextualize (call subject, branding info, etc) and a unique SessionId, with this SessionId is possible to create a subscription and receive events about the call itself and its status progressing on the telco network. @@ -459,9 +459,9 @@ components: Config: description: |- Implementation-specific configuration parameters needed by the subscription manager for acquiring events. `subscriptionExpireTime`, `subscriptionMaxEvents`, `initialEvent` are predefined for CAMARA specifications. - + WebRTC specific event type attributes are included into `subscriptionDetail` - + Note: if a request is performed for several event type, all subscribed event will use same `config` parameters. type: object required: @@ -601,7 +601,7 @@ components: - Events triggered for any media session related event (e.g. far end new media endpoints) - `org.camaraproject.webrtc-events.registration` - Events triggered for any media endpoint registration event (e.g. incomming session) - + `subscription-ends` is not supported for subscription. Sent by defatult enum: - org.camaraproject.webrtc-events.session @@ -734,7 +734,7 @@ components: - $ref: "#/components/schemas/SubscriptionEnds" description: |- Event details payload. Depending of the event type, it will will include one of the data structures defined on this specification. Along with the subscription-ends, that is an authomatic event. - + Check the introduction documentation and the CAMARA WebRTC BYON APIs for extra info about data structures included on the events. time: $ref: "#/components/schemas/DateTime" @@ -779,8 +779,8 @@ components: RegistrationEvent: description: |- A `org.camaraproject.webrtc-events.registration` event includes two main use cases: update about netowrk status of the registration **and** provide notification about requested sessions (incoming calls). - - On one hand, it provides the same session information received using the WebRTC BYON RACM API, when retrieving information from the GET /racm/sessions/{racmSessionId} endpoint. Mainly it includes a unique registration ID, and the registration status. A valid `Registered` registration status grants that endpoint is visible for the network, since an invalid `Unregistered` status value means that network considers your endpoint unreachable. + + On one hand, it provides the same session information received using the WebRTC BYON RACM API, when retrieving information from the GET /racm/sessions/{racmSessionId} endpoint. Mainly it includes a unique registration ID, and the registration status. A valid `Registered` registration status grants that endpoint is visible for the network, since an invalid `Unregistered` status value means that network considers your endpoint unreachable. When a new session is requested, it includes the context information: caller and possible carrier data to contextualize (call subject, branding info, etc) and a unique SessionId, with this SessionId is possible to create a subscription and receive events about the call itself and its status progressing on the telco network. @@ -898,7 +898,7 @@ components: sdp: type: string description: |- - An inlined session description in SDP format [RFC4566].If XML syntax is used, the content of this element SHALL be embedded in a CDATA section + An inlined session description in SDP format [RFC4566].If XML syntax is used, the content of this element SHALL be embedded in a CDATA section # CloudEvent and CAMARA standard EventSubscriptionEnds: @@ -1388,11 +1388,11 @@ components: description: |- A sample of WebRTC **registration** subscription for phone number `+1234567890` at `acme.opentelco.com`. - + This will be used to receive incoming sessions (incoming calls) and to be aware of registration status updates from the server. (i.e. when a REGISTRATION expires). - + The provided example will be able to receive up to 50 calls until subscription is cancelled via server or by configuration timeout. Check callback examples to check some possible events received: @@ -1442,7 +1442,7 @@ components: NEW_SESSION_INCOMING: description: |- Example of `resgitration` events. - + A new WebRTC session is requested (i.e. incoming call). This event starts a session negotiation. All other eventes related with this webrtc session will be shared via the session events. @@ -1459,7 +1459,7 @@ components: subscriptionId: 987654321 subscriber: username: "tel:+447911123456" - domain: acme.opentelco.com + domain: acme.opentelco.com registration: status: active session: @@ -1470,12 +1470,12 @@ components: username: "+1987654320" domain: opentelco.com status: initial - remoteSdp: "" + remoteSdp: "" webrtcSessionId: 1f14dc636262b319-22@0.0.0.0 REGISTRATION_REVOKED: description: |- Example of `resgitration` events. - + When a re-registration is requested from server, maybe due administrative token revocation or due any other technical reason. It is expected from the endpoint to re-register. No new sessions will be @@ -1491,7 +1491,7 @@ components: subscriptionId: 987654321 subscriber: username: "tel:+447911123456" - domain: acme.opentelco.com + domain: acme.opentelco.com registration: status: inactive SESSION_UPDATE: @@ -1502,4 +1502,4 @@ components: status, due changes on the SDP of both parties and / or on the SIP session established on the other side of the gateway. value: - + From eae43b7b8542268a3c1faa00e8e0735abee77867 Mon Sep 17 00:00:00 2001 From: Santiago Troncoso Date: Tue, 12 Nov 2024 12:29:55 +0100 Subject: [PATCH 03/10] fix(api): SessionID incl on NEW_SESSION_INCOMING and linter fix --- code/API_definitions/BYON-Webrtc-Events.yaml | 58 +++++++++++++------- 1 file changed, 39 insertions(+), 19 deletions(-) diff --git a/code/API_definitions/BYON-Webrtc-Events.yaml b/code/API_definitions/BYON-Webrtc-Events.yaml index 3de608d..e3e8f2c 100644 --- a/code/API_definitions/BYON-Webrtc-Events.yaml +++ b/code/API_definitions/BYON-Webrtc-Events.yaml @@ -805,6 +805,9 @@ components: subject: type: string description: Subject of the call + sessionId: + type: string + description: Unique identifier of the session to subscribe to notifications RegistrationStatus: type: string @@ -1403,7 +1406,7 @@ components: protocol: HTTP sink: https://notificationServer.opentelco.com types: - - org.camaraproject.webrtc-events.registration + - org.camaraproject.webrtc-events.registration config: subscriptionDetail: deviceId: "1qazxsw23edc" @@ -1427,7 +1430,7 @@ components: protocol: HTTP sink: https://notificationServer.opentelco.com types: - - org.camaraproject.webrtc-events.session + - org.camaraproject.webrtc-events.session config: subscriptionDetail: deviceId: "1qazxsw23edc" @@ -1456,22 +1459,19 @@ components: datacontenttype: application/json time: 2024-11-05T05:40:23.682Z data: - subscriptionId: 987654321 - subscriber: - username: "tel:+447911123456" - domain: acme.opentelco.com - registration: - status: active - session: - to: - username: "+1987654320" - domain: opentelco.com - from: - username: "+1987654320" - domain: opentelco.com - status: initial - remoteSdp: "" - webrtcSessionId: 1f14dc636262b319-22@0.0.0.0 + subscriptionId: qs15-h556-rt89-1298 + msisdn: "+8801500121121" + regStatus: Registered + sessionRequest: + originator: + username: "tel:+447911123456" + domain: acme.opentelco.com + receiver: + username: "tel:+447911123456" + domain: acme.opentelco.com + subject: "Not defined" + sessionid: 0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EF + REGISTRATION_REVOKED: description: |- Example of `resgitration` events. @@ -1489,6 +1489,7 @@ components: time: 2024-11-05T05:40:23.682Z data: subscriptionId: 987654321 + msisdn: "+8801500121121" subscriber: username: "tel:+447911123456" domain: acme.opentelco.com @@ -1502,4 +1503,23 @@ components: status, due changes on the SDP of both parties and / or on the SIP session established on the other side of the gateway. value: - + id: "VzYQCOClM6Kc7Xmyq7mP58Jx" + source: https://notificationServer.opentelco.com + type: org.camaraproject.webrtc-events.registration + specversion: "1.0" + datacontenttype: application/json + time: 2024-11-05T05:40:23.682Z + data: + originator: + username: "tel:+447911123456" + domain: acme.opentelco.com + receiver: + username: "tel:+447956781234" + domain: acme.opentelco.com + status: "Proceeding" + offer: + sdp: "v=0\r\no=- 4576312012535546667 4 IN IP4 127.0.0.1\r\ns=-\r\nt=0 0\r\nm=audio 47510 RTP/SAVPF 102 113\r\nc=IN IP6 2001:e0:410:243a:a344:cee7:7b39:bb1e\r\nb=AS:64\r\na=rtcp:9 IN IP4 0.0.0.0\r\na=candidate:3108871805 1 udp 2122262783 2001:e0:410:243a:a344:cee7:7b39:bb1e 47510 typ host generation 0 network-id 3 network-cost 900\r\na=ice-ufrag:47Nx\r\na=ice-pwd:ln3CttOSkObcQ7A0tYO1LXqy\r\na=ice-options:trickle renomination\r\na=mid:audio\r\na=extmap:2 http://www.ietf.org/id/draft-holmer-rmcat-transport-wide-cc-extensions-01\r\na=sendrecv\r\na=rtcp-mux\r\na=crypto:1 AES_CM_128_HMAC_SHA1_80 inline:ruAnBNYnTJqDVZAIJV59VpQ5DxGI6tMX9h9kkHSz\r\na=rtpmap:102 AMR-WB/16000\r\na=fmtp:102 octet-align=0; mode-set=0,1,2; mode-change-capability=2\r\na=rtpmap:113 telephone-event/16000\r\na=ptime:20\r\n" + answer: + sdp: "v=0\r\no=- 4576312012535546667 4 IN IP4 127.0.0.1\r\ns=-\r\nt=0 0\r\nm=audio 47510 RTP/SAVPF 102 113\r\nc=IN IP6 2001:e0:410:243a:a344:cee7:7b39:bb1e\r\nb=AS:64\r\na=rtcp:9 IN IP4 0.0.0.0\r\na=candidate:3108871805 1 udp 2122262783 2001:e0:410:243a:a344:cee7:7b39:bb1e 47510 typ host generation 0 network-id 3 network-cost 900\r\na=ice-ufrag:47Nx\r\na=ice-pwd:ln3CttOSkObcQ7A0tYO1LXqy\r\na=ice-options:trickle renomination\r\na=mid:audio\r\na=extmap:2 http://www.ietf.org/id/draft-holmer-rmcat-transport-wide-cc-extensions-01\r\na=sendrecv\r\na=rtcp-mux\r\na=crypto:1 AES_CM_128_HMAC_SHA1_80 inline:ruAnBNYnTJqDVZAIJV59VpQ5DxGI6tMX9h9kkHSz\r\na=rtpmap:102 AMR-WB/16000\r\na=fmtp:102 octet-align=0; mode-set=0,1,2; mode-change-capability=2\r\na=rtpmap:113 telephone-event/16000\r\na=ptime:20\r\n" + clientCorrelator: fda6e26d-e7c8-4596-870c-c083c0d39b2c + vvoipSessionId: 0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EF From a65545df559a35b4a34916a7b61ee240e1bd32f6 Mon Sep 17 00:00:00 2001 From: Santiago Troncoso Date: Tue, 19 Nov 2024 13:36:52 +0100 Subject: [PATCH 04/10] fix(api): Removed not supported protocols (MQTT, AMQP, NATS, KAFKA) --- code/API_definitions/BYON-Webrtc-Events.yaml | 126 +------------------ 1 file changed, 1 insertion(+), 125 deletions(-) diff --git a/code/API_definitions/BYON-Webrtc-Events.yaml b/code/API_definitions/BYON-Webrtc-Events.yaml index e3e8f2c..53810ae 100644 --- a/code/API_definitions/BYON-Webrtc-Events.yaml +++ b/code/API_definitions/BYON-Webrtc-Events.yaml @@ -444,15 +444,10 @@ components: propertyName: protocol mapping: HTTP: "#/components/schemas/HTTPSubscriptionRequest" - MQTT3: "#/components/schemas/MQTTSubscriptionRequest" - MQTT5: "#/components/schemas/MQTTSubscriptionRequest" - AMQP: "#/components/schemas/AMQPSubscriptionRequest" - NATS: "#/components/schemas/NATSSubscriptionRequest" - KAFKA: "#/components/schemas/ApacheKafkaSubscriptionRequest" Protocol: type: string - enum: ["HTTP", "MQTT3", "MQTT5", "AMQP", "NATS", "KAFKA"] + enum: ["HTTP"] description: Identifier of a delivery protocol. Only HTTP is allowed for now example: "HTTP" @@ -974,125 +969,6 @@ components: description: The HTTP method to use for sending the message. enum: - POST - - MQTTSubscriptionRequest: - allOf: - - $ref: "#/components/schemas/SubscriptionRequest" - - type: object - properties: - protocolSettings: - $ref: "#/components/schemas/MQTTSettings" - - MQTTSubscriptionResponse: - allOf: - - $ref: "#/components/schemas/Subscription" - - type: object - properties: - protocolSettings: - $ref: "#/components/schemas/MQTTSettings" - - MQTTSettings: - type: object - properties: - topicName: - type: string - qos: - type: integer - format: int32 - retain: - type: boolean - expiry: - type: integer - format: int32 - userProperties: - type: object - required: - - topicName - - AMQPSubscriptionRequest: - allOf: - - $ref: "#/components/schemas/SubscriptionRequest" - - type: object - properties: - protocolSettings: - $ref: "#/components/schemas/AMQPSettings" - - AMQPSubscriptionResponse: - allOf: - - $ref: "#/components/schemas/Subscription" - - type: object - properties: - protocolSettings: - $ref: "#/components/schemas/AMQPSettings" - - AMQPSettings: - type: object - properties: - address: - type: string - linkName: - type: string - senderSettlementMode: - type: string - enum: ["settled", "unsettled"] - linkProperties: - type: object - additionalProperties: - type: string - - ApacheKafkaSubscriptionRequest: - allOf: - - $ref: "#/components/schemas/SubscriptionRequest" - - type: object - properties: - protocolSettings: - $ref: "#/components/schemas/ApacheKafkaSettings" - - ApacheKafkaSubscriptionResponse: - allOf: - - $ref: "#/components/schemas/Subscription" - - type: object - properties: - protocolSettings: - $ref: "#/components/schemas/ApacheKafkaSettings" - - ApacheKafkaSettings: - type: object - properties: - topicName: - type: string - partitionKeyExtractor: - type: string - clientId: - type: string - ackMode: - type: integer - required: - - topicName - - NATSSubscriptionRequest: - allOf: - - $ref: "#/components/schemas/SubscriptionRequest" - - type: object - properties: - protocolSettings: - $ref: "#/components/schemas/NATSSettings" - - NATSSubscriptionResponse: - allOf: - - $ref: "#/components/schemas/Subscription" - - type: object - properties: - protocolSettings: - $ref: "#/components/schemas/NATSSettings" - - NATSSettings: - type: object - properties: - subject: - type: string - required: - - subject responses: CreateSubscriptionBadRequest400: description: Problem with the client request From b2ecfd3ad9c4fcdaa4c09089bb456e26e81c33a5 Mon Sep 17 00:00:00 2001 From: Santiago Troncoso Date: Tue, 3 Dec 2024 14:21:38 +0100 Subject: [PATCH 05/10] fix(api): Simplified events - Renamed event types - Removed atomic schemas - Reviewed descriptions --- code/API_definitions/BYON-Webrtc-Events.yaml | 391 ++++++++++--------- 1 file changed, 207 insertions(+), 184 deletions(-) diff --git a/code/API_definitions/BYON-Webrtc-Events.yaml b/code/API_definitions/BYON-Webrtc-Events.yaml index 53810ae..f4326b5 100644 --- a/code/API_definitions/BYON-Webrtc-Events.yaml +++ b/code/API_definitions/BYON-Webrtc-Events.yaml @@ -5,39 +5,45 @@ info: ## 1. Introduction This API provide REST API for a client, browser or native application, to - receive events about state of the call or updated of th registration status. - Any device can check for its own active registrations and calls, allowing - them to receive updates about the status of its registrations and calls and - progress them to the UI. + receive events about updates of an active session or new sessions requests + (incoming calls). + + Any device can subscribe for events its own active sessions using the + `sessionId` to identify the session to track. And using a valid + `racmSessionId` it can subscribe to new sessions events. This allows them + to update the UI while WebRTC sessions are progressing and also, allows + them to receive new session request, generating incoming call scenarios for + non SIM devices. A classic use case is the negotiation of a live WebRTC session (call), that requires multiple asynchronous events from server side. Other classic example, is to notify that a subscriber is not logged into the network - anymore, for example, when the IMS expires the registration. + anymore and requires refresh, for example, when the IMS expires the + endpoint registration. - In adition, this API, allows to an external service to create "notification + In addition, this API, allows to an external service to create "notification channels" for other systems that does no support the async event mechanisms. For instance, a classic browser using websockets to receive server-side events. **Use cases to cover:** - Functional: - - A push notitification service based on an external webhook + - A push notification service based on an external webhook - A browser that requires a WS to receive events from the server side. - This will require to create a dedicated endpoint using the NotificationChannel API - Observability: - A monitoring system that wants to monitor registration status of endpoints - - A call audit application that requires to remotly monitor call status + - A call audit application that requires to remotely monitor call status ## 2. Relevant terms and definitions - **BYON**: Bring Your Own Number. A commercial name for the functionality - to use your telco credentials and phone number identity to no-SIM devices - using WebRTC sessions. - - **session**: A media session, an exchange of media between endpoints, - usually knonw as a "single one-to-one call". + to use your network credentials and phone number identity to no-SIM + devices using WebRTC sessions. + - **session**: A media session, an exchange of media between endpoints. + Typical example of session is a "single one-to-one call". - **registration**: An endpoint status were it is properly identified to be reachable by the server side of the WebRTC gateway. @@ -55,66 +61,103 @@ info: Following event types are managed for this API: - - `org.camaraproject.webrtc-events.session` + - `org.camaraproject.webrtc-events.session-status` - - Events triggered for any media session related event (e.g. far end new media endpoints) + - Events triggered for any media session related event (e.g. far end new + media endpoints) - - `org.camaraproject.webrtc-events.registration` + - `org.camaraproject.webrtc-events.session-invitation` - - Events triggered for any media endpoint registration event (e.g. incomming session) + - Events triggered when a new session is requested (e.g. incoming call + received) Note: Additionally to these list, ``org.camaraproject.webrtc-events.subscription-ends`` notification `type` is sent when the subscription ends. This notification does not require dedicated subscription. It is used when: - - the subscription expire time (optionally set by the requester) has been reached - - the maximum number of subscription events (optionally set by the requester) has been reached + - the subscription expire time has been reached (optionally set by the + requester) + - the maximum number of subscription events has been reached (optionally + set by the requester) - the subscription was deleted by the requester - - the Access Token `sinkCredential` (optionally set by the requester) expiration time has been reached + - the Access Token `sinkCredential` expiration time has been reached + (optionally set by the requester) - the API server has to stop sending notification prematurely - ### 3.1. Session events + ### 3.1. Session events (session-status) Find more information at the Schema description. - A `org.camaraproject.webrtc-events.session` event includes the same session information received using the WebRTC BOYN CallHandling API, when retrieving information from the GET /vvoip/session/{vvoipSessionID} endpoint. + A `org.camaraproject.webrtc-events.session-status` event includes + session information updates. With the same schema that is used with the + WebRTC BYON CallHandling API, when retrieving information from the + `GET /vvoip/session/{vvoipSessionID}` endpoint. - In general lines, it is receive each time that an event happens with the session. This might happen when a call is received, when SDP updates are included for any party or when the call is finished due an ordered cleanup or a service outage. + In general lines, it is emitted each time that an event happens within the + subscribed session. This might happen when SDP updates are included for any + party or when the call is finished due an ordered cleanup or a service + outage. Any other any relevant internal event could be transmitted through + this channel (eg.: Any SIP response is potentially a + session-status event. Regarding the SDP descriptions for offer and answer: - - The offer, which MUST be present in a request from the application to the server to create a session. Note that the offer can be absent in a session created by the server as part of an offerless INVITE [RFC3261]. - - For the answer. This type represents an answer in WebRTC Signaling. This element is not present in case there is no answer yet, or the session invitation has been declined by the Terminating Participant. This element MUST NOT be present in a request from the application to the server to create a session. + - The offer, which MUST be present in a request from the application to the + server to create a session. Note that the offer can be absent in a session + created by the server as part of an offerless INVITE [RFC3261]. + - For the answer. This type represents an answer in WebRTC Signaling. This + element is not present in case there is no answer yet, or the session + invitation has been declined by the Terminating Participant. This element + MUST NOT be present in a request from the application to the server to + create a session. - ### 3.2. Registration events + ### 3.2. New session request (session-invitation) Find more information at the Schema description. - A `org.camaraproject.webrtc-events.registration` event includes two main use cases: update about netowrk status of the registration **and** provide notification about requested sessions (incoming calls). + A `org.camaraproject.webrtc-events.session-invitation` event + includes information about new requested sessions (incoming calls), it + requires a valid registration on the network. + + This event is triggered each time that the endpoint is requested to join + an incoming new session. This is done, usually, to indicate that a new + WebRTC "call" is incoming. In practical terms, this is a new WebRTC + session that requests the endpoint presence. The event include all + functional information required to join the session (media info, caller). - On one hand, it provides the same session information received using the WebRTC BYON RACM API, when retrieving information from the GET /racm/sessions/{racmSessionId} endpoint. Mainly it includes a unique registration ID, and the registration status. A valid `Registered` registration status grants that endpoint is visible for the network, since an invalid `Unregistered` status value means that network considers your endpoint unreachable. + When a new session is requested, it will include context information: + identification of the caller and other possible carrier data to + contextualize (call subject, branding info, etc). It will also include + a unique SessionId, to create a dedicated subscription and receive events + about the session itself and its status progressing inside the network. - When a new session is requested, it includes the context information: caller and possible carrier data to contextualize (call subject, branding info, etc) and a unique SessionId, with this SessionId is possible to create a subscription and receive events about the call itself and its status progressing on the telco network. + ### 3.3. Subscription ends (subscription-ends) - **NOTE**: The `Unregistered` status will be only provided by the notification service, a GET /racm/sessions/ for an unregistered endpoint will produce an 404 response. + A `org.camaraproject.webrtc-events.subscription-ends` event will indicate + that the endpoint will not be notified if a new session is received. From + the developer point of view the reception of the `subscription-ends` should + be an indicator to check the registration status and try to register again. ## 4. Authorization and authentication - The "Camara Security and Interoperability Profile" provides details on how a client requests - an access token. Please refer to Identify and Consent Management - (https://github.com/camaraproject/IdentityAndConsentManagement/) for the released version of + The "Camara Security and Interoperability Profile" provides details on how + a client requests an access token. Please refer to [Identify and Consent + Management](https://github.com/camaraproject/IdentityAndConsentManagement/) + for the released version of the Profile. - Which specific authorization flows are to be used will be determined during onboarding process, - happening between the API Client and the API Provider, taking into account the declared purpose - for accessing the API, while also being subject to the prevailing legal framework dictated by - local legislation. + Which specific authorization flows are to be used will be determined during + onboarding process, happening between the API Client and the API Provider, + taking into account the declared purpose for accessing the API, while also + being subject to the prevailing legal framework dictated by local + legislation. - It is important to remark that in cases where personal user data is processed by the API, and - users can exercise their rights through mechanisms such as opt-in and/or opt-out, the use of - 3-legged access tokens becomes mandatory. This measure ensures that the API remains in strict - compliance with user privacy preferences and regulatory obligations, upholding the principles - of transparency and user-centric data control. + It is important to remark that in cases where personal user data is + processed by the API, and users can exercise their rights through + mechanisms such as opt-in and/or opt-out, the use of 3-legged access tokens + becomes mandatory. This measure ensures that the API remains in strict + compliance with user privacy preferences and regulatory obligations, + upholding the principles of transparency and user-centric data control. ## 5. Further info and support (Will be added in a later version of the documentation) @@ -150,14 +193,14 @@ paths: tags: - webrtc-events Subscription summary: "Create a webrtc-events event subscription" - description: Create a webrtc-events event subscription. For the correspoding type, `session` or `registration`. + description: Create a webrtc-events event subscription. For the corresponding type, `session` or `registration`. operationId: createNotificationChannelSubscription parameters: - $ref: "#/components/parameters/x-correlator" security: - openId: - - webrtc-events:org.camaraproject.webrtc-events.session:create - - webrtc-events:org.camaraproject.webrtc-events.registration:create + - webrtc-events:org.camaraproject.webrtc-events.session-status:create + - webrtc-events:org.camaraproject.webrtc-events.session-invitation:create requestBody: content: application/json: @@ -431,8 +474,8 @@ components: types: description: |- Camara Event types eligible to be delivered by this subscription. - Note: for the Commonalities meta-release v0.4 we enforce to have only event type per subscription then for following meta-release use of array MUST be decided - at API project level. + Note: for the Commonalities meta-release v0.4 we enforce to have only event type per subscription + then for following meta-release use of array MUST be decided at API project level. type: array minItems: 1 maxItems: 1 @@ -445,25 +488,22 @@ components: mapping: HTTP: "#/components/schemas/HTTPSubscriptionRequest" - Protocol: - type: string - enum: ["HTTP"] - description: Identifier of a delivery protocol. Only HTTP is allowed for now - example: "HTTP" - Config: description: |- - Implementation-specific configuration parameters needed by the subscription manager for acquiring events. `subscriptionExpireTime`, `subscriptionMaxEvents`, `initialEvent` are predefined for CAMARA specifications. + Implementation-specific configuration parameters needed by the subscription manager for acquiring + events. `subscriptionExpireTime`, `subscriptionMaxEvents`, `initialEvent` are predefined for CAMARA + specifications. - WebRTC specific event type attributes are included into `subscriptionDetail` + WebRTC specific event type attributes are included into `WebrtcSubscriptionDetail` schema. - Note: if a request is performed for several event type, all subscribed event will use same `config` parameters. + Note: if a request is performed for several event type, all subscribed event will use same `config` + parameters. type: object required: - subscriptionDetail properties: subscriptionDetail: - $ref: "#/components/schemas/SubscriptionDetail" + $ref: "#/components/schemas/WebrtcSubscriptionDetail" subscriptionExpireTime: type: string format: date-time @@ -481,6 +521,12 @@ components: Example: Consumer request Roaming event. If consumer sets initialEvent to true and device is in roaming situation, an event is triggered Up to API project decision to keep it. + Protocol: + type: string + enum: ["HTTP"] + description: Identifier of a delivery protocol. Only HTTP is allowed for now + example: "HTTP" + SinkCredential: description: A sink credential provides authentication or authorization information necessary to enable delivery of events to a target. type: object @@ -572,49 +618,66 @@ components: - refreshToken - refreshTokenEndpoint - SubscriptionDetail: + WebrtcSubscriptionDetail: description: |- - The detail of the requested event subscription. `registration` event subscription requires a the subscriber information, while `session` event subscription requires both, the user information and the sessionId to subscribe to. + The detail of the requested event subscription. + - org.camaraproject.webrtc-events.session-invitation requires a + valid `racmSessionId` obtained via RACM endpoint. + - org.camaraproject.webrtc-events.session-status requires both, a + valid `racmSessionId` obtained via RACM endpoint and a valid + `sessionId` obtained via session-invitation event or via CallHandling + API type: object required: - deviceId + - racmSessionId properties: deviceId: type: string example: 1qazxsw23edc + description: The device-id of the client in UUID format. sessionId: + type: string + example: 0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EFAAF209EE52FD0BECC5B7CDE645F50DE7D + description: |- + The VVOIP session ID created by WebRTC Gateway. + The sessionID will identify a unique session between the WebRTC + Gateway and the device client. + It will be included on the events generated. + racmSessionId: type: string example: xsmcaum3z4zw4l0cu4w115m0 - subscriber: - $ref: "#/components/schemas/SubscriberUser" + description: |- + The RACM session ID created by WebRTC Gateway. + Obtained via RACM API. SubscriptionEventTypeNotification: type: string description: |- event-type - Event triggered when an event-type event occurred - - `org.camaraproject.webrtc-events.session` + - `org.camaraproject.webrtc-events.session-status` - Events triggered for any media session related event (e.g. far end new media endpoints) - - `org.camaraproject.webrtc-events.registration` - - Events triggered for any media endpoint registration event (e.g. incomming session) + - `org.camaraproject.webrtc-events.session-invitation` + - Events triggered for any media endpoint registration event (e.g. incoming session) - `subscription-ends` is not supported for subscription. Sent by defatult + `subscription-ends` is not supported for subscription. Sent by default enum: - - org.camaraproject.webrtc-events.session - - org.camaraproject.webrtc-events.registration + - org.camaraproject.webrtc-events.session-status + - org.camaraproject.webrtc-events.session-invitation EventTypeNotification: type: string description: |- event-type - Event triggered when an event-type event occurred - - `org.camaraproject.webrtc-events.session` + - `org.camaraproject.webrtc-events.session-status` - Events triggered for any media session related event (e.g. far end new media endpoints) - - `org.camaraproject.webrtc-events.registration` - - Events triggered for any media endpoint registration event (e.g. incomming session) + - `org.camaraproject.webrtc-events.session-invitation` + - Events triggered for any media endpoint registration event (e.g. incoming session) - `org.camaraproject.webrtc-events.subscription-ends` - Event triggered when the subscription ends enum: - - org.camaraproject.webrtc-events.session - - org.camaraproject.webrtc-events.registration + - org.camaraproject.webrtc-events.session-status + - org.camaraproject.webrtc-events.session-invitation - org.camaraproject.webrtc-events.subscription-ends Subscription: @@ -677,11 +740,6 @@ components: propertyName: protocol mapping: HTTP: '#/components/schemas/HTTPSubscriptionResponse' - MQTT3: '#/components/schemas/MQTTSubscriptionResponse' - MQTT5: '#/components/schemas/MQTTSubscriptionResponse' - AMQP: '#/components/schemas/AMQPSubscriptionResponse' - NATS: '#/components/schemas/NATSSubscriptionResponse' - KAFKA: '#/components/schemas/ApacheKafkaSubscriptionResponse' SubscriptionAsync: description: Response for a event-type subscription request managed asynchronously (Creation or Deletion) @@ -724,8 +782,8 @@ components: data: type: object oneOf: - - $ref: "#/components/schemas/EventRegistration" - - $ref: "#/components/schemas/EventSession" + - $ref: "#/components/schemas/SessionInvitationEvent" + - $ref: "#/components/schemas/SessionStatusEvent" - $ref: "#/components/schemas/SubscriptionEnds" description: |- Event details payload. Depending of the event type, it will will include one of the data structures defined on this specification. Along with the subscription-ends, that is an authomatic event. @@ -736,8 +794,8 @@ components: discriminator: propertyName: "type" mapping: - org.camaraproject.api-name.v0.resgistration: "#/components/schemas/EventRegistration" - org.camaraproject.api-name.v0.session: "#/components/schemas/EventSession" + org.camaraproject.api-name.v0.resgistration: "#/components/schemas/SessionInvitationEvent" + org.camaraproject.api-name.v0.session: "#/components/schemas/SessionStatusEvent" org.camaraproject.api-name.v0.subscription-ends: "#/components/schemas/EventSubscriptionEnds" Source: @@ -762,85 +820,79 @@ components: description: Timestamp of when the occurrence happened. Must adhere to RFC 3339. example: "2018-04-05T17:31:00Z" - EventRegistration: - description: Event detail structure for REGISTRATION events - allOf: - - $ref: "#/components/schemas/CloudEvent" - - type: object - properties: - data: - $ref: "#/components/schemas/RegistrationEvent" - - RegistrationEvent: + SessionInvitationEvent: description: |- - A `org.camaraproject.webrtc-events.registration` event includes two main use cases: update about netowrk status of the registration **and** provide notification about requested sessions (incoming calls). + A `org.camaraproject.webrtc-events.session-invitation` event includes two main use cases: update about network status of the registration **and** provide notification about requested sessions (incoming calls). On one hand, it provides the same session information received using the WebRTC BYON RACM API, when retrieving information from the GET /racm/sessions/{racmSessionId} endpoint. Mainly it includes a unique registration ID, and the registration status. A valid `Registered` registration status grants that endpoint is visible for the network, since an invalid `Unregistered` status value means that network considers your endpoint unreachable. When a new session is requested, it includes the context information: caller and possible carrier data to contextualize (call subject, branding info, etc) and a unique SessionId, with this SessionId is possible to create a subscription and receive events about the call itself and its status progressing on the telco network. **NOTE**: The `Unregistered` status will be only provided by the notification service, a GET /racm/sessions/ for an unregistered endpoint will produce an 404 response. - type: object - properties: - subscriptionId: - $ref: "#/components/schemas/SubscriptionId" - msisdn: - type: string - description: The MSISDN is the mapping of the telephone number to the subscriber identity module in a mobile or cellular phone system. A unique identifier on the network to this subscriber. - regStatus: - $ref: '#/components/schemas/RegistrationStatus' - sessionRequest: - description: Object present only when receiving a new session request - type: object - properties: - originator: - $ref: "#/components/schemas/SubscriberUser" - receiver: - $ref: "#/components/schemas/SubscriberUser" - subject: - type: string - description: Subject of the call - sessionId: - type: string - description: Unique identifier of the session to subscribe to notifications - - RegistrationStatus: - type: string - enum: - - Registered - - Unregistered - - EventSession: - description: event structure for session events allOf: - - $ref: "#/components/schemas/CloudEvent" - type: object - properties: - data: - $ref: "#/components/schemas/SessionInformation" + - $ref: '#/components/schemas/SessionStatusEvent' - SessionInformation: + SessionStatusEvent: description: |- - A `org.camaraproject.webrtc-events.registration` event includes the same session information received using the WebRTC BOYN CallHandling API, when retrieving information from the GET /vvoip/session/{vvoipSessionID} endpoint. + A `org.camaraproject.webrtc-events.session-session` event includes the session updates provided by + the server. This will include actions form the endpoint and the server (far end). - In general lines, it is receive each time that an event happens with the session. This might happen when a call is received, when SDP updates are included for any party or when the call is finished due an ordered cleanup or a service outage. + In general terms, it is received each time that an event happens within the session, and include + all relevant info about the session update. - Regarding the SDP descriptions for offer and answer: - - The offer, which MUST be present in a request from the application to the server to create a session. Note that the offer can be absent in a session created by the server as part of an offerless INVITE [RFC3261]. - - For the answer. This type represents an answer in WebRTC Signaling. This element is not present in case there is no answer yet, or the session invitation has been declined by the Terminating Participant. This element MUST NOT be present in a request from the application to the server to create a session. + Most common use is for SDP updates and signaling updates regarding call status. required: - vvoipSessionID type: object properties: - originator: - $ref: '#/components/schemas/SubscriberUser' - receiver: - $ref: '#/components/schemas/SubscriberUser' + originatorAddress: + type: string + description: Sender (originator) address + pattern: '^(tel:+[0-9]{5,15}|sip:.+@.+|.+)$' + example: 'tel:+11234567899' + originatorName: + type: string + description: Friendly name of the call originator + example: 'Alice' + receiverAddress: + type: string + description: Receiver (terminator) address + pattern: '^(tel:+[0-9]{5,15}|sip:.+@.+|.+)$' + example: 'tel:+11234567899' + receiverName: + type: string + description: Friendly name of the call terminator + example: 'Bob' status: - $ref: '#/components/schemas/SessionStatus' + type: string + description: |- + Provides the status of the VVOIP session. During the session creation, + this attribute contains 'Initial' value + example: Initial + enum: + - Initial + - InProgress + - Ringing + - Proceeding + - Connected + - Terminated + - Hold + - Resume + - SessionCancelled + - Declined + - Failed + - Waiting + - NoAnswer + - NotReachable + - Busy offer: + # allOf: + # - description: SDP descriptor (RFC4566) for call originator + # - $ref: '#/components/schemas/WrtcSDPDescriptor' $ref: '#/components/schemas/WrtcSDPDescriptor' answer: + # description: SDP descriptor (RFC4566) for call terminator $ref: '#/components/schemas/WrtcSDPDescriptor' clientCorrelator: type: string @@ -849,46 +901,16 @@ components: type: string description: The VVOIP session ID created by WebRTC Gateway. The vvoipSessionID shall not be included in POST requests by the client, but must be included in the notifications from the WebRTC GW to client. example: 0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EF - - SubscriberUser: - type: object - description: |- - Information about one of the participants on the WebRTC session. It can - be used to describe a caller or callee (source or destination). It can - be expanded to include any extra information for authentication out of - dialog. - properties: - address: - type: string - description: Sender or Receiver address - pattern: '^(tel:+[0-9]{5,15}|sip:.+@.+|.+)$' - example: 'tel:+11234567899' - name: - type: string - description: Friendly name of the originator - example: 'Jonh Doe' - - SessionStatus: - type: string - description: |- - Provides the status of the VVOIP session. During the session creation, - this attribute contains 'Initial' value - enum: - - Initial - - InProgress - - Ringing - - Proceeding - - Connected - - Terminated - - Hold - - Resume - - SessionCancelled - - Declined - - Failed - - Waiting - - NoAnswer - - NotReachable - - Busy + callObjectRef: + description: The reference to the call object + serverCorrelator: + description: A correlator that the server instructs the client to use for end to end correlation. + offerRequired: + description: This element shall be included and set to true, if the session updates are received without SDP offer. This element indicates clients to send the offer. + reason: + description: The description of the event that has happened within the session + sequenceNumber: + description: The sequence number of the notification sent to client WrtcSDPDescriptor: type: object @@ -969,6 +991,7 @@ components: description: The HTTP method to use for sending the message. enum: - POST + responses: CreateSubscriptionBadRequest400: description: Problem with the client request @@ -1282,7 +1305,7 @@ components: protocol: HTTP sink: https://notificationServer.opentelco.com types: - - org.camaraproject.webrtc-events.registration + - org.camaraproject.webrtc-events.session-invitation config: subscriptionDetail: deviceId: "1qazxsw23edc" @@ -1306,7 +1329,7 @@ components: protocol: HTTP sink: https://notificationServer.opentelco.com types: - - org.camaraproject.webrtc-events.session + - org.camaraproject.webrtc-events.session-status config: subscriptionDetail: deviceId: "1qazxsw23edc" @@ -1330,7 +1353,7 @@ components: value: id: "VzYQCOClM6Kc7Xmyq7mP58Jx" source: https://notificationServer.opentelco.com - type: org.camaraproject.webrtc-events.registration + type: org.camaraproject.webrtc-events.session-invitation specversion: "1.0" datacontenttype: application/json time: 2024-11-05T05:40:23.682Z @@ -1350,16 +1373,16 @@ components: REGISTRATION_REVOKED: description: |- - Example of `resgitration` events. + Example of `session-invitation` events. When a re-registration is requested from server, maybe due administrative token revocation or due any other technical reason. It is expected from the endpoint to re-register. No new sessions will be - delivered to the user endpoint, as the subscrition is not valid anymore. + delivered to the user endpoint, as the subscription is not valid anymore. value: id: "VzYQCOClM6Kc7Xmyq7mP58Jx" source: https://notificationServer.opentelco.com - type: org.camaraproject.webrtc-events.registration + type: org.camaraproject.webrtc-events.session-invitation specversion: "1.0" datacontenttype: application/json time: 2024-11-05T05:40:23.682Z From 248e056ce8ef874809066188fe56629f271f774f Mon Sep 17 00:00:00 2001 From: Santiago Troncoso Date: Tue, 3 Dec 2024 15:53:28 +0100 Subject: [PATCH 06/10] fix(api): comms compliance: server params and subscriptionId --- code/API_definitions/BYON-Webrtc-Events.yaml | 10 +++------- 1 file changed, 3 insertions(+), 7 deletions(-) diff --git a/code/API_definitions/BYON-Webrtc-Events.yaml b/code/API_definitions/BYON-Webrtc-Events.yaml index f4326b5..cbc94e2 100644 --- a/code/API_definitions/BYON-Webrtc-Events.yaml +++ b/code/API_definitions/BYON-Webrtc-Events.yaml @@ -172,17 +172,11 @@ externalDocs: description: Product documentation at CAMARA url: https://github.com/camaraproject/ servers: - - url: "{apiRoot}/webrtc-events/v1" + - url: "{apiRoot}/webrtc-events/vwip" variables: apiRoot: default: http://localhost:9091 description: API root - deviceId: - description: >- - The notification channel creation is specific to a device instance, - the device-id in the uuid format (rfc4412) shall be included in the - request - default: deviceId tags: - name: webrtc-events Subscription description: Operations to manage event subscriptions for WebRTC APIs (BYON and RACM) @@ -846,6 +840,8 @@ components: - vvoipSessionID type: object properties: + subscriptionId: + $ref: "#/components/schemas/SubscriptionId" originatorAddress: type: string description: Sender (originator) address From db6cd15886f88841acccd4b508c0e38df54eb8ee Mon Sep 17 00:00:00 2001 From: Santiago Troncoso Date: Mon, 9 Dec 2024 12:11:41 +0100 Subject: [PATCH 07/10] fix(webrtc-events): Fixed examples and polyform SessionEvent --- code/API_definitions/BYON-Webrtc-Events.yaml | 112 +++++++++++-------- 1 file changed, 65 insertions(+), 47 deletions(-) diff --git a/code/API_definitions/BYON-Webrtc-Events.yaml b/code/API_definitions/BYON-Webrtc-Events.yaml index cbc94e2..a724a1b 100644 --- a/code/API_definitions/BYON-Webrtc-Events.yaml +++ b/code/API_definitions/BYON-Webrtc-Events.yaml @@ -816,28 +816,37 @@ components: SessionInvitationEvent: description: |- - A `org.camaraproject.webrtc-events.session-invitation` event includes two main use cases: update about network status of the registration **and** provide notification about requested sessions (incoming calls). + A `org.camaraproject.webrtc-events.session-invitation` event includes an specific type of session + update for new requested sessions. It is emitted when the endpoint is associated with a valid + registration and the endpoint is susbcribed to recive new incoming calls. - On one hand, it provides the same session information received using the WebRTC BYON RACM API, when retrieving information from the GET /racm/sessions/{racmSessionId} endpoint. Mainly it includes a unique registration ID, and the registration status. A valid `Registered` registration status grants that endpoint is visible for the network, since an invalid `Unregistered` status value means that network considers your endpoint unreachable. + This event includes all the context information: caller, callee and possible carrier data to + contextualize (call subject, branding info, etc). It MUST include a vvoipSessionId, to allow the + endpoint to subscribe to this new call session. - When a new session is requested, it includes the context information: caller and possible carrier data to contextualize (call subject, branding info, etc) and a unique SessionId, with this SessionId is possible to create a subscription and receive events about the call itself and its status progressing on the telco network. - - **NOTE**: The `Unregistered` status will be only provided by the notification service, a GET /racm/sessions/ for an unregistered endpoint will produce an 404 response. allOf: - type: object - - $ref: '#/components/schemas/SessionStatusEvent' + - $ref: '#/components/schemas/SessionEvent' SessionStatusEvent: description: |- - A `org.camaraproject.webrtc-events.session-session` event includes the session updates provided by + A `org.camaraproject.webrtc-events.session-status` event includes the session updates provided by the server. This will include actions form the endpoint and the server (far end). In general terms, it is received each time that an event happens within the session, and include all relevant info about the session update. Most common use is for SDP updates and signaling updates regarding call status. + + allOf: + - type: object + - $ref: '#/components/schemas/SessionEvent' + + SessionEvent: + description: |- + A prototype for Webrtc events. Used at `SessionStatusEvent` and `SessionInvitationEvent` schemas required: - - vvoipSessionID + - vvoipSessionId type: object properties: subscriptionId: @@ -1305,9 +1314,7 @@ components: config: subscriptionDetail: deviceId: "1qazxsw23edc" - subscriber: - address: "tel:+447911123456" - name: Jonh Doe + racmSessionId: "xsmcaum3z4zw4l0cu4w115m0" initialEvent: true subscriptionMaxEvents: 50 subscriptionExpireTime: "2024-11-17T13:18:23.682Z" @@ -1329,23 +1336,26 @@ components: config: subscriptionDetail: deviceId: "1qazxsw23edc" + racmSessionId: "xsmcaum3z4zw4l0cu4w115m0" subscriber: address: "tel:+447911123456" name: Jonh Doe - sessionId: 0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EF + vvoipSessionId: 0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EF initialEvent: true subscriptionMaxEvents: 50 subscriptionExpireTime: "2024-11-17T13:18:23.682Z" # Event examples NEW_SESSION_INCOMING: description: |- - Example of `resgitration` events. + Example of `session-invitation` event. A new WebRTC session is requested (i.e. incoming call). This event starts a session negotiation. All other eventes related with this webrtc session will be shared via the session events. - Check example SESSION_UPDATE + Main point to distinguish between a *new session* and an update over + an *existing session* is the type. A `session-invitation` is described + here with all information required to initiate a new voice-video call. value: id: "VzYQCOClM6Kc7Xmyq7mP58Jx" source: https://notificationServer.opentelco.com @@ -1355,26 +1365,31 @@ components: time: 2024-11-05T05:40:23.682Z data: subscriptionId: qs15-h556-rt89-1298 - msisdn: "+8801500121121" - regStatus: Registered - sessionRequest: - originator: - username: "tel:+447911123456" - domain: acme.opentelco.com - receiver: - username: "tel:+447911123456" - domain: acme.opentelco.com - subject: "Not defined" - sessionid: 0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EF + originatorAddress: tel:+11234567899 + originatorName: Alice + receiverAddress: tel:+11234998765 + receiverName: Bob + status: Initial + offer: + sdp: "v=0\r\no=- 4576312012535546667 4 IN IP4 127.0.0.1\r\ns=-\r\nt=0 0\r\nm=audio 47510 RTP/SAVPF 102 113\r\nc=IN IP6 2001:e0:410:243a:a344:cee7:7b39:bb1e\r\nb=AS:64\r\na=rtcp:9 IN IP4 0.0.0.0\r\na=candidate:3108871805 1 udp 2122262783 2001:e0:410:243a:a344:cee7:7b39:bb1e 47510 typ host generation 0 network-id 3 network-cost 900\r\na=ice-ufrag:47Nx\r\na=ice-pwd:ln3CttOSkObcQ7A0tYO1LXqy\r\na=ice-options:trickle renomination\r\na=mid:audio\r\na=extmap:2 http://www.ietf.org/id/draft-holmer-rmcat-transport-wide-cc-extensions-01\r\na=sendrecv\r\na=rtcp-mux\r\na=crypto:1 AES_CM_128_HMAC_SHA1_80 inline:ruAnBNYnTJqDVZAIJV59VpQ5DxGI6tMX9h9kkHSz\r\na=rtpmap:102 AMR-WB/16000\r\na=fmtp:102 octet-align=0; mode-set=0,1,2; mode-change-capability=2\r\na=rtpmap:113 telephone-event/16000\r\na=ptime:20\r\n" + clientCorrelator: 79520148-0e79-4bd8-adbf-d04c463de6ba + vvoipSessionId: 0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EF + reason: New subscriber incoming call + sequenceNumber: 1 REGISTRATION_REVOKED: description: |- - Example of `session-invitation` events. + Example of `subscription-ends` events. When a re-registration is requested from server, maybe due administrative token revocation or due any other technical reason. It is expected from the endpoint to re-register. No new sessions will be - delivered to the user endpoint, as the subscription is not valid anymore. + delivered to the user endpoint, as the subscription is not valid + anymore. + + Here, an example of how WebRTC GW will communicate to the client that + the subscription is not valida anymore, detailing on + `terminationDescription` the root cause of the susbcription remove. value: id: "VzYQCOClM6Kc7Xmyq7mP58Jx" source: https://notificationServer.opentelco.com @@ -1383,38 +1398,41 @@ components: datacontenttype: application/json time: 2024-11-05T05:40:23.682Z data: - subscriptionId: 987654321 - msisdn: "+8801500121121" - subscriber: - username: "tel:+447911123456" - domain: acme.opentelco.com - registration: - status: inactive + subscriptionId: qs15-h556-rt89-1298 + terminationReason: NETWORK_TERMINATED + terminationDescription: "SIP re-registration required" SESSION_UPDATE: description: |- - Example of `session` events. + Example of `session-status` events. - Session envents are produced when there is an update on the session - status, due changes on the SDP of both parties and / or on the SIP - session established on the other side of the gateway. + Session status events are produced when there is an update on the + session status, due changes on the signaling status of the call (eg.: + InProgress, Ringing, Proceeding, Connected, Terminated, ...) or due + SDP changes on any involved party. + + This example, presents an SDP update due change on call status (to + Progress) and including answer SDP data. Customer client now, can + establish a voice-video channel and start transmitting and receiving + media. value: id: "VzYQCOClM6Kc7Xmyq7mP58Jx" source: https://notificationServer.opentelco.com - type: org.camaraproject.webrtc-events.registration + type: org.camaraproject.webrtc-events.session-status specversion: "1.0" datacontenttype: application/json time: 2024-11-05T05:40:23.682Z data: - originator: - username: "tel:+447911123456" - domain: acme.opentelco.com - receiver: - username: "tel:+447956781234" - domain: acme.opentelco.com - status: "Proceeding" + subscriptionId: qs15-h556-rt89-1298 + originatorAddress: tel:+11234567899 + originatorName: Alice + receiverAddress: tel:+11234998765 + receiverName: Bob + status: Progress offer: sdp: "v=0\r\no=- 4576312012535546667 4 IN IP4 127.0.0.1\r\ns=-\r\nt=0 0\r\nm=audio 47510 RTP/SAVPF 102 113\r\nc=IN IP6 2001:e0:410:243a:a344:cee7:7b39:bb1e\r\nb=AS:64\r\na=rtcp:9 IN IP4 0.0.0.0\r\na=candidate:3108871805 1 udp 2122262783 2001:e0:410:243a:a344:cee7:7b39:bb1e 47510 typ host generation 0 network-id 3 network-cost 900\r\na=ice-ufrag:47Nx\r\na=ice-pwd:ln3CttOSkObcQ7A0tYO1LXqy\r\na=ice-options:trickle renomination\r\na=mid:audio\r\na=extmap:2 http://www.ietf.org/id/draft-holmer-rmcat-transport-wide-cc-extensions-01\r\na=sendrecv\r\na=rtcp-mux\r\na=crypto:1 AES_CM_128_HMAC_SHA1_80 inline:ruAnBNYnTJqDVZAIJV59VpQ5DxGI6tMX9h9kkHSz\r\na=rtpmap:102 AMR-WB/16000\r\na=fmtp:102 octet-align=0; mode-set=0,1,2; mode-change-capability=2\r\na=rtpmap:113 telephone-event/16000\r\na=ptime:20\r\n" answer: sdp: "v=0\r\no=- 4576312012535546667 4 IN IP4 127.0.0.1\r\ns=-\r\nt=0 0\r\nm=audio 47510 RTP/SAVPF 102 113\r\nc=IN IP6 2001:e0:410:243a:a344:cee7:7b39:bb1e\r\nb=AS:64\r\na=rtcp:9 IN IP4 0.0.0.0\r\na=candidate:3108871805 1 udp 2122262783 2001:e0:410:243a:a344:cee7:7b39:bb1e 47510 typ host generation 0 network-id 3 network-cost 900\r\na=ice-ufrag:47Nx\r\na=ice-pwd:ln3CttOSkObcQ7A0tYO1LXqy\r\na=ice-options:trickle renomination\r\na=mid:audio\r\na=extmap:2 http://www.ietf.org/id/draft-holmer-rmcat-transport-wide-cc-extensions-01\r\na=sendrecv\r\na=rtcp-mux\r\na=crypto:1 AES_CM_128_HMAC_SHA1_80 inline:ruAnBNYnTJqDVZAIJV59VpQ5DxGI6tMX9h9kkHSz\r\na=rtpmap:102 AMR-WB/16000\r\na=fmtp:102 octet-align=0; mode-set=0,1,2; mode-change-capability=2\r\na=rtpmap:113 telephone-event/16000\r\na=ptime:20\r\n" - clientCorrelator: fda6e26d-e7c8-4596-870c-c083c0d39b2c + clientCorrelator: 79520148-0e79-4bd8-adbf-d04c463de6ba vvoipSessionId: 0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EF + reason: Answer SDP update + sequenceNumber: 3 From 5a736e27dd7e2738a7f777ad7ea0b63cc6a705d4 Mon Sep 17 00:00:00 2001 From: Santiago Troncoso Date: Tue, 10 Dec 2024 11:33:28 +0100 Subject: [PATCH 08/10] fix(webrtc-events): Examples, descriptions, linter and commonalities - Change event types to include API version v0 - Reviewed descriptions for requests and examples - Resolved linter errors - Uniform schemas: Event_sufix and vvoipSessionInformation - Improved type definitions for VvoipSesisonId --- code/API_definitions/BYON-Webrtc-Events.yaml | 218 ++++++++++--------- 1 file changed, 118 insertions(+), 100 deletions(-) diff --git a/code/API_definitions/BYON-Webrtc-Events.yaml b/code/API_definitions/BYON-Webrtc-Events.yaml index a724a1b..b118ff0 100644 --- a/code/API_definitions/BYON-Webrtc-Events.yaml +++ b/code/API_definitions/BYON-Webrtc-Events.yaml @@ -61,17 +61,17 @@ info: Following event types are managed for this API: - - `org.camaraproject.webrtc-events.session-status` + - `org.camaraproject.webrtc-events.v0.session-status` - Events triggered for any media session related event (e.g. far end new media endpoints) - - `org.camaraproject.webrtc-events.session-invitation` + - `org.camaraproject.webrtc-events.v0.session-invitation` - Events triggered when a new session is requested (e.g. incoming call received) - Note: Additionally to these list, ``org.camaraproject.webrtc-events.subscription-ends`` + Note: Additionally to these list, ``org.camaraproject.webrtc-events.v0.subscription-ends`` notification `type` is sent when the subscription ends. This notification does not require dedicated subscription. @@ -89,10 +89,10 @@ info: Find more information at the Schema description. - A `org.camaraproject.webrtc-events.session-status` event includes + A `org.camaraproject.webrtc-events.v0.session-status` event includes session information updates. With the same schema that is used with the WebRTC BYON CallHandling API, when retrieving information from the - `GET /vvoip/session/{vvoipSessionID}` endpoint. + `GET /vvoip/session/{vvoipSessionId}` endpoint. In general lines, it is emitted each time that an event happens within the subscribed session. This might happen when SDP updates are included for any @@ -115,7 +115,7 @@ info: Find more information at the Schema description. - A `org.camaraproject.webrtc-events.session-invitation` event + A `org.camaraproject.webrtc-events.v0.session-invitation` event includes information about new requested sessions (incoming calls), it requires a valid registration on the network. @@ -133,7 +133,7 @@ info: ### 3.3. Subscription ends (subscription-ends) - A `org.camaraproject.webrtc-events.subscription-ends` event will indicate + A `org.camaraproject.webrtc-events.v0.subscription-ends` event will indicate that the endpoint will not be notified if a new session is received. From the developer point of view the reception of the `subscription-ends` should be an indicator to check the registration status and try to register again. @@ -172,7 +172,7 @@ externalDocs: description: Product documentation at CAMARA url: https://github.com/camaraproject/ servers: - - url: "{apiRoot}/webrtc-events/vwip" + - url: "{apiRoot}/webrtc-events/v0" variables: apiRoot: default: http://localhost:9091 @@ -187,23 +187,36 @@ paths: tags: - webrtc-events Subscription summary: "Create a webrtc-events event subscription" - description: Create a webrtc-events event subscription. For the corresponding type, `session` or `registration`. + description: |- + Create a webrtc-events event subscription. For the corresponding type: + + - `org.camaraproject.webrtc-events.v0.session-invitation`: new calls event + - `org.camaraproject.webrtc-events.v0.session-status`: updates on specific call + + To subscribe and receive notifications about new calls, a + `session-invitation` subscription is required using the `racmSessionId` + obtained from BYON-RACM API. + + Once you create a new voice-video session or receive an + new call event, you can subscribe to `session-status` to receive + updates about the voice-video session in progress using the + `vvoipSessionId` unique identifier. operationId: createNotificationChannelSubscription parameters: - $ref: "#/components/parameters/x-correlator" security: - openId: - - webrtc-events:org.camaraproject.webrtc-events.session-status:create - - webrtc-events:org.camaraproject.webrtc-events.session-invitation:create + - webrtc-events:org.camaraproject.webrtc-events.v0.session-status:create + - webrtc-events:org.camaraproject.webrtc-events.v0.session-invitation:create requestBody: content: application/json: schema: $ref: "#/components/schemas/SubscriptionRequest" examples: - REGISTRATION_SUBSCRIPTION: - $ref: "#/components/examples/REGISTRATION_SUBSCRIPTION" - SESSION_SUBSCRIPTION: + INVITE_SUBSCRIPTION (session-invitation): + $ref: "#/components/examples/INVITE_SUBSCRIPTION" + SESSION_SUBSCRIPTION (session-status): $ref: "#/components/examples/SESSION_SUBSCRIPTION" required: true callbacks: @@ -226,12 +239,12 @@ paths: schema: $ref: "#/components/schemas/CloudEvent" examples: - NEW_SESSION_INCOMING: + NEW_SESSION_INCOMING (session-invitation): $ref: "#/components/examples/NEW_SESSION_INCOMING" - REGISTRATION_REVOKED: - $ref: "#/components/examples/REGISTRATION_REVOKED" - SESSION_UPDATE: + SESSION_UPDATE (session-status): $ref: "#/components/examples/SESSION_UPDATE" + REGISTRATION_REVOKED (subscription-ends): + $ref: "#/components/examples/REGISTRATION_REVOKED" responses: "204": description: Successful notification @@ -615,9 +628,9 @@ components: WebrtcSubscriptionDetail: description: |- The detail of the requested event subscription. - - org.camaraproject.webrtc-events.session-invitation requires a + - org.camaraproject.webrtc-events.v0.session-invitation requires a valid `racmSessionId` obtained via RACM endpoint. - - org.camaraproject.webrtc-events.session-status requires both, a + - org.camaraproject.webrtc-events.v0.session-status requires both, a valid `racmSessionId` obtained via RACM endpoint and a valid `sessionId` obtained via session-invitation event or via CallHandling API @@ -649,30 +662,30 @@ components: type: string description: |- event-type - Event triggered when an event-type event occurred - - `org.camaraproject.webrtc-events.session-status` + - `org.camaraproject.webrtc-events.v0.session-status` - Events triggered for any media session related event (e.g. far end new media endpoints) - - `org.camaraproject.webrtc-events.session-invitation` + - `org.camaraproject.webrtc-events.v0.session-invitation` - Events triggered for any media endpoint registration event (e.g. incoming session) `subscription-ends` is not supported for subscription. Sent by default enum: - - org.camaraproject.webrtc-events.session-status - - org.camaraproject.webrtc-events.session-invitation + - org.camaraproject.webrtc-events.v0.session-status + - org.camaraproject.webrtc-events.v0.session-invitation EventTypeNotification: type: string description: |- event-type - Event triggered when an event-type event occurred - - `org.camaraproject.webrtc-events.session-status` + - `org.camaraproject.webrtc-events.v0.session-status` - Events triggered for any media session related event (e.g. far end new media endpoints) - - `org.camaraproject.webrtc-events.session-invitation` + - `org.camaraproject.webrtc-events.v0.session-invitation` - Events triggered for any media endpoint registration event (e.g. incoming session) - - `org.camaraproject.webrtc-events.subscription-ends` + - `org.camaraproject.webrtc-events.v0.subscription-ends` - Event triggered when the subscription ends enum: - - org.camaraproject.webrtc-events.session-status - - org.camaraproject.webrtc-events.session-invitation - - org.camaraproject.webrtc-events.subscription-ends + - org.camaraproject.webrtc-events.v0.session-status + - org.camaraproject.webrtc-events.v0.session-invitation + - org.camaraproject.webrtc-events.v0.subscription-ends Subscription: description: Represents a event-type subscription. @@ -775,10 +788,6 @@ components: - application/json data: type: object - oneOf: - - $ref: "#/components/schemas/SessionInvitationEvent" - - $ref: "#/components/schemas/SessionStatusEvent" - - $ref: "#/components/schemas/SubscriptionEnds" description: |- Event details payload. Depending of the event type, it will will include one of the data structures defined on this specification. Along with the subscription-ends, that is an authomatic event. @@ -788,9 +797,9 @@ components: discriminator: propertyName: "type" mapping: - org.camaraproject.api-name.v0.resgistration: "#/components/schemas/SessionInvitationEvent" - org.camaraproject.api-name.v0.session: "#/components/schemas/SessionStatusEvent" - org.camaraproject.api-name.v0.subscription-ends: "#/components/schemas/EventSubscriptionEnds" + org.camaraproject.webrtc-events.v0.session-invitation: "#/components/schemas/EventSessionInvitation" + org.camaraproject.webrtc-events.v0.session-status: "#/components/schemas/EventSessionStatus" + org.camaraproject.webrtc-events.v0.subscription-ends: "#/components/schemas/EventSubscriptionEnds" Source: type: string @@ -814,39 +823,49 @@ components: description: Timestamp of when the occurrence happened. Must adhere to RFC 3339. example: "2018-04-05T17:31:00Z" - SessionInvitationEvent: + ############################################ + EventSessionInvitation: description: |- - A `org.camaraproject.webrtc-events.session-invitation` event includes an specific type of session + A `org.camaraproject.webrtc-events.v0.session-invitation` event includes an specific type of session update for new requested sessions. It is emitted when the endpoint is associated with a valid registration and the endpoint is susbcribed to recive new incoming calls. This event includes all the context information: caller, callee and possible carrier data to contextualize (call subject, branding info, etc). It MUST include a vvoipSessionId, to allow the endpoint to subscribe to this new call session. - allOf: + - $ref: "#/components/schemas/CloudEvent" - type: object - - $ref: '#/components/schemas/SessionEvent' + required: + - vvoipSessionId + properties: + data: + $ref: "#/components/schemas/VvoipSessionInformation" - SessionStatusEvent: + ############################################ + EventSessionStatus: description: |- - A `org.camaraproject.webrtc-events.session-status` event includes the session updates provided by + A `org.camaraproject.webrtc-events.v0.session-status` event includes the session updates provided by the server. This will include actions form the endpoint and the server (far end). In general terms, it is received each time that an event happens within the session, and include all relevant info about the session update. Most common use is for SDP updates and signaling updates regarding call status. - allOf: + - $ref: "#/components/schemas/CloudEvent" - type: object - - $ref: '#/components/schemas/SessionEvent' + required: + - vvoipSessionId + - status + properties: + data: + $ref: "#/components/schemas/VvoipSessionInformation" - SessionEvent: + ############################################ + VvoipSessionInformation: description: |- A prototype for Webrtc events. Used at `SessionStatusEvent` and `SessionInvitationEvent` schemas - required: - - vvoipSessionId type: object properties: subscriptionId: @@ -892,29 +911,30 @@ components: - NotReachable - Busy offer: - # allOf: - # - description: SDP descriptor (RFC4566) for call originator - # - $ref: '#/components/schemas/WrtcSDPDescriptor' $ref: '#/components/schemas/WrtcSDPDescriptor' answer: - # description: SDP descriptor (RFC4566) for call terminator $ref: '#/components/schemas/WrtcSDPDescriptor' clientCorrelator: type: string description: A correlator that the client can use to tag this particular resource representation during a request to create a resource on the server. Note - This allows the client to recover from communication failures during resource creation and therefore avoids re-sending the message in such situations. In case the element is present, the WebRTC GW shall not alter its value, and shall provide it as part of the representation of this resource. vvoipSessionId: type: string - description: The VVOIP session ID created by WebRTC Gateway. The vvoipSessionID shall not be included in POST requests by the client, but must be included in the notifications from the WebRTC GW to client. - example: 0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EF + description: The VVOIP session ID created by WebRTC Gateway. The vvoipSessionId shall not be included in POST requests by the client, but must be included in the notifications from the WebRTC GW to client. + example: '0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EF' callObjectRef: + type: string description: The reference to the call object serverCorrelator: + type: string description: A correlator that the server instructs the client to use for end to end correlation. offerRequired: + type: boolean description: This element shall be included and set to true, if the session updates are received without SDP offer. This element indicates clients to send the offer. reason: + type: string description: The description of the event that has happened within the session sequenceNumber: + type: integer description: The sequence number of the notification sent to client WrtcSDPDescriptor: @@ -1291,13 +1311,14 @@ components: message: "Expected property is missing: subscriptionId" examples: # Subscription examples - REGISTRATION_SUBSCRIPTION: + INVITE_SUBSCRIPTION: description: |- - A sample of WebRTC **registration** subscription for phone number + A sample of WebRTC `session-invitation` subscription for phone number `+1234567890` at `acme.opentelco.com`. This will be used to receive incoming sessions (incoming - calls) and to be aware of registration status updates from the server. + calls). The implicit subscription to `subscription-ends` will make + the client aware of registration status updates from the server. (i.e. when a REGISTRATION expires). The provided example will be able to receive up to 50 calls until @@ -1310,7 +1331,7 @@ components: protocol: HTTP sink: https://notificationServer.opentelco.com types: - - org.camaraproject.webrtc-events.session-invitation + - org.camaraproject.webrtc-events.v0.session-invitation config: subscriptionDetail: deviceId: "1qazxsw23edc" @@ -1320,26 +1341,23 @@ components: subscriptionExpireTime: "2024-11-17T13:18:23.682Z" SESSION_SUBSCRIPTION: description: |- - A sample of WebRTC **session** subscription for transactionId - `gnCGil25Wg7cm2vi` where phone number - `+1234567890` at `acme.opentelco.com` domain is involved. - - Identified by for phone number, domain and transactionId, the endpoint - is able to interact with its own live session. This could be used to - remotely control de call or to handle the async session establishment - procedure by the endpoint itself. + A sample of WebRTC `session-status` subscription for a specific + `vvoipSessionId` at `acme.opentelco.com`. + + Identified by for `vvoipSessionId`, and validated via a `racmSessionId` + the endpoint is able to interact with its own voice-video session. + This could be used to remotely control the call or to handle the async + session establishment. For instance, updating the user interface for + different statuses: InProgress, Ringing, Cancel, etc. value: protocol: HTTP sink: https://notificationServer.opentelco.com types: - - org.camaraproject.webrtc-events.session-status + - org.camaraproject.webrtc-events.v0.session-status config: subscriptionDetail: deviceId: "1qazxsw23edc" racmSessionId: "xsmcaum3z4zw4l0cu4w115m0" - subscriber: - address: "tel:+447911123456" - name: Jonh Doe vvoipSessionId: 0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EF initialEvent: true subscriptionMaxEvents: 50 @@ -1350,33 +1368,33 @@ components: Example of `session-invitation` event. A new WebRTC session is requested (i.e. incoming call). This event - starts a session negotiation. All other eventes related with this - webrtc session will be shared via the session events. + starts a session negotiation. All other events related with this + webrtc session will be shared via the `session-status` events, and + identified via the unique `vvoipSessionId`. - Main point to distinguish between a *new session* and an update over - an *existing session* is the type. A `session-invitation` is described - here with all information required to initiate a new voice-video call. + The main point to distinguish between a *new session* and an update over + an *existing session* is the **type**. A `session-invitation` describes + on its content, all information required to initiate a new voice-video call. value: id: "VzYQCOClM6Kc7Xmyq7mP58Jx" source: https://notificationServer.opentelco.com - type: org.camaraproject.webrtc-events.session-invitation + type: org.camaraproject.webrtc-events.v0.session-invitation specversion: "1.0" datacontenttype: application/json time: 2024-11-05T05:40:23.682Z data: - subscriptionId: qs15-h556-rt89-1298 - originatorAddress: tel:+11234567899 - originatorName: Alice - receiverAddress: tel:+11234998765 - receiverName: Bob - status: Initial + subscriptionId: "qs15-h556-rt89-1298" + originatorAddress: "tel:+11234567899" + originatorName: "Alice" + receiverAddress: "tel:+11234998765" + receiverName: "Bob" + status: "Initial" offer: - sdp: "v=0\r\no=- 4576312012535546667 4 IN IP4 127.0.0.1\r\ns=-\r\nt=0 0\r\nm=audio 47510 RTP/SAVPF 102 113\r\nc=IN IP6 2001:e0:410:243a:a344:cee7:7b39:bb1e\r\nb=AS:64\r\na=rtcp:9 IN IP4 0.0.0.0\r\na=candidate:3108871805 1 udp 2122262783 2001:e0:410:243a:a344:cee7:7b39:bb1e 47510 typ host generation 0 network-id 3 network-cost 900\r\na=ice-ufrag:47Nx\r\na=ice-pwd:ln3CttOSkObcQ7A0tYO1LXqy\r\na=ice-options:trickle renomination\r\na=mid:audio\r\na=extmap:2 http://www.ietf.org/id/draft-holmer-rmcat-transport-wide-cc-extensions-01\r\na=sendrecv\r\na=rtcp-mux\r\na=crypto:1 AES_CM_128_HMAC_SHA1_80 inline:ruAnBNYnTJqDVZAIJV59VpQ5DxGI6tMX9h9kkHSz\r\na=rtpmap:102 AMR-WB/16000\r\na=fmtp:102 octet-align=0; mode-set=0,1,2; mode-change-capability=2\r\na=rtpmap:113 telephone-event/16000\r\na=ptime:20\r\n" - clientCorrelator: 79520148-0e79-4bd8-adbf-d04c463de6ba - vvoipSessionId: 0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EF - reason: New subscriber incoming call + sdp: "v=0\r\no=- 4576312012535546667 4 IN IP4 127.0.0.1\r\ns=-\r\nt=0" + clientCorrelator: "79520148-0e79-4bd8-adbf-d04c463de6ba" + vvoipSessionId: "0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EF" + reason: "New subscriber incoming call" sequenceNumber: 1 - REGISTRATION_REVOKED: description: |- Example of `subscription-ends` events. @@ -1388,12 +1406,12 @@ components: anymore. Here, an example of how WebRTC GW will communicate to the client that - the subscription is not valida anymore, detailing on - `terminationDescription` the root cause of the susbcription remove. + the subscription is not valid anymore, detailing on + `terminationDescription` the root cause of the subscription remove. value: id: "VzYQCOClM6Kc7Xmyq7mP58Jx" source: https://notificationServer.opentelco.com - type: org.camaraproject.webrtc-events.session-invitation + type: org.camaraproject.webrtc-events.v0.subscription-ends specversion: "1.0" datacontenttype: application/json time: 2024-11-05T05:40:23.682Z @@ -1417,22 +1435,22 @@ components: value: id: "VzYQCOClM6Kc7Xmyq7mP58Jx" source: https://notificationServer.opentelco.com - type: org.camaraproject.webrtc-events.session-status + type: org.camaraproject.webrtc-events.v0.session-status specversion: "1.0" datacontenttype: application/json time: 2024-11-05T05:40:23.682Z data: - subscriptionId: qs15-h556-rt89-1298 - originatorAddress: tel:+11234567899 - originatorName: Alice - receiverAddress: tel:+11234998765 - receiverName: Bob - status: Progress + subscriptionId: "qs15-h556-rt89-1298" + originatorAddress: "tel:+11234567899" + originatorName: "Alice" + receiverAddress: "tel:+11234998765" + receiverName: "Bob" + status: InProgress offer: sdp: "v=0\r\no=- 4576312012535546667 4 IN IP4 127.0.0.1\r\ns=-\r\nt=0 0\r\nm=audio 47510 RTP/SAVPF 102 113\r\nc=IN IP6 2001:e0:410:243a:a344:cee7:7b39:bb1e\r\nb=AS:64\r\na=rtcp:9 IN IP4 0.0.0.0\r\na=candidate:3108871805 1 udp 2122262783 2001:e0:410:243a:a344:cee7:7b39:bb1e 47510 typ host generation 0 network-id 3 network-cost 900\r\na=ice-ufrag:47Nx\r\na=ice-pwd:ln3CttOSkObcQ7A0tYO1LXqy\r\na=ice-options:trickle renomination\r\na=mid:audio\r\na=extmap:2 http://www.ietf.org/id/draft-holmer-rmcat-transport-wide-cc-extensions-01\r\na=sendrecv\r\na=rtcp-mux\r\na=crypto:1 AES_CM_128_HMAC_SHA1_80 inline:ruAnBNYnTJqDVZAIJV59VpQ5DxGI6tMX9h9kkHSz\r\na=rtpmap:102 AMR-WB/16000\r\na=fmtp:102 octet-align=0; mode-set=0,1,2; mode-change-capability=2\r\na=rtpmap:113 telephone-event/16000\r\na=ptime:20\r\n" answer: sdp: "v=0\r\no=- 4576312012535546667 4 IN IP4 127.0.0.1\r\ns=-\r\nt=0 0\r\nm=audio 47510 RTP/SAVPF 102 113\r\nc=IN IP6 2001:e0:410:243a:a344:cee7:7b39:bb1e\r\nb=AS:64\r\na=rtcp:9 IN IP4 0.0.0.0\r\na=candidate:3108871805 1 udp 2122262783 2001:e0:410:243a:a344:cee7:7b39:bb1e 47510 typ host generation 0 network-id 3 network-cost 900\r\na=ice-ufrag:47Nx\r\na=ice-pwd:ln3CttOSkObcQ7A0tYO1LXqy\r\na=ice-options:trickle renomination\r\na=mid:audio\r\na=extmap:2 http://www.ietf.org/id/draft-holmer-rmcat-transport-wide-cc-extensions-01\r\na=sendrecv\r\na=rtcp-mux\r\na=crypto:1 AES_CM_128_HMAC_SHA1_80 inline:ruAnBNYnTJqDVZAIJV59VpQ5DxGI6tMX9h9kkHSz\r\na=rtpmap:102 AMR-WB/16000\r\na=fmtp:102 octet-align=0; mode-set=0,1,2; mode-change-capability=2\r\na=rtpmap:113 telephone-event/16000\r\na=ptime:20\r\n" - clientCorrelator: 79520148-0e79-4bd8-adbf-d04c463de6ba - vvoipSessionId: 0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EF - reason: Answer SDP update + clientCorrelator: "79520148-0e79-4bd8-adbf-d04c463de6ba" + vvoipSessionId: "0AEE1B58BAEEDA3EABA42B32EBB3DFE07E9CFF402EAF9EED8EF" + reason: "Answer SDP update" sequenceNumber: 3 From 93a4bcf6f12c8fa4792f9be936cffe28c7e06d5b Mon Sep 17 00:00:00 2001 From: Santiago Troncoso Date: Tue, 24 Dec 2024 09:53:04 +0100 Subject: [PATCH 09/10] fix(webrtc-events): Comms review and comments - Server path to vwip - Permissions read/delete naming for security.openId fixed - CredentialType limited to ACCESSTOKEN --- code/API_definitions/BYON-Webrtc-Events.yaml | 14 ++++++-------- 1 file changed, 6 insertions(+), 8 deletions(-) diff --git a/code/API_definitions/BYON-Webrtc-Events.yaml b/code/API_definitions/BYON-Webrtc-Events.yaml index b118ff0..dc77af6 100644 --- a/code/API_definitions/BYON-Webrtc-Events.yaml +++ b/code/API_definitions/BYON-Webrtc-Events.yaml @@ -172,7 +172,7 @@ externalDocs: description: Product documentation at CAMARA url: https://github.com/camaraproject/ servers: - - url: "{apiRoot}/webrtc-events/v0" + - url: "{apiRoot}/webrtc-events/vwip" variables: apiRoot: default: http://localhost:9091 @@ -316,7 +316,7 @@ paths: - $ref: "#/components/parameters/x-correlator" security: - openId: - - api-name:read + - webrtc-events:read responses: "200": description: List of event subscription details @@ -349,7 +349,7 @@ paths: operationId: retrieveNotificationChannelSubscription security: - openId: - - api-name:read + - webrtc-events:read parameters: - $ref: "#/components/parameters/SubscriptionId" - $ref: "#/components/parameters/x-correlator" @@ -383,7 +383,7 @@ paths: description: delete a given webrtc-events subscription. security: - openId: - - api-name:delete + - webrtc-events:delete parameters: - $ref: "#/components/parameters/SubscriptionId" - $ref: "#/components/parameters/x-correlator" @@ -541,9 +541,7 @@ components: credentialType: type: string enum: - - PLAIN - ACCESSTOKEN - - REFRESHTOKEN description: "The type of the credential." discriminator: propertyName: credentialType @@ -709,8 +707,8 @@ components: types: description: |- Camara Event types eligible to be delivered by this subscription. - Note: for the Commonalities meta-release v0.4 we enforce to have only event type per subscription then for following meta-release use of array MUST be decided - at API project level. + For Commonalities v0.4 we enforce to use one subscription per event type. In consequence, + this field is an array of a single element. type: array minItems: 1 maxItems: 1 From 284e4bfa5c37894e5ae7b027172affc5169e07b0 Mon Sep 17 00:00:00 2001 From: Santiago Troncoso Date: Mon, 30 Dec 2024 10:12:19 +0100 Subject: [PATCH 10/10] fix(webrtc-events): Cleanup schema for exclusive accestoken credential type Co-authored-by: tsuyoshi takakura --- code/API_definitions/BYON-Webrtc-Events.yaml | 50 -------------------- 1 file changed, 50 deletions(-) diff --git a/code/API_definitions/BYON-Webrtc-Events.yaml b/code/API_definitions/BYON-Webrtc-Events.yaml index dc77af6..9ad312c 100644 --- a/code/API_definitions/BYON-Webrtc-Events.yaml +++ b/code/API_definitions/BYON-Webrtc-Events.yaml @@ -546,27 +546,9 @@ components: discriminator: propertyName: credentialType mapping: - PLAIN: "#/components/schemas/PlainCredential" ACCESSTOKEN: "#/components/schemas/AccessTokenCredential" - REFRESHTOKEN: "#/components/schemas/RefreshTokenCredential" required: - credentialType - PlainCredential: - type: object - description: A plain credential as a combination of an identifier and a secret. - allOf: - - $ref: "#/components/schemas/SinkCredential" - - type: object - required: - - identifier - - secret - properties: - identifier: - description: The identifier might be an account or username. - type: string - secret: - description: The secret might be a password or passphrase. - type: string AccessTokenCredential: type: object description: An access token credential. @@ -590,38 +572,6 @@ components: - accessToken - accessTokenExpiresUtc - accessTokenType - RefreshTokenCredential: - type: object - description: An access token credential with a refresh token. - allOf: - - $ref: "#/components/schemas/SinkCredential" - - type: object - properties: - accessToken: - description: REQUIRED. An access token is a previously acquired token granting access to the target resource. - type: string - accessTokenExpiresUtc: - type: string - format: date-time - description: REQUIRED. An absolute UTC instant at which the token shall be considered expired. - accessTokenType: - description: REQUIRED. Type of the access token (See [OAuth 2.0](https://tools.ietf.org/html/rfc6749#section-7.1)). - type: string - enum: - - bearer - refreshToken: - description: REQUIRED. An refresh token credential used to acquire access tokens. - type: string - refreshTokenEndpoint: - type: string - format: uri - description: REQUIRED. A URL at which the refresh token can be traded for an access token. - required: - - accessToken - - accessTokenExpiresUtc - - accessTokenType - - refreshToken - - refreshTokenEndpoint WebrtcSubscriptionDetail: description: |-