Policy 1707 commit to LF
[policy/engine.git] / ecomp-sdk-app / src / main / java / org / openecomp / policy / controller / CreatePolicyController.java
diff --git a/ecomp-sdk-app/src/main/java/org/openecomp/policy/controller/CreatePolicyController.java b/ecomp-sdk-app/src/main/java/org/openecomp/policy/controller/CreatePolicyController.java
deleted file mode 100644 (file)
index f5c0a57..0000000
+++ /dev/null
@@ -1,484 +0,0 @@
-/*-
- * ============LICENSE_START=======================================================
- * ECOMP Policy Engine
- * ================================================================================
- * 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.controller;
-
-
-import java.io.BufferedReader;
-import java.io.File;
-import java.io.FileNotFoundException;
-import java.io.FileReader;
-import java.io.IOException;
-import java.io.PrintWriter;
-import java.nio.file.Path;
-import java.nio.file.Paths;
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.Iterator;
-import java.util.LinkedHashMap;
-import java.util.List;
-import java.util.Map;
-import java.util.UUID;
-
-import javax.servlet.http.HttpServletRequest;
-import javax.servlet.http.HttpServletResponse;
-
-//import org.apache.commons.logging.Log;
-//import org.apache.commons.logging.LogFactory;
-import org.json.JSONObject;
-import org.openecomp.policy.adapter.PolicyAdapter;
-import org.openecomp.policy.admin.PolicyNotificationMail;
-import org.openecomp.policy.admin.RESTfulPAPEngine;
-import org.openecomp.policy.dao.PolicyVersionDao;
-import org.openecomp.policy.dao.RuleAlgorithmsDao;
-import org.openecomp.policy.dao.WatchPolicyNotificationDao;
-import org.openecomp.policy.elk.client.PolicyElasticSearchController;
-import org.openecomp.policy.rest.jpa.PolicyVersion;
-import org.openecomp.policy.rest.jpa.RuleAlgorithms;
-import org.openecomp.portalsdk.core.controller.RestrictedBaseController;
-import org.openecomp.portalsdk.core.web.support.JsonMessage;
-import org.openecomp.portalsdk.core.web.support.UserUtils;
-import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.http.MediaType;
-import org.springframework.stereotype.Controller;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.servlet.ModelAndView;
-
-import org.openecomp.policy.common.logging.flexlogger.FlexLogger;
-import org.openecomp.policy.common.logging.flexlogger.Logger;
-
-import com.att.research.xacml.api.XACML3;
-import org.openecomp.policy.xacml.api.XACMLErrorConstants;
-import org.openecomp.policy.xacml.util.XACMLPolicyScanner;
-import com.fasterxml.jackson.databind.DeserializationFeature;
-import com.fasterxml.jackson.databind.JsonNode;
-import com.fasterxml.jackson.databind.ObjectMapper;
-import com.google.common.base.Joiner;
-
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.AllOfType;
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.AnyOfType;
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.AttributeDesignatorType;
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.AttributeValueType;
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.MatchType;
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.PolicyType;
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.RuleType;
-import oasis.names.tc.xacml._3_0.core.schema.wd_17.TargetType;
-
-@Controller
-@RequestMapping("/")
-public class CreatePolicyController extends RestrictedBaseController{
-       private static Logger logger    = FlexLogger.getLogger(CreatePolicyController.class);
-        
-       private static RuleAlgorithmsDao ruleAlgorithmsDao;
-       private static PolicyVersionDao policyVersionDao;
-       private static WatchPolicyNotificationDao policyNotificationDao;
-       
-       @Autowired
-       private CreatePolicyController(RuleAlgorithmsDao ruleAlgorithmsDao, PolicyVersionDao policyVersionDao, WatchPolicyNotificationDao policyNotificationDao){
-               CreatePolicyController.policyVersionDao = policyVersionDao;
-               CreatePolicyController.ruleAlgorithmsDao = ruleAlgorithmsDao;
-               CreatePolicyController.policyNotificationDao = policyNotificationDao;
-       }
-       
-       public CreatePolicyController(){}
-       
-       protected PolicyAdapter policyAdapter = null;
-       private String ruleID = "";
-       private ArrayList<Object> attributeList;
-       boolean isValidForm = false;
-       private int riskLevelCount; 
-       
-       public String newPolicyID() {
-               return Joiner.on(':').skipNulls().join((PolicyController.getDomain().startsWith("urn") ? null: "urn"),
-                               PolicyController.getDomain().replaceAll("[/\\\\.]", ":"), "xacml", "policy", "id", UUID.randomUUID());
-       }
-
-       @RequestMapping(value={"/get_RiskLevelValues"}, method={org.springframework.web.bind.annotation.RequestMethod.GET} , produces=MediaType.APPLICATION_JSON_VALUE)
-       public void getRiskLevelValuesData(HttpServletRequest request, HttpServletResponse response){
-               try{
-                       Map<String, Object> model = new HashMap<String, Object>();
-                       ObjectMapper mapper = new ObjectMapper();
-                       List<String> riskLevelList = new ArrayList<String>();
-                       riskLevelCount = 5;
-                       for (int i = 1; i <= riskLevelCount; i++) {
-                               riskLevelList.add(String.valueOf(i));
-                       }
-                       model.put("riskLevelDatas", mapper.writeValueAsString(riskLevelList));
-                       JsonMessage msg = new JsonMessage(mapper.writeValueAsString(model));
-                       JSONObject j = new JSONObject(msg);
-                       response.getWriter().write(j.toString());
-               }
-               catch (Exception e){
-                       e.printStackTrace();
-               }
-       }
-       
-       @RequestMapping(value={"/get_GuardlValues"}, method={org.springframework.web.bind.annotation.RequestMethod.GET} , produces=MediaType.APPLICATION_JSON_VALUE)
-       public void getGuardValuesData(HttpServletRequest request, HttpServletResponse response){
-               try{
-                       Map<String, Object> model = new HashMap<String, Object>();
-                       ObjectMapper mapper = new ObjectMapper();
-                       List<String> guardList = new ArrayList<String>();
-                       guardList.add("True");
-                       guardList.add("False");
-                       model.put("guardDatas", mapper.writeValueAsString(guardList));
-                       JsonMessage msg = new JsonMessage(mapper.writeValueAsString(model));
-                       JSONObject j = new JSONObject(msg);
-                       response.getWriter().write(j.toString());
-               }
-               catch (Exception e){
-                       e.printStackTrace();
-               }
-       }
-
-       
-       @RequestMapping(value={"/policyController/save_policy.htm"}, method={org.springframework.web.bind.annotation.RequestMethod.POST})
-       public ModelAndView savePolicy(HttpServletRequest request, HttpServletResponse response) throws Exception{
-               try {
-                       String userId = UserUtils.getUserIdFromCookie(request);
-                       RESTfulPAPEngine engine = (RESTfulPAPEngine) PolicyController.getPapEngine();
-                       ObjectMapper mapper = new ObjectMapper();
-                       mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
-                       JsonNode root = mapper.readTree(request.getReader());
-                       PolicyAdapter policyData = (PolicyAdapter)mapper.readValue(root.get("policyData").get("policy").toString(), PolicyAdapter.class);
-                       policyData.setDomainDir(root.get("policyData").get("model").get("name").toString().replace("\"", ""));
-                       if(root.get("policyData").get("model").get("type").toString().replace("\"", "").equals("file")){
-                               policyData.isEditPolicy = true;
-                       }
-                       
-                       if (policyData.getTtlDate()==null){
-                               policyData.setTtlDate("NA");
-                       }else{
-                               String dateTTL = policyData.getTtlDate();
-                               String newDate = convertDate(dateTTL, false);
-                               policyData.setTtlDate(newDate);
-                       }
-                       
-                       if(root.get("policyData").get("model").get("path").size() != 0){
-                               String dirName = "";
-                               for(int i = 0; i < root.get("policyData").get("model").get("path").size(); i++){
-                                       dirName = dirName.replace("\"", "") + root.get("policyData").get("model").get("path").get(i).toString().replace("\"", "") + File.separator;
-                               }
-                               policyData.setDomainDir(dirName.substring(0, dirName.lastIndexOf(File.separator)));
-                       }else{
-                               policyData.setDomainDir(root.get("policyData").get("model").get("name").toString().replace("\"", ""));
-                       }
-                       
-                       int version = 0;
-                       int highestVersion = 0;
-                       int descriptionVersion = 0;
-                       //get the highest version of policy from policy version table.
-                       //getting the sub scope domain where the policy is created or updated
-                       String dbCheckPolicyName = policyData.getDomainDir() + File.separator + "Config_" + policyData.getPolicyName();
-                       List<PolicyVersion> policyVersionlist = policyVersionDao.getPolicyVersionEntityByName(dbCheckPolicyName);
-                       if (policyVersionlist.size() > 0) {             
-                               for(int i = 0;  i < policyVersionlist.size(); i++) {
-                                       PolicyVersion entityItem = policyVersionlist.get(i);
-                                       if(entityItem.getPolicyName().equals(dbCheckPolicyName)){
-                                               highestVersion = entityItem.getHigherVersion();
-                                       }
-                               }
-                       }               
-                       if(highestVersion != 0){
-                               version = highestVersion;
-                               descriptionVersion = highestVersion +1;         
-                       }else{
-                               version = 1;
-                               descriptionVersion = 1;
-                       }
-                       
-                       //set policy adapter values for Building JSON object containing policy data
-                       String createdBy = "";
-                       String modifiedBy = userId;
-                       if(descriptionVersion == 1){
-                               createdBy = userId;
-                       }else{
-                               String policyName = PolicyController.getGitPath().toAbsolutePath().toString() + File.separator + policyData.getDomainDir() + File.separator + policyData.getOldPolicyFileName() + ".xml";
-                               File policyPath = new File(policyName);
-                               try {
-                                       createdBy =     XACMLPolicyScanner.getCreatedBy(policyPath.toPath());
-                               } catch (IOException e) {
-                                       createdBy = "guest";
-                               }
-                       }
-                       
-                       policyData.setPolicyDescription(policyData.getPolicyDescription()+ "@CreatedBy:" +createdBy + "@CreatedBy:" + "@ModifiedBy:" +modifiedBy + "@ModifiedBy:");
-                       
-                       Map<String, String> successMap = new HashMap<String, String>();
-                       Map<String, String> attributeMap = new HashMap<String, String>();
-                       //set the Rule Combining Algorithm Id to be sent to PAP-REST via JSON
-                       List<RuleAlgorithms> ruleAlgorithmList = ruleAlgorithmsDao.getRuleAlgorithms();
-                       for (int i = 0; i < ruleAlgorithmList.size(); i++) {
-                               RuleAlgorithms a = ruleAlgorithmList.get(i);
-                               if (a.getXacmlId().equals(XACML3.ID_RULE_PERMIT_OVERRIDES.stringValue())) {
-                                       policyData.setRuleCombiningAlgId(a.getXacmlId());
-                                       break;
-                               }
-                       }
-                       
-                       if(policyData.getAttributes().size() > 0){
-                               for(Object attribute : policyData.getAttributes()){
-                                       if(attribute instanceof LinkedHashMap<?, ?>){
-                                               String key = ((LinkedHashMap<?, ?>) attribute).get("option").toString();
-                                               String value = ((LinkedHashMap<?, ?>) attribute).get("number").toString();
-                                               attributeMap.put(key, value);   
-                                       }
-                               }
-                       }
-                       policyData.setDynamicFieldConfigAttributes(attributeMap);
-                       
-                       if (policyData.isEditPolicy()){
-                               //increment the version and set in policyAdapter                        
-                               policyData.setVersion(String.valueOf(version));
-                               policyData.setHighestVersion(version);
-                               policyData.setPolicyID(this.newPolicyID());
-                               policyData.setRuleID(ruleID);
-                               successMap = engine.updatePolicyRequest(policyData);
-                       } else {
-                               //send it for policy creation
-                               policyData.setVersion(String.valueOf(version));
-                               policyData.setHighestVersion(version);
-                               successMap = engine.createPolicyRequest(policyData);
-
-                       }
-
-                       if (successMap.containsKey("success")) {
-                               // Add it into our tree
-                               Path finalPolicyPath = null;
-                               finalPolicyPath = Paths.get(successMap.get("success"));
-                               PolicyElasticSearchController controller = new PolicyElasticSearchController();
-                               controller.updateElk(finalPolicyPath.toString());
-                               File file = finalPolicyPath.toFile();
-                               if(file != null){
-                                       String policyName = file.toString();
-                                       String removePath = policyName.substring(policyName.indexOf("repository")+11);
-                                       String removeXml = removePath.replace(".xml", "");
-                                       String removeExtension = removeXml.substring(0, removeXml.indexOf("."));
-                                       List<PolicyVersion> versionList = policyVersionDao.getPolicyVersionEntityByName(removeExtension);
-                                       if (versionList.size() > 0) {           
-                                               for(int i = 0;  i < versionList.size(); i++) {
-                                               PolicyVersion entityItem = versionList.get(i);
-                                                       if(entityItem.getPolicyName().equals(removeExtension)){
-                                                               version = entityItem.getHigherVersion() +1;
-                                                               entityItem.setActiveVersion(version);
-                                                               entityItem.setHigherVersion(version);
-                                                               entityItem.setModifiedBy(userId);
-                                                               policyVersionDao.update(entityItem);
-                                                               if(policyData.isEditPolicy){
-                                                                       PolicyNotificationMail email = new PolicyNotificationMail();
-                                                                       String mode = "EditPolicy";
-                                                                       String policyNameForEmail = policyData.getDomainDir() + File.separator + policyData.getOldPolicyFileName() + ".xml";
-                                                                       email.sendMail(entityItem, policyNameForEmail, mode, policyNotificationDao);
-                                                               }
-                                                       }
-                                               }
-                                       }else{
-                                               PolicyVersion entityItem = new PolicyVersion();
-                                               entityItem.setActiveVersion(version);
-                                               entityItem.setHigherVersion(version);
-                                               entityItem.setPolicyName(removeExtension);
-                                               entityItem.setCreatedBy(userId);
-                                               entityItem.setModifiedBy(userId);
-                                               policyVersionDao.Save(entityItem);
-                                       }       
-                               }
-                       }
-                       response.setCharacterEncoding("UTF-8");
-                       response.setContentType("application / json");
-                       request.setCharacterEncoding("UTF-8");
-
-                       PrintWriter out = response.getWriter();
-                       String responseString = mapper.writeValueAsString(successMap);
-                       JSONObject j = new JSONObject("{policyData: " + responseString + "}");
-                       out.write(j.toString());
-                       return null;
-               }
-               catch (Exception e){
-                       response.setCharacterEncoding("UTF-8");
-                       request.setCharacterEncoding("UTF-8");
-                       PrintWriter out = response.getWriter();
-                       out.write(e.getMessage());
-               }
-               return null;
-       }
-       
-       private String convertDate(String dateTTL, boolean portalType) {
-               String formateDate = null;
-               String[] date;
-               String[] parts;
-               
-               if (portalType){
-                       parts = dateTTL.split("-");
-                       formateDate = parts[2] + "-" + parts[1] + "-" + parts[0] + "T05:00:00.000Z";
-               } else {
-                       date  = dateTTL.split("T");
-                       parts = date[0].split("-");
-                       formateDate = parts[2] + "-" + parts[1] + "-" + parts[0];
-               }
-               return formateDate;
-       }
-
-       public void PrePopulateBaseConfigPolicyData(PolicyAdapter policyAdapter) {
-               attributeList = new ArrayList<Object>();
-               if (policyAdapter.getPolicyData() instanceof PolicyType) {
-                       Object policyData = policyAdapter.getPolicyData();
-                       PolicyType policy = (PolicyType) policyData;
-                       policyAdapter.setOldPolicyFileName(policyAdapter.getPolicyName());
-                       policyAdapter.setConfigBodyData(readBaseConfigJSONFile(policyAdapter));
-                       String policyNameValue = policyAdapter.getPolicyName().substring(policyAdapter.getPolicyName().indexOf("_") + 1 , policyAdapter.getPolicyName().lastIndexOf("."));
-                       policyAdapter.setPolicyName(policyNameValue);
-                       String description = "";
-                       try{
-                               description = policy.getDescription().substring(0, policy.getDescription().indexOf("@CreatedBy:"));
-                       }catch(Exception e){
-                               description = policy.getDescription();
-                       }
-                       policyAdapter.setPolicyDescription(description);
-                       // Get the target data under policy.
-                       TargetType target = policy.getTarget();
-                       if (target != null) {
-                               // Under target we have AnyOFType
-                               List<AnyOfType> anyOfList = target.getAnyOf();
-                               if (anyOfList != null) {
-                                       Iterator<AnyOfType> iterAnyOf = anyOfList.iterator();
-                                       while (iterAnyOf.hasNext()) {
-                                               AnyOfType anyOf = iterAnyOf.next();
-                                               // Under AnyOFType we have AllOFType
-                                               List<AllOfType> allOfList = anyOf.getAllOf();
-                                               if (allOfList != null) {
-                                                       Iterator<AllOfType> iterAllOf = allOfList.iterator();
-                                                       int index = 0;
-                                                       while (iterAllOf.hasNext()) {
-                                                               AllOfType allOf = iterAllOf.next();
-                                                               // Under AllOFType we have Match
-                                                               List<MatchType> matchList = allOf.getMatch();
-                                                               if (matchList != null) {
-                                                                       Iterator<MatchType> iterMatch = matchList.iterator();
-                                                                       while (iterMatch.hasNext()) {
-                                                                               MatchType match = iterMatch.next();
-                                                                               //
-                                                                               // Under the match we have attributevalue and
-                                                                               // attributeDesignator. So,finally down to the actual attribute.
-                                                                               //
-                                                                               AttributeValueType attributeValue = match.getAttributeValue();
-                                                                               String value = (String) attributeValue.getContent().get(0);
-                                                                               AttributeDesignatorType designator = match.getAttributeDesignator();
-                                                                               String attributeId = designator.getAttributeId();
-                                                                               // First match in the target is EcompName, so set that value.
-                                                                               if (index == 1) {
-                                                                                       policyAdapter.setEcompName(value);
-                                                                               }
-                                                                               if (index ==  2){
-                                                                                       policyAdapter.setRiskType(value);
-                                                                               }
-
-                                                                               if (index ==  3){
-                                                                                       policyAdapter.setRiskLevel(value);
-                                                                               }
-                                                                               
-                                                                               if (index ==  4){
-                                                                                       policyAdapter.setGuard(value);
-                                                                               }
-                                                                               if (index == 5 && !value.contains("NA")){
-                                                                                       String newDate = convertDate(value, true);
-                                                                                       policyAdapter.setTtlDate(newDate);
-                                                                               }
-                                                                               if (index == 6){
-                                                                                       policyAdapter.setConfigName(value);
-                                                                               }
-                                                                               // After Ecomp and Config it is optional to have attributes, so
-                                                                               // check weather dynamic values or there or not.
-                                                                               if (index >= 7) {
-                                                                                       Map<String, String> attribute = new HashMap<String, String>();
-                                                                                       attribute.put("option", attributeId);
-                                                                                       attribute.put("number", value);
-                                                                                       attributeList.add(attribute);
-                                                                               }
-                                                                               index++;
-                                                                       }
-                                                               }
-                                                       }
-                                               }
-                                       }
-                               }
-                               
-                               policyAdapter.setAttributes(attributeList);
-                       }
-                       List<Object> ruleList = policy.getCombinerParametersOrRuleCombinerParametersOrVariableDefinition();
-                       for (Object o : ruleList) {
-                               if (o instanceof RuleType) {
-                                       // get the condition data under the rule for rule  Algorithms.
-                                       policyAdapter.setRuleID(((RuleType) o).getRuleId());
-                               }
-                       }
-               }               
-       }
-
-       private String readBaseConfigJSONFile(PolicyAdapter policyAdapter) {
-               String fileName = policyAdapter.getPolicyName();
-               String fileLocation = null;
-               if (fileName != null && fileName.contains("Config")) {
-                       fileLocation = PolicyController.getConfigHome();
-               }
-               if (logger.isDebugEnabled()) {
-                       logger.debug("Attempting to read file from the location: " + fileLocation);
-               }
-
-               if (fileLocation == null) {
-                       logger.error(XACMLErrorConstants.ERROR_DATA_ISSUE + "Error with the FileName: " + fileName);
-                       return fileLocation;
-               }
-
-
-               File dir = new File(fileLocation);
-               File[] listOfFiles = dir.listFiles();
-               String extension = null;
-               for (File file : listOfFiles) {
-                       if (file.isFile() && file.getName().contains(fileName)) {
-                               // For config form we have set the ConfigType Based on the extention.
-                               if (fileName.contains("Config")) {
-                                       extension = file.getName().substring(file.getName().lastIndexOf('.') + 1);
-                                       // Based on file type set Combobox config value
-                                       if (extension.equals("txt")) {
-                                               policyAdapter.setConfigType("OTHER");
-                                       } else {
-                                               policyAdapter.setConfigType(extension.toUpperCase());
-                                       }
-                               }
-                               // Reading the file
-                               try (BufferedReader br = new BufferedReader(new FileReader(file))) {
-                                       StringBuilder sb = new StringBuilder();
-                                       String line = br.readLine();
-                                       while (line != null) {
-                                               sb.append(line);
-                                               sb.append("\n");
-                                               line = br.readLine();
-                                       }
-                                       return sb.toString();
-                               } catch (FileNotFoundException e) {
-                                       logger.error(XACMLErrorConstants.ERROR_DATA_ISSUE + e.getMessage());
-                               } catch (IOException e1) {
-                                       logger.error(XACMLErrorConstants.ERROR_DATA_ISSUE + e1.getMessage());
-                               }
-                       }
-               }
-               return null;
-       }
-}