aboutsummaryrefslogtreecommitdiffstats
path: root/docs/offeredapis
diff options
context:
space:
mode:
Diffstat (limited to 'docs/offeredapis')
-rw-r--r--docs/offeredapis/openapitoolgen/offeredapis/pms-api/index.html2
-rw-r--r--docs/offeredapis/openapitoolgen/offeredapis/pms-api/v3/custom/index.html2
-rw-r--r--docs/offeredapis/openapitoolgen/offeredapis/pms-api/v3/index.html4
-rw-r--r--docs/offeredapis/swagger/custom/a1pms-api-custom-v3.json576
-rw-r--r--docs/offeredapis/swagger/pms-api-v3.json576
-rw-r--r--docs/offeredapis/swagger/pms-api-v3.yaml2426
-rw-r--r--docs/offeredapis/swagger/pms-api.json465
-rw-r--r--docs/offeredapis/swagger/pms-api.yaml1732
8 files changed, 3110 insertions, 2673 deletions
diff --git a/docs/offeredapis/openapitoolgen/offeredapis/pms-api/index.html b/docs/offeredapis/openapitoolgen/offeredapis/pms-api/index.html
index 08df1a87..697ddf6c 100644
--- a/docs/offeredapis/openapitoolgen/offeredapis/pms-api/index.html
+++ b/docs/offeredapis/openapitoolgen/offeredapis/pms-api/index.html
@@ -6047,7 +6047,7 @@ pub fn main() {
<div class="pull-right"></div>
<div class="clearfix"></div>
<p></p>
- <p class="marked">Replace the current Application Configuration with a new configuration. The new configuration, if accepted, will take effect after a short delay. The new configuration must comply with the Application Configuration schema, which can be found from the the Application Documentation (Developer Guide)
+ <p class="marked">Replace the current Application Configuration with a new configuration. The new configuration, if accepted, will take effect after a short delay. The new configuration must comply with the Application Configuration schema, which can be found from the the Application Documentation (Developer Guide)
</p>
<p></p>
<br />
diff --git a/docs/offeredapis/openapitoolgen/offeredapis/pms-api/v3/custom/index.html b/docs/offeredapis/openapitoolgen/offeredapis/pms-api/v3/custom/index.html
index 61b74d18..87eac8e5 100644
--- a/docs/offeredapis/openapitoolgen/offeredapis/pms-api/v3/custom/index.html
+++ b/docs/offeredapis/openapitoolgen/offeredapis/pms-api/v3/custom/index.html
@@ -878,7 +878,7 @@ ul.nav-tabs {
"$ref" : "#/components/schemas/NearRtRicId"
}
},
- "description" : "Information tuple for a single A1 Policy Instance. Contains the A1 Policy Instance ID, and the ID of the Near-RT RIC where the policy is created. \n"
+ "description" : "Information tuple for a single A1 Policy Instance. Contains the A1 Policy Instance ID, and the ID of the Near-RT RIC where the policy is created.\n"
};
defs["PolicyObjectInformation"] = {
"required" : [ "nearRtRicId", "policyObject", "policyTypeId" ],
diff --git a/docs/offeredapis/openapitoolgen/offeredapis/pms-api/v3/index.html b/docs/offeredapis/openapitoolgen/offeredapis/pms-api/v3/index.html
index cfc8c659..a9c59bf5 100644
--- a/docs/offeredapis/openapitoolgen/offeredapis/pms-api/v3/index.html
+++ b/docs/offeredapis/openapitoolgen/offeredapis/pms-api/v3/index.html
@@ -878,7 +878,7 @@ ul.nav-tabs {
"$ref" : "#/components/schemas/NearRtRicId"
}
},
- "description" : "Information tuple for a single A1 Policy Instance. Contains the A1 Policy Instance ID, and the ID of the Near-RT RIC where the policy is created. \n"
+ "description" : "Information tuple for a single A1 Policy Instance. Contains the A1 Policy Instance ID, and the ID of the Near-RT RIC where the policy is created.\n"
};
defs["PolicyObjectInformation"] = {
"required" : [ "nearRtRicId", "policyObject", "policyTypeId" ],
@@ -11466,7 +11466,7 @@ pub fn main() {
<div class="pull-right"></div>
<div class="clearfix"></div>
<p></p>
- <p class="marked">Replace the current Application Configuration with a new configuration. The new configuration, if accepted, will take effect after a short delay. The new configuration must comply with the Application Configuration schema, which can be found from the the Application Documentation (Developer Guide)
+ <p class="marked">Replace the current Application Configuration with a new configuration. The new configuration, if accepted, will take effect after a short delay. The new configuration must comply with the Application Configuration schema, which can be found from the the Application Documentation (Developer Guide)
</p>
<p></p>
<br />
diff --git a/docs/offeredapis/swagger/custom/a1pms-api-custom-v3.json b/docs/offeredapis/swagger/custom/a1pms-api-custom-v3.json
index 7b221983..37dd6ff9 100644
--- a/docs/offeredapis/swagger/custom/a1pms-api-custom-v3.json
+++ b/docs/offeredapis/swagger/custom/a1pms-api-custom-v3.json
@@ -93,19 +93,15 @@
"schema" : {
"nullable" : false,
"type" : "string"
- },
- "style" : "simple"
+ }
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"200" : {
@@ -154,15 +150,12 @@
"style" : "form"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"200" : {
@@ -231,15 +224,12 @@
"style" : "form"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"200" : {
@@ -370,15 +360,12 @@
"style" : "simple"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"200" : {
@@ -506,15 +493,12 @@
"style" : "simple"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"204" : {
@@ -653,15 +637,12 @@
"style" : "simple"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"200" : {
@@ -777,14 +758,12 @@
"description" : "Update an existing A1 Policy instance's policy data using its policy ID.",
"operationId" : "updatePolicy",
"parameters" : [ {
- "explode" : false,
"in" : "path",
"name" : "policyId",
"required" : true,
"schema" : {
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"requestBody" : {
"content" : {
@@ -967,15 +946,12 @@
"style" : "simple"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"200" : {
@@ -1129,15 +1105,12 @@
"style" : "form"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"200" : {
@@ -1273,21 +1246,17 @@
"headers" : {
"Location" : {
"description" : "Contains the URI of the newly created A1 Policy Instances. This URI includes the A1 Policy Instance ID for the newly created policy instance.\n",
- "explode" : false,
"required" : true,
"schema" : {
"type" : "string"
- },
- "style" : "simple"
+ }
},
"Content-Type" : {
"description" : "Media Type of the response",
- "explode" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
}
}
},
@@ -1471,7 +1440,7 @@
"tags" : [ "Configuration" ]
},
"put" : {
- "description" : "Replace the current Application Configuration with a new configuration. The new configuration, if accepted, will take effect after a short delay. The new configuration must comply with the Application Configuration schema, which can be found from the the Application Documentation (Developer Guide) \n",
+ "description" : "Replace the current Application Configuration with a new configuration. The new configuration, if accepted, will take effect after a short delay. The new configuration must comply with the Application Configuration schema, which can be found from the the Application Documentation (Developer Guide)\n",
"operationId" : "putConfiguration",
"requestBody" : {
"content" : {
@@ -1524,15 +1493,12 @@
"style" : "simple"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"requestBody" : {
"content" : {
@@ -1586,15 +1552,12 @@
"style" : "form"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"200" : {
@@ -1734,15 +1697,12 @@
"style" : "simple"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"204" : {
@@ -1773,22 +1733,6 @@
},
"components" : {
"examples" : {
- "ServiceStatusList" : {
- "description" : "List of service information",
- "value" : {
- "serviceList" : [ {
- "callbackUrl" : "http://callback.url",
- "serviceId" : "serviceId1",
- "keepAliveIntervalSeconds" : 0,
- "timeSinceLastActivitySeconds" : 6
- }, {
- "callbackUrl" : "http://callback.url",
- "serviceId" : "serviceId2",
- "keepAliveIntervalSeconds" : 500,
- "timeSinceLastActivitySeconds" : 401
- } ]
- }
- },
"StatusInfo" : {
"value" : {
"status" : "success"
@@ -1817,48 +1761,6 @@
} ]
}
},
- "PolicyObject" : {
- "value" : {
- "scope" : {
- "ueId" : {
- "guRanUeId" : {
- "globalGnbId" : {
- "plmnId" : {
- "mcc" : "123",
- "mnc" : "45"
- },
- "gnbId" : {
- "gnbIdLength" : 24,
- "gnbIdValue" : 12345678
- }
- },
- "RanUeId" : "a31c510b20e64a74"
- }
- },
- "groupId" : {
- "spId" : 123
- },
- "qosId" : {
- "5qI" : 1
- },
- "cellId" : {
- "plmnId" : {
- "mcc" : "123",
- "mnc" : "45"
- },
- "cId" : {
- "ncI" : 123
- }
- }
- },
- "qosObjectives" : {
- "gfbr" : 100,
- "mfbr" : 200,
- "priorityLevel" : 3,
- "pdb" : 50
- }
- }
- },
"PolicyTypeInformation" : {
"value" : [ {
"policyTypeId" : "STD_QOS2_0.1.0",
@@ -1908,10 +1810,68 @@
}
}
}
+ },
+ "PolicyObject" : {
+ "value" : {
+ "scope" : {
+ "ueId" : {
+ "guRanUeId" : {
+ "globalGnbId" : {
+ "plmnId" : {
+ "mcc" : "123",
+ "mnc" : "45"
+ },
+ "gnbId" : {
+ "gnbIdLength" : 24,
+ "gnbIdValue" : 12345678
+ }
+ },
+ "RanUeId" : "a31c510b20e64a74"
+ }
+ },
+ "groupId" : {
+ "spId" : 123
+ },
+ "qosId" : {
+ "5qI" : 1
+ },
+ "cellId" : {
+ "plmnId" : {
+ "mcc" : "123",
+ "mnc" : "45"
+ },
+ "cId" : {
+ "ncI" : 123
+ }
+ }
+ },
+ "qosObjectives" : {
+ "gfbr" : 100,
+ "mfbr" : 200,
+ "priorityLevel" : 3,
+ "pdb" : 50
+ }
+ }
+ },
+ "ServiceStatusList" : {
+ "description" : "List of service information",
+ "value" : {
+ "serviceList" : [ {
+ "callbackUrl" : "http://callback.url",
+ "serviceId" : "serviceId1",
+ "keepAliveIntervalSeconds" : 0,
+ "timeSinceLastActivitySeconds" : 6
+ }, {
+ "callbackUrl" : "http://callback.url",
+ "serviceId" : "serviceId2",
+ "keepAliveIntervalSeconds" : 500,
+ "timeSinceLastActivitySeconds" : 401
+ } ]
+ }
}
},
"responses" : {
- "400" : {
+ "404" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1919,9 +1879,9 @@
}
}
},
- "description" : "Bad Request"
+ "description" : "Not Found"
},
- "401" : {
+ "400" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1929,9 +1889,9 @@
}
}
},
- "description" : "Unauthorized"
+ "description" : "Bad Request"
},
- "403" : {
+ "401" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1939,9 +1899,9 @@
}
}
},
- "description" : "Forbidden"
+ "description" : "Unauthorized"
},
- "404" : {
+ "403" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1949,9 +1909,9 @@
}
}
},
- "description" : "Not Found"
+ "description" : "Forbidden"
},
- "405" : {
+ "406" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1959,9 +1919,9 @@
}
}
},
- "description" : "Method Not Allowed"
+ "description" : "Not Acceptable"
},
- "406" : {
+ "429" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1969,9 +1929,9 @@
}
}
},
- "description" : "Not Acceptable"
+ "description" : "Too Many Requests"
},
- "409" : {
+ "500" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1979,9 +1939,9 @@
}
}
},
- "description" : "Conflict"
+ "description" : "Internal Server Error"
},
- "411" : {
+ "502" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1989,9 +1949,9 @@
}
}
},
- "description" : "Length Required"
+ "description" : "Bad Gateway"
},
- "413" : {
+ "503" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1999,9 +1959,9 @@
}
}
},
- "description" : "Payload Too Large"
+ "description" : "Service Unavailable"
},
- "415" : {
+ "411" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -2009,9 +1969,9 @@
}
}
},
- "description" : "Unsupported Media Type"
+ "description" : "Length Required"
},
- "429" : {
+ "413" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -2019,9 +1979,9 @@
}
}
},
- "description" : "Too Many Requests"
+ "description" : "Payload Too Large"
},
- "500" : {
+ "415" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -2029,19 +1989,24 @@
}
}
},
- "description" : "Internal Server Error"
+ "description" : "Unsupported Media Type"
},
- "502" : {
+ "Locked" : {
"content" : {
"application/problem+json" : {
+ "example" : {
+ "status" : 423,
+ "title" : "Locked",
+ "detail" : "State is Locked in the provided request."
+ },
"schema" : {
- "$ref" : "#/components/schemas/ProblemDetails"
+ "$ref" : "#/components/schemas/ErrorInformation"
}
}
},
- "description" : "Bad Gateway"
+ "description" : "Locked - HTTP Status code which can be used when the state is Locked"
},
- "503" : {
+ "405" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -2049,106 +2014,121 @@
}
}
},
- "description" : "Service Unavailable"
+ "description" : "Method Not Allowed"
},
- "Locked" : {
+ "409" : {
"content" : {
"application/problem+json" : {
- "example" : {
- "status" : 423,
- "title" : "Locked",
- "detail" : "State is Locked in the provided request."
- },
"schema" : {
- "$ref" : "#/components/schemas/ErrorInformation"
+ "$ref" : "#/components/schemas/ProblemDetails"
}
}
},
- "description" : "Locked - HTTP Status code which can be used when the state is Locked"
+ "description" : "Conflict"
}
},
"schemas" : {
- "PolicyTypeInformation" : {
- "description" : "A data tuple to indicate that an identified A1 Policy Type is supported at an identified Near-RT RIC.",
- "example" : {
- "policyTypeId" : "STD_QOS2_0.1.0",
- "nearRtRicId" : "ric_g3_2"
- },
+ "StatusInfo" : {
"properties" : {
- "policyTypeId" : {
- "description" : "A1 Policy Type identifier",
+ "status" : {
+ "description" : "Status text",
"type" : "string"
- },
- "nearRtRicId" : {
- "$ref" : "#/components/schemas/NearRtRicId"
}
},
- "required" : [ "nearRtRicId", "policyTypeId" ],
"type" : "object"
},
- "PolicyObjectInformation" : {
- "description" : "Information to create an A1 Policy Instance",
+ "ProblemDetails" : {
+ "description" : "Object to carry details about a problem in an HTTP response according to IETF RFC 7807",
"properties" : {
- "nearRtRicId" : {
- "description" : "Identity of the target Near-RT RIC",
- "example" : "Near-RT-Ric-ID1",
+ "type" : {
+ "description" : "URI reference according to IETF RFC 3986 that identifies the problem type",
"type" : "string"
},
- "transient" : {
- "default" : false,
- "description" : "If true, the policy is automatically deleted if the targeted Near-RT RIC restarts or recovers. If false, the A1 Policy Instance remains, and is re-pushed to the targeted Near-RT RIC after a restart or recovery. If false, the A1 Policy Instance is maintained and must be deleted separately in the event of Near-RT RIC restart or recovery. Default is false.\n",
- "nullable" : false,
- "type" : "boolean"
- },
- "policyId" : {
- "description" : "An optional identity to be used for the new A1 Policy Instance. If this value is present, it must be unique. If not present the new A1 Policy Instance will be assigned a newly generated unique ID, and the new ID can be extracted from the 'Location' header in the response.\n",
- "example" : "POLICY-ID1",
+ "title" : {
+ "description" : "Human-readable summary of the problem type",
"type" : "string"
},
- "serviceId" : {
- "default" : "",
- "description" : "the identity of the service owning the policy. This can be used to group the policies (it is possible to get all policies associated to a service). Note that the service does not need to be registered. If the service is registered, the newly created A1 Policy Instance will be subject to the same supervision rules as the the service's other policies.",
- "example" : "rApp 1",
- "type" : "string"
+ "status" : {
+ "description" : "HTTP status code",
+ "type" : "number"
},
- "policyObject" : {
- "$ref" : "#/components/schemas/PolicyObject"
+ "detail" : {
+ "description" : "Human-readable explanation",
+ "type" : "string"
},
- "policyTypeId" : {
- "description" : "A1 Policy Type identity",
- "example" : "ORAN_QOS_1.0.0 '(typeName_SemVersion)'",
+ "instance" : {
+ "description" : "URI reference that identifies the specific occurrence of the problem",
"type" : "string"
}
},
- "required" : [ "nearRtRicId", "policyObject", "policyTypeId" ],
"type" : "object"
},
- "ErrorInformation" : {
- "description" : "Problem as defined in https://tools.ietf.org/html/rfc7807",
+ "RicInfo" : {
+ "description" : "Information for a Near-RT RIC",
"properties" : {
- "detail" : {
- "description" : "A human-readable explanation specific to this occurrence of the problem.",
- "example" : "Policy type not found",
+ "ricId" : {
+ "description" : "Identity of the Near-RT RIC",
"type" : "string"
},
- "title" : {
- "description" : "A specific error name",
- "example" : "Not Found",
+ "managedElementIds" : {
+ "description" : "Identities for managed entities",
+ "items" : {
+ "description" : "Identity for a managed entity",
+ "type" : "string"
+ },
+ "type" : "array"
+ },
+ "state" : {
+ "description" : "Represents the state of a Near-RT RIC",
+ "enum" : [ "UNAVAILABLE", "AVAILABLE", "SYNCHRONIZING", "CONSISTENCY_CHECK" ],
"type" : "string"
},
- "status" : {
- "description" : "The HTTP status code generated by the origin server for this occurrence of the problem.\n",
- "example" : 404,
- "format" : "int32",
- "type" : "integer"
+ "policyTypeIds" : {
+ "description" : "Supported A1 Policy Types",
+ "items" : {
+ "description" : "Supported A1 Policy Type ID",
+ "type" : "string"
+ },
+ "type" : "array"
}
},
"type" : "object"
},
- "PolicyObject" : {
- "description" : "Policy Object is a JSON representation policy data for an A1 Policy Instance. The schema for this policy data is defined in the corresponding A1 Policy Type. \n",
+ "RicInfoList" : {
+ "description" : "Collection of Near-RT RIC information objects",
+ "properties" : {
+ "rics" : {
+ "description" : "List of Near-RT RIC information objects",
+ "items" : {
+ "$ref" : "#/components/schemas/RicInfo"
+ },
+ "type" : "array"
+ }
+ },
+ "type" : "object"
+ },
+ "PolicyTypeInformation" : {
+ "description" : "A data tuple to indicate that an identified A1 Policy Type is supported at an identified Near-RT RIC.",
+ "example" : {
+ "policyTypeId" : "STD_QOS2_0.1.0",
+ "nearRtRicId" : "ric_g3_2"
+ },
+ "properties" : {
+ "policyTypeId" : {
+ "description" : "A1 Policy Type identifier",
+ "type" : "string"
+ },
+ "nearRtRicId" : {
+ "$ref" : "#/components/schemas/NearRtRicId"
+ }
+ },
+ "required" : [ "nearRtRicId", "policyTypeId" ],
"type" : "object"
},
+ "NearRtRicId" : {
+ "description" : "Identity of the Near-RT RIC",
+ "type" : "string"
+ },
"PolicyTypeObject" : {
"description" : "An A1 Policy Type, as defined in O-RAN Alliance A1TD",
"example" : {
@@ -2219,72 +2199,101 @@
"description" : "A schema to define the contents of the status information for A1 Policy Instances. Status schemas are Policy Type specific. All status information for all A1 Policy Instances of an A1 Policy Type should comply with the type's status schema.\n",
"type" : "object"
},
- "PolicyStatusObject" : {
- "description" : "A generic policy status object that can be used to transport any policy status. Additionally, a schema for policy status can be defined in the corresponding A1 Policy Type.\n",
- "type" : "object"
- },
- "void" : {
- "description" : "Void/empty",
+ "PolicyObject" : {
+ "description" : "Policy Object is a JSON representation policy data for an A1 Policy Instance. The schema for this policy data is defined in the corresponding A1 Policy Type.\n",
"type" : "object"
},
- "StatusInfo" : {
+ "ErrorInformation" : {
+ "description" : "Problem as defined in https://tools.ietf.org/html/rfc7807",
"properties" : {
- "status" : {
- "description" : "Status text",
+ "detail" : {
+ "description" : "A human-readable explanation specific to this occurrence of the problem.",
+ "example" : "Policy type not found",
+ "type" : "string"
+ },
+ "title" : {
+ "description" : "A specific error name",
+ "example" : "Not Found",
"type" : "string"
+ },
+ "status" : {
+ "description" : "The HTTP status code generated by the origin server for this occurrence of the problem.\n",
+ "example" : 404,
+ "format" : "int32",
+ "type" : "integer"
}
},
"type" : "object"
},
- "RicInfo" : {
- "description" : "Information for a Near-RT RIC",
+ "PolicyStatusObject" : {
+ "description" : "A generic policy status object that can be used to transport any policy status. Additionally, a schema for policy status can be defined in the corresponding A1 Policy Type.\n",
+ "type" : "object"
+ },
+ "PolicyInformation" : {
+ "description" : "Information tuple for a single A1 Policy Instance. Contains the A1 Policy Instance ID, and the ID of the Near-RT RIC where the policy is created.\n",
"properties" : {
- "ricId" : {
- "description" : "Identity of the Near-RT RIC",
- "type" : "string"
- },
- "managedElementIds" : {
- "description" : "Identities for managed entities",
- "items" : {
- "description" : "Identity for a managed entity",
- "type" : "string"
- },
- "type" : "array"
- },
- "state" : {
- "description" : "Represents the state of a Near-RT RIC",
- "enum" : [ "UNAVAILABLE", "AVAILABLE", "SYNCHRONIZING", "CONSISTENCY_CHECK" ],
+ "policyId" : {
+ "description" : "Identity of the A1 Policy Instance",
"type" : "string"
},
- "policyTypeIds" : {
- "description" : "Supported A1 Policy Types",
- "items" : {
- "description" : "Supported A1 Policy Type ID",
- "type" : "string"
- },
- "type" : "array"
+ "nearRtRicId" : {
+ "$ref" : "#/components/schemas/NearRtRicId"
}
},
+ "required" : [ "nearRtRicId", "policyId" ],
"type" : "object"
},
- "ServiceRegistrationInfo" : {
- "description" : "Information for a service to be registered",
+ "PolicyObjectInformation" : {
+ "description" : "Information to create an A1 Policy Instance",
"properties" : {
- "callbackUrl" : {
- "description" : "Callback URL for notifying of Near-RT RIC state changes",
+ "nearRtRicId" : {
+ "description" : "Identity of the target Near-RT RIC",
+ "example" : "Near-RT-Ric-ID1",
+ "type" : "string"
+ },
+ "transient" : {
+ "default" : false,
+ "description" : "If true, the policy is automatically deleted if the targeted Near-RT RIC restarts or recovers. If false, the A1 Policy Instance remains, and is re-pushed to the targeted Near-RT RIC after a restart or recovery. If false, the A1 Policy Instance is maintained and must be deleted separately in the event of Near-RT RIC restart or recovery. Default is false.\n",
+ "nullable" : false,
+ "type" : "boolean"
+ },
+ "policyId" : {
+ "description" : "An optional identity to be used for the new A1 Policy Instance. If this value is present, it must be unique. If not present the new A1 Policy Instance will be assigned a newly generated unique ID, and the new ID can be extracted from the 'Location' header in the response.\n",
+ "example" : "POLICY-ID1",
"type" : "string"
},
"serviceId" : {
- "description" : "Identity of the service",
+ "default" : "",
+ "description" : "the identity of the service owning the policy. This can be used to group the policies (it is possible to get all policies associated to a service). Note that the service does not need to be registered. If the service is registered, the newly created A1 Policy Instance will be subject to the same supervision rules as the the service's other policies.",
+ "example" : "rApp 1",
"type" : "string"
},
- "keepAliveIntervalSeconds" : {
- "description" : "Keep alive interval for the service. This is used to enable optional heartbeat supervision of the service. If set (> 0) the registered service should regularly invoke a 'keepalive' REST call. When a service fails to invoke this 'keepalive' call within the configured time, the service is considered unavailable. An unavailable service will be automatically deregistered and its policies will be deleted. Value 0 means timeout supervision is disabled.\n",
- "format" : "int64",
- "type" : "integer"
+ "policyObject" : {
+ "$ref" : "#/components/schemas/PolicyObject"
+ },
+ "policyTypeId" : {
+ "description" : "A1 Policy Type identity",
+ "example" : "ORAN_QOS_1.0.0 '(typeName_SemVersion)'",
+ "type" : "string"
+ }
+ },
+ "required" : [ "nearRtRicId", "policyObject", "policyTypeId" ],
+ "type" : "object"
+ },
+ "void" : {
+ "description" : "Void/empty",
+ "type" : "object"
+ },
+ "ServiceStatusList" : {
+ "properties" : {
+ "serviceList" : {
+ "description" : "List of Service Status objects, describing a collection of registered services.",
+ "items" : {
+ "$ref" : "#/components/schemas/ServiceStatus"
+ },
+ "type" : "array"
}
},
- "required" : [ "serviceId" ],
"type" : "object"
},
"ServiceStatus" : {
@@ -2311,47 +2320,24 @@
},
"type" : "object"
},
- "RicInfoList" : {
- "description" : "Collection of Near-RT RIC information objects",
- "properties" : {
- "rics" : {
- "description" : "List of Near-RT RIC information objects",
- "items" : {
- "$ref" : "#/components/schemas/RicInfo"
- },
- "type" : "array"
- }
- },
- "type" : "object"
- },
- "NearRtRicId" : {
- "description" : "Identity of the Near-RT RIC",
- "type" : "string"
- },
- "PolicyInformation" : {
- "description" : "Information tuple for a single A1 Policy Instance. Contains the A1 Policy Instance ID, and the ID of the Near-RT RIC where the policy is created. \n",
+ "ServiceRegistrationInfo" : {
+ "description" : "Information for a service to be registered",
"properties" : {
- "policyId" : {
- "description" : "Identity of the A1 Policy Instance",
+ "callbackUrl" : {
+ "description" : "Callback URL for notifying of Near-RT RIC state changes",
"type" : "string"
},
- "nearRtRicId" : {
- "$ref" : "#/components/schemas/NearRtRicId"
- }
- },
- "required" : [ "nearRtRicId", "policyId" ],
- "type" : "object"
- },
- "ServiceStatusList" : {
- "properties" : {
- "serviceList" : {
- "description" : "List of Service Status objects, describing a collection of registered services.",
- "items" : {
- "$ref" : "#/components/schemas/ServiceStatus"
- },
- "type" : "array"
+ "serviceId" : {
+ "description" : "Identity of the service",
+ "type" : "string"
+ },
+ "keepAliveIntervalSeconds" : {
+ "description" : "Keep alive interval for the service. This is used to enable optional heartbeat supervision of the service. If set (> 0) the registered service should regularly invoke a 'keepalive' REST call. When a service fails to invoke this 'keepalive' call within the configured time, the service is considered unavailable. An unavailable service will be automatically deregistered and its policies will be deleted. Value 0 means timeout supervision is disabled.\n",
+ "format" : "int64",
+ "type" : "integer"
}
},
+ "required" : [ "serviceId" ],
"type" : "object"
},
"ServiceCallbackInfo" : {
@@ -2369,32 +2355,6 @@
},
"required" : [ "eventType", "ricId" ],
"type" : "object"
- },
- "ProblemDetails" : {
- "description" : "Object to carry details about a problem in an HTTP response according to IETF RFC 7807",
- "properties" : {
- "type" : {
- "description" : "URI reference according to IETF RFC 3986 that identifies the problem type",
- "type" : "string"
- },
- "title" : {
- "description" : "Human-readable summary of the problem type",
- "type" : "string"
- },
- "status" : {
- "description" : "HTTP status code",
- "type" : "number"
- },
- "detail" : {
- "description" : "Human-readable explanation",
- "type" : "string"
- },
- "instance" : {
- "description" : "URI reference that identifies the specific occurrence of the problem",
- "type" : "string"
- }
- },
- "type" : "object"
}
}
}
diff --git a/docs/offeredapis/swagger/pms-api-v3.json b/docs/offeredapis/swagger/pms-api-v3.json
index 7b221983..37dd6ff9 100644
--- a/docs/offeredapis/swagger/pms-api-v3.json
+++ b/docs/offeredapis/swagger/pms-api-v3.json
@@ -93,19 +93,15 @@
"schema" : {
"nullable" : false,
"type" : "string"
- },
- "style" : "simple"
+ }
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"200" : {
@@ -154,15 +150,12 @@
"style" : "form"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"200" : {
@@ -231,15 +224,12 @@
"style" : "form"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"200" : {
@@ -370,15 +360,12 @@
"style" : "simple"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"200" : {
@@ -506,15 +493,12 @@
"style" : "simple"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"204" : {
@@ -653,15 +637,12 @@
"style" : "simple"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"200" : {
@@ -777,14 +758,12 @@
"description" : "Update an existing A1 Policy instance's policy data using its policy ID.",
"operationId" : "updatePolicy",
"parameters" : [ {
- "explode" : false,
"in" : "path",
"name" : "policyId",
"required" : true,
"schema" : {
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"requestBody" : {
"content" : {
@@ -967,15 +946,12 @@
"style" : "simple"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"200" : {
@@ -1129,15 +1105,12 @@
"style" : "form"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"200" : {
@@ -1273,21 +1246,17 @@
"headers" : {
"Location" : {
"description" : "Contains the URI of the newly created A1 Policy Instances. This URI includes the A1 Policy Instance ID for the newly created policy instance.\n",
- "explode" : false,
"required" : true,
"schema" : {
"type" : "string"
- },
- "style" : "simple"
+ }
},
"Content-Type" : {
"description" : "Media Type of the response",
- "explode" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
}
}
},
@@ -1471,7 +1440,7 @@
"tags" : [ "Configuration" ]
},
"put" : {
- "description" : "Replace the current Application Configuration with a new configuration. The new configuration, if accepted, will take effect after a short delay. The new configuration must comply with the Application Configuration schema, which can be found from the the Application Documentation (Developer Guide) \n",
+ "description" : "Replace the current Application Configuration with a new configuration. The new configuration, if accepted, will take effect after a short delay. The new configuration must comply with the Application Configuration schema, which can be found from the the Application Documentation (Developer Guide)\n",
"operationId" : "putConfiguration",
"requestBody" : {
"content" : {
@@ -1524,15 +1493,12 @@
"style" : "simple"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"requestBody" : {
"content" : {
@@ -1586,15 +1552,12 @@
"style" : "form"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"200" : {
@@ -1734,15 +1697,12 @@
"style" : "simple"
}, {
"description" : "Specifies the content type that the client expects to receive in response to the request. Only application/json is allowed.",
- "explode" : false,
"in" : "header",
"name" : "Accept",
- "required" : false,
"schema" : {
"example" : "application/json",
"type" : "string"
- },
- "style" : "simple"
+ }
} ],
"responses" : {
"204" : {
@@ -1773,22 +1733,6 @@
},
"components" : {
"examples" : {
- "ServiceStatusList" : {
- "description" : "List of service information",
- "value" : {
- "serviceList" : [ {
- "callbackUrl" : "http://callback.url",
- "serviceId" : "serviceId1",
- "keepAliveIntervalSeconds" : 0,
- "timeSinceLastActivitySeconds" : 6
- }, {
- "callbackUrl" : "http://callback.url",
- "serviceId" : "serviceId2",
- "keepAliveIntervalSeconds" : 500,
- "timeSinceLastActivitySeconds" : 401
- } ]
- }
- },
"StatusInfo" : {
"value" : {
"status" : "success"
@@ -1817,48 +1761,6 @@
} ]
}
},
- "PolicyObject" : {
- "value" : {
- "scope" : {
- "ueId" : {
- "guRanUeId" : {
- "globalGnbId" : {
- "plmnId" : {
- "mcc" : "123",
- "mnc" : "45"
- },
- "gnbId" : {
- "gnbIdLength" : 24,
- "gnbIdValue" : 12345678
- }
- },
- "RanUeId" : "a31c510b20e64a74"
- }
- },
- "groupId" : {
- "spId" : 123
- },
- "qosId" : {
- "5qI" : 1
- },
- "cellId" : {
- "plmnId" : {
- "mcc" : "123",
- "mnc" : "45"
- },
- "cId" : {
- "ncI" : 123
- }
- }
- },
- "qosObjectives" : {
- "gfbr" : 100,
- "mfbr" : 200,
- "priorityLevel" : 3,
- "pdb" : 50
- }
- }
- },
"PolicyTypeInformation" : {
"value" : [ {
"policyTypeId" : "STD_QOS2_0.1.0",
@@ -1908,10 +1810,68 @@
}
}
}
+ },
+ "PolicyObject" : {
+ "value" : {
+ "scope" : {
+ "ueId" : {
+ "guRanUeId" : {
+ "globalGnbId" : {
+ "plmnId" : {
+ "mcc" : "123",
+ "mnc" : "45"
+ },
+ "gnbId" : {
+ "gnbIdLength" : 24,
+ "gnbIdValue" : 12345678
+ }
+ },
+ "RanUeId" : "a31c510b20e64a74"
+ }
+ },
+ "groupId" : {
+ "spId" : 123
+ },
+ "qosId" : {
+ "5qI" : 1
+ },
+ "cellId" : {
+ "plmnId" : {
+ "mcc" : "123",
+ "mnc" : "45"
+ },
+ "cId" : {
+ "ncI" : 123
+ }
+ }
+ },
+ "qosObjectives" : {
+ "gfbr" : 100,
+ "mfbr" : 200,
+ "priorityLevel" : 3,
+ "pdb" : 50
+ }
+ }
+ },
+ "ServiceStatusList" : {
+ "description" : "List of service information",
+ "value" : {
+ "serviceList" : [ {
+ "callbackUrl" : "http://callback.url",
+ "serviceId" : "serviceId1",
+ "keepAliveIntervalSeconds" : 0,
+ "timeSinceLastActivitySeconds" : 6
+ }, {
+ "callbackUrl" : "http://callback.url",
+ "serviceId" : "serviceId2",
+ "keepAliveIntervalSeconds" : 500,
+ "timeSinceLastActivitySeconds" : 401
+ } ]
+ }
}
},
"responses" : {
- "400" : {
+ "404" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1919,9 +1879,9 @@
}
}
},
- "description" : "Bad Request"
+ "description" : "Not Found"
},
- "401" : {
+ "400" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1929,9 +1889,9 @@
}
}
},
- "description" : "Unauthorized"
+ "description" : "Bad Request"
},
- "403" : {
+ "401" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1939,9 +1899,9 @@
}
}
},
- "description" : "Forbidden"
+ "description" : "Unauthorized"
},
- "404" : {
+ "403" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1949,9 +1909,9 @@
}
}
},
- "description" : "Not Found"
+ "description" : "Forbidden"
},
- "405" : {
+ "406" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1959,9 +1919,9 @@
}
}
},
- "description" : "Method Not Allowed"
+ "description" : "Not Acceptable"
},
- "406" : {
+ "429" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1969,9 +1929,9 @@
}
}
},
- "description" : "Not Acceptable"
+ "description" : "Too Many Requests"
},
- "409" : {
+ "500" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1979,9 +1939,9 @@
}
}
},
- "description" : "Conflict"
+ "description" : "Internal Server Error"
},
- "411" : {
+ "502" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1989,9 +1949,9 @@
}
}
},
- "description" : "Length Required"
+ "description" : "Bad Gateway"
},
- "413" : {
+ "503" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -1999,9 +1959,9 @@
}
}
},
- "description" : "Payload Too Large"
+ "description" : "Service Unavailable"
},
- "415" : {
+ "411" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -2009,9 +1969,9 @@
}
}
},
- "description" : "Unsupported Media Type"
+ "description" : "Length Required"
},
- "429" : {
+ "413" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -2019,9 +1979,9 @@
}
}
},
- "description" : "Too Many Requests"
+ "description" : "Payload Too Large"
},
- "500" : {
+ "415" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -2029,19 +1989,24 @@
}
}
},
- "description" : "Internal Server Error"
+ "description" : "Unsupported Media Type"
},
- "502" : {
+ "Locked" : {
"content" : {
"application/problem+json" : {
+ "example" : {
+ "status" : 423,
+ "title" : "Locked",
+ "detail" : "State is Locked in the provided request."
+ },
"schema" : {
- "$ref" : "#/components/schemas/ProblemDetails"
+ "$ref" : "#/components/schemas/ErrorInformation"
}
}
},
- "description" : "Bad Gateway"
+ "description" : "Locked - HTTP Status code which can be used when the state is Locked"
},
- "503" : {
+ "405" : {
"content" : {
"application/problem+json" : {
"schema" : {
@@ -2049,106 +2014,121 @@
}
}
},
- "description" : "Service Unavailable"
+ "description" : "Method Not Allowed"
},
- "Locked" : {
+ "409" : {
"content" : {
"application/problem+json" : {
- "example" : {
- "status" : 423,
- "title" : "Locked",
- "detail" : "State is Locked in the provided request."
- },
"schema" : {
- "$ref" : "#/components/schemas/ErrorInformation"
+ "$ref" : "#/components/schemas/ProblemDetails"
}
}
},
- "description" : "Locked - HTTP Status code which can be used when the state is Locked"
+ "description" : "Conflict"
}
},
"schemas" : {
- "PolicyTypeInformation" : {
- "description" : "A data tuple to indicate that an identified A1 Policy Type is supported at an identified Near-RT RIC.",
- "example" : {
- "policyTypeId" : "STD_QOS2_0.1.0",
- "nearRtRicId" : "ric_g3_2"
- },
+ "StatusInfo" : {
"properties" : {
- "policyTypeId" : {
- "description" : "A1 Policy Type identifier",
+ "status" : {
+ "description" : "Status text",
"type" : "string"
- },
- "nearRtRicId" : {
- "$ref" : "#/components/schemas/NearRtRicId"
}
},
- "required" : [ "nearRtRicId", "policyTypeId" ],
"type" : "object"
},
- "PolicyObjectInformation" : {
- "description" : "Information to create an A1 Policy Instance",
+ "ProblemDetails" : {
+ "description" : "Object to carry details about a problem in an HTTP response according to IETF RFC 7807",
"properties" : {
- "nearRtRicId" : {
- "description" : "Identity of the target Near-RT RIC",
- "example" : "Near-RT-Ric-ID1",
+ "type" : {
+ "description" : "URI reference according to IETF RFC 3986 that identifies the problem type",
"type" : "string"
},
- "transient" : {
- "default" : false,
- "description" : "If true, the policy is automatically deleted if the targeted Near-RT RIC restarts or recovers. If false, the A1 Policy Instance remains, and is re-pushed to the targeted Near-RT RIC after a restart or recovery. If false, the A1 Policy Instance is maintained and must be deleted separately in the event of Near-RT RIC restart or recovery. Default is false.\n",
- "nullable" : false,
- "type" : "boolean"
- },
- "policyId" : {
- "description" : "An optional identity to be used for the new A1 Policy Instance. If this value is present, it must be unique. If not present the new A1 Policy Instance will be assigned a newly generated unique ID, and the new ID can be extracted from the 'Location' header in the response.\n",
- "example" : "POLICY-ID1",
+ "title" : {
+ "description" : "Human-readable summary of the problem type",
"type" : "string"
},
- "serviceId" : {
- "default" : "",
- "description" : "the identity of the service owning the policy. This can be used to group the policies (it is possible to get all policies associated to a service). Note that the service does not need to be registered. If the service is registered, the newly created A1 Policy Instance will be subject to the same supervision rules as the the service's other policies.",
- "example" : "rApp 1",
- "type" : "string"
+ "status" : {
+ "description" : "HTTP status code",
+ "type" : "number"
},
- "policyObject" : {
- "$ref" : "#/components/schemas/PolicyObject"
+ "detail" : {
+ "description" : "Human-readable explanation",
+ "type" : "string"
},
- "policyTypeId" : {
- "description" : "A1 Policy Type identity",
- "example" : "ORAN_QOS_1.0.0 '(typeName_SemVersion)'",
+ "instance" : {
+ "description" : "URI reference that identifies the specific occurrence of the problem",
"type" : "string"
}
},
- "required" : [ "nearRtRicId", "policyObject", "policyTypeId" ],
"type" : "object"
},
- "ErrorInformation" : {
- "description" : "Problem as defined in https://tools.ietf.org/html/rfc7807",
+ "RicInfo" : {
+ "description" : "Information for a Near-RT RIC",
"properties" : {
- "detail" : {
- "description" : "A human-readable explanation specific to this occurrence of the problem.",
- "example" : "Policy type not found",
+ "ricId" : {
+ "description" : "Identity of the Near-RT RIC",
"type" : "string"
},
- "title" : {
- "description" : "A specific error name",
- "example" : "Not Found",
+ "managedElementIds" : {
+ "description" : "Identities for managed entities",
+ "items" : {
+ "description" : "Identity for a managed entity",
+ "type" : "string"
+ },
+ "type" : "array"
+ },
+ "state" : {
+ "description" : "Represents the state of a Near-RT RIC",
+ "enum" : [ "UNAVAILABLE", "AVAILABLE", "SYNCHRONIZING", "CONSISTENCY_CHECK" ],
"type" : "string"
},
- "status" : {
- "description" : "The HTTP status code generated by the origin server for this occurrence of the problem.\n",
- "example" : 404,
- "format" : "int32",
- "type" : "integer"
+ "policyTypeIds" : {
+ "description" : "Supported A1 Policy Types",
+ "items" : {
+ "description" : "Supported A1 Policy Type ID",
+ "type" : "string"
+ },
+ "type" : "array"
}
},
"type" : "object"
},
- "PolicyObject" : {
- "description" : "Policy Object is a JSON representation policy data for an A1 Policy Instance. The schema for this policy data is defined in the corresponding A1 Policy Type. \n",
+ "RicInfoList" : {
+ "description" : "Collection of Near-RT RIC information objects",
+ "properties" : {
+ "rics" : {
+ "description" : "List of Near-RT RIC information objects",
+ "items" : {
+ "$ref" : "#/components/schemas/RicInfo"
+ },
+ "type" : "array"
+ }
+ },
+ "type" : "object"
+ },
+ "PolicyTypeInformation" : {
+ "description" : "A data tuple to indicate that an identified A1 Policy Type is supported at an identified Near-RT RIC.",
+ "example" : {
+ "policyTypeId" : "STD_QOS2_0.1.0",
+ "nearRtRicId" : "ric_g3_2"
+ },
+ "properties" : {
+ "policyTypeId" : {
+ "description" : "A1 Policy Type identifier",
+ "type" : "string"
+ },
+ "nearRtRicId" : {
+ "$ref" : "#/components/schemas/NearRtRicId"
+ }
+ },
+ "required" : [ "nearRtRicId", "policyTypeId" ],
"type" : "object"
},
+ "NearRtRicId" : {
+ "description" : "Identity of the Near-RT RIC",
+ "type" : "string"
+ },
"PolicyTypeObject" : {
"description" : "An A1 Policy Type, as defined in O-RAN Alliance A1TD",
"example" : {
@@ -2219,72 +2199,101 @@
"description" : "A schema to define the contents of the status information for A1 Policy Instances. Status schemas are Policy Type specific. All status information for all A1 Policy Instances of an A1 Policy Type should comply with the type's status schema.\n",
"type" : "object"
},
- "PolicyStatusObject" : {
- "description" : "A generic policy status object that can be used to transport any policy status. Additionally, a schema for policy status can be defined in the corresponding A1 Policy Type.\n",
- "type" : "object"
- },
- "void" : {
- "description" : "Void/empty",
+ "PolicyObject" : {
+ "description" : "Policy Object is a JSON representation policy data for an A1 Policy Instance. The schema for this policy data is defined in the corresponding A1 Policy Type.\n",
"type" : "object"
},
- "StatusInfo" : {
+ "ErrorInformation" : {
+ "description" : "Problem as defined in https://tools.ietf.org/html/rfc7807",
"properties" : {
- "status" : {
- "description" : "Status text",
+ "detail" : {
+ "description" : "A human-readable explanation specific to this occurrence of the problem.",
+ "example" : "Policy type not found",
+ "type" : "string"
+ },
+ "title" : {
+ "description" : "A specific error name",
+ "example" : "Not Found",
"type" : "string"
+ },
+ "status" : {
+ "description" : "The HTTP status code generated by the origin server for this occurrence of the problem.\n",
+ "example" : 404,
+ "format" : "int32",
+ "type" : "integer"
}
},
"type" : "object"
},
- "RicInfo" : {
- "description" : "Information for a Near-RT RIC",
+ "PolicyStatusObject" : {
+ "description" : "A generic policy status object that can be used to transport any policy status. Additionally, a schema for policy status can be defined in the corresponding A1 Policy Type.\n",
+ "type" : "object"
+ },
+ "PolicyInformation" : {
+ "description" : "Information tuple for a single A1 Policy Instance. Contains the A1 Policy Instance ID, and the ID of the Near-RT RIC where the policy is created.\n",
"properties" : {
- "ricId" : {
- "description" : "Identity of the Near-RT RIC",
- "type" : "string"
- },
- "managedElementIds" : {
- "description" : "Identities for managed entities",
- "items" : {
- "description" : "Identity for a managed entity",
- "type" : "string"
- },
- "type" : "array"
- },
- "state" : {
- "description" : "Represents the state of a Near-RT RIC",
- "enum" : [ "UNAVAILABLE", "AVAILABLE", "SYNCHRONIZING", "CONSISTENCY_CHECK" ],
+ "policyId" : {
+ "description" : "Identity of the A1 Policy Instance",
"type" : "string"
},
- "policyTypeIds" : {
- "description" : "Supported A1 Policy Types",
- "items" : {
- "description" : "Supported A1 Policy Type ID",
- "type" : "string"
- },
- "type" : "array"
+ "nearRtRicId" : {
+ "$ref" : "#/components/schemas/NearRtRicId"
}
},
+ "required" : [ "nearRtRicId", "policyId" ],
"type" : "object"
},
- "ServiceRegistrationInfo" : {
- "description" : "Information for a service to be registered",
+ "PolicyObjectInformation" : {
+ "description" : "Information to create an A1 Policy Instance",
"properties" : {
- "callbackUrl" : {
- "description" : "Callback URL for notifying of Near-RT RIC state changes",
+ "nearRtRicId" : {
+ "description" : "Identity of the target Near-RT RIC",
+ "example" : "Near-RT-Ric-ID1",
+ "type" : "string"
+ },
+ "transient" : {
+ "default" : false,
+ "description" : "If true, the policy is automatically deleted if the targeted Near-RT RIC restarts or recovers. If false, the A1 Policy Instance remains, and is re-pushed to the targeted Near-RT RIC after a restart or recovery. If false, the A1 Policy Instance is maintained and must be deleted separately in the event of Near-RT RIC restart or recovery. Default is false.\n",
+ "nullable" : false,
+ "type" : "boolean"
+ },
+ "policyId" : {
+ "description" : "An optional identity to be used for the new A1 Policy Instance. If this value is present, it must be unique. If not present the new A1 Policy Instance will be assigned a newly generated unique ID, and the new ID can be extracted from the 'Location' header in the response.\n",
+ "example" : "POLICY-ID1",
"type" : "string"
},
"serviceId" : {
- "description" : "Identity of the service",
+ "default" : "",
+ "description" : "the identity of the service owning the policy. This can be used to group the policies (it is possible to get all policies associated to a service). Note that the service does not need to be registered. If the service is registered, the newly created A1 Policy Instance will be subject to the same supervision rules as the the service's other policies.",
+ "example" : "rApp 1",
"type" : "string"
},
- "keepAliveIntervalSeconds" : {
- "description" : "Keep alive interval for the service. This is used to enable optional heartbeat supervision of the service. If set (> 0) the registered service should regularly invoke a 'keepalive' REST call. When a service fails to invoke this 'keepalive' call within the configured time, the service is considered unavailable. An unavailable service will be automatically deregistered and its policies will be deleted. Value 0 means timeout supervision is disabled.\n",
- "format" : "int64",
- "type" : "integer"
+ "policyObject" : {
+ "$ref" : "#/components/schemas/PolicyObject"
+ },
+ "policyTypeId" : {
+ "description" : "A1 Policy Type identity",
+ "example" : "ORAN_QOS_1.0.0 '(typeName_SemVersion)'",
+ "type" : "string"
+ }
+ },
+ "required" : [ "nearRtRicId", "policyObject", "policyTypeId" ],
+ "type" : "object"
+ },
+ "void" : {
+ "description" : "Void/empty",
+ "type" : "object"
+ },
+ "ServiceStatusList" : {
+ "properties" : {
+ "serviceList" : {
+ "description" : "List of Service Status objects, describing a collection of registered services.",
+ "items" : {
+ "$ref" : "#/components/schemas/ServiceStatus"
+ },
+ "type" : "array"
}
},
- "required" : [ "serviceId" ],
"type" : "object"
},
"ServiceStatus" : {
@@ -2311,47 +2320,24 @@
},
"type" : "object"
},
- "RicInfoList" : {
- "description" : "Collection of Near-RT RIC information objects",
- "properties" : {
- "rics" : {
- "description" : "List of Near-RT RIC information objects",
- "items" : {
- "$ref" : "#/components/schemas/RicInfo"
- },
- "type" : "array"
- }
- },
- "type" : "object"
- },
- "NearRtRicId" : {
- "description" : "Identity of the Near-RT RIC",
- "type" : "string"
- },
- "PolicyInformation" : {
- "description" : "Information tuple for a single A1 Policy Instance. Contains the A1 Policy Instance ID, and the ID of the Near-RT RIC where the policy is created. \n",
+ "ServiceRegistrationInfo" : {
+ "description" : "Information for a service to be registered",
"properties" : {
- "policyId" : {
- "description" : "Identity of the A1 Policy Instance",
+ "callbackUrl" : {
+ "description" : "Callback URL for notifying of Near-RT RIC state changes",
"type" : "string"
},
- "nearRtRicId" : {
- "$ref" : "#/components/schemas/NearRtRicId"
- }
- },
- "required" : [ "nearRtRicId", "policyId" ],
- "type" : "object"
- },
- "ServiceStatusList" : {
- "properties" : {
- "serviceList" : {
- "description" : "List of Service Status objects, describing a collection of registered services.",
- "items" : {
- "$ref" : "#/components/schemas/ServiceStatus"
- },
- "type" : "array"
+ "serviceId" : {
+ "description" : "Identity of the service",
+ "type" : "string"
+ },
+ "keepAliveIntervalSeconds" : {
+ "description" : "Keep alive interval for the service. This is used to enable optional heartbeat supervision of the service. If set (> 0) the registered service should regularly invoke a 'keepalive' REST call. When a service fails to invoke this 'keepalive' call within the configured time, the service is considered unavailable. An unavailable service will be automatically deregistered and its policies will be deleted. Value 0 means timeout supervision is disabled.\n",
+ "format" : "int64",
+ "type" : "integer"
}
},
+ "required" : [ "serviceId" ],
"type" : "object"
},
"ServiceCallbackInfo" : {
@@ -2369,32 +2355,6 @@
},
"required" : [ "eventType", "ricId" ],
"type" : "object"
- },
- "ProblemDetails" : {
- "description" : "Object to carry details about a problem in an HTTP response according to IETF RFC 7807",
- "properties" : {
- "type" : {
- "description" : "URI reference according to IETF RFC 3986 that identifies the problem type",
- "type" : "string"
- },
- "title" : {
- "description" : "Human-readable summary of the problem type",
- "type" : "string"
- },
- "status" : {
- "description" : "HTTP status code",
- "type" : "number"
- },
- "detail" : {
- "description" : "Human-readable explanation",
- "type" : "string"
- },
- "instance" : {
- "description" : "URI reference that identifies the specific occurrence of the problem",
- "type" : "string"
- }
- },
- "type" : "object"
}
}
}
diff --git a/docs/offeredapis/swagger/pms-api-v3.yaml b/docs/offeredapis/swagger/pms-api-v3.yaml
index 0865ff2b..f4e16793 100644
--- a/docs/offeredapis/swagger/pms-api-v3.yaml
+++ b/docs/offeredapis/swagger/pms-api-v3.yaml
@@ -19,531 +19,794 @@
openapi: 3.0.3
info:
- title: ONAP CCSDK - A1 Policy Management API
- version: 1.0.0
- x-api-id: e9776a07-0813-4fca-9801-6f892f0a7c13
- 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 the latest 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>\
- \ <p>Note: parts of this API are strongly based on extracts of the O-RAN Alliance R1 Interface specification\
- \ for A1 Policy Management, and those parts should be considered '© O-RAN ALLIANCE - All rights reserved.'</p>\
- \ <h3>A1 Policy Management</h3>\
- \ <p>This is the latest API for managing A1 Policies. This API is partially compliant with O-RAN\
- \ Alliance R1 Interface specifications for A1 Policy Management:</p><ul><li>A1 Policy retrieval, creation,\
+ contact:
+ email: discuss-list@onap.com
+ url: https://www.onap.org/
+ description: "<h2>General</h2><p>The ONAP CCSDK A1 Policy Management Service provides\
+ \ a REST API for managing A1 policies. <br/>This document describes the latest\
+ \ 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> <p>Note: parts of this API are strongly\
+ \ based on extracts of the O-RAN Alliance R1 Interface specification for A1 Policy\
+ \ Management, and those parts should be considered '© O-RAN ALLIANCE - All rights\
+ \ reserved.'</p> <h3>A1 Policy Management</h3> <p>This is the latest API for managing\
+ \ A1 Policies. This API is partially compliant with O-RAN Alliance R1 Interface\
+ \ specifications for A1 Policy Management:</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 optionally monitored by a heart-beat supervision\
- \ mechanism, and if the registered service becomes unavailable, then it is removed and all its A1 Policies are \
- \ deleted. 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>"
+ \ 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 optionally monitored by a heart-beat supervision mechanism,\
+ \ and if the registered service becomes unavailable, then it is removed and all\
+ \ its A1 Policies are deleted. 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>"
license:
- name: Copyright (C) 2024 - 2025 OpenInfra Foundation Europe. Licensed under the Apache 2 License.
+ name: Copyright (C) 2024 - 2025 OpenInfra Foundation Europe. Licensed under the
+ Apache 2 License.
url: http://www.apache.org/licenses/LICENSE-2.0
- contact:
- url: https://www.onap.org/
- email: discuss-list@onap.com
+ title: ONAP CCSDK - A1 Policy Management API
+ version: 1.0.0
+ x-api-id: e9776a07-0813-4fca-9801-6f892f0a7c13
+ x-audience: external-public
externalDocs:
- description: 'Based on parts of O-RAN ALLIANCE specification: O-RAN.WG2.R1AP-v07.00'
- url: 'https://www.o-ran.org/specifications'
+ description: "Based on parts of O-RAN ALLIANCE specification: O-RAN.WG2.R1AP-v07.00"
+ url: https://www.o-ran.org/specifications
servers:
- - url: '{apiRoot}/a1-policy-management/v1'
- variables:
- apiRoot:
- default: 'https://example.com'
- description: 'This is the Host:Port or Address where the A1-Policy Management Service can be accessed.
- Note: This URL path format aligns with the O-RAN Alliance R1-AP specifications for A1 Policy Management'
+- url: "{apiRoot}/a1-policy-management/v1"
+ variables:
+ apiRoot:
+ default: https://example.com
+ description: "This is the Host:Port or Address where the A1-Policy Management\
+ \ Service can be accessed. Note: This URL path format aligns with the O-RAN\
+ \ Alliance R1-AP specifications for A1 Policy Management"
tags:
- - name: A1 Policy Management
- description: >
- API used to get, create, update and delete A1 Policy Instances. Also used to query A1 Policy Types.
- - name: NearRT-RIC Repository
- description: >
- API used to get information about registered Near-RT RICs.
- - name: Service Registry and Supervision
- description: >
- 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: Configuration
- description: >
- API used to create or fetch the application configuration.
+- description: |
+ API used to get, create, update and delete A1 Policy Instances. Also used to query A1 Policy Types.
+ name: A1 Policy Management
+- description: |
+ API used to get information about registered Near-RT RICs.
+ name: NearRT-RIC Repository
+- description: |
+ API used to manage registered services, and control their keep-alive status via heart-beat messages.
+ name: Service Registry and Supervision
+- description: |
+ API used to get the health status and statistics of this service.
+ name: Health Check
+- description: |
+ API used to create or fetch the application configuration.
+ name: Configuration
paths:
/status:
get:
- operationId: getStatus
description: Returns status and statistics of this service
- summary: Get Status (getStatus)
- tags:
- - Health Check
+ operationId: getStatus
responses:
"200":
content:
application/json:
- schema:
- $ref: '#/components/schemas/StatusInfo'
examples:
status_info:
$ref: '#/components/examples/StatusInfo'
+ schema:
+ $ref: '#/components/schemas/StatusInfo'
description: OK- Service is living Ok
"404":
- $ref: '#/components/responses/404'
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Found
+ summary: Get Status (getStatus)
+ tags:
+ - Health Check
/rics/{ricId}:
get:
+ description: Get information about a Near-RT RIC
operationId: getRic
- description: Get information about a Near-RT RIC
- summary: Get a Near-RT RIC (getRic)
- tags:
- - NearRT-RIC Repository
parameters:
- - description: The identity of a Near-RT RIC to get information for.
- explode: true
- in: path
- name: ricId
- required: true
- schema:
- type: string
- nullable: false
- - description: Specifies the content type that the client expects to receive in response to the request.
- Only application/json is allowed.
- in: header
- name: Accept
- schema:
- type: string
- example: application/json
+ - description: The identity of a Near-RT RIC to get information for.
+ explode: true
+ in: path
+ name: ricId
+ required: true
+ schema:
+ nullable: false
+ type: string
+ - description: Specifies the content type that the client expects to receive
+ in response to the request. Only application/json is allowed.
+ in: header
+ name: Accept
+ schema:
+ example: application/json
+ type: string
responses:
"200":
content:
application/json:
- schema:
- $ref: '#/components/schemas/RicInfo'
examples:
ric_info:
$ref: '#/components/examples/RicInfo'
+ schema:
+ $ref: '#/components/schemas/RicInfo'
description: OK - Near-RT RIC is found OK
"404":
- $ref: '#/components/responses/404'
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Found
+ summary: Get a Near-RT RIC (getRic)
+ tags:
+ - NearRT-RIC Repository
/rics:
get:
- operationId: getRics
description: Get all Near-RT RICs that supports a given A1 Policy Type ID
- summary: Get Near-RT RICs for A1 Policy Type (getRics)
- tags:
- - NearRT-RIC Repository
+ operationId: getRics
parameters:
- - description: >
- The identity of an A1 Policy Type. If given, all Near-RT RICs supporting
- the A1 Policy Type are returned.
- explode: true
- in: query
- name: policyTypeId
- required: false
- schema:
- type: string
- style: form
- - description: Specifies the content type that the client expects to receive in response to the request.
- Only application/json is allowed.
- in: header
- name: Accept
- schema:
- type: string
- example: application/json
+ - description: |
+ The identity of an A1 Policy Type. If given, all Near-RT RICs supporting the A1 Policy Type are returned.
+ explode: true
+ in: query
+ name: policyTypeId
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: Specifies the content type that the client expects to receive
+ in response to the request. Only application/json is allowed.
+ in: header
+ name: Accept
+ schema:
+ example: application/json
+ type: string
responses:
"200":
content:
application/json:
- schema:
- $ref: '#/components/schemas/RicInfoList'
examples:
ric_info_list:
$ref: '#/components/examples/RicInfoList'
+ schema:
+ $ref: '#/components/schemas/RicInfoList'
description: OK
"404":
- $ref: '#/components/responses/404'
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Found
+ summary: Get Near-RT RICs for A1 Policy Type (getRics)
+ tags:
+ - NearRT-RIC Repository
/policy-types:
get:
description: Query A1 Policy Type identities using query parameters
operationId: getPolicyTypes
- summary: Get A1 Policy Types (getPolicyTypes)
- tags:
- - A1 Policy Management
parameters:
- - description: Select types for the given Near-RT RIC identity.
- explode: true
- in: query
- name: nearRtRicId
- required: false
- schema:
- type: string
- style: form
- - description: Select types compatible with the given type name (type identity has the format 'typename_version')
- explode: true
- in: query
- name: typeName
- required: false
- schema:
- type: string
- style: form
- - description: >
- Select types that are compatible with the given version. This
- parameter is only applicable in conjunction with typeName. As an example
- version 1.9.1 is compatible with 1.0.0 but not the other way around. Matching
- types will be returned sorted in ascending order.
- explode: true
- in: query
- name: compatibleWithVersion
- required: false
- schema:
- type: string
- style: form
- - description: Specifies the content type that the client expects to receive in response to the request.
- Only application/json is allowed.
- in: header
- name: Accept
- schema:
- type: string
- example: application/json
+ - description: Select types for the given Near-RT RIC identity.
+ explode: true
+ in: query
+ name: nearRtRicId
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: Select types compatible with the given type name (type identity
+ has the format 'typename_version')
+ explode: true
+ in: query
+ name: typeName
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: |
+ Select types that are compatible with the given version. This parameter is only applicable in conjunction with typeName. As an example version 1.9.1 is compatible with 1.0.0 but not the other way around. Matching types will be returned sorted in ascending order.
+ explode: true
+ in: query
+ name: compatibleWithVersion
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: Specifies the content type that the client expects to receive
+ in response to the request. Only application/json is allowed.
+ in: header
+ name: Accept
+ schema:
+ example: application/json
+ type: string
responses:
- '200':
+ "200":
content:
application/json:
+ examples:
+ PolicyTypeInformation:
+ $ref: '#/components/examples/PolicyTypeInformation'
schema:
items:
$ref: '#/components/schemas/PolicyTypeInformation'
type: array
- examples:
- PolicyTypeInformation:
- $ref: '#/components/examples/PolicyTypeInformation'
description: OK - Policy Type IDs found Ok
- '400':
- $ref: '#/components/responses/400'
- '401':
- $ref: '#/components/responses/401'
- '403':
- $ref: '#/components/responses/403'
- '404':
- $ref: '#/components/responses/404'
- '406':
- $ref: '#/components/responses/406'
- '429':
- $ref: '#/components/responses/429'
- '500':
- $ref: '#/components/responses/500'
- '502':
- $ref: '#/components/responses/502'
- '503':
- $ref: '#/components/responses/503'
+ "400":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Request
+ "401":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Unauthorized
+ "403":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Forbidden
+ "404":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Found
+ "406":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Acceptable
+ "429":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Too Many Requests
+ "500":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Internal Server Error
+ "502":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Gateway
+ "503":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Service Unavailable
+ summary: Get A1 Policy Types (getPolicyTypes)
+ tags:
+ - A1 Policy Management
/policy-types/{policyTypeId}:
get:
- operationId: getPolicyTypeDefinition
description: Get an A1 Policy Type definition using its policy type ID
- summary: Get an A1 Policy Type definition (getPolicyTypeDefinition)
- tags:
- - A1 Policy Management
+ operationId: getPolicyTypeDefinition
parameters:
- - explode: false
- in: path
- name: policyTypeId
- required: true
- schema:
- type: string
- style: simple
- - description: Specifies the content type that the client expects to receive in response to the request.
- Only application/json is allowed.
- in: header
- name: Accept
- schema:
- type: string
- example: application/json
+ - explode: false
+ in: path
+ name: policyTypeId
+ required: true
+ schema:
+ type: string
+ style: simple
+ - description: Specifies the content type that the client expects to receive
+ in response to the request. Only application/json is allowed.
+ in: header
+ name: Accept
+ schema:
+ example: application/json
+ type: string
responses:
- '200':
+ "200":
content:
application/json:
- schema:
- $ref: '#/components/schemas/PolicyTypeObject'
examples:
PolicyTypeObject:
$ref: '#/components/examples/PolicyTypeObject'
+ schema:
+ $ref: '#/components/schemas/PolicyTypeObject'
description: OK - details and schema of the requested A1 Policy Type
- '400':
- $ref: '#/components/responses/400'
- '401':
- $ref: '#/components/responses/401'
- '403':
- $ref: '#/components/responses/403'
- '404':
- $ref: '#/components/responses/404'
- '406':
- $ref: '#/components/responses/406'
- '429':
- $ref: '#/components/responses/429'
- '500':
- $ref: '#/components/responses/500'
- '502':
- $ref: '#/components/responses/502'
- '503':
- $ref: '#/components/responses/503'
- /policies/{policyId}:
- put:
- operationId: updatePolicy
- description: Update an existing A1 Policy instance's policy data using its policy ID.
- summary: Update an A1 Policy's policy data (updatePolicy)
+ "400":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Request
+ "401":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Unauthorized
+ "403":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Forbidden
+ "404":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Found
+ "406":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Acceptable
+ "429":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Too Many Requests
+ "500":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Internal Server Error
+ "502":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Gateway
+ "503":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Service Unavailable
+ summary: Get an A1 Policy Type definition (getPolicyTypeDefinition)
tags:
- - A1 Policy Management
+ - A1 Policy Management
+ /policies/{policyId}:
+ delete:
+ description: Delete an existing A1 Policy instance using its policy ID.
+ operationId: deletePolicy
parameters:
- - name: policyId
- in: path
- required: true
- schema:
- type: string
- requestBody:
+ - explode: false
+ in: path
+ name: policyId
required: true
- content:
- application/json:
- schema:
- $ref: '#/components/schemas/PolicyObject'
- examples:
- policyObject:
- $ref: '#/components/examples/PolicyObject'
+ schema:
+ type: string
+ style: simple
+ - description: Specifies the content type that the client expects to receive
+ in response to the request. Only application/json is allowed.
+ in: header
+ name: Accept
+ schema:
+ example: application/json
+ type: string
responses:
- '200':
+ "204":
+ description: No Content
+ "400":
content:
- application/json:
+ application/problem+json:
schema:
- $ref: '#/components/schemas/PolicyObject'
- description: OK - Policy updated
- '400':
- $ref: '#/components/responses/400'
- '401':
- $ref: '#/components/responses/401'
- '403':
- $ref: '#/components/responses/403'
- '404':
- $ref: '#/components/responses/404'
- '406':
- $ref: '#/components/responses/406'
- '411':
- $ref: '#/components/responses/411'
- '413':
- $ref: '#/components/responses/413'
- '415':
- $ref: '#/components/responses/415'
- '423':
- $ref: '#/components/responses/Locked'
- '429':
- $ref: '#/components/responses/429'
- '500':
- $ref: '#/components/responses/500'
- '502':
- $ref: '#/components/responses/502'
- '503':
- $ref: '#/components/responses/503'
- delete:
- operationId: deletePolicy
- description: Delete an existing A1 Policy instance using its policy ID.
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Request
+ "401":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Unauthorized
+ "403":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Forbidden
+ "404":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Found
+ "405":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Method Not Allowed
+ "406":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Acceptable
+ "423":
+ content:
+ application/problem+json:
+ example:
+ status: 423
+ title: Locked
+ detail: State is Locked in the provided request.
+ schema:
+ $ref: '#/components/schemas/ErrorInformation'
+ description: Locked - HTTP Status code which can be used when the state
+ is Locked
+ "429":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Too Many Requests
+ "500":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Internal Server Error
+ "502":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Gateway
+ "503":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Service Unavailable
summary: Delete an A1 Policy instance (deletePolicy)
tags:
- - A1 Policy Management
- parameters:
- - explode: false
- in: path
- name: policyId
- required: true
- schema:
- type: string
- style: simple
- - description: Specifies the content type that the client expects to receive in response to the request.
- Only application/json is allowed.
- in: header
- name: Accept
- schema:
- type: string
- example: application/json
- responses:
- '204':
- description: 'No Content'
- '400':
- $ref: '#/components/responses/400'
- '401':
- $ref: '#/components/responses/401'
- '403':
- $ref: '#/components/responses/403'
- '404':
- $ref: '#/components/responses/404'
- '405':
- $ref: '#/components/responses/405'
- '406':
- $ref: '#/components/responses/406'
- '423':
- $ref: '#/components/responses/Locked'
- '429':
- $ref: '#/components/responses/429'
- '500':
- $ref: '#/components/responses/500'
- '502':
- $ref: '#/components/responses/502'
- '503':
- $ref: '#/components/responses/503'
+ - A1 Policy Management
get:
- operationId: getPolicy
description: Get an A1 Policy instance's policy data using its policy ID
- summary: Get an A1 Policy's policy data (getPolicy)
- tags:
- - A1 Policy Management
+ operationId: getPolicy
parameters:
- - explode: false
- in: path
- name: policyId
- required: true
- schema:
- type: string
- style: simple
- - description: Specifies the content type that the client expects to receive in response to the request.
- Only application/json is allowed.
- in: header
- name: Accept
- schema:
- type: string
- example: application/json
+ - explode: false
+ in: path
+ name: policyId
+ required: true
+ schema:
+ type: string
+ style: simple
+ - description: Specifies the content type that the client expects to receive
+ in response to the request. Only application/json is allowed.
+ in: header
+ name: Accept
+ schema:
+ example: application/json
+ type: string
responses:
- '200':
+ "200":
content:
application/json:
- schema:
- $ref: '#/components/schemas/PolicyObject'
examples:
policyObject:
$ref: '#/components/examples/PolicyObject'
+ schema:
+ $ref: '#/components/schemas/PolicyObject'
description: OK - Policy found
- '400':
- $ref: '#/components/responses/400'
- '401':
- $ref: '#/components/responses/401'
- '403':
- $ref: '#/components/responses/403'
- '404':
- $ref: '#/components/responses/404'
- '406':
- $ref: '#/components/responses/406'
- '429':
- $ref: '#/components/responses/429'
- '500':
- $ref: '#/components/responses/500'
- '502':
- $ref: '#/components/responses/502'
- '503':
- $ref: '#/components/responses/503'
+ "400":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Request
+ "401":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Unauthorized
+ "403":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Forbidden
+ "404":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Found
+ "406":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Acceptable
+ "429":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Too Many Requests
+ "500":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Internal Server Error
+ "502":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Gateway
+ "503":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Service Unavailable
+ summary: Get an A1 Policy's policy data (getPolicy)
+ tags:
+ - A1 Policy Management
+ put:
+ description: Update an existing A1 Policy instance's policy data using its policy
+ ID.
+ operationId: updatePolicy
+ parameters:
+ - in: path
+ name: policyId
+ required: true
+ schema:
+ type: string
+ requestBody:
+ content:
+ application/json:
+ examples:
+ policyObject:
+ $ref: '#/components/examples/PolicyObject'
+ schema:
+ $ref: '#/components/schemas/PolicyObject'
+ required: true
+ responses:
+ "200":
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/PolicyObject'
+ description: OK - Policy updated
+ "400":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Request
+ "401":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Unauthorized
+ "403":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Forbidden
+ "404":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Found
+ "406":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Acceptable
+ "411":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Length Required
+ "413":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Payload Too Large
+ "415":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Unsupported Media Type
+ "423":
+ content:
+ application/problem+json:
+ example:
+ status: 423
+ title: Locked
+ detail: State is Locked in the provided request.
+ schema:
+ $ref: '#/components/schemas/ErrorInformation'
+ description: Locked - HTTP Status code which can be used when the state
+ is Locked
+ "429":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Too Many Requests
+ "500":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Internal Server Error
+ "502":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Gateway
+ "503":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Service Unavailable
+ summary: Update an A1 Policy's policy data (updatePolicy)
+ tags:
+ - A1 Policy Management
/policies/{policyId}/status:
get:
+ description: Retrieve the status information for an A1 Policy Instance using
+ its policy ID.
operationId: getPolicyStatus
- description: Retrieve the status information for an A1 Policy Instance using its policy ID.
- summary: Get an A1 Policy Instance's status (getPolicyStatus)
- tags:
- - A1 Policy Management
parameters:
- - explode: false
- in: path
- name: policyId
- required: true
- schema:
- type: string
- style: simple
- - description: Specifies the content type that the client expects to receive in response to the request.
- Only application/json is allowed.
- in: header
- name: Accept
- schema:
- type: string
- example: application/json
+ - explode: false
+ in: path
+ name: policyId
+ required: true
+ schema:
+ type: string
+ style: simple
+ - description: Specifies the content type that the client expects to receive
+ in response to the request. Only application/json is allowed.
+ in: header
+ name: Accept
+ schema:
+ example: application/json
+ type: string
responses:
- '200':
+ "200":
content:
application/json:
schema:
$ref: '#/components/schemas/PolicyStatusObject'
description: OK
- '400':
- $ref: '#/components/responses/400'
- '401':
- $ref: '#/components/responses/401'
- '403':
- $ref: '#/components/responses/403'
- '404':
- $ref: '#/components/responses/404'
- '406':
- $ref: '#/components/responses/406'
- '429':
- $ref: '#/components/responses/429'
- '500':
- $ref: '#/components/responses/500'
- '502':
- $ref: '#/components/responses/502'
- '503':
- $ref: '#/components/responses/503'
+ "400":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Request
+ "401":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Unauthorized
+ "403":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Forbidden
+ "404":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Found
+ "406":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Acceptable
+ "429":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Too Many Requests
+ "500":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Internal Server Error
+ "502":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Gateway
+ "503":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Service Unavailable
+ summary: Get an A1 Policy Instance's status (getPolicyStatus)
+ tags:
+ - A1 Policy Management
/policies:
get:
+ description: |
+ Returns a collection of A1 Policy Instance IDs for policies that match given search criteria. If several query parameters are defined, the policies matching all conditions are returned.
operationId: getPolicyIds
- description: >
- Returns a collection of A1 Policy Instance IDs for policies that match given search criteria.
- If several query parameters are defined, the policies matching all conditions are returned.
- summary: Query for A1 Policy instances (getPolicyIds)
- tags:
- - A1 Policy Management
parameters:
- - description: Select policies with a given A1 Policy Type ID.
- explode: true
- in: query
- name: policyTypeId
- required: false
- schema:
- type: string
- style: form
- - description: Select policies for a given Near-RT RIC identity.
- explode: true
- in: query
- name: nearRtRicId
- required: false
- schema:
- type: string
- style: form
- - description: Select policies owned by a given service (registered or unregistered).
- explode: true
- in: query
- name: serviceId
- required: false
- schema:
- type: string
- style: form
- - description: Select policies of a given A1 Policy Type name (type identity has the format 'typename_version').
- explode: true
- in: query
- name: typeName
- required: false
- schema:
- type: string
- style: form
- - description: Specifies the content type that the client expects to receive in response to the request.
- Only application/json is allowed.
- in: header
- name: Accept
- schema:
- type: string
- example: application/json
+ - description: Select policies with a given A1 Policy Type ID.
+ explode: true
+ in: query
+ name: policyTypeId
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: Select policies for a given Near-RT RIC identity.
+ explode: true
+ in: query
+ name: nearRtRicId
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: Select policies owned by a given service (registered or unregistered).
+ explode: true
+ in: query
+ name: serviceId
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: Select policies of a given A1 Policy Type name (type identity
+ has the format 'typename_version').
+ explode: true
+ in: query
+ name: typeName
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: Specifies the content type that the client expects to receive
+ in response to the request. Only application/json is allowed.
+ in: header
+ name: Accept
+ schema:
+ example: application/json
+ type: string
responses:
- '200':
+ "200":
content:
application/json:
schema:
@@ -551,93 +814,187 @@ paths:
$ref: '#/components/schemas/PolicyInformation'
type: array
description: OK - Policy identities
- '400':
- $ref: '#/components/responses/400'
- '401':
- $ref: '#/components/responses/401'
- '403':
- $ref: '#/components/responses/403'
- '404':
- $ref: '#/components/responses/404'
- '406':
- $ref: '#/components/responses/406'
- '429':
- $ref: '#/components/responses/429'
- '500':
- $ref: '#/components/responses/500'
- '502':
- $ref: '#/components/responses/502'
- '503':
- $ref: '#/components/responses/503'
+ "400":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Request
+ "401":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Unauthorized
+ "403":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Forbidden
+ "404":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Found
+ "406":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Acceptable
+ "429":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Too Many Requests
+ "500":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Internal Server Error
+ "502":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Gateway
+ "503":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Service Unavailable
+ summary: Query for A1 Policy instances (getPolicyIds)
+ tags:
+ - A1 Policy Management
post:
- operationId: createPolicy
description: Create an A1 Policy Instance
- summary: Create an A1 Policy Instance (createPolicy)
- tags:
- - A1 Policy Management
+ operationId: createPolicy
requestBody:
- required: true
content:
application/json:
schema:
$ref: '#/components/schemas/PolicyObjectInformation'
+ required: true
responses:
- '201':
- description: 'Created'
+ "201":
content:
application/json:
schema:
$ref: '#/components/schemas/PolicyObjectInformation'
+ description: Created
headers:
Location:
- description: >
- Contains the URI of the newly created A1 Policy Instances.
- This URI includes the A1 Policy Instance ID for the newly
- created policy instance.
+ description: |
+ Contains the URI of the newly created A1 Policy Instances. This URI includes the A1 Policy Instance ID for the newly created policy instance.
required: true
schema:
type: string
Content-Type:
- description: 'Media Type of the response'
+ description: Media Type of the response
schema:
- type: string
example: application/json
-
- '400':
- $ref: '#/components/responses/400'
- '401':
- $ref: '#/components/responses/401'
- '403':
- $ref: '#/components/responses/403'
- '404':
- $ref: '#/components/responses/404'
- '405':
- $ref: '#/components/responses/405'
- '406':
- $ref: '#/components/responses/406'
- '409':
- $ref: '#/components/responses/409'
- '413':
- $ref: '#/components/responses/413'
- '415':
- $ref: '#/components/responses/415'
- '423':
- $ref: '#/components/responses/Locked'
- '429':
- $ref: '#/components/responses/429'
- '500':
- $ref: '#/components/responses/500'
- '502':
- $ref: '#/components/responses/502'
- '503':
- $ref: '#/components/responses/503'
+ type: string
+ "400":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Request
+ "401":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Unauthorized
+ "403":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Forbidden
+ "404":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Found
+ "405":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Method Not Allowed
+ "406":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Acceptable
+ "409":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Conflict
+ "413":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Payload Too Large
+ "415":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Unsupported Media Type
+ "423":
+ content:
+ application/problem+json:
+ example:
+ status: 423
+ title: Locked
+ detail: State is Locked in the provided request.
+ schema:
+ $ref: '#/components/schemas/ErrorInformation'
+ description: Locked - HTTP Status code which can be used when the state
+ is Locked
+ "429":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Too Many Requests
+ "500":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Internal Server Error
+ "502":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Gateway
+ "503":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Service Unavailable
+ summary: Create an A1 Policy Instance (createPolicy)
+ tags:
+ - A1 Policy Management
/configuration:
get:
- operationId: getConfiguration
description: Returns the entire contents of the Application Configuration.
- tags:
- - Configuration
- summary: Get the Application Configuration (getConfiguration)
+ operationId: getConfiguration
responses:
"200":
content:
@@ -646,17 +1003,18 @@ paths:
type: string
description: OK - Application configuration received
"404":
- $ref: '#/components/responses/404'
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Found
+ summary: Get the Application Configuration (getConfiguration)
+ tags:
+ - Configuration
put:
+ description: |
+ Replace the current Application Configuration with a new configuration. The new configuration, if accepted, will take effect after a short delay. The new configuration must comply with the Application Configuration schema, which can be found from the the Application Documentation (Developer Guide)
operationId: putConfiguration
- description: >
- Replace the current Application Configuration with a new configuration.
- The new configuration, if accepted, will take effect after a short delay.
- The new configuration must comply with the Application Configuration schema,
- which can be found from the the Application Documentation (Developer Guide)
- tags:
- - Configuration
- summary: Set/Replace the Application Configuration (putConfiguration)
requestBody:
content:
application/json:
@@ -666,139 +1024,116 @@ paths:
responses:
"200":
content:
- 'application/json':
+ application/json:
schema:
$ref: '#/components/schemas/void'
description: OK - Configuration updated
"400":
- $ref: '#/components/responses/400'
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Request
+ summary: Set/Replace the Application Configuration (putConfiguration)
+ tags:
+ - Configuration
/services/{serviceId}/keepalive:
put:
+ description: "A registered service should invoke this operation regularly to\
+ \ indicate that it is still alive. If a registered service fails to invoke\
+ \ some operation, or this operation, before the end of a timeout period the\
+ \ service will be deregistered and all its A1 policies wil be removed and\
+ \ the service is deleted. This operation is only intended for registered services.\
+ \ (This timeout can be set or disabled when each service is initially registered).\
+ \ Unregistered services do not need to invoke this operation, since the optional\
+ \ keep-alive monitoring feature can only be enabled for registered services."
operationId: keepAliveService
- description: A registered service should invoke this operation regularly to
- indicate that it is still alive. If a registered service fails to invoke some operation,
- or this operation, before the end of a timeout period the service will be deregistered
- and all its A1 policies wil be removed and the service is deleted.
- This operation is only intended for registered services. (This timeout can be set or disabled when
- each service is initially registered). Unregistered services do not need to invoke this operation,
- since the optional keep-alive monitoring feature can only be enabled for registered services.
- summary: Heartbeat message from a service (keepAliveService)
- tags:
- - Service Registry and Supervision
parameters:
- - explode: false
- in: path
- name: serviceId
- required: true
- schema:
- type: string
- style: simple
- - description: Specifies the content type that the client expects to receive in response to the request.
- Only application/json is allowed.
- in: header
- name: Accept
- schema:
- type: string
- example: application/json
+ - explode: false
+ in: path
+ name: serviceId
+ required: true
+ schema:
+ type: string
+ style: simple
+ - description: Specifies the content type that the client expects to receive
+ in response to the request. Only application/json is allowed.
+ in: header
+ name: Accept
+ schema:
+ example: application/json
+ type: string
requestBody:
- required: false
content:
application/json:
schema:
type: string
+ required: false
responses:
"200":
content:
- 'application/json':
+ application/json:
schema:
type: object
- description: OK - Service supervision timer refreshed, OK
+ description: "OK - Service supervision timer refreshed, OK"
"404":
- $ref: '#/components/responses/404'
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Found
+ summary: Heartbeat message from a service (keepAliveService)
+ tags:
+ - Service Registry and Supervision
/services:
get:
+ description: |
+ Get information about all registered services, or a single registered service. If the service ID of a registered service is included in the query, information about that service is returned. Otherwise Information about all registered is returned. This operation does not retrieve information about unregistered services.
operationId: getServices
- description: >
- Get information about all registered services, or a single registered service.
- If the service ID of a registered service is included in the query, information about that
- service is returned. Otherwise Information about all registered is returned.
- This operation does not retrieve information about unregistered services.
- summary: Get Services (getServices)
- tags:
- - Service Registry and Supervision
parameters:
- - description: The identity of the registered service
- explode: true
- in: query
- name: serviceId
- required: false
- schema:
- type: string
- style: form
- - description: Specifies the content type that the client expects to receive in response to the request.
- Only application/json is allowed.
- in: header
- name: Accept
- schema:
- type: string
- example: application/json
+ - description: The identity of the registered service
+ explode: true
+ in: query
+ name: serviceId
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: Specifies the content type that the client expects to receive
+ in response to the request. Only application/json is allowed.
+ in: header
+ name: Accept
+ schema:
+ example: application/json
+ type: string
responses:
"200":
content:
application/json:
- schema:
- $ref: '#/components/schemas/ServiceStatusList'
examples:
service_status_list:
$ref: '#/components/examples/ServiceStatusList'
+ schema:
+ $ref: '#/components/schemas/ServiceStatusList'
description: OK
"404":
- $ref: '#/components/responses/404'
- put:
- operationId: putService
- description: >
- Register a single service, or update a previous registration.
- Service registration is required to get callbacks about available NearRT RICs
- and to enable supervision of the service's active status. If a registered
- service becomes inactive, its policies can be automatically deleted.
- A1 Policy instances can also be created for unregistered services.
- If an unregistered service is later registered, the service's policies are
- retained when the service becomes registered. This feature is optional to use.
- summary: Register or update a Service (putService)
- tags:
- - Service Registry and Supervision
- requestBody:
- content:
- application/json:
- schema:
- $ref: '#/components/schemas/ServiceRegistrationInfo'
- required: true
- responses:
- "200":
- content:
- 'application/json':
- schema:
- type: object
- description: OK - Service updated
- "201":
content:
- 'application/json':
+ application/problem+json:
schema:
- type: object
- description: Created - Service created
- "400":
- $ref: '#/components/responses/400'
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Found
+ summary: Get Services (getServices)
+ tags:
+ - Service Registry and Supervision
+ put:
callbacks:
RICStatus:
- "{$request.body#/callback_url}":
+ '{$request.body#/callback_url}':
post:
+ description: "Callouts to indicate Near-RT RIC status changes relevant\
+ \ for Services. \nThe URL invoked by this callback is provided at\
+ \ Service registration.\n"
operationId: serviceCallback
- description: |
- Callouts to indicate Near-RT RIC status changes relevant for Services.
- The URL invoked by this callback is provided at Service registration.
- summary: Callback for Near-RT RIC status (serviceCallback)
- tags:
- - Service Registry and Supervision
requestBody:
content:
application/json:
@@ -813,57 +1148,84 @@ paths:
$ref: '#/components/schemas/void'
description: OK
"404":
- $ref: '#/components/responses/404'
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Found
+ summary: Callback for Near-RT RIC status (serviceCallback)
+ tags:
+ - Service Registry and Supervision
+ x-callback-request: true
+ description: |
+ Register a single service, or update a previous registration. Service registration is required to get callbacks about available NearRT RICs and to enable supervision of the service's active status. If a registered service becomes inactive, its policies can be automatically deleted. A1 Policy instances can also be created for unregistered services. If an unregistered service is later registered, the service's policies are retained when the service becomes registered. This feature is optional to use.
+ operationId: putService
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/ServiceRegistrationInfo'
+ required: true
+ responses:
+ "200":
+ content:
+ application/json:
+ schema:
+ type: object
+ description: OK - Service updated
+ "201":
+ content:
+ application/json:
+ schema:
+ type: object
+ description: Created - Service created
+ "400":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Request
+ summary: Register or update a Service (putService)
+ tags:
+ - Service Registry and Supervision
/services/{serviceId}:
delete:
+ description: |
+ Unregister a registered Service using its service ID. Only registered services can be unregistered. All A1 Policy Instances for the previously registered service will be removed.
operationId: deleteService
- description: >
- Unregister a registered Service using its service ID.
- Only registered services can be unregistered. All A1 Policy Instances
- for the previously registered service will be removed.
- tags:
- - Service Registry and Supervision
- summary: Unregister a Service (deleteService)
parameters:
- - explode: false
- in: path
- name: serviceId
- required: true
- schema:
- type: string
- style: simple
- - description: Specifies the content type that the client expects to receive in response to the request.
- Only application/json is allowed.
- in: header
- name: Accept
- schema:
- type: string
- example: application/json
+ - explode: false
+ in: path
+ name: serviceId
+ required: true
+ schema:
+ type: string
+ style: simple
+ - description: Specifies the content type that the client expects to receive
+ in response to the request. Only application/json is allowed.
+ in: header
+ name: Accept
+ schema:
+ example: application/json
+ type: string
responses:
"204":
content:
- 'application/json':
+ application/json:
schema:
type: object
description: No Content - Service unregistered
"404":
- $ref: '#/components/responses/404'
-
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Found
+ summary: Unregister a Service (deleteService)
+ tags:
+ - Service Registry and Supervision
components:
-
examples:
- ServiceStatusList:
- description: List of service information
- value:
- serviceList:
- - callbackUrl: http://callback.url
- serviceId: serviceId1
- keepAliveIntervalSeconds: 0
- timeSinceLastActivitySeconds: 6
- - callbackUrl: http://callback.url
- serviceId: serviceId2
- keepAliveIntervalSeconds: 500
- timeSinceLastActivitySeconds: 401
StatusInfo:
value:
status: success
@@ -871,33 +1233,70 @@ components:
value:
ricId: ricId1
managedElementIds:
- - "Note #1"
- - "Athlone small cells"
- - "Some optional string"
+ - "Note #1"
+ - Athlone small cells
+ - Some optional string
state: UNAVAILABLE
policyTypeIds:
- - policyTypeId1
- - policyTypeId2
+ - policyTypeId1
+ - policyTypeId2
RicInfoList:
value:
rics:
- - ricId: ricId1
- managedElementIds:
- - "Note #1"
- - "Athlone small cells"
- - "Fake Cells"
- state: UNAVAILABLE
- policyTypeIds:
- - policyTypeId1
- - policyTypeId2
- - ricId: ricId2
- managedElementIds:
- - "My test element"
- - "Another test element"
- state: UNAVAILABLE
- policyTypeIds:
- - policyTypeId3
- - policyTypeId4
+ - ricId: ricId1
+ managedElementIds:
+ - "Note #1"
+ - Athlone small cells
+ - Fake Cells
+ state: UNAVAILABLE
+ policyTypeIds:
+ - policyTypeId1
+ - policyTypeId2
+ - ricId: ricId2
+ managedElementIds:
+ - My test element
+ - Another test element
+ state: UNAVAILABLE
+ policyTypeIds:
+ - policyTypeId3
+ - policyTypeId4
+ PolicyTypeInformation:
+ value:
+ - policyTypeId: STD_QOS2_0.1.0
+ nearRtRicId: ric_g3_2
+ - policyTypeId: STD_QOS_0_2_0
+ nearRtRicId: ric_g3_2
+ - policyTypeId: STD_QOS2_0.1.0
+ nearRtRicId: ric_g3_1
+ - policyTypeId: STD_QOS_0_2_0
+ nearRtRicId: ric_g3_1
+ PolicyTypeObject:
+ value:
+ policySchema:
+ $schema: http://json-schema.org/draft-07/schema#
+ title: STD_QOS_0_2_0
+ description: STD QOS2 policy type
+ type: object
+ properties:
+ scope:
+ type: object
+ properties:
+ ueId:
+ type: string
+ qosId:
+ type: string
+ additionalProperties: false
+ required:
+ - ueId
+ - qosId
+ qosObjectives:
+ type: object
+ properties:
+ priorityLevel:
+ type: number
+ additionalProperties: false
+ required:
+ - priorityLevel
PolicyObject:
value:
scope:
@@ -910,11 +1309,11 @@ components:
gnbId:
gnbIdLength: 24
gnbIdValue: 12345678
- RanUeId: 'a31c510b20e64a74'
+ RanUeId: a31c510b20e64a74
groupId:
spId: 123
qosId:
- 5qI: 1
+ "5qI": 1
cellId:
plmnId:
mcc: "123"
@@ -926,22 +1325,234 @@ components:
mfbr: 200
priorityLevel: 3
pdb: 50
- PolicyTypeInformation:
+ ServiceStatusList:
+ description: List of service information
value:
- - policyTypeId: STD_QOS2_0.1.0
- nearRtRicId: ric_g3_2
- - policyTypeId: STD_QOS_0_2_0
+ serviceList:
+ - callbackUrl: http://callback.url
+ serviceId: serviceId1
+ keepAliveIntervalSeconds: 0
+ timeSinceLastActivitySeconds: 6
+ - callbackUrl: http://callback.url
+ serviceId: serviceId2
+ keepAliveIntervalSeconds: 500
+ timeSinceLastActivitySeconds: 401
+ responses:
+ "404":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Found
+ "400":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Request
+ "401":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Unauthorized
+ "403":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Forbidden
+ "406":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Not Acceptable
+ "429":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Too Many Requests
+ "500":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Internal Server Error
+ "502":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Bad Gateway
+ "503":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Service Unavailable
+ "411":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Length Required
+ "413":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Payload Too Large
+ "415":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Unsupported Media Type
+ Locked:
+ content:
+ application/problem+json:
+ example:
+ status: 423
+ title: Locked
+ detail: State is Locked in the provided request.
+ schema:
+ $ref: '#/components/schemas/ErrorInformation'
+ description: Locked - HTTP Status code which can be used when the state is Locked
+ "405":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Method Not Allowed
+ "409":
+ content:
+ application/problem+json:
+ schema:
+ $ref: '#/components/schemas/ProblemDetails'
+ description: Conflict
+ schemas:
+ StatusInfo:
+ example:
+ status: status
+ properties:
+ status:
+ description: Status text
+ type: string
+ type: object
+ ProblemDetails:
+ description: Object to carry details about a problem in an HTTP response according
+ to IETF RFC 7807
+ properties:
+ type:
+ description: URI reference according to IETF RFC 3986 that identifies the
+ problem type
+ type: string
+ title:
+ description: Human-readable summary of the problem type
+ type: string
+ status:
+ description: HTTP status code
+ type: number
+ detail:
+ description: Human-readable explanation
+ type: string
+ instance:
+ description: URI reference that identifies the specific occurrence of the
+ problem
+ type: string
+ type: object
+ RicInfo:
+ description: Information for a Near-RT RIC
+ example:
+ ricId: ricId
+ policyTypeIds:
+ - policyTypeIds
+ - policyTypeIds
+ managedElementIds:
+ - managedElementIds
+ - managedElementIds
+ state: UNAVAILABLE
+ properties:
+ ricId:
+ description: Identity of the Near-RT RIC
+ type: string
+ managedElementIds:
+ description: Identities for managed entities
+ items:
+ description: Identity for a managed entity
+ type: string
+ type: array
+ state:
+ description: Represents the state of a Near-RT RIC
+ enum:
+ - UNAVAILABLE
+ - AVAILABLE
+ - SYNCHRONIZING
+ - CONSISTENCY_CHECK
+ type: string
+ policyTypeIds:
+ description: Supported A1 Policy Types
+ items:
+ description: Supported A1 Policy Type ID
+ type: string
+ type: array
+ type: object
+ RicInfoList:
+ description: Collection of Near-RT RIC information objects
+ example:
+ rics:
+ - ricId: ricId
+ policyTypeIds:
+ - policyTypeIds
+ - policyTypeIds
+ managedElementIds:
+ - managedElementIds
+ - managedElementIds
+ state: UNAVAILABLE
+ - ricId: ricId
+ policyTypeIds:
+ - policyTypeIds
+ - policyTypeIds
+ managedElementIds:
+ - managedElementIds
+ - managedElementIds
+ state: UNAVAILABLE
+ properties:
+ rics:
+ description: List of Near-RT RIC information objects
+ items:
+ $ref: '#/components/schemas/RicInfo'
+ type: array
+ type: object
+ PolicyTypeInformation:
+ description: A data tuple to indicate that an identified A1 Policy Type is supported
+ at an identified Near-RT RIC.
+ example:
+ policyTypeId: STD_QOS2_0.1.0
nearRtRicId: ric_g3_2
- - policyTypeId: STD_QOS2_0.1.0
- nearRtRicId: ric_g3_1
- - policyTypeId: STD_QOS_0_2_0
- nearRtRicId: ric_g3_1
+ properties:
+ policyTypeId:
+ description: A1 Policy Type identifier
+ type: string
+ nearRtRicId:
+ description: Identity of the Near-RT RIC
+ type: string
+ required:
+ - nearRtRicId
+ - policyTypeId
+ type: object
+ NearRtRicId:
+ description: Identity of the Near-RT RIC
+ type: string
PolicyTypeObject:
- value:
+ description: "An A1 Policy Type, as defined in O-RAN Alliance A1TD"
+ example:
policySchema:
- "$schema": http://json-schema.org/draft-07/schema#
+ $schema: http://json-schema.org/draft-07/schema#
title: STD_QOS_0_2_0
- description: STD QOS2 policy type
+ description: Policy data schema for STD_QOS_0.2.0 A1 Policy Instances.
type: object
properties:
scope:
@@ -953,8 +1564,8 @@ components:
type: string
additionalProperties: false
required:
- - ueId
- - qosId
+ - ueId
+ - qosId
qosObjectives:
type: object
properties:
@@ -962,200 +1573,161 @@ components:
type: number
additionalProperties: false
required:
- - priorityLevel
-
- schemas:
- PolicyTypeInformation:
- description: >-
- A data tuple to indicate that an identified A1 Policy Type is supported at an identified Near-RT RIC.
+ - priorityLevel
+ statusSchema:
+ $schema: http://json-schema.org/draft-07/schema#
+ title: STD_QOS_0.2.0
+ description: Status schema for STD_QOS_0.2.0 A1 Policy Instances.
+ type: object
+ properties:
+ enforceStatus:
+ type: string
+ enforceReason:
+ type: string
+ additionalProperties: false
+ required:
+ - enforceStatus
+ properties:
+ policySchema:
+ description: |
+ A schema to define the policy data contents of A1 Policy Instances. Policy data schemas are Policy Type specific. All A1 Policy Instances of an A1 Policy Type should comply with the type's policy data schema.
+ type: object
+ statusSchema:
+ description: |
+ A schema to define the contents of the status information for A1 Policy Instances. Status schemas are Policy Type specific. All status information for all A1 Policy Instances of an A1 Policy Type should comply with the type's status schema.
+ type: object
+ required:
+ - policySchema
+ type: object
+ PolicySchema:
+ description: |
+ A schema to define the policy data contents of A1 Policy Instances. Policy data schemas are Policy Type specific. All A1 Policy Instances of an A1 Policy Type should comply with the type's policy data schema.
+ type: object
+ StatusSchema:
+ description: |
+ A schema to define the contents of the status information for A1 Policy Instances. Status schemas are Policy Type specific. All status information for all A1 Policy Instances of an A1 Policy Type should comply with the type's status schema.
+ type: object
+ PolicyObject:
+ description: |
+ Policy Object is a JSON representation policy data for an A1 Policy Instance. The schema for this policy data is defined in the corresponding A1 Policy Type.
type: object
+ ErrorInformation:
+ description: Problem as defined in https://tools.ietf.org/html/rfc7807
properties:
- policyTypeId:
- description: A1 Policy Type identifier
+ detail:
+ description: A human-readable explanation specific to this occurrence of
+ the problem.
+ example: Policy type not found
+ type: string
+ title:
+ description: A specific error name
+ example: Not Found
+ type: string
+ status:
+ description: |
+ The HTTP status code generated by the origin server for this occurrence of the problem.
+ example: 404
+ format: int32
+ type: integer
+ type: object
+ PolicyStatusObject:
+ description: |
+ A generic policy status object that can be used to transport any policy status. Additionally, a schema for policy status can be defined in the corresponding A1 Policy Type.
+ type: object
+ PolicyInformation:
+ description: |
+ Information tuple for a single A1 Policy Instance. Contains the A1 Policy Instance ID, and the ID of the Near-RT RIC where the policy is created.
+ example:
+ policyId: policyId
+ nearRtRicId: nearRtRicId
+ properties:
+ policyId:
+ description: Identity of the A1 Policy Instance
type: string
nearRtRicId:
- $ref: '#/components/schemas/NearRtRicId'
+ description: Identity of the Near-RT RIC
+ type: string
required:
- - policyTypeId
- - nearRtRicId
- example:
- policyTypeId: STD_QOS2_0.1.0
- nearRtRicId: ric_g3_2
+ - nearRtRicId
+ - policyId
+ type: object
PolicyObjectInformation:
description: Information to create an A1 Policy Instance
- type: object
+ example:
+ policyId: POLICY-ID1
+ nearRtRicId: Near-RT-Ric-ID1
+ transient: false
+ policyObject: "{}"
+ serviceId: rApp 1
+ policyTypeId: ORAN_QOS_1.0.0 '(typeName_SemVersion)'
properties:
nearRtRicId:
description: Identity of the target Near-RT RIC
+ example: Near-RT-Ric-ID1
type: string
- example:
- 'Near-RT-Ric-ID1'
transient:
default: false
- description: >
- If true, the policy is automatically deleted if the targeted Near-RT RIC restarts
- or recovers. If false, the A1 Policy Instance remains, and is re-pushed to the targeted
- Near-RT RIC after a restart or recovery. If false, the A1 Policy Instance is maintained and
- must be deleted separately in the event of Near-RT RIC restart or recovery. Default is false.
+ description: |
+ If true, the policy is automatically deleted if the targeted Near-RT RIC restarts or recovers. If false, the A1 Policy Instance remains, and is re-pushed to the targeted Near-RT RIC after a restart or recovery. If false, the A1 Policy Instance is maintained and must be deleted separately in the event of Near-RT RIC restart or recovery. Default is false.
nullable: false
type: boolean
policyId:
- description: >
- An optional identity to be used for the new A1 Policy Instance.
- If this value is present, it must be unique. If not present the new A1
- Policy Instance will be assigned a newly generated unique ID, and the
- new ID can be extracted from the 'Location' header in the response.
+ description: |
+ An optional identity to be used for the new A1 Policy Instance. If this value is present, it must be unique. If not present the new A1 Policy Instance will be assigned a newly generated unique ID, and the new ID can be extracted from the 'Location' header in the response.
+ example: POLICY-ID1
type: string
- example:
- 'POLICY-ID1'
serviceId:
- description: the identity of the service owning the policy. This can be
- used to group the policies (it is possible to get all policies associated
- to a service). Note that the service does not need to be registered.
- If the service is registered, the newly created A1 Policy Instance will be
- subject to the same supervision rules as the the service's other policies.
- type: string
- example:
- 'rApp 1'
default: ""
+ description: "the identity of the service owning the policy. This can be\
+ \ used to group the policies (it is possible to get all policies associated\
+ \ to a service). Note that the service does not need to be registered.\
+ \ If the service is registered, the newly created A1 Policy Instance will\
+ \ be subject to the same supervision rules as the the service's other\
+ \ policies."
+ example: rApp 1
+ type: string
policyObject:
- $ref: '#/components/schemas/PolicyObject'
+ description: |
+ Policy Object is a JSON representation policy data for an A1 Policy Instance. The schema for this policy data is defined in the corresponding A1 Policy Type.
+ type: object
policyTypeId:
description: A1 Policy Type identity
- type: string
example: ORAN_QOS_1.0.0 '(typeName_SemVersion)'
- required:
- - nearRtRicId
- - policyObject
- - policyTypeId
- ErrorInformation:
- description: Problem as defined in https://tools.ietf.org/html/rfc7807
- properties:
- detail:
- description: A human-readable explanation specific to this occurrence of the problem.
- example: Policy type not found
type: string
- title:
- description: A specific error name
- type: string
- example: Not Found
- status:
- description: |
- The HTTP status code generated by the origin server for this occurrence of the problem.
- example: 404
- format: int32
- type: integer
- type: object
- PolicyObject:
- description: >
- Policy Object is a JSON representation policy data for an A1 Policy Instance.
- The schema for this policy data is defined in the corresponding A1 Policy Type.
- type: object
- PolicyTypeObject:
- description: An A1 Policy Type, as defined in O-RAN Alliance A1TD
- type: object
- properties:
- policySchema:
- $ref: '#/components/schemas/PolicySchema'
- statusSchema:
- $ref: '#/components/schemas/StatusSchema'
- required:
- - policySchema
- example:
- policySchema:
- "$schema": http://json-schema.org/draft-07/schema#
- title: STD_QOS_0_2_0
- description: Policy data schema for STD_QOS_0.2.0 A1 Policy Instances.
- type: object
- properties:
- scope:
- type: object
- properties:
- ueId:
- type: string
- qosId:
- type: string
- additionalProperties: false
- required:
- - ueId
- - qosId
- qosObjectives:
- type: object
- properties:
- priorityLevel:
- type: number
- additionalProperties: false
- required:
- - priorityLevel
- statusSchema:
- "$schema": http://json-schema.org/draft-07/schema#
- title: STD_QOS_0.2.0
- description: Status schema for STD_QOS_0.2.0 A1 Policy Instances.
- type: object
- properties:
- enforceStatus:
- type: string
- enforceReason:
- type: string
- additionalProperties: false
- required:
- - enforceStatus
- PolicySchema:
- description: >
- A schema to define the policy data contents of A1 Policy Instances.
- Policy data schemas are Policy Type specific.
- All A1 Policy Instances of an A1 Policy Type should comply with the type's policy data schema.
- type: object
- StatusSchema:
- description: >
- A schema to define the contents of the status information for A1 Policy Instances.
- Status schemas are Policy Type specific.
- All status information for all A1 Policy Instances of an A1 Policy Type should comply
- with the type's status schema.
- type: object
- PolicyStatusObject:
- description: >
- A generic policy status object that can be used to transport any policy status.
- Additionally, a schema for policy status can be defined in the corresponding A1 Policy Type.
+ required:
+ - nearRtRicId
+ - policyObject
+ - policyTypeId
type: object
void:
description: Void/empty
type: object
- StatusInfo:
- properties:
- status:
- description: Status text
- type: string
- type: object
- RicInfo:
- description: Information for a Near-RT RIC
+ ServiceStatusList:
+ example:
+ serviceList:
+ - keepAliveIntervalSeconds: 0
+ callbackUrl: callbackUrl
+ timeSinceLastActivitySeconds: 6
+ serviceId: serviceId
+ - keepAliveIntervalSeconds: 0
+ callbackUrl: callbackUrl
+ timeSinceLastActivitySeconds: 6
+ serviceId: serviceId
properties:
- ricId:
- description: Identity of the Near-RT RIC
- type: string
- managedElementIds:
- description: Identities for managed entities
- items:
- description: Identity for a managed entity
- type: string
- type: array
- state:
- description: Represents the state of a Near-RT RIC
- enum:
- - UNAVAILABLE
- - AVAILABLE
- - SYNCHRONIZING
- - CONSISTENCY_CHECK
- type: string
- policyTypeIds:
- description: Supported A1 Policy Types
+ serviceList:
+ description: "List of Service Status objects, describing a collection of\
+ \ registered services."
items:
- description: Supported A1 Policy Type ID
- type: string
+ $ref: '#/components/schemas/ServiceStatus'
type: array
type: object
- ServiceRegistrationInfo:
- description: Information for a service to be registered
+ ServiceStatus:
+ description: Information about a previously registered service
+ example:
+ keepAliveIntervalSeconds: 0
+ callbackUrl: callbackUrl
+ timeSinceLastActivitySeconds: 6
+ serviceId: serviceId
properties:
callbackUrl:
description: Callback URL for notifying of Near-RT RIC state changes
@@ -1164,21 +1736,21 @@ components:
description: Identity of the service
type: string
keepAliveIntervalSeconds:
- description: >
- Keep alive interval for the service. This is used to enable
- optional heartbeat supervision of the service. If set (> 0) the registered
- service should regularly invoke a 'keepalive' REST call. When a service
- fails to invoke this 'keepalive' call within the configured time, the
- service is considered unavailable. An unavailable service will be automatically
- deregistered and its policies will be deleted. Value 0 means timeout
- supervision is disabled.
+ description: |
+ Keep alive interval (seconds) for the service. This is used to enable optional heartbeat supervision of the service. If set (> 0) the registered service should regularly invoke a 'keepalive' REST call. When a service fails to invoke this 'keepalive' call within the configured time, the service is considered unavailable. An unavailable service will be automatically deregistered and its policies will be deleted. Value 0 means timeout supervision is disabled.
+ format: int64
+ type: integer
+ timeSinceLastActivitySeconds:
+ description: Time (seconds) since last recorded operation by the service
format: int64
type: integer
- required:
- - serviceId
type: object
- ServiceStatus:
- description: Information about a previously registered service
+ ServiceRegistrationInfo:
+ description: Information for a service to be registered
+ example:
+ keepAliveIntervalSeconds: 0
+ callbackUrl: callbackUrl
+ serviceId: serviceId
properties:
callbackUrl:
description: Callback URL for notifying of Near-RT RIC state changes
@@ -1187,186 +1759,30 @@ components:
description: Identity of the service
type: string
keepAliveIntervalSeconds:
- description: >
- Keep alive interval (seconds) for the service. This is used to enable
- optional heartbeat supervision of the service. If set (> 0) the registered
- service should regularly invoke a 'keepalive' REST call. When a service
- fails to invoke this 'keepalive' call within the configured time, the
- service is considered unavailable. An unavailable service will be automatically
- deregistered and its policies will be deleted. Value 0 means timeout
- supervision is disabled.
+ description: |
+ Keep alive interval for the service. This is used to enable optional heartbeat supervision of the service. If set (> 0) the registered service should regularly invoke a 'keepalive' REST call. When a service fails to invoke this 'keepalive' call within the configured time, the service is considered unavailable. An unavailable service will be automatically deregistered and its policies will be deleted. Value 0 means timeout supervision is disabled.
format: int64
type: integer
- timeSinceLastActivitySeconds:
- description: Time (seconds) since last recorded operation by the service
- format: int64
- type: integer
- type: object
- RicInfoList:
- description: Collection of Near-RT RIC information objects
- properties:
- rics:
- description: List of Near-RT RIC information objects
- items:
- $ref: '#/components/schemas/RicInfo'
- type: array
- type: object
- NearRtRicId:
- description: Identity of the Near-RT RIC
- type: string
- PolicyInformation:
- description: >
- Information tuple for a single A1 Policy Instance.
- Contains the A1 Policy Instance ID, and the ID of the Near-RT RIC where the policy is created.
- type: object
- properties:
- policyId:
- description: Identity of the A1 Policy Instance
- type: string
- nearRtRicId:
- $ref: '#/components/schemas/NearRtRicId'
required:
- - policyId
- - nearRtRicId
- ServiceStatusList:
- properties:
- serviceList:
- description: List of Service Status objects, describing a collection of registered services.
- items:
- $ref: '#/components/schemas/ServiceStatus'
- type: array
+ - serviceId
type: object
ServiceCallbackInfo:
- description: |
- Information transferred in Service callbacks,
- if a callback URL was provided for a registered service
+ description: "Information transferred in Service callbacks, \nif a callback\
+ \ URL was provided for a registered service\n"
+ example:
+ ricId: ricId
+ eventType: AVAILABLE
properties:
ricId:
description: Identity of a Near-RT RIC
type: string
eventType:
- description: >
- values:
- AVAILABLE: the Near-RT RIC has become available for A1 Policy management
+ description: "values: \n AVAILABLE: the Near-RT RIC has become available\
+ \ for A1 Policy management\n"
enum:
- - AVAILABLE
+ - AVAILABLE
type: string
required:
- - eventType
- - ricId
- type: object
- ProblemDetails:
- description: Object to carry details about a problem in an HTTP response according to IETF RFC 7807
+ - eventType
+ - ricId
type: object
- properties:
- type:
- description: URI reference according to IETF RFC 3986 that identifies the problem type
- type: string
- title:
- description: Human-readable summary of the problem type
- type: string
- status:
- description: HTTP status code
- type: number
- detail:
- description: Human-readable explanation
- type: string
- instance:
- description: URI reference that identifies the specific occurrence of the problem
- type: string
-
- responses:
- '400':
- description: Bad Request
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/ProblemDetails'
- '401':
- description: Unauthorized
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/ProblemDetails'
- '403':
- description: Forbidden
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/ProblemDetails'
- '404':
- description: Not Found
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/ProblemDetails'
- '405':
- description: Method Not Allowed
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/ProblemDetails'
- '406':
- description: Not Acceptable
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/ProblemDetails'
- '409':
- description: Conflict
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/ProblemDetails'
- '411':
- description: Length Required
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/ProblemDetails'
- '413':
- description: Payload Too Large
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/ProblemDetails'
- '415':
- description: Unsupported Media Type
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/ProblemDetails'
- '429':
- description: Too Many Requests
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/ProblemDetails'
- '500':
- description: Internal Server Error
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/ProblemDetails'
- '502':
- description: Bad Gateway
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/ProblemDetails'
- '503':
- description: Service Unavailable
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/ProblemDetails'
- Locked:
- description: Locked - HTTP Status code which can be used when the state is Locked
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/ErrorInformation'
- example:
- status: 423
- title: Locked
- detail: State is Locked in the provided request.
diff --git a/docs/offeredapis/swagger/pms-api.json b/docs/offeredapis/swagger/pms-api.json
index 26fc1220..c35456a6 100644
--- a/docs/offeredapis/swagger/pms-api.json
+++ b/docs/offeredapis/swagger/pms-api.json
@@ -874,7 +874,7 @@
"tags" : [ "Configuration" ]
},
"put" : {
- "description" : "Replace the current Application Configuration with a new configuration. The new configuration, if accepted, will take effect after a short delay. The new configuration must comply with the Application Configuration schema, which can be found from the the Application Documentation (Developer Guide) \n",
+ "description" : "Replace the current Application Configuration with a new configuration. The new configuration, if accepted, will take effect after a short delay. The new configuration must comply with the Application Configuration schema, which can be found from the the Application Documentation (Developer Guide)\n",
"operationId" : "putConfiguration",
"requestBody" : {
"content" : {
@@ -1017,7 +1017,7 @@
},
"/actuator/heapdump" : {
"get" : {
- "description" : "A1-PMS Springboot Service Actuator web endpoint - HeapDump. \n",
+ "description" : "A1-PMS Springboot Service Actuator web endpoint - HeapDump.\n",
"externalDocs" : {
"description" : "Spring Boot Actuator Web API Documentation",
"url" : "https://docs.spring.io/spring-boot/reference/actuator/endpoints.html"
@@ -1042,7 +1042,7 @@
},
"/actuator/info" : {
"get" : {
- "description" : "A1-PMS Springboot Service Actuator web endpoint - Info. \n",
+ "description" : "A1-PMS Springboot Service Actuator web endpoint - Info.\n",
"externalDocs" : {
"description" : "Spring Boot Actuator Web API Documentation",
"url" : "https://docs.spring.io/spring-boot/reference/actuator/endpoints.html"
@@ -1077,7 +1077,7 @@
},
"/actuator/threaddump" : {
"get" : {
- "description" : "A1-PMS Springboot Service Actuator web endpoint - ThreadDump. \n",
+ "description" : "A1-PMS Springboot Service Actuator web endpoint - ThreadDump.\n",
"externalDocs" : {
"description" : "Spring Boot Actuator Web API Documentation",
"url" : "https://docs.spring.io/spring-boot/reference/actuator/endpoints.html"
@@ -1117,7 +1117,7 @@
},
"/actuator/loggers" : {
"get" : {
- "description" : "A1-PMS Springboot Service Actuator web endpoint - Get a list of Loggers. \n",
+ "description" : "A1-PMS Springboot Service Actuator web endpoint - Get a list of Loggers.\n",
"externalDocs" : {
"description" : "Spring Boot Actuator Web API Documentation",
"url" : "https://docs.spring.io/spring-boot/reference/actuator/endpoints.html"
@@ -1152,7 +1152,7 @@
},
"/actuator/loggers/{name}" : {
"get" : {
- "description" : "A1-PMS Springboot Service Actuator web endpoint - Get a single named Logger. \n",
+ "description" : "A1-PMS Springboot Service Actuator web endpoint - Get a single named Logger.\n",
"externalDocs" : {
"description" : "Spring Boot Actuator Web API Documentation",
"url" : "https://docs.spring.io/spring-boot/reference/actuator/endpoints.html"
@@ -1195,7 +1195,7 @@
"x-internal" : true
},
"post" : {
- "description" : "A1-PMS Springboot Service Actuator web endpoint - Create or Update single named Logger. \n",
+ "description" : "A1-PMS Springboot Service Actuator web endpoint - Create or Update single named Logger.\n",
"externalDocs" : {
"description" : "Spring Boot Actuator Web API Documentation",
"url" : "https://docs.spring.io/spring-boot/reference/actuator/endpoints.html"
@@ -1240,7 +1240,7 @@
},
"/actuator/logfile" : {
"get" : {
- "description" : "A1-PMS Springboot Service Actuator web endpoint - Get the Log file. \n",
+ "description" : "A1-PMS Springboot Service Actuator web endpoint - Get the Log file.\n",
"externalDocs" : {
"description" : "Spring Boot Actuator Web API Documentation",
"url" : "https://docs.spring.io/spring-boot/reference/actuator/endpoints.html"
@@ -1265,7 +1265,7 @@
},
"/actuator/health" : {
"get" : {
- "description" : "A1-PMS Springboot Service Actuator web endpoint - Health Check. \n",
+ "description" : "A1-PMS Springboot Service Actuator web endpoint - Health Check.\n",
"externalDocs" : {
"description" : "Spring Boot Actuator Web API Documentation",
"url" : "https://docs.spring.io/spring-boot/reference/actuator/endpoints.html"
@@ -1300,7 +1300,7 @@
},
"/actuator/health/**" : {
"get" : {
- "description" : "A1-PMS Springboot Service Actuator web endpoint - Health Status for an Application Component. \n",
+ "description" : "A1-PMS Springboot Service Actuator web endpoint - Health Status for an Application Component.\n",
"externalDocs" : {
"description" : "Spring Boot Actuator Web API Documentation",
"url" : "https://docs.spring.io/spring-boot/reference/actuator/endpoints.html"
@@ -1335,7 +1335,7 @@
},
"/actuator/shutdown" : {
"post" : {
- "description" : "A1-PMS Springboot Service Actuator web endpoint - Shutdown the Application. \n",
+ "description" : "A1-PMS Springboot Service Actuator web endpoint - Shutdown the Application.\n",
"externalDocs" : {
"description" : "Spring Boot Actuator Web API Documentation",
"url" : "https://docs.spring.io/spring-boot/reference/actuator/endpoints.html"
@@ -1370,7 +1370,7 @@
},
"/actuator/metrics" : {
"get" : {
- "description" : "A1-PMS Springboot Service Actuator web endpoint - Get a list of Application metrics names. \n",
+ "description" : "A1-PMS Springboot Service Actuator web endpoint - Get a list of Application metrics names.\n",
"externalDocs" : {
"description" : "Spring Boot Actuator Web API Documentation",
"url" : "https://docs.spring.io/spring-boot/reference/actuator/endpoints.html"
@@ -1405,7 +1405,7 @@
},
"/actuator/metrics/{requiredMetricName}" : {
"get" : {
- "description" : "A1-PMS Springboot Service Actuator web endpoint - Get the value for a named Application metric. \n",
+ "description" : "A1-PMS Springboot Service Actuator web endpoint - Get the value for a named Application metric.\n",
"externalDocs" : {
"description" : "Spring Boot Actuator Web API Documentation",
"url" : "https://docs.spring.io/spring-boot/reference/actuator/endpoints.html"
@@ -1450,13 +1450,50 @@
},
"components" : {
"examples" : {
- "service_status" : {
- "description" : "List of service information",
+ "status_info" : {
+ "value" : {
+ "status" : "status"
+ }
+ },
+ "ric_info" : {
+ "value" : {
+ "ric_id" : "ric_id",
+ "managed_element_ids" : [ "some_managed_element_id", "some_managed_element_id" ],
+ "state" : "UNAVAILABLE",
+ "policytype_ids" : [ "some_policytype_id", "some_policytype_id" ]
+ }
+ },
+ "policy_type_id_list" : {
+ "description" : "Array of A1 Policy Type id's",
"value" : {
- "callback_url" : "callback_url",
- "service_id" : "service_id",
- "keep_alive_interval_seconds" : 0,
- "time_since_last_activity_seconds" : 6
+ "policy_type_id_list" : [ "policytype_id", "policytype_id" ]
+ }
+ },
+ "policy_info" : {
+ "description" : "Information for an A1 Policy Instance",
+ "value" : {
+ "ric_id" : "ric_id1",
+ "policy_id" : "policy_id1",
+ "transient" : false,
+ "service_id" : "service_id1",
+ "policy_data" : "{}",
+ "status_notification_uri" : "status_notification_uri",
+ "policytype_id" : "policytype_id1"
+ }
+ },
+ "ric_info_list" : {
+ "value" : {
+ "rics" : [ {
+ "ric_id" : "ric_id",
+ "managed_element_ids" : [ "some_managed_element_id", "some_managed_element_id" ],
+ "state" : "UNAVAILABLE",
+ "policytype_ids" : [ "policytype_id", "policytype_id" ]
+ }, {
+ "ric_id" : "ric_id",
+ "managed_element_ids" : [ "managed_element_ids", "managed_element_ids" ],
+ "state" : "UNAVAILABLE",
+ "policytype_ids" : [ "policytype_ids", "policytype_ids" ]
+ } ]
}
},
"service_status_list" : {
@@ -1481,22 +1518,10 @@
"policy_schema" : "{}"
}
},
- "policy_type_id_list" : {
- "description" : "Array of A1 Policy Type id's",
- "value" : {
- "policy_type_id_list" : [ "policytype_id", "policytype_id" ]
- }
- },
- "policy_info" : {
- "description" : "Information for an A1 Policy Instance",
+ "policy_id_list" : {
+ "description" : "A list of policy identities",
"value" : {
- "ric_id" : "ric_id1",
- "policy_id" : "policy_id1",
- "transient" : false,
- "service_id" : "service_id1",
- "policy_data" : "{}",
- "status_notification_uri" : "status_notification_uri",
- "policytype_id" : "policytype_id1"
+ "policy_ids" : [ "some_policy_id", "some_policy_id" ]
}
},
"policy_info_list" : {
@@ -1521,12 +1546,6 @@
} ]
}
},
- "policy_id_list" : {
- "description" : "A list of policy identities",
- "value" : {
- "policy_ids" : [ "some_policy_id", "some_policy_id" ]
- }
- },
"policy_status_info" : {
"description" : "Status for one A1-P Policy",
"value" : {
@@ -1537,37 +1556,17 @@
}
}
}
- },
- "status_info" : {
- "value" : {
- "status" : "status"
- }
- },
- "ric_info" : {
- "value" : {
- "ric_id" : "ric_id",
- "managed_element_ids" : [ "some_managed_element_id", "some_managed_element_id" ],
- "state" : "UNAVAILABLE",
- "policytype_ids" : [ "some_policytype_id", "some_policytype_id" ]
- }
- },
- "ric_info_list" : {
- "value" : {
- "rics" : [ {
- "ric_id" : "ric_id",
- "managed_element_ids" : [ "some_managed_element_id", "some_managed_element_id" ],
- "state" : "UNAVAILABLE",
- "policytype_ids" : [ "policytype_id", "policytype_id" ]
- }, {
- "ric_id" : "ric_id",
- "managed_element_ids" : [ "managed_element_ids", "managed_element_ids" ],
- "state" : "UNAVAILABLE",
- "policytype_ids" : [ "policytype_ids", "policytype_ids" ]
- } ]
- }
}
},
"responses" : {
+ "NotFound" : {
+ "content" : {
+ "application/problem+json" : {
+ "example" : [ ]
+ }
+ },
+ "description" : "Not Found"
+ },
"Locked" : {
"content" : {
"application/problem+json" : {
@@ -1612,53 +1611,9 @@
}
},
"description" : "Forbidden"
- },
- "NotFound" : {
- "content" : {
- "application/problem+json" : {
- "example" : [ ]
- }
- },
- "description" : "Not Found"
}
},
"schemas" : {
- "policy_type_definition" : {
- "description" : "Contains A1 Policy Type schema definition",
- "properties" : {
- "policy_schema" : {
- "description" : "A1 Policy Type json schema. The schema is a json object following http://json-schema.org/draft-07/schema",
- "type" : "object"
- }
- },
- "type" : "object"
- },
- "error_information" : {
- "description" : "Problem as defined in https://tools.ietf.org/html/rfc7807",
- "properties" : {
- "detail" : {
- "description" : " A human-readable explanation specific to this occurrence of the problem.",
- "example" : "A1 Policy Type not found",
- "type" : "string"
- },
- "title" : {
- "description" : "A specific error name",
- "example" : "Not Found",
- "type" : "string"
- },
- "status" : {
- "description" : "The HTTP status code generated by the origin server for this occurrence of the problem. ",
- "example" : 404,
- "format" : "int32",
- "type" : "integer"
- }
- },
- "type" : "object"
- },
- "void" : {
- "description" : "Void/empty",
- "type" : "object"
- },
"status_info" : {
"properties" : {
"status" : {
@@ -1668,20 +1623,6 @@
},
"type" : "object"
},
- "authorization_result" : {
- "description" : "Result of authorization",
- "example" : {
- "result" : true
- },
- "properties" : {
- "result" : {
- "description" : "If true, the access is granted",
- "type" : "boolean"
- }
- },
- "required" : [ "result" ],
- "type" : "object"
- },
"ric_info" : {
"description" : "Information for a Near-RT RIC",
"properties" : {
@@ -1713,49 +1654,106 @@
},
"type" : "object"
},
- "service_registration_info" : {
- "description" : "Information for one service",
+ "policy_type_id_list" : {
+ "description" : "Information about A1 Policy Types",
"properties" : {
- "callback_url" : {
- "description" : "Callback for notifying of Near-RT RIC state changes",
+ "policytype_ids" : {
+ "description" : "A1 Policy Type identities",
+ "items" : {
+ "description" : "A1 Policy Type identities",
+ "type" : "string"
+ },
+ "type" : "array"
+ }
+ },
+ "type" : "object"
+ },
+ "policy_info" : {
+ "description" : "Information for one A1-P Policy",
+ "properties" : {
+ "ric_id" : {
+ "description" : "identity of the target Near-RT RIC",
"type" : "string"
},
+ "policy_id" : {
+ "description" : "identity of the policy",
+ "type" : "string"
+ },
+ "transient" : {
+ "default" : false,
+ "description" : "If true, the policy is automatically deleted if the targeted Near-RT RIC restarts or recovers. If false, the A1 Policy Instance remains, and is re-pushed to the targeted Near-RT RIC after a restart or recovery. If false, the A1 Policy Instance is maintained and must be deleted separately in the event of Near-RT RIC restart or recovery. Default is false.\n",
+ "example" : false,
+ "nullable" : false,
+ "type" : "boolean"
+ },
"service_id" : {
- "description" : "identity of the service",
+ "default" : "",
+ "description" : "The identity of the service owning the policy. This can be used to group the policies (it is possible to get all policies associated to a service). Note that the service does not need to be registered. If the service is registered, the A1 Policy Instance will be subject to the same supervision rules as the the service's other policies.\n",
"type" : "string"
},
- "keep_alive_interval_seconds" : {
- "description" : "Keep alive interval for the service. This is used to enable optional heartbeat supervision of the service. If set (> 0) the registered service should regularly invoke a 'keepalive' REST call. When a service fails to invoke this 'keepalive' call within the configured time, the service is considered unavailable. An unavailable service will be automatically deregistered and its policies will be deleted. Value 0 means timeout supervision is disabled.\n",
- "format" : "int64",
+ "policy_data" : {
+ "description" : "the configuration of the policy",
+ "type" : "object"
+ },
+ "status_notification_uri" : {
+ "description" : "Callback URI for policy status updates",
+ "type" : "string"
+ },
+ "policytype_id" : {
+ "description" : "identity of the A1 Policy Type",
+ "type" : "string"
+ }
+ },
+ "required" : [ "policy_data", "policy_id", "policytype_id", "ric_id" ],
+ "type" : "object"
+ },
+ "void" : {
+ "description" : "Void/empty",
+ "type" : "object"
+ },
+ "error_information" : {
+ "description" : "Problem as defined in https://tools.ietf.org/html/rfc7807",
+ "properties" : {
+ "detail" : {
+ "description" : " A human-readable explanation specific to this occurrence of the problem.",
+ "example" : "A1 Policy Type not found",
+ "type" : "string"
+ },
+ "title" : {
+ "description" : "A specific error name",
+ "example" : "Not Found",
+ "type" : "string"
+ },
+ "status" : {
+ "description" : "The HTTP status code generated by the origin server for this occurrence of the problem. ",
+ "example" : 404,
+ "format" : "int32",
"type" : "integer"
}
},
- "required" : [ "service_id" ],
"type" : "object"
},
- "policy_info_list" : {
- "description" : "List of policy information",
+ "ric_info_list" : {
+ "description" : "List of Near-RT RIC information",
"properties" : {
- "policies" : {
- "description" : "List of policy information",
+ "rics" : {
+ "description" : "List of Near-RT RIC information",
"items" : {
- "$ref" : "#/components/schemas/policy_info"
+ "$ref" : "#/components/schemas/ric_info"
},
"type" : "array"
}
},
"type" : "object"
},
- "policy_status_info" : {
- "description" : "Status for one A1-P Policy",
+ "service_status_list" : {
"properties" : {
- "last_modified" : {
- "description" : "timestamp, last modification time",
- "type" : "string"
- },
- "status" : {
- "description" : "the Policy status",
- "type" : "object"
+ "service_list" : {
+ "description" : "List of service information",
+ "items" : {
+ "$ref" : "#/components/schemas/service_status"
+ },
+ "type" : "array"
}
},
"type" : "object"
@@ -1783,100 +1781,50 @@
},
"type" : "object"
},
- "ric_info_list" : {
- "description" : "List of Near-RT RIC information",
- "properties" : {
- "rics" : {
- "description" : "List of Near-RT RIC information",
- "items" : {
- "$ref" : "#/components/schemas/ric_info"
- },
- "type" : "array"
- }
- },
- "type" : "object"
- },
- "input" : {
- "description" : "input",
+ "service_registration_info" : {
+ "description" : "Information for one service",
"properties" : {
- "access_type" : {
- "description" : "Access type",
- "enum" : [ "READ", "WRITE", "DELETE" ],
+ "callback_url" : {
+ "description" : "Callback for notifying of Near-RT RIC state changes",
"type" : "string"
},
- "auth_token" : {
- "description" : "Authorization token",
+ "service_id" : {
+ "description" : "identity of the service",
"type" : "string"
},
- "policy_type_id" : {
- "description" : "A1 Policy Type identifier",
- "type" : "string"
- }
- },
- "required" : [ "access_type", "auth_token", "policy_type_id" ],
- "type" : "object"
- },
- "policy_authorization" : {
- "description" : "Authorization request for A1 policy requests",
- "properties" : {
- "input" : {
- "$ref" : "#/components/schemas/input"
+ "keep_alive_interval_seconds" : {
+ "description" : "Keep alive interval for the service. This is used to enable optional heartbeat supervision of the service. If set (> 0) the registered service should regularly invoke a 'keepalive' REST call. When a service fails to invoke this 'keepalive' call within the configured time, the service is considered unavailable. An unavailable service will be automatically deregistered and its policies will be deleted. Value 0 means timeout supervision is disabled.\n",
+ "format" : "int64",
+ "type" : "integer"
}
},
- "required" : [ "input" ],
+ "required" : [ "service_id" ],
"type" : "object"
},
- "policy_type_id_list" : {
- "description" : "Information about A1 Policy Types",
+ "service_callback_info_v2" : {
+ "description" : "Information transferred in Service callbacks, \nif a callback URL was provided for a registered service\n",
"properties" : {
- "policytype_ids" : {
- "description" : "A1 Policy Type identities",
- "items" : {
- "description" : "A1 Policy Type identities",
- "type" : "string"
- },
- "type" : "array"
+ "ric_id" : {
+ "description" : "identity of a Near-RT RIC",
+ "type" : "string"
+ },
+ "event_type" : {
+ "description" : "values: \n AVAILABLE: the Near-RT RIC has become available for A1 Policy management\n",
+ "enum" : [ "AVAILABLE" ],
+ "type" : "string"
}
},
+ "required" : [ "event_type", "ric_id" ],
"type" : "object"
},
- "policy_info" : {
- "description" : "Information for one A1-P Policy",
+ "policy_type_definition" : {
+ "description" : "Contains A1 Policy Type schema definition",
"properties" : {
- "ric_id" : {
- "description" : "identity of the target Near-RT RIC",
- "type" : "string"
- },
- "policy_id" : {
- "description" : "identity of the policy",
- "type" : "string"
- },
- "transient" : {
- "default" : false,
- "description" : "If true, the policy is automatically deleted if the targeted Near-RT RIC restarts or recovers. If false, the A1 Policy Instance remains, and is re-pushed to the targeted Near-RT RIC after a restart or recovery. If false, the A1 Policy Instance is maintained and must be deleted separately in the event of Near-RT RIC restart or recovery. Default is false.\n",
- "example" : false,
- "nullable" : false,
- "type" : "boolean"
- },
- "service_id" : {
- "default" : "",
- "description" : "The identity of the service owning the policy. This can be used to group the policies (it is possible to get all policies associated to a service). Note that the service does not need to be registered. If the service is registered, the A1 Policy Instance will be subject to the same supervision rules as the the service's other policies.\n",
- "type" : "string"
- },
- "policy_data" : {
- "description" : "the configuration of the policy",
+ "policy_schema" : {
+ "description" : "A1 Policy Type json schema. The schema is a json object following http://json-schema.org/draft-07/schema",
"type" : "object"
- },
- "status_notification_uri" : {
- "description" : "Callback URI for policy status updates",
- "type" : "string"
- },
- "policytype_id" : {
- "description" : "identity of the A1 Policy Type",
- "type" : "string"
}
},
- "required" : [ "policy_data", "policy_id", "policytype_id", "ric_id" ],
"type" : "object"
},
"policy_id_list" : {
@@ -1896,32 +1844,75 @@
},
"type" : "object"
},
- "service_status_list" : {
+ "policy_info_list" : {
+ "description" : "List of policy information",
"properties" : {
- "service_list" : {
- "description" : "List of service information",
+ "policies" : {
+ "description" : "List of policy information",
"items" : {
- "$ref" : "#/components/schemas/service_status"
+ "$ref" : "#/components/schemas/policy_info"
},
"type" : "array"
}
},
"type" : "object"
},
- "service_callback_info_v2" : {
- "description" : "Information transferred in Service callbacks, \nif a callback URL was provided for a registered service\n",
+ "policy_status_info" : {
+ "description" : "Status for one A1-P Policy",
"properties" : {
- "ric_id" : {
- "description" : "identity of a Near-RT RIC",
+ "last_modified" : {
+ "description" : "timestamp, last modification time",
"type" : "string"
},
- "event_type" : {
- "description" : "values: \n AVAILABLE: the Near-RT RIC has become available for A1 Policy management\n",
- "enum" : [ "AVAILABLE" ],
+ "status" : {
+ "description" : "the Policy status",
+ "type" : "object"
+ }
+ },
+ "type" : "object"
+ },
+ "policy_authorization" : {
+ "description" : "Authorization request for A1 policy requests",
+ "properties" : {
+ "input" : {
+ "$ref" : "#/components/schemas/input"
+ }
+ },
+ "required" : [ "input" ],
+ "type" : "object"
+ },
+ "input" : {
+ "description" : "input",
+ "properties" : {
+ "access_type" : {
+ "description" : "Access type",
+ "enum" : [ "READ", "WRITE", "DELETE" ],
+ "type" : "string"
+ },
+ "auth_token" : {
+ "description" : "Authorization token",
+ "type" : "string"
+ },
+ "policy_type_id" : {
+ "description" : "A1 Policy Type identifier",
"type" : "string"
}
},
- "required" : [ "event_type", "ric_id" ],
+ "required" : [ "access_type", "auth_token", "policy_type_id" ],
+ "type" : "object"
+ },
+ "authorization_result" : {
+ "description" : "Result of authorization",
+ "example" : {
+ "result" : true
+ },
+ "properties" : {
+ "result" : {
+ "description" : "If true, the access is granted",
+ "type" : "boolean"
+ }
+ },
+ "required" : [ "result" ],
"type" : "object"
},
"Link" : {
diff --git a/docs/offeredapis/swagger/pms-api.yaml b/docs/offeredapis/swagger/pms-api.yaml
index ea6d5d1e..5f54504f 100644
--- a/docs/offeredapis/swagger/pms-api.yaml
+++ b/docs/offeredapis/swagger/pms-api.yaml
@@ -19,87 +19,83 @@
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>"
+ contact:
+ email: discuss-list@onap.com
+ name: ONAP CCSDK Project
+ url: https://www.onap.org/
+ 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.
+ name: "Copyright (C) 2020-2023 Nordix Foundation, and Copyright (C) 2024-2025\
+ \ OpenInfra Foundation Europe. \nAll rights reserved. Licensed under the Apache\
+ \ 2 License.\n"
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
+ x-api-id: a31c510b-20e6-4a08-af16-368c44d7fba8
+ x-audience: external-public
servers:
- - url: /
+- 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
-
+- description: |
+ Older pre-spec API used to get, create, update and delete A1 Policy Instances. Also used to query A1 Policy Types.
+ name: A1 Policy Management
+- description: |
+ Older API used to get information about registered Near-RT RICs.
+ name: NearRT-RIC Repository
+- description: |
+ Older API used to manage registered services, and control their keep-alive status via heart-beat messages.
+ name: Service Registry and Supervision
+- description: |
+ API used to get the health status and statistics of this service
+ name: Health Check
+- 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: Service Callbacks
+- 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: Authorization API
+- description: |
+ API used to create or fetch the application configuration.
+ name: Configuration
+- 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
+ name: Actuator API
paths:
/status:
get:
- operationId: getStatusV1
description: Returns status and statistics of this service
- summary: Get Status (getStatusV1)
- tags:
- - Health Check
+ operationId: getStatusV1
responses:
"200":
content:
@@ -107,100 +103,100 @@ paths:
schema:
type: string
description: OK - Service is living
+ summary: Get Status (getStatusV1)
+ tags:
+ - Health Check
/a1-policy/v2/status:
get:
- operationId: getStatus
description: Returns status and statistics of this service
- summary: Get Status (getStatus)
- tags:
- - Health Check
+ operationId: getStatus
responses:
"200":
content:
application/json:
- schema:
- $ref: '#/components/schemas/status_info'
examples:
status_info:
$ref: '#/components/examples/status_info'
+ schema:
+ $ref: '#/components/schemas/status_info'
description: OK- Service is living Ok
+ summary: Get Status (getStatus)
+ tags:
+ - Health Check
/a1-policy/v2/rics/ric:
get:
- description: >
- Query information about a Near-RT RIC. Either a Near-RT RIC identity or a Managed Element
- identity can be specified. The intention with Managed Element identity is the ID used
- in O1 for accessing the traffical element (such as the ID of CU).
+ description: |
+ Query information about a Near-RT RIC. Either a Near-RT RIC identity or a Managed Element identity can be specified. The intention with Managed Element identity is the ID used in O1 for accessing the traffical element (such as the ID of CU).
operationId: getRic
- summary: Get a Near-RT RIC (getRic)
- tags:
- - NearRT-RIC Repository
parameters:
- - description: >
- The identity of a Managed Element. If given, the Near-RT RIC managing the ME is returned.
- explode: true
- in: query
- name: managed_element_id
- required: false
- schema:
- type: string
- style: form
- - description: The identity of a Near-RT RIC to get information for.
- explode: true
- in: query
- name: ric_id
- required: false
- schema:
- type: string
- style: form
+ - description: |
+ The identity of a Managed Element. If given, the Near-RT RIC managing the ME is returned.
+ explode: true
+ in: query
+ name: managed_element_id
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: The identity of a Near-RT RIC to get information for.
+ explode: true
+ in: query
+ name: ric_id
+ required: false
+ schema:
+ type: string
+ style: form
responses:
"200":
content:
application/json:
- schema:
- $ref: '#/components/schemas/ric_info'
examples:
ric_info:
$ref: '#/components/examples/ric_info'
+ schema:
+ $ref: '#/components/schemas/ric_info'
description: OK - Near-RT RIC is found
"404":
- $ref: '#/components/responses/NotFound'
- description: NotFound - Requested NearRT-RIC Not Found
+ content:
+ application/problem+json:
+ example: []
+ description: Not Found
+ summary: Get a Near-RT RIC (getRic)
+ tags:
+ - NearRT-RIC Repository
/a1-policy/v2/policy-types:
get:
- operationId: getPolicyTypes
description: Query A1 Policy Type identities using query parameters
- summary: Get A1 Policy Types (getPolicyTypes)
- tags:
- - A1 Policy Management
+ operationId: getPolicyTypes
parameters:
- - description: Select types for the given Near-RT RIC identity.
- explode: true
- in: query
- name: ric_id
- required: false
- schema:
- type: string
- style: form
- - description: Select types compatible with the given type name (type identity has the
- format 'typename_version')
- explode: true
- in: query
- name: type_name
- required: false
- schema:
- type: string
- style: form
- - description: Select types that are compatible with the given version. This
- parameter is only applicable in conjunction with type_name. As an example
- version 1.9.1 is compatible with 1.0.0 but not the other way around. Matching
- types will be returned sorted in ascending order.
- explode: true
- in: query
- name: compatible_with_version
- required: false
- schema:
- type: string
- style: form
+ - description: Select types for the given Near-RT RIC identity.
+ explode: true
+ in: query
+ name: ric_id
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: Select types compatible with the given type name (type identity
+ has the format 'typename_version')
+ explode: true
+ in: query
+ name: type_name
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: Select types that are compatible with the given version. This
+ parameter is only applicable in conjunction with type_name. As an example
+ version 1.9.1 is compatible with 1.0.0 but not the other way around. Matching
+ types will be returned sorted in ascending order.
+ explode: true
+ in: query
+ name: compatible_with_version
+ required: false
+ schema:
+ type: string
+ style: form
responses:
"200":
content:
@@ -212,23 +208,25 @@ paths:
$ref: '#/components/schemas/policy_type_id_list'
description: OK - Policy Type IDs Found
"404":
- $ref: '#/components/responses/NotFound'
- description: 'Not Found - Requested Policy Type IDs Not Found'
+ content:
+ application/problem+json:
+ example: []
+ description: Not Found
+ summary: Get A1 Policy Types (getPolicyTypes)
+ tags:
+ - A1 Policy Management
/a1-policy/v2/policies/{policy_id}:
delete:
description: Delete an A1 Policy instance using its policy ID.
operationId: deletePolicy
- summary: Delete an A1 Policy instance (deletePolicy)
- tags:
- - A1 Policy Management
parameters:
- - explode: false
- in: path
- name: policy_id
- required: true
- schema:
- type: string
- style: simple
+ - explode: false
+ in: path
+ name: policy_id
+ required: true
+ schema:
+ type: string
+ style: simple
responses:
"200":
content:
@@ -237,138 +235,179 @@ paths:
$ref: '#/components/schemas/void'
description: OK - Policy deleted
"423":
- $ref: '#/components/responses/Locked'
- description: 'The requested policy using policy_id is Locked'
+ content:
+ application/problem+json:
+ example:
+ status: 423
+ title: Locked
+ detail: Requested resource is in a locked state.
+ schema:
+ $ref: '#/components/schemas/error_information'
+ description: Locked - HTTP Status code which can be used when the state
+ is Locked
+ summary: Delete an A1 Policy instance (deletePolicy)
+ tags:
+ - A1 Policy Management
get:
description: Get an A1 Policy instance using its policy ID
operationId: getPolicy
- summary: Get an A1 Policy instance (getPolicy)
- tags:
- - A1 Policy Management
parameters:
- - explode: false
- in: path
- name: policy_id
- required: true
- schema:
- type: string
- style: simple
+ - explode: false
+ in: path
+ name: policy_id
+ required: true
+ schema:
+ type: string
+ style: simple
responses:
"200":
content:
application/json:
- schema:
- $ref: '#/components/schemas/policy_info'
examples:
policy_info:
$ref: '#/components/examples/policy_info'
+ schema:
+ $ref: '#/components/schemas/policy_info'
description: OK - Policy found
"404":
- $ref: '#/components/responses/NotFound'
- description: 'Not Found - Requested Policy using policy_id is not found'
+ content:
+ application/problem+json:
+ example: []
+ description: Not Found
+ summary: Get an A1 Policy instance (getPolicy)
+ tags:
+ - A1 Policy Management
/a1-policy/v2/services/{service_id}/keepalive:
put:
- description: A registered service should invoke this operation regularly to
- indicate that it is still alive. If a registered service fails to invoke some operation,
- or this operation, before the end of a timeout period the service will be deregistered
- and all its A1 policies wil be removed. This operation is only intended for registered
- services. (This timeout can be set or disabled when each service is initially registered)
+ description: "A registered service should invoke this operation regularly to\
+ \ indicate that it is still alive. If a registered service fails to invoke\
+ \ some operation, or this operation, before the end of a timeout period the\
+ \ service will be deregistered and all its A1 policies wil be removed. This\
+ \ operation is only intended for registered services. (This timeout can be\
+ \ set or disabled when each service is initially registered)"
operationId: keepAliveService
- summary: Heartbeat message from a service (keepAliveService)
- tags:
- - Service Registry and Supervision
parameters:
- - explode: false
- in: path
- name: service_id
- required: true
- schema:
- type: string
- style: simple
+ - explode: false
+ in: path
+ name: service_id
+ required: true
+ schema:
+ type: string
+ style: simple
responses:
"200":
content:
'*/*':
schema:
type: object
- description: OK - Service supervision timer refreshed, OK
+ description: "OK - Service supervision timer refreshed, OK"
"404":
- $ref: '#/components/responses/NotFound'
+ content:
+ application/problem+json:
+ example: []
+ description: Not Found
+ summary: Heartbeat message from a service (keepAliveService)
+ tags:
+ - Service Registry and Supervision
/a1-policy/v2/rics:
get:
description: Get all Near-RT RICs that supports a given A1 Policy Type ID
operationId: getRics
- summary: Get Near-RT RICs for A1 Policy Type (getRics)
- tags:
- - NearRT-RIC Repository
parameters:
- - description: >
- The identity of an A1 Policy Type. If given, all Near-RT RICs supporting
- the A1 Policy Type are returned.
- explode: true
- in: query
- name: policytype_id
- required: false
- schema:
- type: string
- style: form
+ - description: |
+ The identity of an A1 Policy Type. If given, all Near-RT RICs supporting the A1 Policy Type are returned.
+ explode: true
+ in: query
+ name: policytype_id
+ required: false
+ schema:
+ type: string
+ style: form
responses:
"200":
content:
application/json:
- schema:
- $ref: '#/components/schemas/ric_info_list'
examples:
ric_info_list:
$ref: '#/components/examples/ric_info_list'
+ schema:
+ $ref: '#/components/schemas/ric_info_list'
description: OK
"404":
- $ref: '#/components/responses/NotFound'
+ content:
+ application/problem+json:
+ example: []
+ description: Not Found
+ summary: Get Near-RT RICs for A1 Policy Type (getRics)
+ tags:
+ - NearRT-RIC Repository
/a1-policy/v2/services:
get:
- description: >
- Get information about all registered services, or a single registered service.
- If the service ID of a registered service is included in the query, information about that
- service is returned. Otherwise Information about all registered is returned.
- This operation does not retrieve information about unregistered services.
+ description: |
+ Get information about all registered services, or a single registered service. If the service ID of a registered service is included in the query, information about that service is returned. Otherwise Information about all registered is returned. This operation does not retrieve information about unregistered services.
operationId: getServices
- summary: Get Services (getServices)
- tags:
- - Service Registry and Supervision
parameters:
- - description: The identity of the registered service
- explode: true
- in: query
- name: service_id
- required: false
- schema:
- type: string
- style: form
+ - description: The identity of the registered service
+ explode: true
+ in: query
+ name: service_id
+ required: false
+ schema:
+ type: string
+ style: form
responses:
"200":
content:
application/json:
- schema:
- $ref: '#/components/schemas/service_status_list'
examples:
service_status_list:
$ref: '#/components/examples/service_status_list'
+ schema:
+ $ref: '#/components/schemas/service_status_list'
description: OK
"404":
- $ref: '#/components/responses/NotFound'
+ content:
+ application/problem+json:
+ example: []
+ description: Not Found
+ summary: Get Services (getServices)
+ tags:
+ - Service Registry and Supervision
put:
- description: >
- Register a single service, or update a previous registtration.
- Service registration is required to get callbacks about available NearRT RICs
- and to enable supervision of the service's active status. If a registered
- service becomes inactive, its policies can be automatically deleted.
- A1 Policy instances can also be created for unregistered services.
- If an unregistered service is later registered, the service's policies are
- retained when the service becomes registered. This feature is optional to use.
+ callbacks:
+ RICStatus:
+ '{$request.body#/callback_url}':
+ post:
+ description: "Callouts to indicate Near-RT RIC status changes relevant\
+ \ for Services. \nThe URL invoked by this callback is provided at\
+ \ Service registration.\n"
+ operationId: serviceCallback
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/service_callback_info_v2'
+ required: true
+ responses:
+ "200":
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/void'
+ description: OK
+ "404":
+ content:
+ application/problem+json:
+ example: []
+ description: Not Found
+ summary: Callback for Near-RT RIC status (serviceCallback)
+ tags:
+ - Service Registry and Supervision
+ - Service Callbacks
+ x-callback-request: true
+ description: |
+ Register a single service, or update a previous registtration. Service registration is required to get callbacks about available NearRT RICs and to enable supervision of the service's active status. If a registered service becomes inactive, its policies can be automatically deleted. A1 Policy instances can also be created for unregistered services. If an unregistered service is later registered, the service's policies are retained when the service becomes registered. This feature is optional to use.
operationId: putService
- summary: Register or update a Service (putService)
- tags:
- - Service Registry and Supervision
requestBody:
content:
application/json:
@@ -389,105 +428,88 @@ paths:
type: object
description: Created - Service created
"400":
- $ref: '#/components/responses/BadRequest'
- callbacks:
- RICStatus:
- "{$request.body#/callback_url}":
- post:
- description: |
- Callouts to indicate Near-RT RIC status changes relevant for Services.
- The URL invoked by this callback is provided at Service registration.
- operationId: serviceCallback
- summary: Callback for Near-RT RIC status (serviceCallback)
- tags:
- - Service Registry and Supervision
- - Service Callbacks
- requestBody:
- content:
- application/json:
- schema:
- $ref: '#/components/schemas/service_callback_info_v2'
- required: true
- responses:
- "200":
- content:
- application/json:
- schema:
- $ref: '#/components/schemas/void'
- description: OK
- "404":
- $ref: '#/components/responses/NotFound'
+ content:
+ application/problem+json:
+ example:
+ status: 400
+ title: Bad Request
+ detail: The provided request is not valid.
+ schema:
+ $ref: '#/components/schemas/error_information'
+ description: Bad Request
+ summary: Register or update a Service (putService)
+ tags:
+ - Service Registry and Supervision
/a1-policy/v2/policy-types/{policytype_id}:
get:
description: Get an A1 Policy Type definition using its policy type ID
operationId: getPolicyTypeDefinition
- summary: Get an A1 Policy Type definition (getPolicyTypeDefinition)
- tags:
- - A1 Policy Management
parameters:
- - explode: false
- in: path
- name: policytype_id
- required: true
- schema:
- type: string
- style: simple
+ - explode: false
+ in: path
+ name: policytype_id
+ required: true
+ schema:
+ type: string
+ style: simple
responses:
"200":
content:
application/json:
- schema:
- $ref: '#/components/schemas/policy_type_definition'
examples:
policy_type_definition:
$ref: '#/components/examples/policy_type_definition'
+ schema:
+ $ref: '#/components/schemas/policy_type_definition'
description: OK - schema of the requested A1 Policy Type
"404":
- $ref: '#/components/responses/NotFound'
+ content:
+ application/problem+json:
+ example: []
+ description: Not Found
+ summary: Get an A1 Policy Type definition (getPolicyTypeDefinition)
+ tags:
+ - A1 Policy Management
/a1-policy/v2/policies:
get:
- description: >
- Retrieve a list of A1 Policy Instance IDs for policies that match given search criteria.
- If multiple query parameters are given, the policies matching all conditions are returned.
+ description: |
+ Retrieve a list of A1 Policy Instance IDs for policies that match given search criteria. If multiple query parameters are given, the policies matching all conditions are returned.
operationId: getPolicyIds
- summary: Query A1 Policy Instances (getPolicyIds)
- tags:
- - A1 Policy Management
parameters:
- - description: Select policies of a given A1 Policy Type ID.
- explode: true
- in: query
- name: policytype_id
- required: false
- schema:
- type: string
- style: form
- - description: Select policies of a given Near-RT RIC identity.
- explode: true
- in: query
- name: ric_id
- required: false
- schema:
- type: string
- style: form
- - description: Select policies owned by a given service. (Both registered and unregistered services)
- explode: true
- in: query
- name: service_id
- required: false
- schema:
- type: string
- style: form
- - description: >
- Select policies of types with the given A1 Policy Type name
- (type names have the format 'typename_version')
- explode: true
- in: query
- name: type_name
- required: false
- schema:
- type: string
- style: form
+ - description: Select policies of a given A1 Policy Type ID.
+ explode: true
+ in: query
+ name: policytype_id
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: Select policies of a given Near-RT RIC identity.
+ explode: true
+ in: query
+ name: ric_id
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: Select policies owned by a given service. (Both registered and
+ unregistered services)
+ explode: true
+ in: query
+ name: service_id
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: |
+ Select policies of types with the given A1 Policy Type name (type names have the format 'typename_version')
+ explode: true
+ in: query
+ name: type_name
+ required: false
+ schema:
+ type: string
+ style: form
responses:
"200":
content:
@@ -499,13 +521,16 @@ paths:
$ref: '#/components/schemas/policy_id_list'
description: OK - Policy identities
"404":
- $ref: '#/components/responses/NotFound'
+ content:
+ application/problem+json:
+ example: []
+ description: Not Found
+ summary: Query A1 Policy Instances (getPolicyIds)
+ tags:
+ - A1 Policy Management
put:
description: Create or Update an A1 Policy Instance
- tags:
- - A1 Policy Management
operationId: putPolicy
- summary: Create or Update an A1 Policy Instance (putPolicy)
requestBody:
content:
application/json:
@@ -526,49 +551,58 @@ paths:
$ref: '#/components/schemas/void'
description: Created - Policy created
"423":
- $ref: '#/components/responses/Locked'
+ content:
+ application/problem+json:
+ example:
+ status: 423
+ title: Locked
+ detail: Requested resource is in a locked state.
+ schema:
+ $ref: '#/components/schemas/error_information'
+ description: Locked - HTTP Status code which can be used when the state
+ is Locked
+ summary: Create or Update an A1 Policy Instance (putPolicy)
+ tags:
+ - A1 Policy Management
/a1-policy/v2/policy-instances:
get:
- description: >
- Returns a collection of A1 Policy Instance information for policies that match given search criteria.
- If several query parameters are defined, the policies matching all conditions are returned.
+ description: |
+ Returns a collection of A1 Policy Instance information for policies that match given search criteria. If several query parameters are defined, the policies matching all conditions are returned.
operationId: getPolicyInstances
- summary: Query for A1 Policy instances (getPolicyInstances)
- tags:
- - A1 Policy Management
parameters:
- - description: Select policies with a given A1 Policy Type ID.
- explode: true
- in: query
- name: policytype_id
- required: false
- schema:
- type: string
- style: form
- - description: Select policies for a given Near-RT RIC identity.
- explode: true
- in: query
- name: ric_id
- required: false
- schema:
- type: string
- style: form
- - description: Select policies owned by a given service (registered or unregistered).
- explode: true
- in: query
- name: service_id
- required: false
- schema:
- type: string
- style: form
- - description: Select policies of a given A1 Policy Type name (type identity has the format 'typename_version').
- explode: true
- in: query
- name: type_name
- required: false
- schema:
- type: string
- style: form
+ - description: Select policies with a given A1 Policy Type ID.
+ explode: true
+ in: query
+ name: policytype_id
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: Select policies for a given Near-RT RIC identity.
+ explode: true
+ in: query
+ name: ric_id
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: Select policies owned by a given service (registered or unregistered).
+ explode: true
+ in: query
+ name: service_id
+ required: false
+ schema:
+ type: string
+ style: form
+ - description: Select policies of a given A1 Policy Type name (type identity
+ has the format 'typename_version').
+ explode: true
+ in: query
+ name: type_name
+ required: false
+ schema:
+ type: string
+ style: form
responses:
"200":
content:
@@ -584,25 +618,24 @@ paths:
application/json:
schema:
$ref: '#/components/schemas/error_information'
- description: Not Found - Near-RT RIC, A1 Policy Type or service was not found
+ description: "Not Found - Near-RT RIC, A1 Policy Type or service was not\
+ \ found"
+ summary: Query for A1 Policy instances (getPolicyInstances)
+ tags:
+ - A1 Policy Management
/a1-policy/v2/services/{service_id}:
delete:
- description: >
- Unregister a registered Service using its service ID.
- Only registered services can be unregistered. All A1 Policy Instances
- for the previously registered service will be removed.
- tags:
- - Service Registry and Supervision
+ description: |
+ Unregister a registered Service using its service ID. Only registered services can be unregistered. All A1 Policy Instances for the previously registered service will be removed.
operationId: deleteService
- summary: Unregister a Service (deleteService)
parameters:
- - explode: false
- in: path
- name: service_id
- required: true
- schema:
- type: string
- style: simple
+ - explode: false
+ in: path
+ name: service_id
+ required: true
+ schema:
+ type: string
+ style: simple
responses:
"204":
content:
@@ -611,41 +644,47 @@ paths:
type: object
description: No Content - Service unregistered
"404":
- $ref: '#/components/responses/NotFound'
+ content:
+ application/problem+json:
+ example: []
+ description: Not Found
+ summary: Unregister a Service (deleteService)
+ tags:
+ - Service Registry and Supervision
/a1-policy/v2/policies/{policy_id}/status:
get:
description: Retrieve the status information for an A1 Policy Instance.
- tags:
- - A1 Policy Management
operationId: getPolicyStatus
- summary: Get an A1 Policy Instance's status (getPolicyStatus)
parameters:
- - explode: false
- in: path
- name: policy_id
- required: true
- schema:
- type: string
- style: simple
+ - explode: false
+ in: path
+ name: policy_id
+ required: true
+ schema:
+ type: string
+ style: simple
responses:
"200":
content:
application/json:
- schema:
- $ref: '#/components/schemas/policy_status_info'
examples:
policy_status_info:
$ref: '#/components/examples/policy_status_info'
+ schema:
+ $ref: '#/components/schemas/policy_status_info'
description: OK - Policy status
"404":
- $ref: '#/components/responses/NotFound'
+ content:
+ application/problem+json:
+ example: []
+ description: Not Found
+ summary: Get an A1 Policy Instance's status (getPolicyStatus)
+ tags:
+ - A1 Policy Management
/a1-policy/v2/configuration:
get:
description: Returns the entire contents of the Application Configuration.
- tags:
- - Configuration
operationId: getConfiguration
- summary: Get the Application Configuration (getConfiguration)
responses:
"200":
content:
@@ -654,18 +693,17 @@ paths:
type: string
description: OK - Configuration
"404":
- $ref: '#/components/responses/NotFound'
- description: Not Found - Configuration is not found or is not readable
- put:
- description: >
- Replace the current Application Configuration with a new configuration.
- The new configuration, if accepted, will take effect after a short delay.
- The new configuration must comply with the Application Configuration schema,
- which can be found from the the Application Documentation (Developer Guide)
+ content:
+ application/problem+json:
+ example: []
+ description: Not Found
+ summary: Get the Application Configuration (getConfiguration)
tags:
- - Configuration
+ - Configuration
+ put:
+ description: |
+ Replace the current Application Configuration with a new configuration. The new configuration, if accepted, will take effect after a short delay. The new configuration must comply with the Application Configuration schema, which can be found from the the Application Documentation (Developer Guide)
operationId: putConfiguration
- summary: Set/Replace the Application Configuration (putConfiguration)
requestBody:
content:
application/json:
@@ -680,16 +718,23 @@ paths:
$ref: '#/components/schemas/void'
description: OK - Configuration updated
"400":
- $ref: '#/components/responses/BadRequest'
+ content:
+ application/problem+json:
+ example:
+ status: 400
+ title: Bad Request
+ detail: The provided request is not valid.
+ schema:
+ $ref: '#/components/schemas/error_information'
+ description: Bad Request
+ summary: Set/Replace the Application Configuration (putConfiguration)
+ tags:
+ - Configuration
/example-authz-check:
post:
- description: >
- A template endpoint for callout requests to an external authorization function.
- The authorization function, if enabled, decides if individual operations are permitted.
+ description: |
+ A template endpoint for callout requests to an external authorization function. The authorization function, if enabled, decides if individual operations are permitted.
operationId: performAccessControl
- summary: Callout request for access authorization (performAccessControl)
- tags:
- - Authorization API
requestBody:
content:
application/json:
@@ -704,20 +749,27 @@ paths:
$ref: '#/components/schemas/authorization_result'
description: OK
"403":
- $ref: '#/components/responses/Forbidden'
+ content:
+ application/problem+json:
+ example:
+ status: 403
+ title: Forbidden
+ detail: Your role does not allow to perform this action. Contact System
+ Administrator to change your access rights.
+ schema:
+ $ref: '#/components/schemas/error_information'
+ description: Forbidden
+ summary: Callout request for access authorization (performAccessControl)
+ tags:
+ - Authorization API
/actuator:
get:
- x-internal: true
- operationId: actuatorLinks
- description: >
- A1-PMS Springboot Service Actuator web endpoint.
- Returns a set of links to available/enabled actuator endpoints.
+ description: |
+ A1-PMS Springboot Service Actuator web endpoint. Returns a set of links to available/enabled actuator endpoints.
externalDocs:
description: Spring Boot Actuator Web API Documentation
url: https://docs.spring.io/spring-boot/reference/actuator/endpoints.html
- summary: Actuator endpoint - Root (actuatorLinks)
- tags:
- - Actuator API
+ operationId: actuatorLinks
responses:
"200":
content:
@@ -743,18 +795,18 @@ paths:
type: object
type: object
description: OK
+ summary: Actuator endpoint - Root (actuatorLinks)
+ tags:
+ - Actuator API
+ x-internal: true
/actuator/heapdump:
get:
- x-internal: true
- operationId: actuatorHeapdump
- description: >
- A1-PMS Springboot Service Actuator web endpoint - HeapDump.
+ description: |
+ A1-PMS Springboot Service Actuator web endpoint - HeapDump.
externalDocs:
description: Spring Boot Actuator Web API Documentation
url: https://docs.spring.io/spring-boot/reference/actuator/endpoints.html
- summary: Actuator endpoint - Heapdump (actuatorHeapdump)
- tags:
- - Actuator API
+ operationId: actuatorHeapdump
responses:
"200":
content:
@@ -762,18 +814,18 @@ paths:
schema:
type: object
description: OK
+ summary: Actuator endpoint - Heapdump (actuatorHeapdump)
+ tags:
+ - Actuator API
+ x-internal: true
/actuator/info:
get:
- x-internal: true
- operationId: actuatorInfo
- description: >
- A1-PMS Springboot Service Actuator web endpoint - Info.
+ description: |
+ A1-PMS Springboot Service Actuator web endpoint - Info.
externalDocs:
description: Spring Boot Actuator Web API Documentation
url: https://docs.spring.io/spring-boot/reference/actuator/endpoints.html
- summary: Actuator endpoint - Info (actuatorInfo)
- tags:
- - Actuator API
+ operationId: actuatorInfo
responses:
"200":
content:
@@ -787,18 +839,18 @@ paths:
schema:
type: object
description: OK
+ summary: Actuator endpoint - Info (actuatorInfo)
+ tags:
+ - Actuator API
+ x-internal: true
/actuator/threaddump:
get:
- x-internal: true
- operationId: actuatorThreaddump
- description: >
- A1-PMS Springboot Service Actuator web endpoint - ThreadDump.
+ description: |
+ A1-PMS Springboot Service Actuator web endpoint - ThreadDump.
externalDocs:
description: Spring Boot Actuator Web API Documentation
url: https://docs.spring.io/spring-boot/reference/actuator/endpoints.html
- summary: Actuator endpoint - Threaddump (actuatorThreaddump)
- tags:
- - Actuator API
+ operationId: actuatorThreaddump
responses:
"200":
content:
@@ -815,18 +867,18 @@ paths:
schema:
type: object
description: OK
+ summary: Actuator endpoint - Threaddump (actuatorThreaddump)
+ tags:
+ - Actuator API
+ x-internal: true
/actuator/loggers:
get:
- x-internal: true
- operationId: actuatorLoggers
- description: >
- A1-PMS Springboot Service Actuator web endpoint - Get a list of Loggers.
+ description: |
+ A1-PMS Springboot Service Actuator web endpoint - Get a list of Loggers.
externalDocs:
description: Spring Boot Actuator Web API Documentation
url: https://docs.spring.io/spring-boot/reference/actuator/endpoints.html
- summary: Actuator endpoint - Get Loggers (actuatorLoggers)
- tags:
- - Actuator API
+ operationId: actuatorLoggers
responses:
"200":
content:
@@ -840,26 +892,26 @@ paths:
schema:
type: object
description: OK
+ summary: Actuator endpoint - Get Loggers (actuatorLoggers)
+ tags:
+ - Actuator API
+ x-internal: true
/actuator/loggers/{name}:
get:
- x-internal: true
- operationId: actuatorGetLogger
- description: >
- A1-PMS Springboot Service Actuator web endpoint - Get a single named Logger.
+ description: |
+ A1-PMS Springboot Service Actuator web endpoint - Get a single named Logger.
externalDocs:
description: Spring Boot Actuator Web API Documentation
url: https://docs.spring.io/spring-boot/reference/actuator/endpoints.html
- summary: Actuator endpoint - Get Logger (actuatorGetLogger)
- tags:
- - Actuator API
+ operationId: actuatorGetLogger
parameters:
- - explode: false
- in: path
- name: name
- required: true
- schema:
- type: string
- style: simple
+ - explode: false
+ in: path
+ name: name
+ required: true
+ schema:
+ type: string
+ style: simple
responses:
"200":
content:
@@ -873,37 +925,37 @@ paths:
schema:
type: object
description: OK
- post:
+ summary: Actuator endpoint - Get Logger (actuatorGetLogger)
+ tags:
+ - Actuator API
x-internal: true
- operationId: actuatorSetlogger
- description: >
- A1-PMS Springboot Service Actuator web endpoint - Create or Update single named Logger.
+ post:
+ description: |
+ A1-PMS Springboot Service Actuator web endpoint - Create or Update single named Logger.
externalDocs:
description: Spring Boot Actuator Web API Documentation
url: https://docs.spring.io/spring-boot/reference/actuator/endpoints.html
- summary: Actuator endpoint - Set Logger (actuatorSetlogger)
- tags:
- - Actuator API
+ operationId: actuatorSetlogger
parameters:
- - explode: false
- in: path
- name: name
- required: true
- schema:
- type: string
- style: simple
+ - explode: false
+ in: path
+ name: name
+ required: true
+ schema:
+ type: string
+ style: simple
requestBody:
content:
application/json:
schema:
enum:
- - TRACE
- - DEBUG
- - INFO
- - WARN
- - ERROR
- - FATAL
- - "OFF"
+ - TRACE
+ - DEBUG
+ - INFO
+ - WARN
+ - ERROR
+ - FATAL
+ - "OFF"
type: string
responses:
"200":
@@ -912,18 +964,18 @@ paths:
schema:
type: object
description: OK
+ summary: Actuator endpoint - Set Logger (actuatorSetlogger)
+ tags:
+ - Actuator API
+ x-internal: true
/actuator/logfile:
get:
- x-internal: true
- operationId: actuatorGetLogFile
- description: >
- A1-PMS Springboot Service Actuator web endpoint - Get the Log file.
+ description: |
+ A1-PMS Springboot Service Actuator web endpoint - Get the Log file.
externalDocs:
description: Spring Boot Actuator Web API Documentation
url: https://docs.spring.io/spring-boot/reference/actuator/endpoints.html
- summary: Actuator endpoint - Log File (actuatorGetLogFile)
- tags:
- - Actuator API
+ operationId: actuatorGetLogFile
responses:
"200":
content:
@@ -931,18 +983,18 @@ paths:
schema:
type: object
description: OK
+ summary: Actuator endpoint - Log File (actuatorGetLogFile)
+ tags:
+ - Actuator API
+ x-internal: true
/actuator/health:
get:
- x-internal: true
- operationId: actuatorHealth
- description: >
- A1-PMS Springboot Service Actuator web endpoint - Health Check.
+ description: |
+ A1-PMS Springboot Service Actuator web endpoint - Health Check.
externalDocs:
description: Spring Boot Actuator Web API Documentation
url: https://docs.spring.io/spring-boot/reference/actuator/endpoints.html
- summary: Actuator endpoint - Health (actuatorHealth)
- tags:
- - Actuator API
+ operationId: actuatorHealth
responses:
"200":
content:
@@ -956,18 +1008,18 @@ paths:
schema:
type: object
description: OK
+ summary: Actuator endpoint - Health (actuatorHealth)
+ tags:
+ - Actuator API
+ x-internal: true
/actuator/health/**:
get:
- x-internal: true
- operationId: actuatorHealthComponent
- description: >
- A1-PMS Springboot Service Actuator web endpoint - Health Status for an Application Component.
+ description: |
+ A1-PMS Springboot Service Actuator web endpoint - Health Status for an Application Component.
externalDocs:
description: Spring Boot Actuator Web API Documentation
url: https://docs.spring.io/spring-boot/reference/actuator/endpoints.html
- summary: Actuator endpoint - Component Health (actuatorHealthComponent)
- tags:
- - Actuator API
+ operationId: actuatorHealthComponent
responses:
"200":
content:
@@ -981,18 +1033,18 @@ paths:
schema:
type: object
description: OK
+ summary: Actuator endpoint - Component Health (actuatorHealthComponent)
+ tags:
+ - Actuator API
+ x-internal: true
/actuator/shutdown:
post:
- x-internal: true
- operationId: actuatorShutdown
- description: >
- A1-PMS Springboot Service Actuator web endpoint - Shutdown the Application.
+ description: |
+ A1-PMS Springboot Service Actuator web endpoint - Shutdown the Application.
externalDocs:
description: Spring Boot Actuator Web API Documentation
url: https://docs.spring.io/spring-boot/reference/actuator/endpoints.html
- summary: Actuator endpoint - Shutdown (actuatorShutdown)
- tags:
- - Actuator API
+ operationId: actuatorShutdown
responses:
"200":
content:
@@ -1006,18 +1058,18 @@ paths:
schema:
type: object
description: OK
+ summary: Actuator endpoint - Shutdown (actuatorShutdown)
+ tags:
+ - Actuator API
+ x-internal: true
/actuator/metrics:
get:
- x-internal: true
- operationId: actuatorMetrics
- description: >
- A1-PMS Springboot Service Actuator web endpoint - Get a list of Application metrics names.
+ description: |
+ A1-PMS Springboot Service Actuator web endpoint - Get a list of Application metrics names.
externalDocs:
description: Spring Boot Actuator Web API Documentation
url: https://docs.spring.io/spring-boot/reference/actuator/endpoints.html
- summary: Actuator endpoint - Metrics (actuatorMetrics)
- tags:
- - Actuator API
+ operationId: actuatorMetrics
responses:
"200":
content:
@@ -1031,24 +1083,26 @@ paths:
schema:
type: object
description: OK
+ summary: Actuator endpoint - Metrics (actuatorMetrics)
+ tags:
+ - Actuator API
+ x-internal: true
/actuator/metrics/{requiredMetricName}:
get:
- x-internal: true
- operationId: actuatorGetMetric
- description: >
- A1-PMS Springboot Service Actuator web endpoint - Get the value for a named Application metric.
+ description: |
+ A1-PMS Springboot Service Actuator web endpoint - Get the value for a named Application metric.
externalDocs:
description: Spring Boot Actuator Web API Documentation
url: https://docs.spring.io/spring-boot/reference/actuator/endpoints.html
- summary: Actuator endpoint - Get Metric (actuatorGetMetric)
+ operationId: actuatorGetMetric
parameters:
- - explode: false
- in: path
- name: requiredMetricName
- required: true
- schema:
- type: string
- style: simple
+ - explode: false
+ in: path
+ name: requiredMetricName
+ required: true
+ schema:
+ type: string
+ style: simple
responses:
"200":
content:
@@ -1062,78 +1116,29 @@ paths:
schema:
type: object
description: OK
-
+ summary: Actuator endpoint - Get Metric (actuatorGetMetric)
+ x-internal: true
components:
-
- responses:
- Locked:
- description: Locked - HTTP Status code which can be used when the state is Locked
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/error_information'
- example:
- status: 423
- title: Locked
- detail: Requested resource is in a locked state.
- BadRequest:
- description: Bad Request
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/error_information'
- example:
- status: 400
- title: Bad Request
- detail: The provided request is not valid.
- Forbidden:
- description: Forbidden
- content:
- application/problem+json:
- schema:
- $ref: '#/components/schemas/error_information'
- example:
- status: 403
- title: Forbidden
- detail: Your role does not allow to perform this action. Contact System Administrator to change your access rights.
- NotFound:
- description: Not Found
- content:
- application/problem+json:
- example:
- [ ]
-
examples:
- service_status:
- description: List of service information
- value:
- callback_url: callback_url
- service_id: service_id
- keep_alive_interval_seconds: 0
- time_since_last_activity_seconds: 6
-
- service_status_list:
- description: List of service information
+ status_info:
value:
- service_list:
- - callback_url: callback_url
- service_id: service_id
- keep_alive_interval_seconds: 0
- time_since_last_activity_seconds: 6
- - callback_url: callback_url
- service_id: service_id
- keep_alive_interval_seconds: 0
- time_since_last_activity_seconds: 6
- policy_type_definition:
- description: Schema of the given A1 Policy Type
+ status: status
+ ric_info:
value:
- policy_schema: "{}"
+ ric_id: ric_id
+ managed_element_ids:
+ - some_managed_element_id
+ - some_managed_element_id
+ state: UNAVAILABLE
+ policytype_ids:
+ - some_policytype_id
+ - some_policytype_id
policy_type_id_list:
description: Array of A1 Policy Type id's
value:
policy_type_id_list:
- - policytype_id
- - policytype_id
+ - policytype_id
+ - policytype_id
policy_info:
description: Information for an A1 Policy Instance
value:
@@ -1144,30 +1149,65 @@ components:
policy_data: "{}"
status_notification_uri: status_notification_uri
policytype_id: policytype_id1
- policy_info_list:
- description: List of policy information
+ ric_info_list:
value:
- policies:
- - ric_id: ric_id1
- policy_id: policy_id1
- transient: false
- service_id: service_id1
- policy_data: "{}"
- status_notification_uri: status_notification_uri
- policytype_id: policytype_id1
- - ric_id: ric_id2
- policy_id: policy_id2
- transient: true
- service_id: service_id2
- policy_data: "{}"
- status_notification_uri: status_notification_uri
- policytype_id: policytype_id2
+ rics:
+ - ric_id: ric_id
+ managed_element_ids:
+ - some_managed_element_id
+ - some_managed_element_id
+ state: UNAVAILABLE
+ policytype_ids:
+ - policytype_id
+ - policytype_id
+ - ric_id: ric_id
+ managed_element_ids:
+ - managed_element_ids
+ - managed_element_ids
+ state: UNAVAILABLE
+ policytype_ids:
+ - policytype_ids
+ - policytype_ids
+ service_status_list:
+ description: List of service information
+ value:
+ service_list:
+ - callback_url: callback_url
+ service_id: service_id
+ keep_alive_interval_seconds: 0
+ time_since_last_activity_seconds: 6
+ - callback_url: callback_url
+ service_id: service_id
+ keep_alive_interval_seconds: 0
+ time_since_last_activity_seconds: 6
+ policy_type_definition:
+ description: Schema of the given A1 Policy Type
+ value:
+ policy_schema: "{}"
policy_id_list:
description: A list of policy identities
value:
policy_ids:
- - some_policy_id
- - some_policy_id
+ - some_policy_id
+ - some_policy_id
+ policy_info_list:
+ description: List of policy information
+ value:
+ policies:
+ - ric_id: ric_id1
+ policy_id: policy_id1
+ transient: false
+ service_id: service_id1
+ policy_data: "{}"
+ status_notification_uri: status_notification_uri
+ policytype_id: policytype_id1
+ - ric_id: ric_id2
+ policy_id: policy_id2
+ transient: true
+ service_id: service_id2
+ policy_data: "{}"
+ status_notification_uri: status_notification_uri
+ policytype_id: policytype_id2
policy_status_info:
description: Status for one A1-P Policy
value:
@@ -1175,89 +1215,63 @@ components:
status:
value:
status: status
- status_info:
- value:
- status: status
- ric_info:
- value:
- ric_id: ric_id
- managed_element_ids:
- - some_managed_element_id
- - some_managed_element_id
- state: UNAVAILABLE
- policytype_ids:
- - some_policytype_id
- - some_policytype_id
- ric_info_list:
- value:
- rics:
- - ric_id: ric_id
- managed_element_ids:
- - some_managed_element_id
- - some_managed_element_id
- state: UNAVAILABLE
- policytype_ids:
- - policytype_id
- - policytype_id
- - ric_id: ric_id
- managed_element_ids:
- - managed_element_ids
- - managed_element_ids
- state: UNAVAILABLE
- policytype_ids:
- - policytype_ids
- - policytype_ids
-
+ responses:
+ NotFound:
+ content:
+ application/problem+json:
+ example: []
+ description: Not Found
+ Locked:
+ content:
+ application/problem+json:
+ example:
+ status: 423
+ title: Locked
+ detail: Requested resource is in a locked state.
+ schema:
+ $ref: '#/components/schemas/error_information'
+ description: Locked - HTTP Status code which can be used when the state is Locked
+ BadRequest:
+ content:
+ application/problem+json:
+ example:
+ status: 400
+ title: Bad Request
+ detail: The provided request is not valid.
+ schema:
+ $ref: '#/components/schemas/error_information'
+ description: Bad Request
+ Forbidden:
+ content:
+ application/problem+json:
+ example:
+ status: 403
+ title: Forbidden
+ detail: Your role does not allow to perform this action. Contact System
+ Administrator to change your access rights.
+ schema:
+ $ref: '#/components/schemas/error_information'
+ description: Forbidden
schemas:
- policy_type_definition:
- description: Contains A1 Policy Type schema definition
- type: object
- properties:
- policy_schema:
- description: A1 Policy Type json schema. The schema is a json object following
- http://json-schema.org/draft-07/schema
- type: object
- error_information:
- description: Problem as defined in https://tools.ietf.org/html/rfc7807
- properties:
- detail:
- description: ' A human-readable explanation specific to this occurrence
- of the problem.'
- example: A1 Policy Type not found
- type: string
- title:
- description: 'A specific error name'
- type: string
- example: Not Found
- status:
- description: 'The HTTP status code generated by the origin server for this
- occurrence of the problem. '
- example: 404
- format: int32
- type: integer
- type: object
- void:
- description: Void/empty
- type: object
status_info:
+ example:
+ status: status
properties:
status:
description: status text
type: string
type: object
- authorization_result:
- description: Result of authorization
- example:
- result: true
- properties:
- result:
- description: If true, the access is granted
- type: boolean
- required:
- - result
- type: object
ric_info:
description: Information for a Near-RT RIC
+ example:
+ ric_id: ric_id
+ managed_element_ids:
+ - managed_element_ids
+ - managed_element_ids
+ state: UNAVAILABLE
+ policytype_ids:
+ - policytype_ids
+ - policytype_ids
properties:
ric_id:
description: identity of the Near-RT RIC
@@ -1271,10 +1285,10 @@ components:
state:
description: Represents the states for a Near-RT RIC
enum:
- - UNAVAILABLE
- - AVAILABLE
- - SYNCHRONIZING
- - CONSISTENCY_CHECK
+ - UNAVAILABLE
+ - AVAILABLE
+ - SYNCHRONIZING
+ - CONSISTENCY_CHECK
type: string
policytype_ids:
description: supported A1 Policy Types
@@ -1283,49 +1297,141 @@ components:
type: string
type: array
type: object
- service_registration_info:
- description: Information for one service
+ policy_type_id_list:
+ description: Information about A1 Policy Types
+ example:
+ policytype_ids:
+ - policytype_ids
+ - policytype_ids
properties:
- callback_url:
- description: Callback for notifying of Near-RT RIC state changes
+ policytype_ids:
+ description: A1 Policy Type identities
+ items:
+ description: A1 Policy Type identities
+ type: string
+ type: array
+ type: object
+ policy_info:
+ description: Information for one A1-P Policy
+ example:
+ ric_id: ric_id
+ policy_id: policy_id
+ transient: false
+ service_id: ""
+ policy_data: "{}"
+ status_notification_uri: status_notification_uri
+ policytype_id: policytype_id
+ properties:
+ ric_id:
+ description: identity of the target Near-RT RIC
+ type: string
+ policy_id:
+ description: identity of the policy
type: string
+ transient:
+ default: false
+ description: |
+ If true, the policy is automatically deleted if the targeted Near-RT RIC restarts or recovers. If false, the A1 Policy Instance remains, and is re-pushed to the targeted Near-RT RIC after a restart or recovery. If false, the A1 Policy Instance is maintained and must be deleted separately in the event of Near-RT RIC restart or recovery. Default is false.
+ example: false
+ nullable: false
+ type: boolean
service_id:
- description: identity of the service
+ default: ""
+ description: |
+ The identity of the service owning the policy. This can be used to group the policies (it is possible to get all policies associated to a service). Note that the service does not need to be registered. If the service is registered, the A1 Policy Instance will be subject to the same supervision rules as the the service's other policies.
+ type: string
+ policy_data:
+ description: the configuration of the policy
+ type: object
+ status_notification_uri:
+ description: Callback URI for policy status updates
+ type: string
+ policytype_id:
+ description: identity of the A1 Policy Type
type: string
- keep_alive_interval_seconds:
- description: >
- Keep alive interval for the service. This is used to enable
- optional heartbeat supervision of the service. If set (> 0) the registered
- service should regularly invoke a 'keepalive' REST call. When a service
- fails to invoke this 'keepalive' call within the configured time, the
- service is considered unavailable. An unavailable service will be automatically
- deregistered and its policies will be deleted. Value 0 means timeout
- supervision is disabled.
- format: int64
- type: integer
required:
- - service_id
+ - policy_data
+ - policy_id
+ - policytype_id
+ - ric_id
type: object
- policy_info_list:
- description: List of policy information
+ void:
+ description: Void/empty
+ type: object
+ error_information:
+ description: Problem as defined in https://tools.ietf.org/html/rfc7807
+ example:
+ detail: A1 Policy Type not found
+ title: Not Found
+ status: 404
properties:
- policies:
- description: List of policy information
+ detail:
+ description: ' A human-readable explanation specific to this occurrence
+ of the problem.'
+ example: A1 Policy Type not found
+ type: string
+ title:
+ description: A specific error name
+ example: Not Found
+ type: string
+ status:
+ description: 'The HTTP status code generated by the origin server for this
+ occurrence of the problem. '
+ example: 404
+ format: int32
+ type: integer
+ type: object
+ ric_info_list:
+ description: List of Near-RT RIC information
+ example:
+ rics:
+ - ric_id: ric_id
+ managed_element_ids:
+ - managed_element_ids
+ - managed_element_ids
+ state: UNAVAILABLE
+ policytype_ids:
+ - policytype_ids
+ - policytype_ids
+ - ric_id: ric_id
+ managed_element_ids:
+ - managed_element_ids
+ - managed_element_ids
+ state: UNAVAILABLE
+ policytype_ids:
+ - policytype_ids
+ - policytype_ids
+ properties:
+ rics:
+ description: List of Near-RT RIC information
items:
- $ref: '#/components/schemas/policy_info'
+ $ref: '#/components/schemas/ric_info'
type: array
type: object
- policy_status_info:
- description: Status for one A1-P Policy
+ service_status_list:
+ example:
+ service_list:
+ - callback_url: callback_url
+ service_id: service_id
+ keep_alive_interval_seconds: 0
+ time_since_last_activity_seconds: 6
+ - callback_url: callback_url
+ service_id: service_id
+ keep_alive_interval_seconds: 0
+ time_since_last_activity_seconds: 6
properties:
- last_modified:
- description: timestamp, last modification time
- type: string
- status:
- description: the Policy status
- type: object
+ service_list:
+ description: List of service information
+ items:
+ $ref: '#/components/schemas/service_status'
+ type: array
type: object
service_status:
+ example:
+ callback_url: callback_url
+ service_id: service_id
+ keep_alive_interval_seconds: 0
+ time_since_last_activity_seconds: 6
properties:
callback_url:
description: callback for notifying of RIC synchronization
@@ -1342,103 +1448,56 @@ components:
format: int64
type: integer
type: object
- ric_info_list:
- description: List of Near-RT RIC information
- properties:
- rics:
- description: List of Near-RT RIC information
- items:
- $ref: '#/components/schemas/ric_info'
- type: array
- type: object
- input:
- description: input
+ service_registration_info:
+ description: Information for one service
properties:
- access_type:
- description: Access type
- enum:
- - READ
- - WRITE
- - DELETE
- type: string
- auth_token:
- description: Authorization token
+ callback_url:
+ description: Callback for notifying of Near-RT RIC state changes
type: string
- policy_type_id:
- description: A1 Policy Type identifier
+ service_id:
+ description: identity of the service
type: string
+ keep_alive_interval_seconds:
+ description: |
+ Keep alive interval for the service. This is used to enable optional heartbeat supervision of the service. If set (> 0) the registered service should regularly invoke a 'keepalive' REST call. When a service fails to invoke this 'keepalive' call within the configured time, the service is considered unavailable. An unavailable service will be automatically deregistered and its policies will be deleted. Value 0 means timeout supervision is disabled.
+ format: int64
+ type: integer
required:
- - access_type
- - auth_token
- - policy_type_id
- type: object
- policy_authorization:
- description: Authorization request for A1 policy requests
- properties:
- input:
- $ref: '#/components/schemas/input'
- required:
- - input
- type: object
- policy_type_id_list:
- description: Information about A1 Policy Types
- properties:
- policytype_ids:
- description: A1 Policy Type identities
- items:
- description: A1 Policy Type identities
- type: string
- type: array
+ - service_id
type: object
- policy_info:
- description: Information for one A1-P Policy
+ service_callback_info_v2:
+ description: "Information transferred in Service callbacks, \nif a callback\
+ \ URL was provided for a registered service\n"
properties:
ric_id:
- description: identity of the target Near-RT RIC
- type: string
- policy_id:
- description: identity of the policy
- type: string
- transient:
- default: false
- description: >
- If true, the policy is automatically deleted if the targeted Near-RT RIC restarts
- or recovers. If false, the A1 Policy Instance remains, and is re-pushed to the targeted
- Near-RT RIC after a restart or recovery. If false, the A1 Policy Instance is maintained and
- must be deleted separately in the event of Near-RT RIC restart or recovery. Default is false.
- example: false
- nullable: false
- type: boolean
- service_id:
- description: >
- The identity of the service owning the policy. This can be
- used to group the policies (it is possible to get all policies associated
- to a service). Note that the service does not need to be registered.
- If the service is registered, the A1 Policy Instance will be
- subject to the same supervision rules as the the service's other policies.
- type: string
- default: ""
- policy_data:
- description: the configuration of the policy
- type: object
- status_notification_uri:
- description: Callback URI for policy status updates
+ description: identity of a Near-RT RIC
type: string
- policytype_id:
- description: identity of the A1 Policy Type
+ event_type:
+ description: "values: \n AVAILABLE: the Near-RT RIC has become available\
+ \ for A1 Policy management\n"
+ enum:
+ - AVAILABLE
type: string
required:
- - ric_id
- - policy_id
- - policy_data
- - policytype_id
+ - event_type
+ - ric_id
+ type: object
+ policy_type_definition:
+ description: Contains A1 Policy Type schema definition
+ example:
+ policy_schema: "{}"
+ properties:
+ policy_schema:
+ description: A1 Policy Type json schema. The schema is a json object following
+ http://json-schema.org/draft-07/schema
+ type: object
type: object
policy_id_list:
description: A list of policy identities
example:
policy_ids:
- - policy_ids
- - policy_ids
+ - policy_ids
+ - policy_ids
properties:
policy_ids:
description: Policy identities
@@ -1447,32 +1506,83 @@ components:
type: string
type: array
type: object
- service_status_list:
+ policy_info_list:
+ description: List of policy information
+ example:
+ policies:
+ - ric_id: ric_id
+ policy_id: policy_id
+ transient: false
+ service_id: ""
+ policy_data: "{}"
+ status_notification_uri: status_notification_uri
+ policytype_id: policytype_id
+ - ric_id: ric_id
+ policy_id: policy_id
+ transient: false
+ service_id: ""
+ policy_data: "{}"
+ status_notification_uri: status_notification_uri
+ policytype_id: policytype_id
properties:
- service_list:
- description: List of service information
+ policies:
+ description: List of policy information
items:
- $ref: '#/components/schemas/service_status'
+ $ref: '#/components/schemas/policy_info'
type: array
type: object
- service_callback_info_v2:
- description: |
- Information transferred in Service callbacks,
- if a callback URL was provided for a registered service
+ policy_status_info:
+ description: Status for one A1-P Policy
+ example:
+ last_modified: last_modified
+ status: "{}"
properties:
- ric_id:
- description: identity of a Near-RT RIC
+ last_modified:
+ description: "timestamp, last modification time"
type: string
- event_type:
- description: >
- values:
- AVAILABLE: the Near-RT RIC has become available for A1 Policy management
+ status:
+ description: the Policy status
+ type: object
+ type: object
+ policy_authorization:
+ description: Authorization request for A1 policy requests
+ properties:
+ input:
+ $ref: '#/components/schemas/input'
+ required:
+ - input
+ type: object
+ input:
+ description: input
+ properties:
+ access_type:
+ description: Access type
enum:
- - AVAILABLE
+ - READ
+ - WRITE
+ - DELETE
+ type: string
+ auth_token:
+ description: Authorization token
+ type: string
+ policy_type_id:
+ description: A1 Policy Type identifier
type: string
required:
- - event_type
- - ric_id
+ - access_type
+ - auth_token
+ - policy_type_id
+ type: object
+ authorization_result:
+ description: Result of authorization
+ example:
+ result: true
+ properties:
+ result:
+ description: "If true, the access is granted"
+ type: boolean
+ required:
+ - result
type: object
Link:
properties:
@@ -1480,4 +1590,4 @@ components:
type: boolean
href:
type: string
- type: object \ No newline at end of file
+ type: object