]> git.aero2k.de Git - tmp/jakarta-migration.git/blob
87640f908736fcd87ea77f6a518e0c27bfe53770
[tmp/jakarta-migration.git] /
1 /**
2  *  This document is a part of the source code and related artifacts
3  *  for CollectionSpace, an open source collections management system
4  *  for museums and related institutions:
5
6  *  http://www.collectionspace.org
7  *  http://wiki.collectionspace.org
8
9  *  Copyright 2009 University of California at Berkeley
10
11  *  Licensed under the Educational Community License (ECL), Version 2.0.
12  *  You may not use this file except in compliance with this License.
13
14  *  You may obtain a copy of the ECL 2.0 License at
15
16  *  https://source.collectionspace.org/collection-space/LICENSE.txt
17
18  *  Unless required by applicable law or agreed to in writing, software
19  *  distributed under the License is distributed on an "AS IS" BASIS,
20  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
21  *  See the License for the specific language governing permissionRoles and
22  *  limitations under the License.
23  */
24 package org.collectionspace.services.authorization.storage;
25
26 import java.util.ArrayList;
27 import java.util.List;
28
29 import org.collectionspace.services.authorization.PermissionRole;
30 import org.collectionspace.services.authorization.PermissionRoleRel;
31 import org.collectionspace.services.authorization.PermissionValue;
32 import org.collectionspace.services.authorization.PermissionsRolesList;
33 import org.collectionspace.services.authorization.RoleValue;
34 import org.collectionspace.services.authorization.SubjectType;
35
36 import org.collectionspace.services.common.document.AbstractDocumentHandlerImpl;
37 import org.collectionspace.services.common.document.DocumentFilter;
38 import org.collectionspace.services.common.document.DocumentWrapper;
39 import org.slf4j.Logger;
40 import org.slf4j.LoggerFactory;
41
42 /**
43  * Document handler for PermissionRole association
44  * @author 
45  */
46 public class PermissionRoleDocumentHandler
47         extends AbstractDocumentHandlerImpl<PermissionRole, PermissionsRolesList, List<PermissionRoleRel>, List<PermissionRoleRel>> {
48
49     private final Logger logger = LoggerFactory.getLogger(PermissionRoleDocumentHandler.class);
50     private PermissionRole permissionRole;
51     private PermissionsRolesList permissionRolesList;
52
53     @Override
54     public void handleCreate(DocumentWrapper<List<PermissionRoleRel>> wrapDoc) throws Exception {
55         fillCommonPart(getCommonPart(), wrapDoc);
56     }
57
58     @Override
59     public void completeCreate(DocumentWrapper<List<PermissionRoleRel>> wrapDoc) throws Exception {
60         PermissionRole pr = getCommonPart();
61         AuthorizationDelegate.addPermissions(getServiceContext(), pr);
62     }
63
64     @Override
65     public void handleUpdate(DocumentWrapper<List<PermissionRoleRel>> wrapDoc) throws Exception {
66         throw new UnsupportedOperationException("operation not relevant for PermissionRoleDocumentHandler");
67     }
68
69     @Override
70     public void completeUpdate(DocumentWrapper<List<PermissionRoleRel>> wrapDoc) throws Exception {
71         throw new UnsupportedOperationException("operation not relevant for PermissionRoleDocumentHandler");
72     }
73
74     @Override
75     public void handleGet(DocumentWrapper<List<PermissionRoleRel>> wrapDoc) throws Exception {
76         setCommonPart(extractCommonPart(wrapDoc));
77         getServiceContext().setOutput(permissionRole);
78     }
79
80     @Override
81     public void handleGetAll(DocumentWrapper<List<PermissionRoleRel>> wrapDoc) throws Exception {
82         throw new UnsupportedOperationException("operation not relevant for PermissionRoleDocumentHandler");
83     }
84
85
86     @Override
87     public void completeDelete(DocumentWrapper<List<PermissionRoleRel>> wrapDoc) throws Exception {
88 //
89     }
90
91     @Override
92     public PermissionRole extractCommonPart(
93             DocumentWrapper<List<PermissionRoleRel>> wrapDoc)
94             throws Exception {
95         List<PermissionRoleRel> prrl = wrapDoc.getWrappedObject();
96         PermissionRole pr = new PermissionRole();
97         SubjectType subject = PermissionRoleUtil.getRelationSubject(getServiceContext());
98         PermissionRoleRel prr0 = prrl.get(0);
99         if (SubjectType.ROLE.equals(subject)) {
100
101             List<PermissionValue> pvs = new ArrayList<PermissionValue>();
102             pr.setPermissions(pvs);
103             PermissionValue pv = buildPermissionValue(prr0);
104             pvs.add(pv);
105
106             //add roles
107             List<RoleValue> rvs = new ArrayList<RoleValue>();
108             pr.setRoles(rvs);
109             for (PermissionRoleRel prr : prrl) {
110                 RoleValue rv = buildRoleValue(prr);
111                 rvs.add(rv);
112             }
113         } else if (SubjectType.PERMISSION.equals(subject)) {
114
115             List<RoleValue> rvs = new ArrayList<RoleValue>();
116             pr.setRoles(rvs);
117             RoleValue rv = buildRoleValue(prr0);
118             rvs.add(rv);
119
120             //add permssions
121             List<PermissionValue> pvs = new ArrayList<PermissionValue>();
122             pr.setPermissions(pvs);
123             for (PermissionRoleRel prr : prrl) {
124                 PermissionValue pv = buildPermissionValue(prr);
125                 pvs.add(pv);
126             }
127         }
128         return pr;
129     }
130
131     @Override
132     public void fillCommonPart(PermissionRole pr, DocumentWrapper<List<PermissionRoleRel>> wrapDoc)
133             throws Exception {
134         List<PermissionRoleRel> prrl = wrapDoc.getWrappedObject();
135         SubjectType subject = pr.getSubject();
136         if (subject == null) {
137             //it is not required to give subject as URI determines the subject
138             subject = PermissionRoleUtil.getRelationSubject(getServiceContext());
139         } else {
140             //subject mismatch should have been checked during validation
141         }
142         if (subject.equals(SubjectType.ROLE)) {
143             PermissionValue pv = pr.getPermissions().get(0);
144             for (RoleValue rv : pr.getRoles()) {
145                 PermissionRoleRel prr = buildPermissonRoleRel(pv, rv);
146                 prrl.add(prr);
147             }
148         } else if (SubjectType.PERMISSION.equals(subject)) {
149             RoleValue rv = pr.getRoles().get(0);
150             for (PermissionValue pv : pr.getPermissions()) {
151                 PermissionRoleRel prr = buildPermissonRoleRel(pv, rv);
152                 prrl.add(prr);
153             }
154         }
155     }
156
157     @Override
158     public PermissionsRolesList extractCommonPartList(
159             DocumentWrapper<List<PermissionRoleRel>> wrapDoc)
160             throws Exception {
161
162         throw new UnsupportedOperationException("operation not relevant for PermissionRoleDocumentHandler");
163     }
164
165     @Override
166     public PermissionRole getCommonPart() {
167         return permissionRole;
168     }
169
170     @Override
171     public void setCommonPart(PermissionRole permissionRole) {
172         this.permissionRole = permissionRole;
173     }
174
175     @Override
176     public PermissionsRolesList getCommonPartList() {
177         return permissionRolesList;
178     }
179
180     @Override
181     public void setCommonPartList(PermissionsRolesList permissionRolesList) {
182         this.permissionRolesList = permissionRolesList;
183     }
184
185     @Override
186     public String getQProperty(
187             String prop) {
188         return null;
189     }
190
191     @Override
192     public DocumentFilter createDocumentFilter() {
193         return new DocumentFilter(this.getServiceContext());
194     }
195
196     private PermissionValue buildPermissionValue(PermissionRoleRel prr) {
197         PermissionValue pv = new PermissionValue();
198         pv.setPermissionId(prr.getPermissionId());
199         pv.setResourceName(prr.getPermissionResource());
200         return pv;
201     }
202
203     private RoleValue buildRoleValue(PermissionRoleRel prr) {
204         RoleValue rv = new RoleValue();
205         rv.setRoleId(prr.getRoleId());
206         rv.setRoleName(prr.getRoleName());
207         return rv;
208     }
209
210     private PermissionRoleRel buildPermissonRoleRel(PermissionValue pv, RoleValue rv) {
211         PermissionRoleRel prr = new PermissionRoleRel();
212         prr.setPermissionId(pv.getPermissionId());
213         prr.setPermissionResource(pv.getResourceName());
214         prr.setRoleId(rv.getRoleId());
215         prr.setRoleName(rv.getRoleName());
216         return prr;
217     }
218 }