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