aboutsummaryrefslogtreecommitdiffstats
path: root/ECOMP-PDP-REST/src/main/java/org/openecomp/policy/pdp/rest/api/services/FirewallPolicyService.java
blob: f301bf05d89618c10c51e9da27a3b5e9edbb4559 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
/*-
 * ============LICENSE_START=======================================================
 * ECOMP-PDP-REST
 * ================================================================================
 * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
 * ================================================================================
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ============LICENSE_END=========================================================
 */
package org.openecomp.policy.pdp.rest.api.services;

import javax.json.JsonException;
import javax.json.JsonObject;

import org.openecomp.policy.api.PolicyException;
import org.openecomp.policy.api.PolicyParameters;
import org.openecomp.policy.common.logging.flexlogger.FlexLogger;
import org.openecomp.policy.common.logging.flexlogger.Logger;
import org.openecomp.policy.pdp.rest.api.utils.PolicyApiUtils;
import org.openecomp.policy.xacml.api.XACMLErrorConstants;
import org.openecomp.policy.xacml.std.pap.StdPAPPolicy;

/**
 * Firewall Policy Implementation. 
 * 
 * @version 0.1
 */
public class FirewallPolicyService {
	private static final Logger LOGGER = FlexLogger.getLogger(FirewallPolicyService.class.getName());
	
	private  PAPServices papServices = null;
	private PolicyParameters policyParameters = null;
	private String message = null;
	private String policyName = null;
	private String policyScope = null;
	private String date = null;
	private JsonObject firewallJson = null;
	
	public FirewallPolicyService(String policyName, String policyScope,
			PolicyParameters policyParameters, String date) {
		this.policyParameters = policyParameters;
		this.policyName = policyName;
		this.policyScope = policyScope;
		this.date = date;
		papServices = new PAPServices();
	}

	public Boolean getValidation() {
		if(policyParameters.getConfigBody()==null){
			message = XACMLErrorConstants.ERROR_DATA_ISSUE+ "No Config Body given.";
			return false;
		}
		try{
			firewallJson = PolicyApiUtils.stringToJsonObject(policyParameters.getConfigBody());
		} catch(JsonException| IllegalStateException e){
			message = XACMLErrorConstants.ERROR_DATA_ISSUE+ " improper JSON object : " + policyParameters.getConfigBody();
			LOGGER.error("Error while parsing JSON body for creating Firewall Policy " , e);
			return false;
		}
		if(firewallJson==null|| firewallJson.isEmpty()){
			message = XACMLErrorConstants.ERROR_DATA_ISSUE + "No Config-Body given.";
			return false;
		}
		boolean levelCheck = false;
		levelCheck = PolicyApiUtils.isNumeric(policyParameters.getRiskLevel());
		if (!levelCheck){
			message = XACMLErrorConstants.ERROR_DATA_ISSUE + "Incorrect Risk Level given.";
			return false;
		}
		return true;
	}

	public String getMessage() {
		return message;
	}

	public String getResult(boolean updateFlag) throws PolicyException {
		String response = null;
		String operation = null;
		if (updateFlag){
			operation = "update";
		} else {
			operation = "create";
		}
		//set values for basic policy information
		if(!firewallJson.containsKey("configName")){
			message = XACMLErrorConstants.ERROR_DATA_ISSUE + "No configName given in firwall JSON.";
			LOGGER.error(message);
			return message;
		}
		String configName = firewallJson.get("configName").toString();
		String configDescription = "";
		String json = firewallJson.toString();
		// Create Policy. 
		StdPAPPolicy newPAPPolicy = new StdPAPPolicy("Firewall Config", policyName, configDescription, configName, updateFlag, policyScope, json, 0, 
				policyParameters.getRiskLevel(),policyParameters.getRiskType(), String.valueOf(policyParameters.getGuard()), date);
		// Send Json to PAP. 
		response = (String) papServices.callPAP(newPAPPolicy, new String[] {"operation="+operation, "apiflag=api", "policyType=Config"}, policyParameters.getRequestID(), "ConfigFirewall");
		LOGGER.info(response);
		return response;
	}

}