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.authorization.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;
59 * RoleJpaFilter is to build where clause for role queries
62 public class RoleJpaFilter extends JpaDocumentFilter {
64 private final Logger logger = LoggerFactory.getLogger(RoleJpaFilter.class);
67 public List<ParamBinding> buildWhereForSearch(StringBuilder queryStrBldr) {
69 List<ParamBinding> paramList = new ArrayList<ParamBinding>();
70 boolean hasWhere = false;
73 String roleName = null;
74 List<String> rn = getQueryParam(RoleStorageConstants.Q_ROLE_NAME);
78 if (null != roleName && !roleName.isEmpty()) {
80 queryStrBldr.append(" WHERE");
81 queryStrBldr.append(" UPPER(a." + RoleStorageConstants.ROLE_NAME + ")");
82 queryStrBldr.append(" LIKE");
83 queryStrBldr.append(" :" + RoleStorageConstants.Q_ROLE_NAME);
84 paramList.add(new ParamBinding(RoleStorageConstants.Q_ROLE_NAME, "%"
85 + roleName.toUpperCase() + "%"));
88 if (logger.isDebugEnabled()) {
89 String query = queryStrBldr.toString();
90 logger.debug("query=" + query);
97 public List<ParamBinding> buildWhere(StringBuilder queryStrBldr) {
98 return new ArrayList<ParamBinding>();