2b7b06697328c6e5229240d51699d719f82b45fb
[clamp.git] / src / main / java / org / onap / clamp / clds / client / OperationalPolicyDelegate.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * ONAP CLAMP
4  * ================================================================================
5  * Copyright (C) 2017 AT&T Intellectual Property. All rights
6  *                             reserved.
7  * ================================================================================
8  * Licensed under the Apache License, Version 2.0 (the "License"); 
9  * you may not use this file except in compliance with the License. 
10  * You may obtain a copy of the License at
11  * 
12  * http://www.apache.org/licenses/LICENSE-2.0
13  * 
14  * Unless required by applicable law or agreed to in writing, software 
15  * distributed under the License is distributed on an "AS IS" BASIS, 
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 
17  * See the License for the specific language governing permissions and 
18  * limitations under the License.
19  * ============LICENSE_END============================================
20  * ===================================================================
21  * ECOMP is a trademark and service mark of AT&T Intellectual Property.
22  */
23
24 package org.onap.clamp.clds.client;
25
26 import org.onap.clamp.clds.client.req.OperationalPolicyReq;
27 import org.onap.clamp.clds.model.prop.ModelProperties;
28 import org.onap.clamp.clds.model.refprop.RefProp;
29 import org.onap.policy.api.AttributeType;
30 import org.camunda.bpm.engine.delegate.DelegateExecution;
31 import org.camunda.bpm.engine.delegate.JavaDelegate;
32 import org.springframework.beans.factory.annotation.Autowired;
33
34 import java.util.Map;
35 import java.util.UUID;
36 import java.util.logging.Logger;
37
38
39 /**
40  * Send Operational Policy info to policy api.
41  */
42 public class OperationalPolicyDelegate implements JavaDelegate {
43     // currently uses the java.util.logging.Logger like the Camunda engine
44     private static final Logger logger = Logger.getLogger(OperationalPolicyDelegate.class.getName());
45
46     @Autowired 
47     private PolicyClient policyClient;
48     
49     @Autowired
50     private RefProp refProp;
51
52     /**
53      * Perform activity.  Send Operational Policy info to policy api.
54      *
55      * @param execution
56      */
57     public void execute(DelegateExecution execution) throws Exception {
58         String operationalPolicyRequestUuid = UUID.randomUUID().toString();
59         execution.setVariable("operationalPolicyRequestUuid", operationalPolicyRequestUuid);
60
61         ModelProperties prop = ModelProperties.create(execution);
62         Map<AttributeType, Map<String, String>> attributes = OperationalPolicyReq.formatAttributes(refProp, prop);
63         String responseMessage = policyClient.sendBrms(attributes, prop, operationalPolicyRequestUuid);
64         if (responseMessage != null) {
65             execution.setVariable("operationalPolicyResponseMessage", responseMessage.getBytes());
66         }
67     }
68
69 }