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

Add notifications API specs #169

Merged
merged 45 commits into from
Mar 24, 2024

Conversation

spapadop
Copy link
Contributor

Description

Currently notifications API specs are missing, along with a number of others, as described at #168.
This PR will cover the gap for the notifications API.
Note: I know the PR is not complete as it does not cover all notifications API calls yet, just wanted to get an initial feedback to ensure I'm on the right path. And couple of questions:

  1. Should the "model/notifications" folder that I am adding rather be placed under model/_plugins/notifications so that future missing API specs end up within model/_plugins too?

  2. Shall I also update the OpenSearch.openapi.json accordingly, or is there an automation to take care of that?

Issues Resolved

By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.
For more information on following Developer Certificate of Origin and signing off your commits, please check here.

@dblock
Copy link
Member

dblock commented Dec 21, 2023

@nhtruong take a look?

@nhtruong
Copy link
Collaborator

nhtruong commented Dec 21, 2023

Thanks @spapadop. To answer your questions:

  1. putting it in model/notifications is exactly what we want IF this plugin has become a core feature of Opensearch. That's what we did with the security plugin.
  2. The OpenAPI file will be updated automatically by a follow-up PR.

One thing to note about the xOperationGroup. It serves 2 purposes:

  • Grouping operations with identical functionality. For example the search API action is comprised of 4 operations. Notice how they all have identical @documentation?
  • It dictates the namespace and the API method name on the clients. For example, indices.create will result in client.indices.create() in the clients.

For the vast majority of API actions, like those in the notifications plugin, there's only 1 Operation per action. The 2 operations in your operations.smithy file should belong to 2 different OperationGroups (say notifications.get_configs and notification.create_config) and should be put in separate locations (model/notifications/get_configs/ and model/notifications/create_config)

The reference should also use anchor to pinpoint the location of the API doc on the page:
That is, use https://opensearch.org/docs/latest/observing-your-data/notifications/api/#list-all-notification-configurations
instead of https://opensearch.org/docs/latest/observing-your-data/notifications/api/

I'll update the DEVELOPER_GUIDE to make it more clear.

@spapadop
Copy link
Contributor Author

Hi @nhtruong, many thanks for all the input and sorry for the late answer (long break for me), it's more clear now! I'll continue work on this one and come back to you asap.

I see Notifications is documented under "Observability", so it rather feels more like it should go under _plugins folder, which will later include the majority of things mentioned here. Let me know if you have any objections, else I'll go ahead with that structure.

@nhtruong
Copy link
Collaborator

Is notifications gonna be a part of the core client. If so, it should be in the notifications namespace so that a call to one of its endpoint from the client will look like this client.notifications.create_channel.

@dblock what do we do with plugins?

@spapadop
Copy link
Contributor Author

spapadop commented Jan 11, 2024

I believe it's not gonna be part of the core client. Notifications API is not worked yet in the python client, but seeing that there is a plugins folder there, already containing alerting and index_management, I'd guess notifications also belongs there. So the endpoint from the client will look like this client.plugins.notifications.create_channel.

But I'll let @dblock confirm.

@spapadop spapadop force-pushed the enhancement/notificationsapi branch from b3d34bd to 5f8572e Compare January 12, 2024 13:02
Sokratis Papadopoulos added 12 commits January 12, 2024 15:40
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
This reverts commit b4c3f11.

Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
@spapadop spapadop force-pushed the enhancement/notificationsapi branch from 78a1eb3 to a9c0251 Compare January 12, 2024 14:40
Sokratis Papadopoulos added 2 commits January 12, 2024 15:48
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
remove name field from NotificationsConfig

Co-authored-by: Thomas Farr <xtansia@xtansia.com>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadop@gmail.com>
Sokratis Papadopoulos added 13 commits March 8, 2024 16:56
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
…nConfigType

Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadopoulos@cern.ch>
@spapadop spapadop requested a review from Xtansia March 17, 2024 15:39
@Xtansia
Copy link
Collaborator

Xtansia commented Mar 21, 2024

@spapadop Thanks for making those changes, just a couple minor things left to fix and please also rebase your branch onto the latest main so that the API Coverage workflow can pass.

spapadop and others added 3 commits March 22, 2024 10:28
Co-authored-by: Thomas Farr <xtansia@xtansia.com>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadop@gmail.com>
Co-authored-by: Thomas Farr <xtansia@xtansia.com>
Signed-off-by: Sokratis Papadopoulos <sokratis.papadop@gmail.com>
Copy link
Contributor

API specs implemented for 241/649 (37%) APIs.

@spapadop
Copy link
Contributor Author

@Xtansia many thanks for the thorough review! I applied your suggestions and synced my fork.
Back to you

@spapadop spapadop requested a review from Xtansia March 22, 2024 09:42
@Xtansia Xtansia merged commit a44e6d9 into opensearch-project:main Mar 24, 2024
5 checks passed
@spapadop spapadop deleted the enhancement/notificationsapi branch March 26, 2024 11:54
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.

4 participants