blob: 5329d8fb6627ace92f4c2598d55b7f5d740c0330 [file] [log] [blame]
Pamela Dragosh5fc2fdb2019-05-17 09:42:27 -04001.. This work is licensed under a Creative Commons Attribution 4.0 International License.
Jim Hahnd5cc9482019-05-29 15:41:48 -04002.. http://creativecommons.org/licenses/by/4.0
Pamela Dragosh5fc2fdb2019-05-17 09:42:27 -04003
4.. _pap-label:
5
6Policy Administration Point (PAP) Architecture
liamfallon4d1d9832019-05-30 20:53:05 +00007##############################################
Jim Hahnd5cc9482019-05-29 15:41:48 -04008
liamfallon4d1d9832019-05-30 20:53:05 +00009.. contents::
10 :depth: 3
Jim Hahnd5cc9482019-05-29 15:41:48 -040011
Pamela Dragosh6eec8752020-05-21 11:06:03 -040012.. toctree::
13 InternalPapPdp.rst
14
Ram Krishna Verma2145c752020-04-30 14:11:54 -040015The Policy Administration Point (PAP) keeps track of PDPs, supporting the deployment of PDP groups and the deployment
16of policies across those PDP groups. Policies are created using the Policy API, but are deployed via the PAP.
Jim Hahnd5cc9482019-05-29 15:41:48 -040017
Ram Krishna Verma2145c752020-04-30 14:11:54 -040018The PAP is stateless in a RESTful sense, using the database (persistent storage) to track PDPs and the deployment of
19policies to those PDPs. In short, policy management on PDPs is the responsibility of PAP; management of policies by
20any other manner is not permitted.
liamfallon4d1d9832019-05-30 20:53:05 +000021
22Because the PDP is the main unit of scalability in the Policy Framework, the framework is designed to allow PDPs in a
23PDP group to arbitrarily appear and disappear and for policy consistency across all PDPs in a PDP group to be easily
24maintained. The PAP is responsible for controlling the state across the PDPs in a PDP group. The PAP interacts with the
Ram Krishna Verma2145c752020-04-30 14:11:54 -040025policy database and transfers policies to PDPs.
Pamela Dragosh5fc2fdb2019-05-17 09:42:27 -040026
Pamela Dragoshf65c8ff2020-04-29 08:23:12 -040027The unit of execution and scaling in the Policy Framework is a *PolicyImpl* entity. A *PolicyImpl* entity runs on a PDP.
28As is explained above, a *PolicyImpl* entity is a *PolicyTypeImpl* implementation parameterized with a TOSCA *Policy*.
29
30.. image:: images/PolicyImplPDPSubGroup.svg
31
32In order to achieve horizontal scalability, we group the PDPs running instances of a given *PolicyImpl* entity logically
33together into a *PDPSubGroup*. The number of PDPs in a *PDPSubGroup* can then be scaled up and down using Kubernetes. In
34other words, all PDPs in a subgroup run the same *PolicyImpl*, that is the same policy template implementation (in
35XACML, Drools, or APEX) with the same parameters.
36
37The figure above shows the layout of *PDPGroup* and *PDPSubGroup* entities. The figure shows examples of PDP groups for
38Control Loop and Monitoring policies on the right.
39
40The health of PDPs is monitored by the PAP in order to alert operations teams managing policies. The PAP manages the life
41cycle of policies running on PDPs.
42
43The table below shows the deployment methods in which *PolicyImpl* entities can be deployed to PDP Subgroups.
44
45========== =========================================== ============================== ==================================
46**Method** **Description** **Advantages** **Disadvantages**
47========== =========================================== ============================== ==================================
48Cold The *PolicyImpl* (*PolicyTypeImpl* and No run time configuration Very restrictive, no run time
49 TOSCA *Policy*) are predeployed on the PDP. required and run time configuration of PDPs is possible.
50 PDP is fully configured and ready to administration is simple.
51 execute when started.
52
53 PDPs register with the PAP when they
54 start, providing the *pdpGroup* they
55 have been preconfigured with.
56
57Warm The *PolicyTypeImpl* entity is predeployed The configuration, parameters, Administration and management is
58 on the PDP. A TOSCA *Policy* may be loaded and PDP group of PDPs may be required. The configuration and
59 at startup. The PDP may be configured or changed at run time by loading life cycle of the TOSCA policies
60 reconfigured with a new or updated TOSCA or updating a TOSCA *Policy* can change at run time and must be
61 *Policy* at run time. into the PDP. administered and managed.
62
63 PDPs register with the PAP when they start, Support TOSCA *Policy* entity
64 providing the *pdpGroup* they have been life cycle managgement is
65 predeployed with if any. The PAP may update supported, allowing features
66 the TOSCA *Policy* on a PDP at any time such as *PolicyImpl* Safe Mode
67 after registration. and *PolicyImpl* retirement.
68
69Hot The *PolicyImpl* (*PolicyTypeImpl* and The policy logic, rules, Administration and management is
70 TOSCA *Policy*) are deployed at run time. configuration, parameters, and more complex. The *PolicyImpl*
71 The *PolicyImpl* (*PolicyTypeImpl* and PDP group of PDPs may be itself and its configuration and
72 TOSCA *Policy*) may be loaded at startup. changed at run time by loading life cycle as well as the life
73 The PDP may be configured or reconfigured or updating a TOSCA *Policy* cycle of the TOSCA policies can
74 with a new or updated *PolicyTypeImpl* and *PolicyTypeImpl* into the change at run time and must be
75 and/or TOSCA *Policy* at run time. PDP. administered and managed.
76
77 PDPs register with the PAP when they Lifecycle management of TOSCA
78 start, providing the *pdpGroup* they have *Policy* entities and
79 been preconfigured with if any. The PAP may *PolicyTypeImpl* entites is
80 update the TOSCA *Policy* and supported, allowing features
81 *PolicyTypeImpl* on a PDP at any time after such as *PolicyImpl* Safe Mode
82 registration and *PolicyImpl* retirement.
83========== =========================================== ============================== ==================================
84
Pamela Dragosh5fc2fdb2019-05-17 09:42:27 -040085
liamfallon4d1d9832019-05-30 20:53:05 +0000861 APIs
87======
88The APIs in the subchapters below are supported by the PAP.
89
901.1 REST API
91------------
92
93The purpose of this API is to support CRUD of PDP groups and subgroups and to support the deployment and life cycles of
94policies on PDP sub groups and PDPs. This API is provided by the *PolicyAdministration* component (PAP) of the Policy
95Framework, see the :ref:`ONAP Policy Framework Architecture <architecture-label>` page.
96
97PDP groups and subgroups may be prefedined in the system. Predefined groups and subgroups may be modified or deleted
98over this API. The policies running on predefined groups or subgroups as well as the instance counts and properties may
99also be modified.
100
101A PDP may be preconfigured with its PDP group, PDP subgroup, and policies. The PDP sends this information to the PAP
102when it starts. If the PDP group, subgroup, or any policy is unknown to the PAP, the PAP locks the PDP in state PASSIVE.
Pamela Dragosh5fc2fdb2019-05-17 09:42:27 -0400103
Jim Hahnd5cc9482019-05-29 15:41:48 -0400104PAP supports the operations listed in the following table, via its REST API:
105
106.. csv-table::
107 :header: "Operation", "Description"
108 :widths: 25,70
109
110 "Health check", "Queries the health of the PAP"
Ram Krishna Verma2145c752020-04-30 14:11:54 -0400111 "Consolidated healthcheck", "Queries the health of all policy components"
Jim Hahnd5cc9482019-05-29 15:41:48 -0400112 "Statistics", "Queries various statistics"
113 "PDP state change", "Changes the state of all PDPs in a PDP Group"
114 "PDP Group create/update", "Creates/updates PDP Groups"
115 "PDP Group delete", "Deletes a PDP Group"
116 "PDP Group query", "Queries all PDP Groups"
Ram Krishna Verma2145c752020-04-30 14:11:54 -0400117 "Deployment update", "Deploy/undeploy one or more policies in specified PdpGroups"
Jim Hahnd5cc9482019-05-29 15:41:48 -0400118 "Deploy policy", "Deploys one or more policies to the PDPs"
119 "Undeploy policy", "Undeploys a policy from the PDPs"
Ram Krishna Verma2145c752020-04-30 14:11:54 -0400120 "Policy deployment status", "Queries the status of all deployed policies"
121 "PDP statistics", "Queries the statistics of PDPs"
Jim Hahnd5cc9482019-05-29 15:41:48 -0400122
liamfallon4d1d9832019-05-30 20:53:05 +00001231.2 DMaaP API
124-------------
Jim Hahnd5cc9482019-05-29 15:41:48 -0400125
126PAP interacts with the PDPs via the DMaaP Message Router. The messages listed
127in the following table are transmitted via DMaaP:
128
129.. csv-table::
130 :header: "Message", "Direction", "Description"
131 :widths: 25,10,70
132
133 "PDP status", "Incoming", "Registers a PDP with PAP; also sent as a periodic heart beat; also sent in response to requests from the PAP"
134 "PDP update", "Outgoing", "Assigns a PDP to a PDP Group and Subgroup; also deploys or undeploys policies from the PDP"
135 "PDP state change", "Outgoing", "Changes the state of a PDP or all PDPs within a PDP Group or Subgroup"
136
Saryu Shah3c711d12019-12-04 23:17:41 +0000137In addition, PAP generates notifications via the DMaaP Message Router when policies are successfully or unsuccessfully
138deployed (or undeployed) from all relevant PDPs.
139
140Here is a sample notification:
141
142.. literalinclude:: notification/dmaap-pap-notif.json
143 :language: json
144
Jim Hahnd5cc9482019-05-29 15:41:48 -0400145
liamfallon4d1d9832019-05-30 20:53:05 +00001462 PAP REST API Swagger
147======================
Jim Hahnd5cc9482019-05-29 15:41:48 -0400148
liamfallon4d1d9832019-05-30 20:53:05 +0000149It is worth noting that we use basic authorization for access with user name and password set to *healthcheck* and
150*zb!XztG34*, respectively.
Jim Hahnd5cc9482019-05-29 15:41:48 -0400151
liamfallon4d1d9832019-05-30 20:53:05 +0000152For every call, the client is encouraged to insert a uuid-type *requestID* as parameter. It is helpful for tracking each
153http transaction and facilitates debugging. More importantly, it complies with Logging requirements v1.2. If the client
154does not provide the requestID in a call, one will be randomly generated and attached to the response header,
155*x-onap-requestid*.
Jim Hahnd5cc9482019-05-29 15:41:48 -0400156
liamfallon4d1d9832019-05-30 20:53:05 +0000157In accordance with `ONAP API Common Versioning Strategy Guidelines
158<https://wiki.onap.org/display/DW/ONAP+API+Common+Versioning+Strategy+%28CVS%29+Guidelines>`_, several custom headers
159are added in the response to each call:
Jim Hahnd5cc9482019-05-29 15:41:48 -0400160
161.. csv-table::
162 :header: "Header", "Example value", "Description"
163 :widths: 25,10,70
164
165 "x-latestversion", "1.0.0", "latest version of the API"
166 "x-minorversion", "0", "MINOR version of the API"
167 "x-patchversion", "0", "PATCH version of the API"
168 "x-onap-requestid", "e1763e61-9eef-4911-b952-1be1edd9812b", "described above; used for logging purposes"
Pamela Dragosh1d101d22020-07-09 13:46:16 -0400169
170:download:`Download Health Check PAP API Swagger <swagger/health-check-pap.json>`
Jim Hahnd5cc9482019-05-29 15:41:48 -0400171
172.. swaggerv2doc:: swagger/health-check-pap.json
173
liamfallon4d1d9832019-05-30 20:53:05 +0000174This operation performs a health check on the PAP.
175
Jim Hahn0f079d22019-08-01 11:05:24 -0400176Here is a sample response:
177
178.. literalinclude:: response/health-check-pap-resp.json
179 :language: json
180
Pamela Dragosh1d101d22020-07-09 13:46:16 -0400181:download:`Download Consolidated Health Check PAP API Swagger <swagger/consolidated-healthcheck-pap.json>`
182
Ram Krishna Verma2145c752020-04-30 14:11:54 -0400183.. swaggerv2doc:: swagger/consolidated-healthcheck-pap.json
184
185This operation performs a health check of all policy components. The response
186contains the health check result of each component. The consolidated health check
187is reported as healthy only if all the components are healthy, otherwise the
188"healthy" flag is marked as false.
189
190Here is a sample response:
191
192.. literalinclude:: response/consolidated-healthcheck-pap-resp.json
193 :language: json
194
Pamela Dragosh1d101d22020-07-09 13:46:16 -0400195:download:`Download Statistics PAP API Swagger <swagger/statistics-pap.json>`
196
Jim Hahnd5cc9482019-05-29 15:41:48 -0400197.. swaggerv2doc:: swagger/statistics-pap.json
198
liamfallon4d1d9832019-05-30 20:53:05 +0000199This operation allows statistics for PDP groups, PDP subgroups, and individual PDPs to be retrieved.
200
201.. note::
202 While this API is supported, most of the statistics are not currently updated; that work has been deferred to a later
203 release.
Jim Hahnd5cc9482019-05-29 15:41:48 -0400204
Jim Hahn0f079d22019-08-01 11:05:24 -0400205Here is a sample response:
206
207.. literalinclude:: response/statistics-pap-resp.json
208 :language: json
209
Pamela Dragosh1d101d22020-07-09 13:46:16 -0400210:download:`Download State Change PAP Swagger <swagger/state-change-pap.json>`
211
Jim Hahnd5cc9482019-05-29 15:41:48 -0400212.. swaggerv2doc:: swagger/state-change-pap.json
213
liamfallon4d1d9832019-05-30 20:53:05 +0000214The state of PDP groups is managed by this operation. PDP groups can be in states PASSIVE, TEST, SAFE, or ACTIVE. For a full
215description of PDP group states, see the :ref:`ONAP Policy Framework Architecture <architecture-label>` page.
216
Pamela Dragosh1d101d22020-07-09 13:46:16 -0400217:download:`Download Group Batch PAP API Swagger <swagger/groups-batch-pap.json>`
218
Jim Hahn5eeeedd2019-12-11 16:25:56 -0500219.. swaggerv2doc:: swagger/groups-batch-pap.json
Jim Hahnd5cc9482019-05-29 15:41:48 -0400220
liamfallon4d1d9832019-05-30 20:53:05 +0000221This operation allows the PDP groups and subgroups to be created and updated. Many PDP groups can be created or updated
222in a single POST operation by specifying more than one PDP group in the POST operation body.
a.sreekumar8e455042020-01-27 10:50:02 +0000223This can be used to create the PDP group by providing all the details including the supported policy types for each subgroup.
Jim Hahn5eeeedd2019-12-11 16:25:56 -0500224However, it cannot be used to update policies; that is done using one of
a.sreekumar8e455042020-01-27 10:50:02 +0000225the deployment requests. Consequently, the "policies" property of this
Jim Hahn5eeeedd2019-12-11 16:25:56 -0500226request will be ignored.
a.sreekumar8e455042020-01-27 10:50:02 +0000227This can also be used to update a PDP Group, but supported policy types cannot be updated during the update operation.
228So, "policies" and "supportedPolicyTypes" properties in the request will be ignored if provided during the PDP Group update operation.
liamfallon4d1d9832019-05-30 20:53:05 +0000229
Jim Hahnf90bf9d2020-10-13 14:42:43 -0400230The "desiredInstanceCount" specifies the minimum number of PDPs of the given
231type that should be registered with PAP. Currently, this is just used for
232health check purposes; if the number of PDPs registered with PAP drops below
233the given value, then PAP will return an "unhealthy" indicator if a
234"Consolidated Health Check" is performed.
235
liamfallon4d1d9832019-05-30 20:53:05 +0000236.. note::
Jim Hahn5f80cfc2019-12-17 08:43:30 -0500237 If a subgroup is to be deleted from a PDP Group, then the policies must be removed from
Jim Hahn5eeeedd2019-12-11 16:25:56 -0500238 the subgroup first.
Jim Hahnd5cc9482019-05-29 15:41:48 -0400239
a.sreekumar8e455042020-01-27 10:50:02 +0000240.. note::
241 Policies cannot be added/updated during PDP Group create/update operations. So, if provided, they are ignored.
242 Supported policy types are defined during PDP Group creation. They cannot be updated once they are created.
243 So, supportedPolicyTypes are expected during PDP Group create, but ignored if provided during PDP Group update.
244
Jim Hahn0f079d22019-08-01 11:05:24 -0400245Here is a sample request:
246
Jim Hahn5eeeedd2019-12-11 16:25:56 -0500247.. literalinclude:: request/groups-batch-pap-req.json
Jim Hahn0f079d22019-08-01 11:05:24 -0400248 :language: json
249
Pamela Dragosh1d101d22020-07-09 13:46:16 -0400250:download:`Download Group Delete PAP API Swagger <swagger/group-delete-pap.json>`
251
Jim Hahnd5cc9482019-05-29 15:41:48 -0400252.. swaggerv2doc:: swagger/group-delete-pap.json
253
liamfallon4d1d9832019-05-30 20:53:05 +0000254The API also allows PDP groups to be deleted. DELETE operations are only permitted on PDP groups in PASSIVE state.
255
Pamela Dragosh1d101d22020-07-09 13:46:16 -0400256:download:`Download Group Query PAP API Swagger <swagger/group-query-pap.json>`
257
Jim Hahnd5cc9482019-05-29 15:41:48 -0400258.. swaggerv2doc:: swagger/group-query-pap.json
259
liamfallon4d1d9832019-05-30 20:53:05 +0000260This operation allows the PDP groups and subgroups to be listed as well as the policies that are deployed on each PDP
261group and subgroup.
262
Jim Hahn0f079d22019-08-01 11:05:24 -0400263Here is a sample response:
264
265.. literalinclude:: response/group-query-pap-resp.json
266 :language: json
267
Pamela Dragosh1d101d22020-07-09 13:46:16 -0400268:download:`Download Deployments Batch PAP API Swagger <swagger/deployments-batch-pap.json>`
269
Jim Hahn5eeeedd2019-12-11 16:25:56 -0500270.. swaggerv2doc:: swagger/deployments-batch-pap.json
271
272This operation allows policies to be deployed on specific PDP groups.
273Each subgroup includes an "action" property, which is used to indicate
274that the policies are being added (POST) to the subgroup, deleted (DELETE)
275from the subgroup, or that the subgroup's entire set of policies is being
276replaced (PATCH) by a new set of policies. As such, a subgroup may appear
277more than once in a single request, one time to delete some policies and
278another time to add new policies to the same subgroup.
279
280Here is a sample request:
281
282.. literalinclude:: request/deployment-batch-pap-req.json
283 :language: json
284
a.sreekumare756dc92021-02-19 17:29:40 +0000285Here is a sample response:
286
287.. literalinclude:: response/deployment-pap-resp.json
288 :language: json
289
Pamela Dragosh1d101d22020-07-09 13:46:16 -0400290:download:`Download Deploy PAP API Swagger <swagger/policy-deploy-pap.json>`
291
Jim Hahnd5cc9482019-05-29 15:41:48 -0400292.. swaggerv2doc:: swagger/policy-deploy-pap.json
293
Jim Hahn5eeeedd2019-12-11 16:25:56 -0500294This operation allows policies to be deployed across all relevant PDP groups.
295PAP will deploy the specified policies to all relevant subgroups. Only the
296policies supported by a given subgroup will be deployed to that subgroup.
liamfallon4d1d9832019-05-30 20:53:05 +0000297
298.. note::
299 The policy version is optional. If left unspecified, then the latest version of the policy is deployed. On the other
300 hand, if it is specified, it may be an integer, or it may be a fully qualified version (e.g., "3.0.2").
Jim Hahn5eeeedd2019-12-11 16:25:56 -0500301 In addition, a subgroup to which a policy is being deployed must have at
302 least one PDP instance, otherwise the request will be rejected.
Jim Hahnd5cc9482019-05-29 15:41:48 -0400303
Jim Hahn0f079d22019-08-01 11:05:24 -0400304Here is a sample request:
305
306.. literalinclude:: request/policy-deploy-pap-req.json
307 :language: json
308
a.sreekumare756dc92021-02-19 17:29:40 +0000309Here is a sample response:
310
311.. literalinclude:: response/deployment-pap-resp.json
312 :language: json
313
Pamela Dragosh1d101d22020-07-09 13:46:16 -0400314:download:`Download Undeploy PAP API Swagger <swagger/policy-undeploy-pap.json>`
315
Jim Hahnd5cc9482019-05-29 15:41:48 -0400316.. swaggerv2doc:: swagger/policy-undeploy-pap.json
317
liamfallon4d1d9832019-05-30 20:53:05 +0000318This operation allows policies to be undeployed from PDP groups.
Jim Hahnd5cc9482019-05-29 15:41:48 -0400319
liamfallon4d1d9832019-05-30 20:53:05 +0000320.. note::
321 If the policy version is specified, then it may be an integer, or it may be a fully qualified version (e.g., "3.0.2").
322 On the other hand, if left unspecified, then the latest deployed version will be undeployed.
323
324.. note::
325 Due to current limitations, a fully qualified policy version must always be specified.
Ram Krishna Verma2145c752020-04-30 14:11:54 -0400326
a.sreekumare756dc92021-02-19 17:29:40 +0000327Here is a sample response:
328
329.. literalinclude:: response/deployment-pap-resp.json
330 :language: json
331
332:download:`Download Policy Status PAP API Swagger <swagger/policy-status-pap.json>`
333
334.. swaggerv2doc:: swagger/policy-status-pap.json
335
336This operation allows the status of all policies that are deployed or undeployed to be listed together.
337The result can be filtered based on pdp group name, policy name & version.
338
339.. note::
340 When a policy is successfully undeployed, it will no longer appear in the policy status response.
341
342Here is a sample response:
343
344.. literalinclude:: response/policy-status-pap-resp.json
345 :language: json
346
Pamela Dragosh1d101d22020-07-09 13:46:16 -0400347:download:`Download Deployed Policy PAP API Swagger <swagger/deployed-policy-pap.json>`
348
Ram Krishna Verma2145c752020-04-30 14:11:54 -0400349.. swaggerv2doc:: swagger/deployed-policy-pap.json
350
351This operation allows the deployed policies to be listed together with their respective deployment status.
352The result can be filtered based on policy name & version.
353
354Here is a sample response:
355
356.. literalinclude:: response/deployed-policy-pap-resp.json
357 :language: json
358
Pamela Dragosh1d101d22020-07-09 13:46:16 -0400359:download:`Download PDP Statistics PAP API Swagger <swagger/pdp-statistics-pap.json>`
360
Ram Krishna Verma2145c752020-04-30 14:11:54 -0400361.. swaggerv2doc:: swagger/pdp-statistics-pap.json
362
363This operation allows the PDP statistics to be retrieved for all registered PDPs.
364The result can be filtered based on PDP group, PDP subgroup & PDP instance.
365
366Here is a sample response:
367
368.. literalinclude:: response/pdp-statistics-pap-resp.json
369 :language: json
370
371
3723 Future Features
liamfallon4d1d9832019-05-30 20:53:05 +0000373=================
374
Ram Krishna Verma2145c752020-04-30 14:11:54 -04003753.1 Disable policies in PDP
376===========================
liamfallon4d1d9832019-05-30 20:53:05 +0000377
Ram Krishna Verma2145c752020-04-30 14:11:54 -0400378This operation will allow disabling individual policies running in PDP engine. It is mainly beneficial
379in scenarios where network operators/administrators want to disable a particular policy in PDP engine
380for a period of time due to a failure in the system or for scheduled maintenance.
Pamela Dragosh5fc2fdb2019-05-17 09:42:27 -0400381
382End of Document