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:
6 * http://www.collectionspace.org
7 * http://wiki.collectionspace.org
9 * Copyright 2009 University of California at Berkeley
11 * Licensed under the Educational Community License (ECL), Version 2.0.
12 * You may not use this file except in compliance with this License.
14 * You may obtain a copy of the ECL 2.0 License at
16 * https://source.collectionspace.org/collection-space/LICENSE.txt
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.
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:
28 * http://www.collectionspace.org
29 * http://wiki.collectionspace.org
31 * Copyright 2009 University of California at Berkeley
33 * Licensed under the Educational Community License (ECL), Version 2.0.
34 * You may not use this file except in compliance with this License.
36 * You may obtain a copy of the ECL 2.0 License at
38 * https://source.collectionspace.org/collection-space/LICENSE.txt
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.
47 * To change this template, choose Tools | Templates
48 * and open the template in the editor.
50 package org.collectionspace.services.account.storage;
52 import java.util.ArrayList;
53 import java.util.List;
54 import org.collectionspace.services.common.storage.jpa.JpaDocumentFilter;
55 import org.slf4j.Logger;
56 import org.slf4j.LoggerFactory;
62 public class AccountJpaFilter extends JpaDocumentFilter {
64 private final Logger logger = LoggerFactory.getLogger(AccountJpaFilter.class);
67 public List<ParamBinding> buildWhereForSearch(StringBuilder queryStrBldr) {
69 List<ParamBinding> paramList = new ArrayList<ParamBinding>();
70 boolean hasWhere = false;
73 String screenName = null;
74 List<String> snvals = getQueryParam(AccountStorageConstants.Q_SCREEN_NAME);
76 screenName = snvals.get(0);
78 if (null != screenName && !screenName.isEmpty()) {
80 queryStrBldr.append(" WHERE");
81 queryStrBldr.append(" UPPER(a." + AccountStorageConstants.SCREEN_NAME + ")");
82 queryStrBldr.append(" LIKE");
83 queryStrBldr.append(" :" + AccountStorageConstants.Q_SCREEN_NAME);
84 paramList.add(new ParamBinding(AccountStorageConstants.Q_SCREEN_NAME, "%"
85 + screenName.toUpperCase() + "%"));
89 List<String> uidvals = getQueryParam(AccountStorageConstants.Q_USER_ID);
90 if (uidvals != null) {
93 if (null != uid && !uid.isEmpty()) {
95 queryStrBldr.append(" AND");
97 queryStrBldr.append(" WHERE");
99 queryStrBldr.append(" UPPER(a." + AccountStorageConstants.USER_ID + ")");
100 queryStrBldr.append(" LIKE");
101 queryStrBldr.append(" :" + AccountStorageConstants.Q_USER_ID);
102 paramList.add(new ParamBinding(AccountStorageConstants.Q_USER_ID, "%"
103 + uid.toUpperCase() + "%"));
108 List<String> emailvals = getQueryParam(AccountStorageConstants.Q_EMAIL);
109 if (emailvals != null) {
110 email = emailvals.get(0);
112 if (null != email && !email.isEmpty()) {
114 queryStrBldr.append(" AND");
116 queryStrBldr.append(" WHERE");
118 queryStrBldr.append(" UPPER(a." + AccountStorageConstants.EMAIL + ")");
119 queryStrBldr.append(" LIKE");
120 queryStrBldr.append(" :" + AccountStorageConstants.Q_EMAIL);
121 paramList.add(new ParamBinding(AccountStorageConstants.Q_EMAIL, "%"
122 + email.toUpperCase() + "%"));
126 if (logger.isDebugEnabled()) {
127 logger.debug("query=" + queryStrBldr.toString());
134 public List<ParamBinding> buildWhere(StringBuilder queryStrBldr) {
135 return new ArrayList<ParamBinding>();