Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Notification compliance #53

Open
wants to merge 10 commits into
base: main
Choose a base branch
from

Conversation

stroncoso-quobis
Copy link
Collaborator

@stroncoso-quobis stroncoso-quobis commented Oct 24, 2024

What type of PR is this?

Add one of the following kinds:

  • enhancement/feature

What this PR does / why we need it:

This PR is needed to have an event notification system compliant with the CAMARA framework and also to grant async event communications that are inherent for the WebRTC call use cases.

Which issue(s) this PR fixes:

Fixes #15

Special notes for reviewers:

n/a

Changelog input

 release-note
- Fix notification system granting explicit subscription for sessions and registrations.
- Updated UML documentation
- Included callback for Registration and Session handling

Additional documentation

UML must be updated within this PR.
A dedicated websocket use case must be explained on Conlfuence or at supporting documentation

@stroncoso-quobis stroncoso-quobis force-pushed the feat/notification-service branch from e83fc8a to 72d67fa Compare October 25, 2024 16:53
@stroncoso-quobis
Copy link
Collaborator Author

Hi team,

Good news, PR is ready for a first review.

Main elements to consider:

  • API works based on two kind of susbcriptions: registration and session. One is designed to keep the device reachable, and the other to track a session in progress.
  • regsitration
    • Event when the network requires to refresh register
    • Event when a new session is requested (incoming call)
  • session
    • Event to update and define participants on the call
    • Event to update session status (ringing, progressing, accepting, cancel, cleared, …)
    • Event to update SDP information (new candidates, network updates, track bw update, ...)

Use a Swagger rendered view appending https://editor.swagger.io/?url= to the RAW commint file.

The file is big, I know, so I will track your attention to:

  • Initial description, check texts and provide comments about general approach
  • SubscriptionRequest schema: It is the payload for a new subscription
    • registration event subscription requires a the subscriber information, while session event subscription requires both, the user information and the sessionId to subscribe to.
    • Have in mind that, per CloudEvents+CAMARA specs, our WebRTC details are included into SubscriptionDetail that is included into config.
  • CloudEvent schema: It is the payload of the event received for any case
    • Our WebRTC relevant information is placed into the data property that could be one of the two possible events: EventRegistration and EventSession.
    • The SubscriptionEnds event is a CAMARA requirement
  • EventRegistration schema: Brand new object
    • To inform about re-registration or a new incomming session.
    • Tries to map to the BYON-RACM session info, but including an optional new session structure (call incoming)
    • Included a hook for future branded calls with a subject field
  • EventSession: Event about session updates
    • It is mapped to the vvoipSessionInformation schema of the BYON-CallHandling API
    • Tries to unify a couple of duplicated schemas like the SubscriberUser info or the SDP descriptor

Please, @deepakjaiswal1 , share with your team and provide some feedback, while I clean the linter errors and try to create some documentation for this update (workflows are not valida anymore) and document some bugs detected on other files.

Best regards,

@stroncoso-quobis stroncoso-quobis marked this pull request as ready for review November 8, 2024 18:40
@stroncoso-quobis stroncoso-quobis force-pushed the feat/notification-service branch from 682eba7 to eae43b7 Compare November 12, 2024 11:46
@stroncoso-quobis
Copy link
Collaborator Author

Hi all,

An update about today's commit. I fixed all linter errors and also reviewed the examples for a better comprehension of the events. Reviewing the examples, I found that sessionId was missing on the new_session_event, so I included it as part of the EventRegistration / sessionRequest . Without it, it is not possible to grant a valid suscription for session events.

Waiting for comments and reviews

@rartych
Copy link
Collaborator

rartych commented Nov 19, 2024

According to https://github.com/camaraproject/Commonalities/blob/main/documentation/API-design-guidelines.md#resource-based-explicit-subscription

type must follow the format: org.camaraproject... with the api-version with letter v and the major version

Then the event types should be like (with v0 inserted):
org.camaraproject.webrtc-events.v0.session
org.camaraproject.webrtc-events.v0.registration

@stroncoso-quobis stroncoso-quobis force-pushed the feat/notification-service branch from e22fd79 to a65545d Compare November 19, 2024 14:56
- Renamed event types
- Removed atomic schemas
- Reviewed descriptions
@stroncoso-quobis stroncoso-quobis force-pushed the feat/notification-service branch from 2be6276 to b2ecfd3 Compare December 3, 2024 14:39
@stroncoso-quobis stroncoso-quobis force-pushed the feat/notification-service branch from a89a07c to db6cd15 Compare December 9, 2024 11:15
- 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
@stroncoso-quobis
Copy link
Collaborator Author

Hi team,

Big update following latest meeting agreements:

  • Commonalities:
    • Added v0 to type events
    • Solved linter errors abstracting the class of data object for CloudEvents (removed oneOf)
    • Uniform schema naming: EventSessionStatus, EventSessionInvitation and EventSubscriptionEnds
  • Voice video info:
    • Renamed the data content of API-specific events to VvoipSessionInformation to grant same naming for all three APIs: RACM, CallHandling and webrtc-events
    • Description and examples reviews to fit schemas and describe actions in progress

Please, @rartych and @deepakjaiswal1 , if you can review and approve or provide comments it will be great.
Any other group participant, feel free to provide feedback.

Best regards,

@stroncoso-quobis stroncoso-quobis self-assigned this Dec 11, 2024
- Server path to vwip
- Permissions read/delete naming for security.openId fixed
- CredentialType limited to ACCESSTOKEN
@stroncoso-quobis
Copy link
Collaborator Author

So, all threads resolved, and reviews done as requested during the last bi-weekly.
Please, review and approve in order to proceed to launch release PR.

Best regards,

@stroncoso-quobis
Copy link
Collaborator Author

stroncoso-quobis commented Jan 9, 2025

Hi team,
Looking for a formal approval about this PR. We need to launch the release PR prior to 17th January and since we are all agree on this API proposition, we need to get an approval to continue with the other minor fixes:

  • Comms v0.5
  • API rename

@sushanthmavenir , @pradeepachar-mavenir , @hdamker

Thanks in advance

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Notify Event must be define on callback part in the same openapi spec
4 participants