]> git.aero2k.de Git - tmp/jakarta-migration.git/blob
438e9495f055a64f67b201e70b0569db45ed0963
[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 permissions and
22  *  limitations under the License.
23  *//**
24  *  This document is a part of the source code and related artifacts
25  *  for CollectionSpace, an open source collections management system
26  *  for museums and related institutions:
27
28  *  http://www.collectionspace.org
29  *  http://wiki.collectionspace.org
30
31  *  Copyright 2009 University of California at Berkeley
32
33  *  Licensed under the Educational Community License (ECL), Version 2.0.
34  *  You may not use this file except in compliance with this License.
35
36  *  You may obtain a copy of the ECL 2.0 License at
37
38  *  https://source.collectionspace.org/collection-space/LICENSE.txt
39
40  *  Unless required by applicable law or agreed to in writing, software
41  *  distributed under the License is distributed on an "AS IS" BASIS,
42  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
43  *  See the License for the specific language governing permissions and
44  *  limitations under the License.
45  */
46 /*
47  * To change this template, choose Tools | Templates
48  * and open the template in the editor.
49  */
50 package org.collectionspace.services.account.storage;
51
52 import java.util.List;
53 import java.util.regex.Matcher;
54 import java.util.regex.Pattern;
55 import org.collectionspace.services.account.AccountTenant;
56 import org.collectionspace.services.account.AccountsCommon;
57 import org.collectionspace.services.account.Tenant;
58 import org.collectionspace.services.common.ServiceMessages;
59 import org.collectionspace.services.common.context.ServiceContext;
60 import org.collectionspace.services.common.document.DocumentHandler.Action;
61 import org.collectionspace.services.common.document.DocumentNotFoundException;
62 import org.collectionspace.services.common.document.InvalidDocumentException;
63 import org.collectionspace.services.common.document.ValidatorHandler;
64 import org.collectionspace.services.common.storage.jpa.JpaStorageUtils;
65 import org.slf4j.Logger;
66 import org.slf4j.LoggerFactory;
67
68 /**
69  *
70  * @author 
71  */
72 public class AccountValidatorHandler implements ValidatorHandler {
73
74     final Logger logger = LoggerFactory.getLogger(AccountValidatorHandler.class);
75
76     @Override
77     public void validate(Action action, ServiceContext ctx)
78             throws InvalidDocumentException {
79         if (logger.isDebugEnabled()) {
80             logger.debug("validate() action=" + action.name());
81         }
82         try {
83             AccountsCommon account = (AccountsCommon) ctx.getInput();
84             StringBuilder msgBldr = new StringBuilder(ServiceMessages.VALIDATION_FAILURE);
85             boolean invalid = false;
86
87             List<AccountTenant> tl = account.getTenants();
88             if (tl != null && tl.size() > 0) {
89                 if (isInvalidTenant(tl, msgBldr)) {
90                     invalid = true;
91                 }
92             }
93
94             if (action.equals(Action.CREATE)) {
95
96                 //create specific validation here
97                 if (account.getScreenName() == null || account.getScreenName().isEmpty()) {
98                     invalid = true;
99                     msgBldr.append("\nscreenName : missing");
100                 }
101                 if (account.getUserId() == null || account.getUserId().isEmpty()) {
102                     invalid = true;
103                     msgBldr.append("\nuserId : missing");
104                 }
105                 if (account.getEmail() == null || account.getEmail().isEmpty()) {
106                     invalid = true;
107                     msgBldr.append("\nemail : missing");
108                 } else {
109                     if (isInvalidEmail(account.getEmail(), msgBldr)) {
110                         invalid = true;
111                     }
112                 }
113             } else if (action.equals(Action.UPDATE)) {
114                 //update specific validation here
115                 if (account.getScreenName() != null && account.getScreenName().isEmpty()) {
116                     invalid = true;
117                     msgBldr.append("\nscreenName : cannot be changed!");
118                 }
119                 if (account.getPassword() != null
120                         && (account.getUserId() == null || account.getUserId().isEmpty())) {
121                     invalid = true;
122                     msgBldr.append("\npassword : userId is needed");
123                 }
124                 if (account.getEmail() != null) {
125                     if (isInvalidEmail(account.getEmail(), msgBldr)) {
126                         invalid = true;
127                     }
128                 }
129             }
130             if (invalid) {
131                 String msg = msgBldr.toString();
132                 logger.error(msg);
133                 throw new InvalidDocumentException(msg);
134             }
135         } catch (InvalidDocumentException ide) {
136             throw ide;
137         } catch (Exception e) {
138             throw new InvalidDocumentException(e);
139         }
140     }
141
142     private boolean isInvalidEmail(String email, StringBuilder msgBldr) {
143         boolean invalid = false;
144         Pattern p = Pattern.compile("^[_A-Za-z0-9-]+(\\.[_A-Za-z0-9-]+)*@[A-Za-z0-9-]+(\\.[A-Za-z0-9-]+)*(\\.[_A-Za-z0-9-]+)");
145         Matcher m = p.matcher(email);
146         if (!m.find()) {
147             invalid = true;
148             msgBldr.append("\nemail : invalid " + email);
149         }
150         return invalid;
151     }
152
153     private boolean isInvalidTenant(List<AccountTenant> atList, StringBuilder msgBldr)
154                 throws DocumentNotFoundException {
155         boolean invalid = false;
156         for (AccountTenant at : atList) {
157             String tid = at.getTenantId();
158             if (tid == null || tid.isEmpty()) {
159                 invalid = true;
160                 msgBldr.append("\n tenant : tenantId is missing");
161                 break;
162             }
163             Tenant tenantFound = (Tenant) JpaStorageUtils.getEntity(tid, Tenant.class);
164             if (tenantFound == null) {
165                 invalid = true;
166                 msgBldr.append("\n tenant : tenantId=" + tid
167                         + " not found");
168                 break;
169             }
170         }
171         return invalid;
172     }
173 }