]> git.aero2k.de Git - tmp/jakarta-migration.git/blob
3e87d65ce4bf20bad53c3012e851092b9f11241a
[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         boolean hasWhere = false;
51         //TODO: add tenant id
52
53         String screenName = null;
54         List<String> snvals = getQueryParam(AccountStorageConstants.Q_SCREEN_NAME);
55         if (snvals != null) {
56             screenName = snvals.get(0);
57         }
58         if (null != screenName && !screenName.isEmpty()) {
59             hasWhere = true;
60             queryStrBldr.append(" WHERE");
61             queryStrBldr.append(" UPPER(a." + AccountStorageConstants.SCREEN_NAME + ")");
62             queryStrBldr.append(" LIKE");
63             queryStrBldr.append(" :" + AccountStorageConstants.Q_SCREEN_NAME);
64             paramList.add(new ParamBinding(AccountStorageConstants.Q_SCREEN_NAME, "%"
65                     + screenName.toUpperCase() + "%"));
66         }
67
68         String uid = null;
69         List<String> uidvals = getQueryParam(AccountStorageConstants.Q_USER_ID);
70         if (uidvals != null) {
71             uid = uidvals.get(0);
72         }
73         if (null != uid && !uid.isEmpty()) {
74             if (hasWhere) {
75                 queryStrBldr.append(" AND");
76             } else {
77                 queryStrBldr.append(" WHERE");
78             }
79             queryStrBldr.append(" UPPER(a." + AccountStorageConstants.USER_ID + ")");
80             queryStrBldr.append(" LIKE");
81             queryStrBldr.append(" :" + AccountStorageConstants.Q_USER_ID);
82             paramList.add(new ParamBinding(AccountStorageConstants.Q_USER_ID, "%"
83                     + uid.toUpperCase() + "%"));
84             hasWhere = true;
85         }
86
87         String email = null;
88         List<String> emailvals = getQueryParam(AccountStorageConstants.Q_EMAIL);
89         if (emailvals != null) {
90             email = emailvals.get(0);
91         }
92         if (null != email && !email.isEmpty()) {
93             if (hasWhere) {
94                 queryStrBldr.append(" AND");
95             } else {
96                 queryStrBldr.append(" WHERE");
97             }
98             queryStrBldr.append(" UPPER(a." + AccountStorageConstants.EMAIL + ")");
99             queryStrBldr.append(" LIKE");
100             queryStrBldr.append(" :" + AccountStorageConstants.Q_EMAIL);
101             paramList.add(new ParamBinding(AccountStorageConstants.Q_EMAIL, "%"
102                     + email.toUpperCase() + "%"));
103             hasWhere = true;
104         }
105
106         if (logger.isDebugEnabled()) {
107             logger.debug("query=" + queryStrBldr.toString());
108         }
109
110         return paramList;
111     }
112
113     @Override
114     public List<ParamBinding> buildWhere(StringBuilder queryStrBldr) {
115         return new ArrayList<ParamBinding>();
116     }
117 }