KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > com > sslexplorer > policyframework > wizards > actions > AccessRightsFinishAction


1 /*
2  * SSL-Explorer
3  *
4  * Copyright (C) 2003-2006 3SP LTD. All Rights Reserved
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU General Public License
8  * as published by the Free Software Foundation; either version 2 of
9  * the License, or (at your option) any later version.
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public
16  * License along with this program; if not, write to the Free Software
17  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
18  */

19             
20 package com.sslexplorer.policyframework.wizards.actions;
21
22 import java.util.ArrayList JavaDoc;
23 import java.util.Calendar JavaDoc;
24 import java.util.Iterator JavaDoc;
25 import java.util.List JavaDoc;
26
27 import javax.servlet.http.HttpServletRequest JavaDoc;
28 import javax.servlet.http.HttpServletResponse JavaDoc;
29 import javax.servlet.http.HttpSession JavaDoc;
30
31 import org.apache.commons.logging.Log;
32 import org.apache.commons.logging.LogFactory;
33 import org.apache.struts.action.ActionForm;
34 import org.apache.struts.action.ActionForward;
35 import org.apache.struts.action.ActionMapping;
36 import org.apache.struts.util.MessageResources;
37
38 import com.sslexplorer.boot.PropertyList;
39 import com.sslexplorer.core.CoreAttributeConstants;
40 import com.sslexplorer.core.CoreEvent;
41 import com.sslexplorer.core.CoreEventConstants;
42 import com.sslexplorer.core.CoreServlet;
43 import com.sslexplorer.core.CoreUtil;
44 import com.sslexplorer.policyframework.AccessRight;
45 import com.sslexplorer.policyframework.AccessRights;
46 import com.sslexplorer.policyframework.DefaultAccessRights;
47 import com.sslexplorer.policyframework.PolicyDatabaseFactory;
48 import com.sslexplorer.policyframework.Resource;
49 import com.sslexplorer.policyframework.forms.AbstractWizardPolicySelectionForm;
50 import com.sslexplorer.policyframework.wizards.forms.AccessRightsDetailsForm;
51 import com.sslexplorer.policyframework.wizards.forms.AccessRightsPermissionsForm;
52 import com.sslexplorer.security.LogonControllerFactory;
53 import com.sslexplorer.security.SessionInfo;
54 import com.sslexplorer.wizard.AbstractWizardSequence;
55 import com.sslexplorer.wizard.WizardActionStatus;
56 import com.sslexplorer.wizard.actions.AbstractWizardAction;
57 import com.sslexplorer.wizard.forms.AbstractWizardFinishForm;
58
59 /**
60  * The <i>AccessRightsFinishAction> {@link com.sslexplorer.wizard.actions.AbstractWizardAction} implementation
61  * is responsible finishing the creation of a Access right.
62  *
63  * @author James D Robinson <a HREF="mailto:james@3sp.com">&lt;james@3sp.com&gt;</a>
64  *
65  */

66 public class AccessRightsFinishAction extends AbstractWizardAction {
67     final static Log log = LogFactory.getLog(AccessRightsFinishAction.class);
68
69     /**
70      *
71      */

72     public AccessRightsFinishAction() {
73         super();
74     }
75
76     public int getNavigationContext(ActionMapping mapping, ActionForm form, HttpServletRequest JavaDoc request, HttpServletResponse JavaDoc response) {
77         return SessionInfo.MANAGEMENT_CONSOLE_CONTEXT;
78     }
79
80     public ActionForward unspecified(ActionMapping mapping, ActionForm form, HttpServletRequest JavaDoc request,
81                     HttpServletResponse JavaDoc response) throws Exception JavaDoc {
82         List JavaDoc actionStatus = new ArrayList JavaDoc();
83         AbstractWizardSequence seq = getWizardSequence(request);
84         SessionInfo info = this.getSessionInfo(request);
85         String JavaDoc name = (String JavaDoc) seq.getAttribute(AccessRightsDetailsForm.ATTR_RESOURCE_NAME, null);
86         String JavaDoc description = (String JavaDoc) seq.getAttribute(AccessRightsDetailsForm.ATTR_RESOURCE_DESCRIPTION, null);
87         List JavaDoc permissions = (List JavaDoc) seq.getAttribute(AccessRightsPermissionsForm.ATTR_RESOURCE_TYPE_PERMISSIONS, null);
88         String JavaDoc permissionClass = (String JavaDoc) seq.getAttribute(AccessRightsDetailsForm.ATTR_RESOURCE_PERMISSION_CLASS, null);
89         AccessRights accessRights = null;
90         Calendar JavaDoc now = Calendar.getInstance();
91         try {
92             accessRights = PolicyDatabaseFactory.getInstance().createAccessRights(
93                             new DefaultAccessRights(info.getUser().getRealm().getRealmID(), 0, name, description, permissions, permissionClass, now, now));
94             
95             actionStatus.add(new WizardActionStatus(WizardActionStatus.COMPLETED_OK,
96                             "accessRightsWizard.resourceFinish.status.resourceCreated"));
97             
98             CoreEvent coreEvent = new CoreEvent(this, CoreEventConstants.CREATE_ACCESS_RIGHT, accessRights, info, CoreEvent.STATE_SUCCESSFUL)
99                                     .addAttribute(CoreAttributeConstants.EVENT_ATTR_RESOURCE_NAME, accessRights.getResourceName())
100                                     .addAttribute(CoreAttributeConstants.EVENT_ATTR_RESOURCE_DESCRIPTION, accessRights.getResourceDescription())
101                                     .addAttribute(CoreAttributeConstants.EVENT_ATTR_TYPE_ACCESS_RIGHT, getAccessRightType(request.getSession(), permissionClass));
102            List JavaDoc permissionsList = accessRights.getAccessRights();
103             if (permissionsList != null) {
104                 int j =0;
105                 for (Iterator JavaDoc i = permissionsList.iterator(); i.hasNext();) {
106                     j++;
107                     AccessRight permission = (AccessRight)i.next();
108
109                     MessageResources mrPermission = CoreUtil.getMessageResources(request.getSession(), permission.getPermission().getBundle());
110                     String JavaDoc permissionName = mrPermission.getMessage("permission."+permission.getPermission().getId()+".title");
111
112                     MessageResources mrResourceType = CoreUtil.getMessageResources(request.getSession(), permission.getResourceType().getBundle());
113                     String JavaDoc resourceTypeName = mrResourceType.getMessage("resourceType."+permission.getResourceType().getResourceTypeId()+".title");
114                     coreEvent.addAttribute(CoreAttributeConstants.EVENT_ATTR_TYPE_PERMISSION + Integer.toString(j), permissionName + " " + resourceTypeName);
115                 }
116             }
117             CoreServlet.getServlet().fireCoreEvent(coreEvent);
118             
119         } catch (Exception JavaDoc e) {
120             log.error("Failed to create delegation resource.", e);
121             CoreServlet.getServlet().fireCoreEvent(new CoreEvent(this, CoreEventConstants.CREATE_ACCESS_RIGHT, accessRights, info, CoreEvent.STATE_UNSUCCESSFUL)
122                                     .addAttribute(CoreAttributeConstants.EVENT_ATTR_RESOURCE_NAME, accessRights.getResourceName())
123                                     .addAttribute(CoreAttributeConstants.EVENT_ATTR_RESOURCE_DESCRIPTION, accessRights.getResourceDescription())
124                                     .addAttribute(CoreAttributeConstants.EVENT_ATTR_TYPE_ACCESS_RIGHT, getAccessRightType(request.getSession(), permissionClass)));
125             actionStatus.add(new WizardActionStatus(WizardActionStatus.COMPLETED_WITH_ERRORS,
126                             "accessRightsWizard.resourceFinish.status.failedToCreateResource", e.getMessage()));
127         }
128         if (accessRights != null) {
129             actionStatus.add(attachToPolicies(seq, info, accessRights));
130         }
131         ((AbstractWizardFinishForm) form).setActionStatus(actionStatus);
132         // we now need to rebuild any menus, as more or less could be visable.
133
LogonControllerFactory.getInstance().applyMenuItemChanges(request);
134         return super.unspecified(mapping, form, request, response);
135     }
136     
137     private static String JavaDoc getAccessRightType(HttpSession JavaDoc session, String JavaDoc permissionClass) {
138         MessageResources messageResources = CoreUtil.getMessageResources(session, "policyframework");
139         String JavaDoc accessRightType = messageResources.getMessage("permission.type." + permissionClass);
140         return accessRightType;
141     }
142     
143     /**
144      * @param mapping
145      * @param form
146      * @param request
147      * @param response
148      * @return action forward
149      * @throws Exception
150      */

151     public ActionForward exit(ActionMapping mapping, ActionForm form, HttpServletRequest JavaDoc request, HttpServletResponse JavaDoc response)
152                     throws Exception JavaDoc {
153         return cancel(mapping, form, request, response);
154     }
155
156     WizardActionStatus attachToPolicies(AbstractWizardSequence seq, SessionInfo info, Resource resource) {
157         PropertyList selectedPolicies = (PropertyList) seq.getAttribute(AbstractWizardPolicySelectionForm.ATTR_SELECTED_POLICIES,
158                         null);
159         try {
160             PolicyDatabaseFactory.getInstance().attachResourceToPolicyList(resource, selectedPolicies, info);
161             return new WizardActionStatus(WizardActionStatus.COMPLETED_OK,
162                             "accessRightsWizard.resourceFinish.status.attachedToPolicies");
163         } catch (Exception JavaDoc e) {
164             log.error("Failed to create profile.", e);
165             return new WizardActionStatus(WizardActionStatus.COMPLETED_WITH_ERRORS,
166                             "accessRightsWizard.resourceFinish.status.failedToAttachToPolicies", e.getMessage());
167         }
168     }
169
170 }
171
Popular Tags