aboutsummaryrefslogtreecommitdiffstats
path: root/a1-policy-management/open-api-fragments/v2-fragments/pms-api.yaml
diff options
context:
space:
mode:
Diffstat (limited to 'a1-policy-management/open-api-fragments/v2-fragments/pms-api.yaml')
-rw-r--r--a1-policy-management/open-api-fragments/v2-fragments/pms-api.yaml149
1 files changed, 149 insertions, 0 deletions
diff --git a/a1-policy-management/open-api-fragments/v2-fragments/pms-api.yaml b/a1-policy-management/open-api-fragments/v2-fragments/pms-api.yaml
new file mode 100644
index 00000000..57fe3a4e
--- /dev/null
+++ b/a1-policy-management/open-api-fragments/v2-fragments/pms-api.yaml
@@ -0,0 +1,149 @@
+# ============LICENSE_START=======================================================
+# Copyright (C) 2020-2023 Nordix Foundation. All rights reserved.
+# Copyright (C) 2023-2025 OpenInfra Foundation Europe. All rights reserved.
+# ================================================================================
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+# SPDX-License-Identifier: Apache-2.0
+# ============LICENSE_END=========================================================
+
+openapi: 3.0.3
+info:
+ x-api-id: a31c510b-20e6-4a08-af16-368c44d7fba8
+ x-audience: external-public
+ description: "<h2>General</h2><p>The ONAP CCSDK A1 Policy Management Service\
+ \ provides a REST API for managing A1 policies. <br/>This document describes an older pre-spec API set
+ \ to perform tasks for: </p><ul><li>A1 Policy creation, modification and deletion.</li><li>Monitoring\
+ \ and maintaining consistency of the SMO view of A1 Policies and the Near-RT RICs</li><li>Maintaining\
+ \ a view of each Near-RT RIC's supported A1 Policy Types</li><li>Supervision of registered services\
+ \ (rApps). When a registered service is unavailable, its policies are removed.</li></ul><h2>APIs\
+ \ provided or defined by the service</h2><h3>A1 Policy Management (Older pre-spec version) </h3>\
+ \ <p>This is an older API for managing A1 Policies:</p><ul><li>A1 Policy retrieval, creation,\
+ \ modification and deletion.</li><li>Retrieval of supported A1 Policy Types for\
+ \ a Near-RT RIC</li><li>Retrieval of status for existing A1 policies</li></ul><h3>Management\
+ \ of configuration</h3><p>API for updating and retrieval of the component configuration.\
+ \ Note that there other ways to maintain the configuration.</p><h3>Service Callbacks</h3><p>These\
+ \ are endpoints that are invoked by this service. The callbacks are registered\
+ \ in this service at service registration.</p><h3>NearRT-RIC Repository (Older version)</h3>\
+ \ <p>This is an API that provides support for looking up a NearRT-RIC. Each A1 policy\
+ \ is targeted towards one Near-RT RIC.</p><h3>Health Check</h3><p>API used for supervision\
+ \ of the A1 Policy Management Service .</p><h3>Service Registry and Supervision</h3>\
+ \ <p>API used for registering services/clients/rApps. Each A1 Policy can be tagged with an owner.\
+ \ If the owner service is registered, then the service can be monitored by a heart-beat supervision\
+ \ mechanism, and if the registered service becomes unavailable, then its A1 Policies are removed. Note \
+ \ that services do not need to be registered to create A1 Policies, but unregistered services are not \
+ \ supervised. This is a feature that is optional to use.</p><h3>Authorization API</h3><p>API used\
+ \ for access control of A1 Policy access. If configured, an external authorization\
+ \ provider is requested to grant access to the A1 Policy Type.</p><h3>Spring Boot\
+ \ Actuator</h3><p>Provides built-in functions used to monitor and configure the Spring\
+ \ web application hosting the service.</p>"
+ license:
+ name: |
+ Copyright (C) 2020-2023 Nordix Foundation, and Copyright (C) 2024-2025 OpenInfra Foundation Europe.
+ All rights reserved. Licensed under the Apache 2 License.
+ url: http://www.apache.org/licenses/LICENSE-2.0
+ title: ONAP CCSDK - Pre-Spec A1 Policy Management API
+ version: 1.3.0
+ contact:
+ name: ONAP CCSDK Project
+ url: https://www.onap.org/
+ email: discuss-list@onap.com
+servers:
+ - url: /
+tags:
+ - name: A1 Policy Management
+ description: >
+ Older pre-spec API used to get, create, update and delete A1 Policy Instances. Also used to query A1 Policy Types.
+ - name: NearRT-RIC Repository
+ description: >
+ Older API used to get information about registered Near-RT RICs.
+ - name: Service Registry and Supervision
+ description: >
+ Older API used to manage registered services, and control their keep-alive status via heart-beat messages.
+ - name: Health Check
+ description: >
+ API used to get the health status and statistics of this service
+ - name: Service Callbacks
+ description: >
+ Callout to registered services to indicate a status changes for a Near-RT RIC.
+ Note that these operations are called by the A1 Policy Management Service, not provided.
+ - name: Authorization API
+ description: >
+ API used for authorization of information A1 policy access (this is
+ provided by an authorization producer such as OPA).
+ Note that these operations are called by the A1 Policy Management Service, not provided.
+ - name: Configuration
+ description: >
+ API used to create or fetch the application configuration.
+ - name: Actuator API
+ description: >
+ API used to monitor and configure the A1-PMS Springboot Service.
+ externalDocs:
+ description: Spring Boot Actuator Web API Documentation
+ url: https://docs.spring.io/spring-boot/reference/actuator/endpoints.html
+
+paths:
+ /status:
+ $ref: 'healthcheck-api.yaml#/status'
+ /a1-policy/v2/status:
+ $ref: 'healthcheck-api.yaml#/status-v2'
+ /a1-policy/v2/rics/ric:
+ $ref: 'ric-api.yaml#/ric'
+ /a1-policy/v2/policy-types:
+ $ref: 'pms-lcm-api.yaml#/policy-types'
+ /a1-policy/v2/policies/{policy_id}:
+ $ref: 'pms-lcm-api.yaml#/policy'
+ /a1-policy/v2/services/{service_id}/keepalive:
+ $ref: 'service-api.yaml#/keep-alive'
+ /a1-policy/v2/rics:
+ $ref: 'ric-api.yaml#/rics'
+ /a1-policy/v2/services:
+ $ref: 'service-api.yaml#/services'
+ /a1-policy/v2/policy-types/{policytype_id}:
+ $ref: 'pms-lcm-api.yaml#/policy-type'
+ /a1-policy/v2/policies:
+ $ref: 'pms-lcm-api.yaml#/policies'
+ /a1-policy/v2/policy-instances:
+ $ref: 'pms-lcm-api.yaml#/policy-instances'
+ /a1-policy/v2/services/{service_id}:
+ $ref: 'service-api.yaml#/service'
+ /a1-policy/v2/policies/{policy_id}/status:
+ $ref: 'pms-lcm-api.yaml#/policy-status'
+ /a1-policy/v2/configuration:
+ $ref: 'configuration-api.yaml#/configuration'
+ /example-authz-check:
+ $ref: 'authz-api.yaml#/authz'
+ /actuator:
+ $ref: 'actuator-api.yaml#/actuator'
+ /actuator/heapdump:
+ $ref: 'actuator-api.yaml#/heapdump'
+ /actuator/info:
+ $ref: 'actuator-api.yaml#/actuator-info'
+ /actuator/threaddump:
+ $ref: 'actuator-api.yaml#/threaddump'
+ /actuator/loggers:
+ $ref: 'actuator-api.yaml#/loggers'
+ /actuator/loggers/{name}:
+ $ref: 'actuator-api.yaml#/logger'
+ /actuator/logfile:
+ $ref: 'actuator-api.yaml#/logfile'
+ /actuator/health:
+ $ref: 'actuator-api.yaml#/health'
+ /actuator/health/**:
+ $ref: 'actuator-api.yaml#/health-all'
+ /actuator/shutdown:
+ $ref: 'actuator-api.yaml#/shutdown'
+ /actuator/metrics:
+ $ref: 'actuator-api.yaml#/metrics'
+ /actuator/metrics/{requiredMetricName}:
+ $ref: 'actuator-api.yaml#/metric'