diff options
Diffstat (limited to 'docs')
31 files changed, 888 insertions, 2 deletions
diff --git a/docs/index.rst b/docs/index.rst index 4df15fc8d..f3d2bdb79 100644 --- a/docs/index.rst +++ b/docs/index.rst @@ -4,6 +4,7 @@ Policy Engine ------------- .. toctree:: - :maxdepth: 1 - + :maxdepth: 2 + platform/index + release-notes/index diff --git a/docs/platform/PolicyArchitectureDetails.png b/docs/platform/PolicyArchitectureDetails.png Binary files differnew file mode 100755 index 000000000..39705465d --- /dev/null +++ b/docs/platform/PolicyArchitectureDetails.png diff --git a/docs/platform/PolicyEngineApiList.png b/docs/platform/PolicyEngineApiList.png Binary files differnew file mode 100755 index 000000000..deb38b9ae --- /dev/null +++ b/docs/platform/PolicyEngineApiList.png diff --git a/docs/platform/PolicyGUI_Access.png b/docs/platform/PolicyGUI_Access.png Binary files differnew file mode 100755 index 000000000..781ce918a --- /dev/null +++ b/docs/platform/PolicyGUI_Access.png diff --git a/docs/platform/PolicyGUI_Admin.png b/docs/platform/PolicyGUI_Admin.png Binary files differnew file mode 100755 index 000000000..0465a07bc --- /dev/null +++ b/docs/platform/PolicyGUI_Admin.png diff --git a/docs/platform/PolicyGUI_Dashboard.png b/docs/platform/PolicyGUI_Dashboard.png Binary files differnew file mode 100755 index 000000000..ece03ba78 --- /dev/null +++ b/docs/platform/PolicyGUI_Dashboard.png diff --git a/docs/platform/PolicyGUI_Dictionary.png b/docs/platform/PolicyGUI_Dictionary.png Binary files differnew file mode 100755 index 000000000..53a604f08 --- /dev/null +++ b/docs/platform/PolicyGUI_Dictionary.png diff --git a/docs/platform/PolicyGUI_Editor.png b/docs/platform/PolicyGUI_Editor.png Binary files differnew file mode 100755 index 000000000..ce579749f --- /dev/null +++ b/docs/platform/PolicyGUI_Editor.png diff --git a/docs/platform/PolicyGUI_Editor_CreatePolicy.png b/docs/platform/PolicyGUI_Editor_CreatePolicy.png Binary files differnew file mode 100755 index 000000000..f09bb90ad --- /dev/null +++ b/docs/platform/PolicyGUI_Editor_CreatePolicy.png diff --git a/docs/platform/PolicyGUI_Editor_PolicyActions.png b/docs/platform/PolicyGUI_Editor_PolicyActions.png Binary files differnew file mode 100755 index 000000000..7b376f3e8 --- /dev/null +++ b/docs/platform/PolicyGUI_Editor_PolicyActions.png diff --git a/docs/platform/PolicyGUI_Editor_PolicyActionsDetail.png b/docs/platform/PolicyGUI_Editor_PolicyActionsDetail.png Binary files differnew file mode 100755 index 000000000..4cfbbbac5 --- /dev/null +++ b/docs/platform/PolicyGUI_Editor_PolicyActionsDetail.png diff --git a/docs/platform/PolicyGUI_Editor_Scope.png b/docs/platform/PolicyGUI_Editor_Scope.png Binary files differnew file mode 100755 index 000000000..09de9669d --- /dev/null +++ b/docs/platform/PolicyGUI_Editor_Scope.png diff --git a/docs/platform/PolicyGUI_PDP.png b/docs/platform/PolicyGUI_PDP.png Binary files differnew file mode 100755 index 000000000..af575d262 --- /dev/null +++ b/docs/platform/PolicyGUI_PDP.png diff --git a/docs/platform/PolicyGUI_Push.png b/docs/platform/PolicyGUI_Push.png Binary files differnew file mode 100755 index 000000000..ccf092a71 --- /dev/null +++ b/docs/platform/PolicyGUI_Push.png diff --git a/docs/platform/PolicyGUI_Roles.png b/docs/platform/PolicyGUI_Roles.png Binary files differnew file mode 100755 index 000000000..d1ef99c47 --- /dev/null +++ b/docs/platform/PolicyGUI_Roles.png diff --git a/docs/platform/PolicyR1Architecture.png b/docs/platform/PolicyR1Architecture.png Binary files differnew file mode 100755 index 000000000..def3d2aae --- /dev/null +++ b/docs/platform/PolicyR1Architecture.png diff --git a/docs/platform/PolicyTargetArchitecture.png b/docs/platform/PolicyTargetArchitecture.png Binary files differnew file mode 100755 index 000000000..74e05da31 --- /dev/null +++ b/docs/platform/PolicyTargetArchitecture.png diff --git a/docs/platform/api-docs.json b/docs/platform/api-docs.json new file mode 100755 index 000000000..55726b271 --- /dev/null +++ b/docs/platform/api-docs.json @@ -0,0 +1 @@ +{"swagger":"2.0","info":{"description":"This API helps to make queries against Policy Engine","version":"3.0","title":"Policy Engine REST API"},"host":"104.239.197.207:8081","basePath":"/pdp/api","tags":[{"name":"policy-engine-services","description":"Policy Engine Services"}],"paths":{"/createConfig":{"put":{"tags":["policy-engine-services"],"summary":"Creates a Config Policy based on given Policy Parameters.","operationId":"createConfigUsingPUT","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"configPolicyAPIRequest","description":"configPolicyAPIRequest","required":true,"schema":{"$ref":"#/definitions/ConfigPolicyAPIRequest"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"type":"string"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}},"deprecated":true}},"/createDictionaryItem":{"put":{"tags":["policy-engine-services"],"summary":"Creates a Dictionary Item for a specific dictionary based on given Parameters.","operationId":"createDictionaryItemUsingPUT","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"dictionaryParameters","description":"dictionaryParameters","required":true,"schema":{"$ref":"#/definitions/DictionaryParameters"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"type":"string"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}}}},"/createFirewallConfig":{"put":{"tags":["policy-engine-services"],"summary":"Creates a Config Firewall Policy","operationId":"createFirewallConfigUsingPUT","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"configFirewallPolicyAPIRequest","description":"configFirewallPolicyAPIRequest","required":true,"schema":{"$ref":"#/definitions/ConfigFirewallPolicyAPIRequest"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"type":"string"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}},"deprecated":true}},"/createPolicy":{"put":{"tags":["policy-engine-services"],"summary":"Creates a Policy based on given Policy Parameters.","operationId":"createPolicyUsingPUT","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"policyParameters","description":"policyParameters","required":true,"schema":{"$ref":"#/definitions/PolicyParameters"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"type":"string"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}}}},"/deletePolicy":{"delete":{"tags":["policy-engine-services"],"summary":"Deletes the specified policy from the PDP Group or PAP.","operationId":"deletePolicyUsingDELETE","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"deletePolicyParameters","description":"deletePolicyParameters","required":true,"schema":{"$ref":"#/definitions/DeletePolicyParameters"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"type":"string"}},"401":{"description":"Unauthorized"},"204":{"description":"No Content"},"403":{"description":"Forbidden"}}}},"/getConfig":{"post":{"tags":["policy-engine-services"],"summary":"Gets the configuration from the PolicyDecisionPoint(PDP)","operationId":"getConfigUsingPOST","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"configRequestParameters","description":"configRequestParameters","required":true,"schema":{"$ref":"#/definitions/ConfigRequestParameters"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"$ref":"#/definitions/Collection«PolicyConfig»"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}}}},"/getConfigByPolicyName":{"post":{"tags":["policy-engine-services"],"summary":"Gets the configuration from the PolicyDecisionPoint(PDP) using PolicyName","operationId":"getConfigByPolicyNameUsingPOST","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"configNameRequest","description":"configNameRequest","required":true,"schema":{"$ref":"#/definitions/ConfigNameRequest"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"$ref":"#/definitions/Collection«PolicyConfig»"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}},"deprecated":true}},"/getDecision":{"post":{"tags":["policy-engine-services"],"summary":"Gets the Decision using specified decision parameters","operationId":"getDecisionUsingPOST","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"decisionRequestParameters","description":"decisionRequestParameters","required":true,"schema":{"$ref":"#/definitions/DecisionRequestParameters"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"$ref":"#/definitions/DecisionResponse"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}}}},"/getDictionaryItems":{"post":{"tags":["policy-engine-services"],"summary":"Gets the dictionary items from the PAP","operationId":"getDictionaryItemsUsingPOST","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"dictionaryParameters","description":"dictionaryParameters","required":true,"schema":{"$ref":"#/definitions/DictionaryParameters"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"$ref":"#/definitions/DictionaryResponse"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}}}},"/getMetrics":{"get":{"tags":["policy-engine-services"],"summary":"Gets the policy metrics from the PolicyAccessPoint(PAP)","operationId":"getMetricsUsingGET","consumes":["application/json"],"produces":["*/*"],"parameters":[{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"$ref":"#/definitions/MetricsResponse"}},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}}}},"/getNotification":{"post":{"tags":["policy-engine-services"],"summary":"Registers DMaaP Topic to recieve notification from Policy Engine","operationId":"getNotificationUsingPOST","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"notificationTopic","description":"notificationTopic","required":true,"schema":{"type":"string"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"type":"string"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}}}},"/listConfig":{"post":{"tags":["policy-engine-services"],"summary":"Gets the list of configuration policies from the PDP","operationId":"listConfigUsingPOST","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"configRequestParameters","description":"configRequestParameters","required":true,"schema":{"$ref":"#/definitions/ConfigRequestParameters"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"$ref":"#/definitions/Collection«string»"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}}}},"/policyEngineImport":{"post":{"tags":["policy-engine-services"],"summary":"Imports Policy based on the parameters which represent the service used to create a policy Service.","operationId":"policyEngineImportUsingPOST","consumes":["multipart/form-data"],"produces":["*/*"],"parameters":[{"name":"importParametersJson","in":"query","description":"importParametersJson","required":true,"type":"string"},{"name":"file","in":"formData","description":"file","required":true,"type":"file"},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"type":"string"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}}}},"/pushPolicy":{"put":{"tags":["policy-engine-services"],"summary":"Pushes the specified policy to the PDP Group.","operationId":"pushPolicyUsingPUT","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"pushPolicyParameters","description":"pushPolicyParameters","required":true,"schema":{"$ref":"#/definitions/PushPolicyParameters"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"type":"string"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}}}},"/sendEvent":{"post":{"tags":["policy-engine-services"],"summary":"Sends the Events specified to the Policy Engine","operationId":"sendEventUsingPOST","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"eventRequestParameters","description":"eventRequestParameters","required":true,"schema":{"$ref":"#/definitions/EventRequestParameters"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"$ref":"#/definitions/Collection«PolicyResponse»"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}}}},"/sendHeartbeat":{"post":{"tags":["policy-engine-services"],"summary":"Sends Heartbeat to DMaaP Topic Registry to continue recieving notifications from Policy Engine","operationId":"sendHeartbeatUsingPOST","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"notificationTopic","description":"notificationTopic","required":true,"schema":{"type":"string"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"type":"string"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}}}},"/stopNotification":{"post":{"tags":["policy-engine-services"],"summary":"De-Registers DMaaP Topic to stop recieving notifications from Policy Engine","operationId":"stopNotificationUsingPOST","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"notificationTopic","description":"notificationTopic","required":true,"schema":{"type":"string"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"type":"string"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}}}},"/updateConfig":{"put":{"tags":["policy-engine-services"],"summary":"Updates a Config Policy based on given Policy Parameters.","operationId":"updateConfigUsingPUT","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"configPolicyAPIRequest","description":"configPolicyAPIRequest","required":true,"schema":{"$ref":"#/definitions/ConfigPolicyAPIRequest"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"type":"string"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}},"deprecated":true}},"/updateDictionaryItem":{"put":{"tags":["policy-engine-services"],"summary":"Updates a Dictionary Item for a specific dictionary based on given Parameters.","operationId":"updateDictionaryItemUsingPUT","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"dictionaryParameters","description":"dictionaryParameters","required":true,"schema":{"$ref":"#/definitions/DictionaryParameters"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"type":"string"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}}}},"/updateFirewallConfig":{"put":{"tags":["policy-engine-services"],"summary":"Updates a Config Firewall Policy","operationId":"updateFirewallConfigUsingPUT","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"configFirewallPolicyAPIRequest","description":"configFirewallPolicyAPIRequest","required":true,"schema":{"$ref":"#/definitions/ConfigFirewallPolicyAPIRequest"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"type":"string"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}},"deprecated":true}},"/updatePolicy":{"put":{"tags":["policy-engine-services"],"summary":"Updates a Policy based on given Policy Parameters.","operationId":"updatePolicyUsingPUT","consumes":["application/json"],"produces":["*/*"],"parameters":[{"in":"body","name":"policyParameters","description":"policyParameters","required":true,"schema":{"$ref":"#/definitions/PolicyParameters"}},{"name":"ClientAuth","in":"header","description":"ClientAuth","required":true,"type":"string"},{"name":"X-ECOMP-RequestID","in":"header","description":"X-ECOMP-RequestID","required":false,"type":"string"},{"name":"Authorization","in":"header","required":true,"type":"string"},{"name":"Environment","in":"header","required":true,"type":"string"}],"responses":{"200":{"description":"OK","schema":{"type":"string"}},"201":{"description":"Created"},"401":{"description":"Unauthorized"},"403":{"description":"Forbidden"},"404":{"description":"Not Found"}}}}},"definitions":{"PolicyParameters":{"type":"object","properties":{"actionAttribute":{"type":"string"},"actionPerformer":{"type":"string"},"attributes":{"type":"object","additionalProperties":{"$ref":"#/definitions/Map«string,string»"}},"configBody":{"type":"string"},"configBodyType":{"type":"string","enum":["Properties","json","xml","other"]},"configName":{"type":"string"},"controllerName":{"type":"string"},"dependencyNames":{"type":"array","items":{"type":"string"}},"dynamicRuleAlgorithmField1":{"type":"array","items":{"type":"string"}},"dynamicRuleAlgorithmField2":{"type":"array","items":{"type":"string"}},"dynamicRuleAlgorithmFunctions":{"type":"array","items":{"type":"string"}},"dynamicRuleAlgorithmLabels":{"type":"array","items":{"type":"string"}},"ecompName":{"type":"string"},"extendedOption":{"type":"string"},"guard":{"type":"boolean"},"onapName":{"type":"string"},"policyClass":{"type":"string","enum":["Config","Action","Decision"]},"policyConfigType":{"type":"string","enum":["Base","Fault","PM","FW","BRMS_Raw","BRMS_Param","MS","EXTENDED"]},"policyDescription":{"type":"string"},"policyName":{"type":"string"},"priority":{"type":"string"},"requestID":{"type":"string"},"riskLevel":{"type":"string"},"riskType":{"type":"string"},"ruleProvider":{"type":"string","enum":["Custom","AAF","GUARD_YAML","GUARD_BL_YAML"]},"ttlDate":{"type":"string","format":"date-time"}}},"ConfigRequestParameters":{"type":"object","properties":{"configAttributes":{"type":"object","additionalProperties":{"type":"string"}},"configName":{"type":"string"},"ecompName":{"type":"string"},"onapName":{"type":"string"},"policyName":{"type":"string"},"requestID":{"type":"string"},"unique":{"type":"boolean"}}},"Collection«PolicyResponse»":{"type":"object"},"DecisionResponse":{"type":"object","properties":{"decision":{"type":"string","enum":["permit","deny","error"]},"details":{"type":"string"}}},"DictionaryParameters":{"type":"object","properties":{"dictionary":{"type":"string"},"dictionaryJson":{"type":"string"},"dictionaryType":{"type":"string","enum":["Common","Action","ClosedLoop","Firewall","Decision","BRMS","MicroService","DescriptiveScope","PolicyScope","Enforcer","SafePolicy","Extended"]},"requestID":{"type":"string"}}},"JsonValue":{"type":"object","properties":{"valueType":{"type":"string","enum":["ARRAY","OBJECT","STRING","NUMBER","TRUE","FALSE","NULL"]}}},"DecisionRequestParameters":{"type":"object","properties":{"decisionAttributes":{"type":"object","additionalProperties":{"type":"string"}},"ecompcomponentName":{"type":"string"},"onapName":{"type":"string"},"requestID":{"type":"string"}}},"ConfigPolicyAPIRequest":{"type":"object","properties":{"body":{"type":"string"},"configAttributes":{"type":"object","additionalProperties":{"type":"string"}},"configName":{"type":"string"},"configType":{"type":"string"},"ecompName":{"type":"string"},"guard":{"type":"string"},"onapName":{"type":"string"},"policyDescription":{"type":"string"},"policyName":{"type":"string"},"policyScope":{"type":"string"},"riskLevel":{"type":"string"},"riskType":{"type":"string"},"ttlDate":{"type":"string"}}},"PushPolicyParameters":{"type":"object","properties":{"pdpGroup":{"type":"string"},"policyName":{"type":"string"},"policyType":{"type":"string"},"requestID":{"type":"string"}}},"ConfigFirewallPolicyAPIRequest":{"type":"object","properties":{"firewallJson":{"type":"string"},"guard":{"type":"string"},"policyName":{"type":"string"},"policyScope":{"type":"string"},"riskLevel":{"type":"string"},"riskType":{"type":"string"},"ttlDate":{"type":"string"}}},"PolicyConfig":{"type":"object","properties":{"config":{"type":"string"},"matchingConditions":{"type":"object","additionalProperties":{"type":"string"}},"policyConfigMessage":{"type":"string"},"policyConfigStatus":{"type":"string","enum":["retrieved","not_found"]},"policyName":{"type":"string"},"policyVersion":{"type":"string"},"property":{"type":"object","additionalProperties":{"type":"string"}},"responseAttributes":{"type":"object","additionalProperties":{"type":"string"}},"type":{"type":"string","enum":["Properties","json","xml","other"]}}},"EventRequestParameters":{"type":"object","properties":{"eventAttributes":{"type":"object","additionalProperties":{"type":"string"}},"requestID":{"type":"string"}}},"Map«string,string»":{"type":"object","additionalProperties":{"type":"string"}},"Collection«PolicyConfig»":{"type":"object"},"DictionaryResponse":{"type":"object","properties":{"dictionaryData":{"type":"object","additionalProperties":{"type":"string"}},"dictionaryJson":{"type":"object","additionalProperties":{"$ref":"#/definitions/JsonValue"}},"responseCode":{"type":"integer","format":"int32"},"responseMessage":{"type":"string"}}},"ConfigNameRequest":{"type":"object","properties":{"policyName":{"type":"string"}}},"MetricsResponse":{"type":"object","properties":{"metricsTotal":{"type":"integer","format":"int32"},"papMetrics":{"type":"integer","format":"int32"},"pdpMetrics":{"type":"integer","format":"int32"},"responseCode":{"type":"integer","format":"int32"},"responseMessage":{"type":"string"}}},"Collection«string»":{"type":"object"},"PolicyResponse":{"type":"object","properties":{"actionAdvised":{"type":"object","additionalProperties":{"type":"string"}},"actionTaken":{"type":"object","additionalProperties":{"type":"string"}},"policyResponseMessage":{"type":"string"},"policyResponseStatus":{"type":"string","enum":["no_action","action_advised","action_taken"]},"requestAttributes":{"type":"object","additionalProperties":{"type":"string"}}}},"DeletePolicyParameters":{"type":"object","properties":{"deleteCondition":{"type":"string","enum":["Current Version","All Versions"]},"pdpGroup":{"type":"string"},"policyComponent":{"type":"string"},"policyName":{"type":"string"},"policyType":{"type":"string"},"requestID":{"type":"string"}}}}}
\ No newline at end of file diff --git a/docs/platform/architecture.rst b/docs/platform/architecture.rst new file mode 100644 index 000000000..d9ce3c8cb --- /dev/null +++ b/docs/platform/architecture.rst @@ -0,0 +1,98 @@ +.. This work is licensed under a Creative Commons Attribution 4.0 International License. +.. http://creativecommons.org/licenses/by/4.0 + + +Architecture +------------ + +.. contents:: + :depth: 3 + +POLICY is a subsystem of ONAP that maintains, distributes, and operates on the set of rules that underlie ONAP’s control, orchestration, and management functions. + +POLICY provides a logically centralized environment for the creation and management of policies, including conditional rules. This provides the capability to **create** and **validate** policies/rules, **identify overlaps**, **resolve conflicts**, and **derive** additional policies as needed. Policies are used to **control**, **influence**, and help **ensure compliance** with goals. Policies can support infrastructure, products and services, operation automation, and security. Users, including network and service designers, operations engineers, and security experts, can easily **create**, **change**, and **manage** policy rules from the POLICY Manager in the ONAP Portal. + +The figure below represents the target POLICY Architecture. + +.. image:: PolicyTargetArchitecture.png + + +The figure below represents the current POLICY Architecture. + +.. image:: PolicyR1Architecture.png + + +A policy is defined to create a condition, requirement, constraint, decision, or a need that must be provided, evaluated, maintained, and/or enforced. The policy is validated and corrected for any conflicts, and then placed in the appropriate repository, and made available for use by other subsystems and components. Alternately, some policies are directly distributed to policy decision engines such as Drools or XACML. In this manner, the constraints, decisions and actions to be taken are distributed. + + +System Architecture +^^^^^^^^^^^^^^^^^^^ + +ONAP POLICY is composed of several subcomponents: the **Policy Administration Point (PAP)**, which offers interfaces for policy creation, and two types of **Policy Decision Point (PDP)**, each based on a specific rules technology. PDP-X is based on XACML technology and PDP-D is based on Drools technology. PDP-X is **stateless** and can be deployed as a resource pool of PDP-X servers. The number of servers can be grown to increase both capacity (horizontal scalability) and to increase availability. The PDP-D is **stateful**, as it utilizes Drools in its native, stateful way and transactions persist so long as the PDP-D is active. Persistent Drools sessions, state management, local and geo-redundancy have been deactivated for the initial release of ONAP POLICY and can be turned on in a future release. Additional instances of XACML/Drools engines and assigned roles/purposes may also be added in the future to provide a flexible, expandable policy capability. + +As illustrated in the Figure below, the POLICY components are supported by a number of interfaces and subsystems. The ONAP Portal provides a human interface for the creation, management and deployment of policies. It is a web-based system that utilizes internal APIs in the PAP. + +.. image:: PolicyArchitectureDetails.png + + +The PAP provides interfaces for the management of policies. It utilizes the XACML database to store policies, which are then distributed to the PDPs. + +The XACML and Drools databases are hosted in a MariaDB cluster. The XACML database is used to persist policies and policy dictionaries and provide a point for PDPs to retrieve policies. The XACML database also has tables used for node state management, detection of node failure and failover. As indicated above, the state management tables will only include entries for the PAP and PDP-X as the testing is not yet complete for the PDP-D. + +The PDP-X receives deployed policies and has interfaces to handle XACML policy transactions. These transactions are stateless and once complete, they are removed from memory. If a policy that is deployed to the PDP-X is of an operational nature it will contain Drools rules and Java executables. These artifacts are processed into Maven artifacts and pushed to the Maven repository. The PDP-D is then notified a new policy has been deployed. + +When the PDP-D is notified a new policy has been deployed, it downloads it from the Maven repository and assigns it to an internal controller. This controller provides the external Closed Loop interfaces to the DMaaP message bus over which events and messages are exchanged with external systems. As events or messages arrive at the PDP-D, they are assigned to the appropriate controller and a Drools session is either created or retrieved from memory. The events, messages or facts are passed to the Drools session and the corresponding rule is fired, resulting in a change of internal session state and possibly actions taken in response to the rule processing. Response messages and requests are passed by the controller back over the DMaaP message bus to the appropriate system. The Drools session can also have timers and autonomous events. In a future release the PDP-D can enable the node state management and session persistence in the Drools DB. + + +Policy Creation +^^^^^^^^^^^^^^^ +The Policy Creation component of the Policy subsystem enables creation of new policies and modification of existing polices, both during the design phase and during runtime. Policy Creation is targeted to be integrated to a unified Service Design and Creation (SDC) environment. + +A policy can be defined at a high level to create a condition, requirement, constraint, decision or a need that must be provided, evaluated, maintained, and/or enforced. A policy can also be defined at a lower or functional level, such as a machine-readable rule or software condition/assertion which enables actions to be taken based on a trigger or request, specific to particular selected conditions in effect at that time. + +Some examples of types of policies are: + +* VNF placement — rules governing where VNFs should be placed, including affinity rules +* Data and feed management — what data to collect and when, retention periods, and when to send alarms about issues +* Access control — who (or what) can have access to which data +* Trigger conditions and actions — what conditions are actionable, and what to do under those conditions +* Interactions — how interactions between change management and fault/performance management are handled (for example, should closed loops be disabled during maintenance?) + + +Policy Distribution +^^^^^^^^^^^^^^^^^^^ + +After a policy has been initially created or an existing policy has been modified, the Policy Distribution Framework sends the policy from the repository to its points of use, which include Policy Decision Points (PDPs) and Policy enforcement points (DCAE, Controllers, etc), before the policy is actually needed. + +The decisions and actions taken by the policy are distributed. Policies are distributed either in conjunction with installation packages (for example, related to service instantiation) or independently, if unrelated to a particular service. Some policies can be configured (e.g., configuring policy parameters within microservices), while other polices are delivered to policy engines such as XAMCL and Drools. With this methodology, policies will already be available when needed by a component, minimizing real-time requests to a central policy engine or PDP (Policy Decision Point). This improves scalability and reduces latency. + +Separate notifications or events communicate the link or URL for a policy to the components that need it. Then, when a component needs the policy, it uses the link to fetch it. Components in some cases might also publish events indicating that they need new policies, eliciting a response with updated links or URLs. Also, in some cases, policies can indicate to components that they should subscribe to one or more policies, so that they receive automatic updates to those policies as they become available. + + +Policy Decision and Enforcement +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +Run-time policy enforcement is performed by ONAP subsystems that are policy-enabled or can respond to commands from a policy-enabled element such as a PDP. For example, policy rules for data collection are enforced by the data collection functionality of DCAE. Analytic policy rules, identification of anomalous or abnormal conditions, and publication of events signaling detection of such conditions are enforced by DCAE analytic applications. Policy rules for associated remedial actions, or for further diagnostics, are enforced by the correct component in a control loop such as the MSO, a Controller, or DCAE. Policy engines such as XACML and Drools also enforce policies and can trigger other components as a result (for example, causing a controller to take specific actions specified by the policy). Additionally, some policies (“Guard Policies”) may enforce checks against decided actions. + + +Policy Unification and Organization +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ +Because the POLICY framework is expandable and multipurpose, it is likely to contain many types of policies which require organization according to some useful dimensions. Users can define attributes that specify the scope of policies, and these attributes can be extended to the policy-enabled functions and components. Useful policy organizing dimensions might include: + +* Policy type or category (taxonomical) +* Policy life cycle +* Policy ownership or administrative domain +* Geographic area or location, +* Technology type +* Policy language and version +* Security level or other security-related values, specifiers, or limiters + +Attributes can be specified for each dimension. In addition to being defined for individual policies themselves, these attributes can be used to define the scope of these additional additional policy-related functions: + +* Policy events or requests/triggers +* Policy decision, enforcement, or other functions +* Virtual functions of any type + +Policy writers can define attributes so that policy events or requests self-indicate their scope. The scope is then examined by a suitable function and subsequently acted upon accordingly. Policy decisions and enforcement functions can self-indicate their scope of decision-making, enforcement, or other capabilities. Virtual functions can be automatically attached to the appropriate POLICY Framework and distribution mechanisms. + + diff --git a/docs/platform/index.rst b/docs/platform/index.rst new file mode 100644 index 000000000..b489b2fb3 --- /dev/null +++ b/docs/platform/index.rst @@ -0,0 +1,12 @@ +.. This work is licensed under a Creative Commons Attribution 4.0 International License. + +Policy Engine +------------- + +.. toctree:: + :maxdepth: 1 + + architecture.rst + offeredapis.rst + installation.rst + policygui.rst diff --git a/docs/platform/installation.rst b/docs/platform/installation.rst new file mode 100644 index 000000000..a10f02689 --- /dev/null +++ b/docs/platform/installation.rst @@ -0,0 +1,315 @@ +.. This work is licensed under a Creative Commons Attribution 4.0 International License. +.. http://creativecommons.org/licenses/by/4.0 + +Installation +------------ + +.. contents:: + :depth: 3 + +The installation of ONAP Policy is **automated** by design and can be done via Docker as a standalone system. +Various tools, including healthcheck, logs, and Swagger can be used to ensure proper operation. + +ONAP Policy Framework: Standalone Quick Start +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ +This procedure explains how build the ONAP Policy Framework and get it running in Docker as a standalone system. +This procedure assumes that: + +* You are using a *\*nix* operating system such as linux or macOS. +* You are using a directory called *git* off your home directory *(~/git)* for your git repositories +* Your local maven repository is in the location *~/.m2/repository* + +The procedure documented here has been verified to work on a MacBook laptop running macOS Sierra Version 10.12.6 and a HP Z600 desktop running Ubuntu 16.04.3 LTS. + + +.. code-block:: bash + :caption: Typical ONAP Policy Framework Clone Script + :linenos: + + #!/usr/bin/env bash + + ## script name for output + MOD_SCRIPT_NAME=`basename $0` + + ## the ONAP clone directory, defaults to "onap" + clone_dir="onap" + + ## the ONAP repos to clone + onap_repos="\ + oparent \ + ecompsdkos \ + policy/api \ + policy/common \ + policy/docker \ + policy/drools-applications \ + policy/drools-pdp \ + policy/engine \ + policy/gui \ + policy/pap \ + policy/pdp" + + ## + ## Help screen and exit condition (i.e. too few arguments) + ## + Help() + { + echo "" + echo "$MOD_SCRIPT_NAME - clones all required ONAP git repositories" + echo "" + echo " Usage: $MOD_SCRIPT_NAME [-options]" + echo "" + echo " Options" + echo " -d - the ONAP clone directory, defaults to '.'" + echo " -h - this help screen" + echo "" + exit 255; + } + + ## + ## read command line + ## + while [ $# -gt 0 ] + do + case $1 in + #-d ONAP clone directory + -d) + shift + if [ -z "$1" ]; then + echo "$MOD_SCRIPT_NAME: no clone directory" + exit 1 + fi + clone_dir=$1 + shift + ;; + + #-h prints help and exists + -h) + Help;exit 0;; + + *) echo "$MOD_SCRIPT_NAME: undefined CLI option - $1"; exit 255;; + esac + done + + if [ -f "$clone_dir" ]; then + echo "$MOD_SCRIPT_NAME: requested clone directory '$clone_dir' exists as file" + exit 2 + fi + if [ -d "$clone_dir" ]; then + echo "$MOD_SCRIPT_NAME: requested clone directory '$clone_dir' exists as directory" + exit 2 + fi + + mkdir $clone_dir + if [ $? != 0 ] + then + echo cannot clone ONAP repositories, could not create directory '"'$clone_dir'"' + exit 3 + fi + + for repo in $onap_repos + do + repoDir=`dirname "$repo"` + repoName=`basename "$repo"` + + if [ ! -z $dirName ] + then + mkdir "$clone_dir/$repoDir" + if [ $? != 0 ] + then + echo cannot clone ONAP repositories, could not create directory '"'$clone_dir/repoDir'"' + exit 4 + fi + fi + + git clone https://gerrit.onap.org/r/${repo} $clone_dir/$repo + done + + echo ONAP has been cloned into '"'$clone_dir'"' + +Execution of the script above results in the following directory hierarchy in your *~/git* directory: + + * ~/git/onap + * ~/git/onap/ecompsdkos + * ~/git/onap/oparent + * ~/git/onap/policy + * ~/git/onap/policy/api + * ~/git/onap/policy/common + * ~/git/onap/policy/docker + * ~/git/onap/policy/drools-applications + * ~/git/onap/policy/drools-pdp + * ~/git/onap/policy/engine + * ~/git/onap/policy/gui + * ~/git/onap/policy/pap + * ~/git/onap/policy/pdp + + + +Building ONAP +^^^^^^^^^^^^^ + +**Step 1.** Optionally, for a completely clean build, remove the ONAP built modules from your local repository. + + * rm -fr ~/.m2/repository/org/onap + * rm -fr ~/.m2/repository/org/openecomp + + +**Step 2**. A pom such as the one below can be used to build all the ONAP policy modules and their dependencies. Create the *pom.xml* file in the directory *~/git/onap*. + +.. code-block:: xml + :caption: Typical pom.xml to build the ONAP Policy Framework + :linenos: + + <project xmlns="http://maven.apache.org/POM/4.0.0" + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> + + <modelVersion>4.0.0</modelVersion> + <groupId>org.onap</groupId> + <artifactId>onap-policy_standalone</artifactId> + <version>1.0.0-SNAPSHOT</version> + <packaging>pom</packaging> + <name>${project.artifactId}</name> + <inceptionYear>2017</inceptionYear> + <organization> + <name>ONAP</name> + </organization> + + <profiles> + <profile> + <id>policy-dependencies</id> + <activation> + <property> + <name>policyDeps</name> + </property> + </activation> + <modules> + <module>oparent</module> + <module>ecompsdkos/ecomp-sdk</module> + </modules> + </profile> + <profile> + <id>policy</id> + <activation> + <activeByDefault>true</activeByDefault> + </activation> + <modules> + <module>oparent</module> + <module>ecompsdkos/ecomp-sdk</module> + <module>policy</module> + </modules> + </profile> + </profiles> + </project> + + + +**Step 3**. A pom such as the one below can be used to build the ONAP Policy Framework modules. Create the *pom.xml* file in the directory *~/git/onap/policy* + +.. code-block:: xml + :caption: Typical pom.xml to build the ONAP Policy Framework Policy Modules + :linenos: + + <project xmlns="http://maven.apache.org/POM/4.0.0" + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> + + <modelVersion>4.0.0</modelVersion> + <groupId>org.onap</groupId> + <artifactId>onap-policy</artifactId> + <version>1.0.0-SNAPSHOT</version> + <packaging>pom</packaging> + <name>${project.artifactId}</name> + <inceptionYear>2017</inceptionYear> + <organization> + <name>ONAP</name> + </organization> + + <modules> + <module>common</module> + <module>engine</module> + <module>pdp</module> + <module>pap</module> + <module>drools-pdp</module> + <module>drools-applications</module> + <module>api</module> + <module>gui</module> + <module>docker</module> + </modules> + </project> + +**Step 4**. The build cannot currently find the *org.onap.oparent:version-check-maven-plugin* plugin so, for now, comment that plugin out in the POMs *policy/drools-pdp/pom.xml* and *policy/drools-applications/pom.xml*. + +**Step 5**. Build the ONAP dependencies that are required for the ONAP policy framework and which must be built first to be available to the ONAP Policy Framework proper. + + * cd ~/git/onap + * mvn clean install -DpolicyDeps + +**Step 6**. You can now build the ONAP framework + + * On *Ubuntu*, just build the Policy Framework tests and all + + - cd ~/git/onap + - mvn clean install + + * On *macOS*, you must build build the ONAP framework with tests turned off first. Then rebuild the framework with tests turned on and all tests will pass. Note: The reason for this behaviour will be explored later. + + - cd ~/git/onap + - mvn clean install -DskipTests + - mvn install + + +Building the ONAP Policy Framework Docker Images +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ +The instructions here are based on the instructions in the file *~/git/onap/policy/docker/README*. + +**Step 1.** Prepare the Docker packages. This will pull the installation zip files needed for building the policy-pe and policy-drools Docker images into the target directory. It will not actually build the docker images; the additional steps below must be followed to actually build the Docker images. + + * cd ~/git/onap/policy/docker + * mvn prepare-package + +**Step 2**. Copy the files under *policy-pe* to *target/policy-pe*. + + * cp policy-pe/* target/policy-pe + +**Step 3**. Copy the files under *policy-drools* to *target/policy-drools*. + + * cp policy-drools/* target/policy-drools + +**Step 4**. Run the *docker build* command on the following directories in the order below. +Note that on some systems you may have to run the *docker* command as root or using *sudo*. + + * docker build -t onap/policy/policy-os policy-os + * docker build -t onap/policy/policy-db policy-db + * docker build -t onap/policy/policy-nexus policy-nexus + * docker build -t onap/policy/policy-base policy-base + * docker build -t onap/policy/policy-pe target/policy-pe + * docker build -t onap/policy/policy-drools target/policy-drools + +Starting the ONAP Policy Framework Docker Images +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ +In order to run the containers, you can use *docker-compose*. This uses the *docker-compose.yml* yaml file to bring up the ONAP Policy Framework. + +**Step 1.** Make the file *config/drools/drools-tweaks.sh* executable + + * chmod +x config/drools/drools-tweaks.sh + +**Step 2**. Set the IP address to use to be an IP address of a suitable interface on your machine. Save the IP address into the file *config/pe/ip_addr.txt*. + +**Step 3**. Set the environment variable *MTU* to be a suitable MTU size for the application. + + * export MTU=9126 + +**Step 4**. Run the system using *docker-compose*. Note that on some systems you may have to run the *docker-compose* command as root or using *sudo*. Note that this command takes a number of minutes to execute on a laptop or desktop computer. + + * docker-compose up + + +Installation Complete +^^^^^^^^^^^^^^^^^^^^^ + +**You now have a full standalone ONAP Policy framework up and running!** + + +.. _Standalone Quick Start : https://wiki.onap.org/display/DW/ONAP+Policy+Framework%3A+Standalone+Quick+Start + + diff --git a/docs/platform/offeredapis.rst b/docs/platform/offeredapis.rst new file mode 100644 index 000000000..8d4cfebd1 --- /dev/null +++ b/docs/platform/offeredapis.rst @@ -0,0 +1,49 @@ +.. This work is licensed under a Creative Commons Attribution 4.0 International License. +.. http://creativecommons.org/licenses/by/4.0 + + +Offered APIs +============ + +.. contents:: + :depth: 2 + +The Policy subsystem of ONAP maintains, distributes, and operates on the set of rules that underlie ONAP’s control, orchestration, and management functions. Policy provides a centralized environment for the creation and management of easily-updatable conditional rules. It enables users to validate policies and rules, identify and resolve overlaps and conflicts, and derive additional policies where needed. The following operations are supported by the policy API: + +* Create policies on the PAP +* Update policies on the PAP +* Delete policies on the PAP or PDP +* Push policies from the PAP to the PDP +* List policies on the PDP +* Get config data of policies on the PDP +* Create Dictionary Items +* Update Dictionary Items +* Retrieve Dictionary Items +* Import Micro Services Models +* Retrieve Metrics for policy counts from PDP and PAP + + +POLICY Engine Services +^^^^^^^^^^^^^^^^^^^^^^ + +.. image:: PolicyEngineApiList.png + +POLICY API Details +^^^^^^^^^^^^^^^^^^ + +.. swaggerv2doc:: api-docs.json + + +Additional Information +^^^^^^^^^^^^^^^^^^^^^^ + +Additional information, including examples, can be found at `PolicyApi link`_. + +.. _PolicyApi link: https://wiki.onap.org/display/DW/Policy+API + + + + + +End of document + diff --git a/docs/platform/policygui.rst b/docs/platform/policygui.rst new file mode 100644 index 000000000..dbfb2740b --- /dev/null +++ b/docs/platform/policygui.rst @@ -0,0 +1,136 @@ +.. This work is licensed under a Creative Commons Attribution 4.0 International License. +.. http://creativecommons.org/licenses/by/4.0 + +********** +Policy GUI +********** + +.. contents:: + :depth: 3 + +| The POLICY GUI is a graphical user interface, available via web-access, for **creating and managing** policies. +| +| The targeted users are those responsible for creating and managing policies that control network operations, including policy based network configuration and auto-corrective actions. This typically includes network and service designers, operations engineers and security experts. +| +| The GUI consists of the **Editor, Dictionary, PDP, Push, Roles, Admin** and **Dashboard** Tabs; which provide for an intuitive manner for policy rules to be created, changed, and managed. + + +Access to the POLICY GUI +^^^^^^^^^^^^^^^^^^^^^^^^ + +The POLICY GUI can be accessed via the ONAP Portal. + +.. image:: PolicyGUI_Access.png + + +POLICY Editor +^^^^^^^^^^^^^ + +The POLICY **Editor** tab supports the following **key** functionality: + +• Create Policies and Scopes +• Edit, View and Describe Policies +• Rename, Move and Clone Policies +• Switch Versions of Policies +• Delete Policies and Scopes +• List Policies and Scopes +• Export and Import Policies +• Search for Policies + +.. image:: PolicyGUI_Editor.png + + +Scope Management +---------------- + +A Scope must exist before a policy can be created. The figure below shows how to add and manage Scopes. + +.. image:: PolicyGUI_Editor_Scope.png + + +Policy Creation +--------------- + +The most important function of the GUI is to facilitate the creation of policies. +The figure below specifies how a policy can be created. + +.. image:: PolicyGUI_Editor_CreatePolicy.png + + +Managing a Policy +----------------- + +The GUI provides actions (Edit, Clone, Move, Rename, Describe, View etc) to support maintaining +the policy after it has been created. The figure below specifies how to initiate an action. + +.. image:: PolicyGUI_Editor_PolicyActions.png + + +The next step of the selected action is shown below. + +.. image:: PolicyGUI_Editor_PolicyActionsDetail.png + +| + +POLICY Dictionary +^^^^^^^^^^^^^^^^^ + +| The POLICY **Dictionary** tab is used to create and manage attributes in the dictionaries. +| Each policy type has one or more dictionaries associated with it. Policy writers have the ability to easily define and add attributes into the dictionary as shown below. + +.. image:: PolicyGUI_Dictionary.png + +| + +POLICY PDP +^^^^^^^^^^ + +| The POLICY **PDP** tab is used to manage **PDP Groups** and **PDPs in the group**. +| This tab provides the capability to create, edit and delete PDP groups and associated PDPs. This tab also provides the ability to check status and view policies in a PDP groups. + +.. image:: PolicyGUI_PDP.png + +| + +POLICY Push +^^^^^^^^^^^ + +| The POLICY **Push** tab allows policies to be selectively pushed to the all PDPs. +| Once pushed, the policies can be seen on the PDP tab. A Status of the PDPs indicate “UP-TO-DATE” if the policy has been pushed correctly. A Status of “LAST-UPDATE-FAILED” indicates an error occurred in pushing the policies. + +.. image:: PolicyGUI_Push.png + +| + +POLICY Dashboard +^^^^^^^^^^^^^^^^ + +| The POLICY **Dashboard** shows the **status** and **health** of the system through metrics logs and status update messages. The dashboard consists of two tabs, a **Logging** tab and a **Health** tab. + +.. image:: PolicyGUI_Dashboard.png + +| + +POLICY Admin +^^^^^^^^^^^^ + +| The POLICY **Admin** tab houses functionality that is performed by an administrator. +| Only super users have access to the Admin Tab. The Lockdown feature is accessed from this tab. + +.. image:: PolicyGUI_Admin.png + +| + +POLICY Roles +^^^^^^^^^^^^ + +| The POLICY **Roles** tab allows system administrators to assign roles for system access. +| The GUI options vary depending on the role. + +.. image:: PolicyGUI_Roles.png + +| + + + +End of Document diff --git a/docs/release-notes/bug-fixes.rst b/docs/release-notes/bug-fixes.rst new file mode 100644 index 000000000..24ec32c42 --- /dev/null +++ b/docs/release-notes/bug-fixes.rst @@ -0,0 +1,86 @@ +.. This work is licensed under a Creative Commons Attribution 4.0 International License. + +Bug Fixes +--------- + +ONAP POLICY Framework items for: (Last Updated: 10/23/2017) + +* **Version**: Amsterdam Release +* **Release Date**: 02 November, 2017 +* **Description**: R1 + +Bug +^^^ + + * [POLICY-12] - Clean up warnings in drools-pdp project + * [POLICY-14] - Fix docker-compose to use onap/* instead of openecomp/* + * [POLICY-15] - 1.1.0-SNAPSHOT bring up issues + * [POLICY-16] - correct problems introduced by swagger addition to pdp-d + * [POLICY-19] - PDP-X getConfig API Authentication error + * [POLICY-20] - PDP-X getConfig - Configuration Policy not found + * [POLICY-21] - PDP-D occasionally stuck during shutdown + * [POLICY-23] - PDP-X getConfig issues + * [POLICY-24] - PDP-X pushPolicy problems + * [POLICY-27] - excessive long idle timeouts in DB introduced unnecessarily + * [POLICY-29] - BRMS GW - client configuration + * [POLICY-74] - policy-engine build failure + * [POLICY-75] - KieScanner repeatedly updating Drools container + * [POLICY-84] - Query Name validation before execution + * [POLICY-91] - drools-applications - vFW/vDNS dependencies issues + * [POLICY-92] - brmsgw - vFW/vDNS dependency rename issue + * [POLICY-94] - Health check failure in R1.1.0 in DFW on Rackspace + * [POLICY-134] - PolicyLogger.info(Object arg0) executes recursively causing stack overflow error. + * [POLICY-144] - PAP: console: browser access: 500 code + * [POLICY-145] - Healthcheck functionality not working + * [POLICY-146] - brmsgw: vFW/vDNS rules jars not generated + * [POLICY-165] - Support Backward compatibility for the Policy Interface + * [POLICY-170] - policy build by vagrant fails + * [POLICY-175] - 0% Code Coverage in some projects + * [POLICY-191] - PDP-D: Enhancement: feature session-persistence + * [POLICY-192] - verify and/or merge job hang running JUnit test + * [POLICY-194] - policy/drools-applications: fix template to enable JUnits + * [POLICY-195] - policy/drools-pdp/session-persistence: remove new sonar blocker and criticals + * [POLICY-197] - drools-applications: logger change breaks junit on drl template + * [POLICY-199] - Policy UI page displays blank in ONAP + * [POLICY-203] - Test case testGetPropertiesValue fails if we run test case or build code other than C: + * [POLICY-205] - policy/engine: missing license files + * [POLICY-206] - Missing license for drools-applications + * [POLICY-211] - Policy Fails Robot Health Check + * [POLICY-213] - remove sonar blocker/criticals introduced by feature-test-transaction + * [POLICY-221] - Policy GUI Cosmetic Issues + * [POLICY-223] - PDP Health Check Fail + * [POLICY-229] - Policy healthcheck failure in RS ORD ONAP 1.1.0 + * [POLICY-234] - PDP-D: drools session remains hung on an update + * [POLICY-275] - pdp-x: automated pushing of policies shows that some operations failed + * [POLICY-276] - brmsgw: not generating amsterdam rules jar + * [POLICY-278] - console: sql injection protection not working properly + * [POLICY-295] - brmsgw: amsterdam controller rules generation cannot be built + * [POLICY-296] - pdp-d guard db access causes control loop failures + * [POLICY-298] - pdp-d: drl template drops messages in clean up rules + * [POLICY-299] - Policy CSIT tests are running over 15 hours long + * [POLICY-300] - Use correct format for messages from Policy to APPC_LCM_READ + * [POLICY-301] - DB sessionpersistence.sessioninfo to mediumblob + * [POLICY-302] - brmsgw: set up rules should not be generated + * [POLICY-305] - Policy Guard Deny response + * [POLICY-306] - vDNS yaml that is pushed should contain "SO" as actor not "MSO" + * [POLICY-310] - Policy GUI Fixes + * [POLICY-313] - Update MicroService vCPE Config Policy with new values + * [POLICY-314] - pdp-d: better handling of unsuccessful AAI responses + * [POLICY-315] - Change back docker compose version to 2 from 3 + * [POLICY-339] - pdp-d apps aai vdns : update aai interface from v8 to v11 + * [POLICY-340] - console: upgrade to latest portal sdk + * [POLICY-341] - pdp-d apps vfw: subsequent onsets on same resource not discarded + * [POLICY-342] - docker push-policies : config and operational policies must use the same control loop name + * [POLICY-343] - console: displaying corporate logo + * [POLICY-344] - Operations History Persistence Unit Not Found + * [POLICY-345] - Operations History Table is not written to + * [POLICY-350] - pdp-d apps drl: resiliency to exceptions and null values returned/thrown from java models + * [POLICY-353] - Bug in UebTopicSinkFactory + * [POLICY-354] - Update the latest Portal Properties + * [POLICY-356] - pdp-d apps: print networked messages over http interface + * [POLICY-357] - pdp-d db-migrator when ALL dbs flag is used upgrade not working properly + * [POLICY-363] - docker pdp-d: set DCAE DMaaP Server default to vm1.mr.simpledemo.openecomp.org + * [POLICY-364] - Policy template should not reject Event if A&AI lookup fails. + + + diff --git a/docs/release-notes/deprecation-notes.rst b/docs/release-notes/deprecation-notes.rst new file mode 100644 index 000000000..e954e8764 --- /dev/null +++ b/docs/release-notes/deprecation-notes.rst @@ -0,0 +1,5 @@ +.. This work is licensed under a Creative Commons Attribution 4.0 International License. + +Deprecation Notes +----------------- + diff --git a/docs/release-notes/index.rst b/docs/release-notes/index.rst new file mode 100644 index 000000000..0ac56af2f --- /dev/null +++ b/docs/release-notes/index.rst @@ -0,0 +1,11 @@ +.. This work is licensed under a Creative Commons Attribution 4.0 International License. + +Release Notes +============= + +.. toctree:: + :maxdepth: 1 + + new-features.rst + bug-fixes.rst + known-issues.rst diff --git a/docs/release-notes/known-issues.rst b/docs/release-notes/known-issues.rst new file mode 100644 index 000000000..b4ee9540c --- /dev/null +++ b/docs/release-notes/known-issues.rst @@ -0,0 +1,17 @@ +.. This work is licensed under a Creative Commons Attribution 4.0 International License. + +Known Issues +------------ + +ONAP POLICY Framework items for: (Last Updated: 10/10/2017) + +* **Version**: Amsterdam Release +* **Release Date**: 02 November, 2017 +* **Description**: R1 + +Issues +^^^^^^ + +* No known issues at this time + + diff --git a/docs/release-notes/new-features.rst b/docs/release-notes/new-features.rst new file mode 100644 index 000000000..e72f9262c --- /dev/null +++ b/docs/release-notes/new-features.rst @@ -0,0 +1,140 @@ +.. This work is licensed under a Creative Commons Attribution 4.0 International License. + +New Features +------------ + +ONAP POLICY Framework items for: (Last Updated: 10/23/2017) + +* **Version**: Amsterdam Release +* **Release Date**: 02 November, 2017 +* **Description**: R1 + +.. contents:: + :depth: 2 + +Epic +^^^^ + + * [POLICY-31] - Stabilization of Seed Code + * [POLICY-33] - This epic covers the body of work involved in deploying the Policy Platform components + * [POLICY-34] - This epic covers the work required to support a Policy developer environment in which Policy Developers can create, update policy templates/rules separate from the policy Platform runtime platform. + * [POLICY-35] - This epic covers the body of work involved in supporting policy that is platform specific. + * [POLICY-37] - This epic covers the work required to capture, update, extend Policy(s) during Service Design. + * [POLICY-39] - This epic covers the work required to support the Policy Platform during runtime. + * [POLICY-76] - This epic covers the body of work involved in supporting R1 Amsterdam Milestone Release Planning Milestone Tasks. + +Story +^^^^^ + + * [POLICY-25] - Replace any remaining openecomp reference by onap + * [POLICY-32] - JUnit test code coverage + * [POLICY-40] - MSB Integration + * [POLICY-41] - OOM Integration + * [POLICY-43] - Amsterdam Use Case Template + * [POLICY-48] - CLAMP Configuration and Operation Policies for vCPE Use Case + * [POLICY-51] - Runtime Policy Update Support + * [POLICY-57] - VF-C Actor code development + * [POLICY-59] - vCPE Use Case - Runtime + * [POLICY-60] - VOLTE Use Case - Runtime + * [POLICY-61] - vFW Use Case - Runtime + * [POLICY-62] - vDNS Use Case - Runtime + * [POLICY-63] - CLAMP Configuration and Operation Policies for VOLTE Use Case + * [POLICY-64] - CLAMP Configuration and Operation Policies for vFW Use Case + * [POLICY-65] - CLAMP Configuration and Operation Policies for vDNS Use Case + * [POLICY-66] - PDP-D Feature mechanism enhancements + * [POLICY-67] - Rainy Day Decision Policy + * [POLICY-68] - TOSCA Parsing for nested objects for Microservice Policies + * [POLICY-77] - Functional Test case definition for Control Loops + * [POLICY-93] - Notification API + * [POLICY-119] - PDP-D: noop sinks + * [POLICY-121] - Update POM to inherit from oparent + * [POLICY-124] - Integration with oparent + * [POLICY-158] - policy/engine: SQL injection Mitigation + * [POLICY-161] - Security Event Logging + * [POLICY-173] - Deployment of Operational Policies Documentation + * [POLICY-210] - Independent Versioning and Release Process + * [POLICY-316] - vCPE Use Case - Runtime Testing + * [POLICY-320] - VOLTE Use Case - Runtime Testing + * [POLICY-324] - vFW Use Case - Runtime Testing + * [POLICY-328] - vDNS Use Case - Runtime Testing + + +Task +^^^^ + + * [POLICY-3] - Add appropriate unit tests back into the distribution + * [POLICY-6] - Updates to License and Trademark in the Policy Source Code + * [POLICY-8] - Fix PDP-D Sonar Blocker Issues + * [POLICY-11] - Enhancements to extract fact information for a given Drools Application + * [POLICY-17] - Removal of ECOMP-SDK-APP dbscripts + * [POLICY-18] - Enhancement: Add additional feature hooks in Drools PDP + * [POLICY-22] - drools-applications reorganization and template upgrade + * [POLICY-26] - PDP-D Telemetry REST CLI + * [POLICY-30] - PDP-D Logging Enhancements + * [POLICY-53] - Update drools-application docker scripts to find reorganized pom changes + * [POLICY-54] - POLICY-54 Add HTTP Proxy Support to docker image builds + * [POLICY-55] - Ensure drools-application JUnit test works on ONAP JJB using in memory database + * [POLICY-58] - Update Policy Engine dependencies and use case policies to support the latest drools-application code + * [POLICY-70] - Add vagrant functionality to build/setup policy + * [POLICY-78] - Update Drools version to 6.5.0.Final + * [POLICY-80] - Policy Guard + * [POLICY-87] - Implement Recommended Fix for Portal + * [POLICY-88] - Delete the yaml sdk and sdc projects located in policy/engine + * [POLICY-95] - Fix policy/commons sonar blocker issues with exception of integrity-monitor/audit + * [POLICY-96] - Fix policy/common integrity-[monitor/audit] sonar blockers + * [POLICY-97] - Fix policy/engine sonar blockers + * [POLICY-98] - policy/commons critical sonar issues - NON integrity/monitor related + * [POLICY-100] - fix policy/common critical sonar items - integrity monitor/audit related + * [POLICY-105] - Common-Modules changes to RefreshStateAudit + * [POLICY-111] - policy/drools-applications: sonar blockers + * [POLICY-113] - policy/engine: sonar critical + * [POLICY-114] - policy/drools-pdp: sonar critical + * [POLICY-115] - policy/drools-application: sonar critical + * [POLICY-116] - Remove MojoHaus Maven plug-in from pom file + * [POLICY-117] - Resolve Policy Sonar Critical issues + * [POLICY-122] - Policy GUI Fixes for Dictionary and Dashboard tabs + * [POLICY-125] - Update Project FOSS Table + * [POLICY-126] - Identify and outline the set of documentations to be delivered in this Release + * [POLICY-133] - Addition of policy-persistence feature + * [POLICY-154] - policy/engine finish eclipse warnings for unused imports/variables + * [POLICY-155] - Addition of state-management feature + * [POLICY-156] - Addition of active-standby-management feature + * [POLICY-163] - Add 'install' and 'uninstall' option to DroolsPDP 'features' script + * [POLICY-167] - Clean additional pom warnings policy/engine + * [POLICY-168] - Clean pom warnings policy/drools-applications + * [POLICY-171] - Update policy/docker README to reflect current project paths + * [POLICY-176] - policy/drools-applications: convert System.out, System.err to use slf4j/logback + * [POLICY-177] - test-transaction feature to check on the healthiness of policy controllers + * [POLICY-178] - policy/common: convert integrity monitor to use slf4j/logback as in drools-pdp + * [POLICY-180] - Upgrade policy/engine release build to use more memory + * [POLICY-181] - Policy/common change jenkins job to not ignore JUnit tests for verify job. + * [POLICY-193] - Created a new cleanup process + * [POLICY-196] - Enhancement on MS JSON File + * [POLICY-218] - LF Open Source License Issues + * [POLICY-228] - Create common object to consolidate AAI response + * [POLICY-231] - Remove Binary files from Policy Repo + * [POLICY-237] - Address remaining sonar/critical for policy/common + * [POLICY-239] - Address sonar major issues + * [POLICY-247] - Modify docker push-policies to push the Amsterdam Template and latest policies + * [POLICY-253] - Modify policy/engine pom.xml to remove sonar scan on 3rd party code. + * [POLICY-261] - policy/drools-pdp last remaining sonar critical + * [POLICY-266] - feature-state-management JUnit coverage + * [POLICY-273] - Revert the SDK properties from onap to ecomp + * [POLICY-274] - .gitignore policy/engine directories/files created after running mvn clean install or mvn test + * [POLICY-297] - policy/drools-applications stage-site build is failing due to heap space + * [POLICY-304] - Add ability for Docker scripts to NOT pre-load policies for testing + * [POLICY-307] - Delete the pre-Amsterdam policy template etc. + * [POLICY-312] - Change Policy CSIT Integration Tests to utilize the PRELOAD_POLICIES=false + * [POLICY-335] - Add more documentation details + * [POLICY-337] - Update CSIT Integration Tests with latest Config/Operational Policies + * [POLICY-355] - Exclude dependencies for mysql and iText + + +Additional Information +^^^^^^^^^^^^^^^^^^^^^^ + +Latest details for Policy Framework Amsterdam Release can be found at `PolicyReleaseNotes`_. + +.. _PolicyReleaseNotes: https://jira.onap.org/secure/ReleaseNote.jspa?projectId=10106&version=10300 + + diff --git a/docs/release-notes/other.rst b/docs/release-notes/other.rst new file mode 100644 index 000000000..2ce683b5b --- /dev/null +++ b/docs/release-notes/other.rst @@ -0,0 +1,5 @@ +.. This work is licensed under a Creative Commons Attribution 4.0 International License. + +Other +----- + diff --git a/docs/release-notes/security-issues.rst b/docs/release-notes/security-issues.rst new file mode 100644 index 000000000..96e1fe95e --- /dev/null +++ b/docs/release-notes/security-issues.rst @@ -0,0 +1,5 @@ +.. This work is licensed under a Creative Commons Attribution 4.0 International License. + +Security Issues +--------------- + diff --git a/docs/release-notes/upgrade-notes.rst b/docs/release-notes/upgrade-notes.rst new file mode 100644 index 000000000..f31c74a69 --- /dev/null +++ b/docs/release-notes/upgrade-notes.rst @@ -0,0 +1,5 @@ +.. This work is licensed under a Creative Commons Attribution 4.0 International License. + +Upgrade Notes +------------- + |