]> git.aero2k.de Git - tmp/jakarta-migration.git/blob
eaa84856f7ac30e5c482128bfa50f0e35d567a8b
[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  */
25 package org.collectionspace.services.account.storage;
26
27 import java.util.ArrayList;
28 import java.util.List;
29 import org.collectionspace.services.common.storage.jpa.JpaDocumentFilter;
30 import org.collectionspace.services.common.context.ServiceContext;
31 import org.slf4j.Logger;
32 import org.slf4j.LoggerFactory;
33
34 /**
35  *
36  * @author 
37  */
38 public class AccountJpaFilter extends JpaDocumentFilter {
39
40     private final Logger logger = LoggerFactory.getLogger(AccountJpaFilter.class);
41
42     public AccountJpaFilter(ServiceContext ctx) {
43         super(ctx);
44     }
45
46     @Override
47     public List<ParamBinding> buildWhereForSearch(StringBuilder queryStrBldr) {
48
49         List<ParamBinding> paramList = new ArrayList<ParamBinding>();
50         String screenName = null;
51         List<String> snvals = getQueryParam(AccountStorageConstants.Q_SCREEN_NAME);
52         if (null != snvals && snvals.size() > 0) {
53             screenName = snvals.get(0);
54         }
55         queryStrBldr.append(addTenant(false, paramList));
56         if (null != screenName && !screenName.isEmpty()) {
57             queryStrBldr.append(" AND");
58             queryStrBldr.append(" UPPER(a." + AccountStorageConstants.SCREEN_NAME + ")");
59             queryStrBldr.append(" LIKE");
60             queryStrBldr.append(" :" + AccountStorageConstants.Q_SCREEN_NAME);
61             paramList.add(new ParamBinding(AccountStorageConstants.Q_SCREEN_NAME, "%"
62                     + screenName.toUpperCase() + "%"));
63         }
64
65         String uid = null;
66         List<String> uidvals = getQueryParam(AccountStorageConstants.Q_USER_ID);
67         if (null != uidvals && uidvals.size() > 0) {
68             uid = uidvals.get(0);
69         }
70         if (null != uid && !uid.isEmpty()) {
71             queryStrBldr.append(" AND");
72             queryStrBldr.append(" UPPER(a." + AccountStorageConstants.USER_ID + ")");
73             queryStrBldr.append(" LIKE");
74             queryStrBldr.append(" :" + AccountStorageConstants.Q_USER_ID);
75             paramList.add(new ParamBinding(AccountStorageConstants.Q_USER_ID, "%"
76                     + uid.toUpperCase() + "%"));
77         }
78
79         String email = null;
80         List<String> emailvals = getQueryParam(AccountStorageConstants.Q_EMAIL);
81         if (null != emailvals && emailvals.size() > 0) {
82             email = emailvals.get(0);
83         }
84         if (null != email && !email.isEmpty()) {
85
86             queryStrBldr.append(" AND");
87             queryStrBldr.append(" UPPER(a." + AccountStorageConstants.EMAIL + ")");
88             queryStrBldr.append(" LIKE");
89             queryStrBldr.append(" :" + AccountStorageConstants.Q_EMAIL);
90             paramList.add(new ParamBinding(AccountStorageConstants.Q_EMAIL, "%"
91                     + email.toUpperCase() + "%"));
92         }
93         
94         if (logger.isDebugEnabled()) {
95             String query = queryStrBldr.toString();
96             logger.debug("query=" + query);
97         }
98
99         return paramList;
100     }
101
102     @Override
103     public List<ParamBinding> buildWhere(StringBuilder queryStrBldr) {
104         return new ArrayList<ParamBinding>();
105     }
106
107     @Override
108     protected String addTenant(boolean append, List<ParamBinding> paramList) {
109         String whereClause = " JOIN a.tenants as at WHERE at.tenantId = :tenantId";
110         paramList.add(new ParamBinding("tenantId", getTenantId()));
111         return whereClause;
112     }
113 }