[POLICY-122] Policy GUI Fixes
[policy/engine.git] / POLICY-SDK-APP / src / main / java / org / openecomp / policy / controller / PDPController.java
index 2fcf793..c2c0bc8 100644 (file)
 package org.openecomp.policy.controller;
 
 
+import java.io.File;
 import java.io.PrintWriter;
 import java.util.ArrayList;
 import java.util.Collections;
+import java.util.HashSet;
+import java.util.Iterator;
 import java.util.List;
+import java.util.Set;
 
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
 
 import org.json.JSONObject;
+import org.openecomp.policy.common.logging.flexlogger.FlexLogger;
+import org.openecomp.policy.common.logging.flexlogger.Logger;
 import org.openecomp.policy.model.PDPGroupContainer;
+import org.openecomp.policy.model.Roles;
+import org.openecomp.policy.xacml.api.XACMLErrorConstants;
+import org.openecomp.policy.xacml.api.pap.EcompPDPGroup;
+import org.openecomp.policy.xacml.std.pap.StdPDP;
+import org.openecomp.policy.xacml.std.pap.StdPDPGroup;
 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.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 org.openecomp.policy.xacml.api.XACMLErrorConstants;
-import org.openecomp.policy.xacml.api.pap.EcompPDPGroup;
 
 import com.att.research.xacml.api.pap.PAPException;
-import org.openecomp.policy.xacml.std.pap.StdPDP;
-import org.openecomp.policy.xacml.std.pap.StdPDPGroup;
+import com.att.research.xacml.api.pap.PDPPolicy;
 import com.fasterxml.jackson.databind.DeserializationFeature;
 import com.fasterxml.jackson.databind.JsonNode;
 import com.fasterxml.jackson.databind.ObjectMapper;
@@ -54,209 +58,307 @@ import com.fasterxml.jackson.databind.ObjectMapper;
 @Controller
 @RequestMapping({"/"})
 public class PDPController extends RestrictedBaseController {
-       private static final  Logger logger = FlexLogger.getLogger(PDPController.class);
-       
+       private static final  Logger policyLogger = FlexLogger.getLogger(PDPController.class);
+
        protected List<EcompPDPGroup> groups = Collections.synchronizedList(new ArrayList<EcompPDPGroup>());
        private PDPGroupContainer container;
-       
-       public synchronized void refreshGroups() {
+
+       private static String SUPERADMIN = "super-admin";
+       private static String SUPEREDITOR = "super-editor";
+       private static String SUPERGUEST = "super-guest";
+
+       private Set<EcompPDPGroup> groupsData;
+
+       private boolean junit = false;
+
+       private PolicyController policyController;
+       public PolicyController getPolicyController() {
+               return policyController;
+       }
+
+       public void setPolicyController(PolicyController policyController) {
+               this.policyController = policyController;
+       }
+
+       public synchronized void refreshGroups(HttpServletRequest request) {
                synchronized(this.groups) { 
                        this.groups.clear();
                        try {
-                               this.groups.addAll(PolicyController.getPapEngine().getEcompPDPGroups());
+                               PolicyController controller = getPolicyControllerInstance();
+                               Set<PDPPolicy> filteredPolicies = new HashSet<>();
+                               Set<String> scopes = null;
+                               List<String> roles = null;
+                               String userId =  isJunit()  ? "Test" : UserUtils.getUserSession(request).getOrgUserId();
+                               List<Object> userRoles = controller.getRoles(userId);
+                               roles = new ArrayList<>();
+                               scopes = new HashSet<>();
+                               for(Object role: userRoles){
+                                       Roles userRole = (Roles) role;
+                                       roles.add(userRole.getRole());
+                                       if(userRole.getScope() != null){
+                                               if(userRole.getScope().contains(",")){
+                                                       String[] multipleScopes = userRole.getScope().split(",");
+                                                       for(int i =0; i < multipleScopes.length; i++){
+                                                               scopes.add(multipleScopes[i]);
+                                                       }
+                                               }else{
+                                                       scopes.add(userRole.getScope());
+                                               }
+                                       }       
+                               }
+                               if (roles.contains(SUPERADMIN) || roles.contains(SUPEREDITOR) || roles.contains(SUPERGUEST) ) {
+                                       if(!junit){
+                                               this.groups.addAll(controller.getPapEngine().getEcompPDPGroups());
+                                       }else{
+                                               this.groups.addAll(this.getGroupsData());
+                                       }       
+                               }else{
+                                       if(!userRoles.isEmpty()){
+                                               if(!scopes.isEmpty()){
+                                                       this.groups.addAll(controller.getPapEngine().getEcompPDPGroups());
+                                                       List<EcompPDPGroup> tempGroups = new ArrayList<>();
+                                                       if(!groups.isEmpty()){
+                                                               Iterator<EcompPDPGroup> pdpGroup = groups.iterator();
+                                                               while(pdpGroup.hasNext()){
+                                                                       EcompPDPGroup group = pdpGroup.next();
+                                                                       Set<PDPPolicy> policies = group.getPolicies();
+                                                                       for(PDPPolicy policy : policies){
+                                                                               for(String scope : scopes){
+                                                                                       scope = scope.replace(File.separator, ".");
+                                                                                       String policyName = policy.getId();
+                                                                                       if(policyName.contains(".Config_")){
+                                                                                               policyName = policyName.substring(0, policyName.lastIndexOf(".Config_"));
+                                                                                       }else if(policyName.contains(".Action_")){
+                                                                                               policyName = policyName.substring(0, policyName.lastIndexOf(".Action_"));
+                                                                                       }else if(policyName.contains(".Decision_")){
+                                                                                               policyName = policyName.substring(0, policyName.lastIndexOf(".Decision_"));
+                                                                                       }
+                                                                                       if(policyName.startsWith(scope)){
+                                                                                               filteredPolicies.add(policy);
+                                                                                       }
+                                                                               }
+                                                                       }
+                                                                       pdpGroup.remove();
+                                                                       StdPDPGroup newGroup = (StdPDPGroup) group;
+                                                                       newGroup.setPolicies(filteredPolicies);
+                                                                       tempGroups.add(newGroup);
+                                                               }       
+                                                               groups.clear();
+                                                               groups = tempGroups;    
+                                                       }
+                                               }
+                                       }
+                               }
                        } catch (PAPException e) {
                                String message = "Unable to retrieve Groups from server: " + e;
-                               logger.error(XACMLErrorConstants.ERROR_SYSTEM_ERROR+"Pap Engine is Null" + message);
+                               policyLogger.error(XACMLErrorConstants.ERROR_SYSTEM_ERROR+"Pap Engine is Null" + message);
                        }
-               
                }
        }
-       
-       @RequestMapping(value={"/get_PDPGroupContainerData"}, method={org.springframework.web.bind.annotation.RequestMethod.GET} , produces=MediaType.APPLICATION_JSON_VALUE)
-       public void getPDPGroupContainerData(HttpServletRequest request, HttpServletResponse response){
+
+       @RequestMapping(value={"/get_PDPGroupData"}, method={org.springframework.web.bind.annotation.RequestMethod.GET} , produces=MediaType.APPLICATION_JSON_VALUE)
+       public void getPDPGroupEntityData(HttpServletRequest request, HttpServletResponse response){
                try{
                        ObjectMapper mapper = new ObjectMapper();
-                       refreshGroups();
+                       refreshGroups(request);
                        JsonMessage msg = new JsonMessage(mapper.writeValueAsString(groups));
                        JSONObject j = new JSONObject(msg);
                        response.getWriter().write(j.toString());
                }
                catch (Exception e){
-                       logger.error(XACMLErrorConstants.ERROR_DATA_ISSUE+"Error Occured while retrieving the PDP Group Container data" + e);
+                       policyLogger.error(XACMLErrorConstants.ERROR_DATA_ISSUE+"Error Occured while retrieving the PDP Group data" + e);
                }
        }
-       
-       @RequestMapping(value={"/get_PDPGroupData"}, method={org.springframework.web.bind.annotation.RequestMethod.GET} , produces=MediaType.APPLICATION_JSON_VALUE)
-       public void getPDPGroupEntityData(HttpServletRequest request, HttpServletResponse response){
-               try{
+
+       @RequestMapping(value={"/pdp_Group/save_pdp_group"}, method={org.springframework.web.bind.annotation.RequestMethod.POST})
+       public void savePDPGroup(HttpServletRequest request, HttpServletResponse response){
+               try {
                        ObjectMapper mapper = new ObjectMapper();
-                       refreshGroups();
+                       PolicyController controller = getPolicyControllerInstance();
+                       mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
+                       JsonNode root = mapper.readTree(request.getReader());
+                       this.container = new PDPGroupContainer(controller.getPapEngine());
+                       StdPDPGroup pdpGroupData =  mapper.readValue(root.get("pdpGroupData").toString().replace("groupName", "name"), StdPDPGroup.class);
+                       try {
+                               if(pdpGroupData.getId() == null){
+                                       this.container.addNewGroup(pdpGroupData.getName(), pdpGroupData.getDescription());
+                               }else{
+                                       this.container.updateGroup(pdpGroupData);
+                               }
+
+                       } catch (Exception e) {
+                               String message = "Unable to create Group.  Reason:\n" + e.getMessage();
+                               policyLogger.error(XACMLErrorConstants.ERROR_DATA_ISSUE+"Error Occured while creating the PDP Group" + message + e);
+                       }
+
+
+                       response.setCharacterEncoding("UTF-8");
+                       response.setContentType("application / json");
+                       request.setCharacterEncoding("UTF-8");
+
+                       PrintWriter out = response.getWriter();
+                       refreshGroups(request);
                        JsonMessage msg = new JsonMessage(mapper.writeValueAsString(groups));
                        JSONObject j = new JSONObject(msg);
-                       response.getWriter().write(j.toString());
+                       out.write(j.toString());
                }
                catch (Exception e){
-                       logger.error(XACMLErrorConstants.ERROR_DATA_ISSUE+"Error Occured while retrieving the PDP Group data" + e);
+                       policyLogger.error(XACMLErrorConstants.ERROR_DATA_ISSUE+"Error Occured while Saving the PDP Group" + e);
+                       response.setCharacterEncoding("UTF-8");
+                       PrintWriter out = null;
+                       try {
+                               request.setCharacterEncoding("UTF-8");
+                               out = response.getWriter();
+                               out.write(e.getMessage());
+                       } catch (Exception e1) {
+                               policyLogger.error(XACMLErrorConstants.ERROR_DATA_ISSUE+"Error Occured while Saving the PDP Group" + e1);
+                       }
                }
        }
-       
-       @RequestMapping(value={"/pdp_Group/save_pdp_group"}, method={org.springframework.web.bind.annotation.RequestMethod.POST})
-         public ModelAndView savePDPGroup(HttpServletRequest request, HttpServletResponse response) throws Exception{
-           try {
-             ObjectMapper mapper = new ObjectMapper();
-             mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
-             JsonNode root = mapper.readTree(request.getReader());
-             this.container = new PDPGroupContainer(PolicyController.getPapEngine());
-             StdPDPGroup pdpGroupData =  mapper.readValue(root.get("pdpGroupData").toString().replace("groupName", "name"), StdPDPGroup.class);
-             try {
-                 if(pdpGroupData.getId() == null){
-                         this.container.addNewGroup(pdpGroupData.getName(), pdpGroupData.getDescription());
-                 }else{
-                         this.container.updateGroup(pdpGroupData);
-                 }
-                               
-                       } catch (Exception e) {
-                               String message = "Unable to create Group.  Reason:\n" + e.getMessage();
-                               logger.error(XACMLErrorConstants.ERROR_DATA_ISSUE+"Error Occured while creating the PDP Group" + message);
-                       }
-               
-           
-             response.setCharacterEncoding("UTF-8");
-             response.setContentType("application / json");
-             request.setCharacterEncoding("UTF-8");
-             
-             PrintWriter out = response.getWriter();
-             refreshGroups();
-             JsonMessage msg = new JsonMessage(mapper.writeValueAsString(groups));
-                 JSONObject j = new JSONObject(msg);
-             out.write(j.toString());
-             
-             return null;
-           }
-           catch (Exception e){
-            logger.error(XACMLErrorConstants.ERROR_DATA_ISSUE+"Error Occured while Saving the PDP Group" + e);
-             response.setCharacterEncoding("UTF-8");
-             request.setCharacterEncoding("UTF-8");
-             PrintWriter out = response.getWriter();
-             out.write(e.getMessage());
-           }
-           return null;
-         }
-         
-         @RequestMapping(value={"/pdp_Group/remove_pdp_group"}, method={org.springframework.web.bind.annotation.RequestMethod.POST})
-         public ModelAndView removePDPGroup(HttpServletRequest request, HttpServletResponse response) throws Exception {
-           try{
-             ObjectMapper mapper = new ObjectMapper();
-             mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
-             JsonNode root = mapper.readTree(request.getReader());
-             this.container = new PDPGroupContainer(PolicyController.getPapEngine()); 
-             StdPDPGroup pdpGroupData =  mapper.readValue(root.get("pdpGroupData").toString(), StdPDPGroup.class);
-               if(pdpGroupData.getName().equals("Default")) {
+
+       @RequestMapping(value={"/pdp_Group/remove_pdp_group"}, method={org.springframework.web.bind.annotation.RequestMethod.POST})
+       public void removePDPGroup(HttpServletRequest request, HttpServletResponse response){
+               try{
+                       ObjectMapper mapper = new ObjectMapper();
+                       mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
+                       JsonNode root = mapper.readTree(request.getReader());
+                       PolicyController controller = getPolicyControllerInstance();
+                       this.container = new PDPGroupContainer(controller.getPapEngine()); 
+                       StdPDPGroup pdpGroupData =  mapper.readValue(root.get("pdpGroupData").toString(), StdPDPGroup.class);
+                       if(pdpGroupData.getName().equals("Default")) {
                                throw new UnsupportedOperationException("You can't remove the Default Group.");
                        }else{
                                this.container.removeGroup(pdpGroupData, null);
                        }
-         
-             response.setCharacterEncoding("UTF-8");
-             response.setContentType("application / json");
-             request.setCharacterEncoding("UTF-8");
-             
-             PrintWriter out = response.getWriter();
-             
-             refreshGroups();
-             JsonMessage msg = new JsonMessage(mapper.writeValueAsString(groups));
-                 JSONObject j = new JSONObject(msg);
-             out.write(j.toString());
-             
-             return null;
-           }
-           catch (Exception e){
-             logger.error(XACMLErrorConstants.ERROR_DATA_ISSUE+"Error Occured while Removing the PDP Group" + e);
-             response.setCharacterEncoding("UTF-8");
-             request.setCharacterEncoding("UTF-8");
-             PrintWriter out = response.getWriter();
-             out.write(e.getMessage());
-           }
-           return null;
-         }
-         
-         @RequestMapping(value={"/pdp_Group/save_pdpTogroup"}, method={org.springframework.web.bind.annotation.RequestMethod.POST})
-         public ModelAndView savePDPToGroup(HttpServletRequest request, HttpServletResponse response) throws Exception{
-           try {
-             ObjectMapper mapper = new ObjectMapper();
-             mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
-             JsonNode root = mapper.readTree(request.getReader());
-             this.container = new PDPGroupContainer(PolicyController.getPapEngine()); 
-             String update = root.get("update").toString();
-             PdpData pdpGroupData = (PdpData)mapper.readValue(root.get("pdpInGroup").toString(), PdpData.class);
-             StdPDPGroup activeGroupData =  mapper.readValue(root.get("activePDP").toString(), StdPDPGroup.class);
-             try {
-                 
-                 if(update.contains("false")){
-                         this.container.addNewPDP(pdpGroupData.getId(), activeGroupData, pdpGroupData.getName(), pdpGroupData.getDescription(), pdpGroupData.getJmxPort());
-                 }else{
-                         this.container.updateGroup(activeGroupData);
-                 }
+
+                       response.setCharacterEncoding("UTF-8");
+                       response.setContentType("application / json");
+                       request.setCharacterEncoding("UTF-8");
+
+                       PrintWriter out = response.getWriter();
+
+                       refreshGroups(request);
+                       JsonMessage msg = new JsonMessage(mapper.writeValueAsString(groups));
+                       JSONObject j = new JSONObject(msg);
+                       out.write(j.toString());
+               }
+               catch (Exception e){
+                       policyLogger.error(XACMLErrorConstants.ERROR_DATA_ISSUE+"Error Occured while Removing the PDP Group" + e);
+                       PrintWriter out;
+                       try {
+                               response.setCharacterEncoding("UTF-8");
+                               request.setCharacterEncoding("UTF-8");
+                               out = response.getWriter();
+                               out.write(e.getMessage());
+                       } catch (Exception e1) {
+                               policyLogger.error("Exception Occured"+ e1);
+                       }
+               }
+       }
+
+       @RequestMapping(value={"/pdp_Group/save_pdpTogroup"}, method={org.springframework.web.bind.annotation.RequestMethod.POST})
+       public void savePDPToGroup(HttpServletRequest request, HttpServletResponse response){
+               try {
+                       ObjectMapper mapper = new ObjectMapper();
+                       mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
+                       JsonNode root = mapper.readTree(request.getReader());
+                       PolicyController controller = getPolicyControllerInstance();
+                       this.container = new PDPGroupContainer(controller.getPapEngine()); 
+                       String update = root.get("update").toString();
+                       PdpData pdpGroupData = (PdpData)mapper.readValue(root.get("pdpInGroup").toString(), PdpData.class);
+                       StdPDPGroup activeGroupData =  mapper.readValue(root.get("activePDP").toString(), StdPDPGroup.class);
+                       try {
+
+                               if(update.contains("false")){
+                                       this.container.addNewPDP(pdpGroupData.getId(), activeGroupData, pdpGroupData.getName(), pdpGroupData.getDescription(), pdpGroupData.getJmxPort());
+                               }else{
+                                       this.container.updateGroup(activeGroupData);
+                               }
                        } catch (Exception e) {
                                String message = "Unable to create Group.  Reason:\n" + e.getMessage();
-                                logger.error(XACMLErrorConstants.ERROR_DATA_ISSUE+"Error Occured while Creating Pdp in PDP Group" + message);
+                               policyLogger.error(XACMLErrorConstants.ERROR_DATA_ISSUE+"Error Occured while Creating Pdp in PDP Group" + message + e);
+                       }
+
+
+                       response.setCharacterEncoding("UTF-8");
+                       response.setContentType("application / json");
+                       request.setCharacterEncoding("UTF-8");
+
+                       PrintWriter out = response.getWriter();
+                       refreshGroups(request);
+                       JsonMessage msg = new JsonMessage(mapper.writeValueAsString(groups));
+                       JSONObject j = new JSONObject(msg);
+                       out.write(j.toString());
+               }
+               catch (Exception e){
+                       policyLogger.error(XACMLErrorConstants.ERROR_DATA_ISSUE+"Error Occured while Creating Pdp in PDP Group" + e);
+                       PrintWriter out;
+                       try {
+                               response.setCharacterEncoding("UTF-8");
+                               request.setCharacterEncoding("UTF-8");
+                               out = response.getWriter();
+                               out.write(e.getMessage());
+                       } catch (Exception e1) {
+                               policyLogger.error("Exception Occured"+ e1);
+                       }
+               }
+       }
+
+       @RequestMapping(value={"/pdp_Group/remove_pdpFromGroup"}, method={org.springframework.web.bind.annotation.RequestMethod.POST})
+       public void removePDPFromGroup(HttpServletRequest request, HttpServletResponse response){
+               try{
+                       ObjectMapper mapper = new ObjectMapper();
+                       mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
+                       JsonNode root = mapper.readTree(request.getReader());
+                       PolicyController controller = getPolicyControllerInstance();
+                       this.container = new PDPGroupContainer(controller.getPapEngine()); 
+                       StdPDP deletePdp =  mapper.readValue(root.get("data").toString(), StdPDP.class);
+                       StdPDPGroup activeGroupData =  mapper.readValue(root.get("activePDP").toString(), StdPDPGroup.class);
+
+                       this.container.removePDP(deletePdp, activeGroupData);
+                       response.setCharacterEncoding("UTF-8");
+                       response.setContentType("application / json");
+                       request.setCharacterEncoding("UTF-8");
+
+                       PrintWriter out = response.getWriter();
+                       refreshGroups(request);
+                       String responseString = mapper.writeValueAsString(groups);
+                       JSONObject j = new JSONObject("{pdpEntityDatas: " + responseString + "}");
+                       out.write(j.toString());
+               }
+               catch (Exception e){
+                       policyLogger.error(XACMLErrorConstants.ERROR_DATA_ISSUE+"Error Occured while Removing Pdp from PDP Group" + e);
+                       PrintWriter out;
+                       try {
+                               response.setCharacterEncoding("UTF-8");
+                               request.setCharacterEncoding("UTF-8");
+                               out = response.getWriter();
+                               out.write(e.getMessage());
+                       } catch (Exception e1) {
+                               policyLogger.error("Exception Occured"+ e1);
                        }
-               
-           
-             response.setCharacterEncoding("UTF-8");
-             response.setContentType("application / json");
-             request.setCharacterEncoding("UTF-8");
-             
-             PrintWriter out = response.getWriter();
-             refreshGroups();
-             JsonMessage msg = new JsonMessage(mapper.writeValueAsString(groups));
-                 JSONObject j = new JSONObject(msg);
-             out.write(j.toString());
-             
-             return null;
-           }
-           catch (Exception e){
-             logger.error(XACMLErrorConstants.ERROR_DATA_ISSUE+"Error Occured while Creating Pdp in PDP Group" + e);
-             response.setCharacterEncoding("UTF-8");
-             request.setCharacterEncoding("UTF-8");
-             PrintWriter out = response.getWriter();
-             out.write(e.getMessage());
-           }
-           return null;
-         }
-         
-         @RequestMapping(value={"/pdp_Group/remove_pdpFromGroup"}, method={org.springframework.web.bind.annotation.RequestMethod.POST})
-         public ModelAndView removePDPFromGroup(HttpServletRequest request, HttpServletResponse response) throws Exception {
-           try{
-             ObjectMapper mapper = new ObjectMapper();
-             mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
-             JsonNode root = mapper.readTree(request.getReader());
-             this.container = new PDPGroupContainer(PolicyController.getPapEngine()); 
-             StdPDP deletePdp =  mapper.readValue(root.get("data").toString(), StdPDP.class);
-             StdPDPGroup activeGroupData =  mapper.readValue(root.get("activePDP").toString(), StdPDPGroup.class);
-               
-             this.container.removePDP(deletePdp, activeGroupData);
-             response.setCharacterEncoding("UTF-8");
-             response.setContentType("application / json");
-             request.setCharacterEncoding("UTF-8");
-             
-             PrintWriter out = response.getWriter();
-             refreshGroups();
-             String responseString = mapper.writeValueAsString(groups);
-             JSONObject j = new JSONObject("{pdpEntityDatas: " + responseString + "}");
-             out.write(j.toString());
-             
-             return null;
-           }
-           catch (Exception e){
-             logger.error(XACMLErrorConstants.ERROR_DATA_ISSUE+"Error Occured while Removing Pdp from PDP Group" + e);
-             response.setCharacterEncoding("UTF-8");
-             request.setCharacterEncoding("UTF-8");
-             PrintWriter out = response.getWriter();
-             out.write(e.getMessage());
-           }
-           return null;
-         }
+               }
+       }
+
+       private PolicyController getPolicyControllerInstance(){
+               return policyController != null ? getPolicyController() : new PolicyController();
+       }
+
+       public boolean isJunit() {
+               return junit;
+       }
+
+       public void setJunit(boolean junit) {
+               this.junit = junit;
+       }
+
+       public Set<EcompPDPGroup> getGroupsData() {
+               return groupsData;
+       }
+
+       public void setGroupsData(Set<EcompPDPGroup> groupsData) {
+               this.groupsData = groupsData;
+       }
 }
 
 class PdpData{