Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * Copyright 2012 JBoss by Red Hat.
   *
   * Licensed under the Apache License, Version 2.0 (the "License");
   * you may not use this file except in compliance with the License.
   * You may obtain a copy of the License at
   *
   *      http://www.apache.org/licenses/LICENSE-2.0
   *
  * Unless required by applicable law or agreed to in writing, software
  * distributed under the License is distributed on an "AS IS" BASIS,
  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  * See the License for the specific language governing permissions and
  * limitations under the License.
  */
 
 package org.jbpm.services.task.persistence;
 
 import static org.kie.internal.query.QueryParameterIdentifiers.*;
 import java.util.Map;
 
 
 import  org.slf4j.Logger;
 import  org.slf4j.LoggerFactory;
 
 public class TaskQueryManager {
 	
 	private static final Logger logger = LoggerFactory.getLogger(TaskQueryManager.class);
 	
 	private Map<StringStringqueries = new ConcurrentHashMap<StringString>();
 	
 	private static TaskQueryManager instance = new TaskQueryManager();
 	
 	public static TaskQueryManager get() {
 		return ;
 	}
 	
 	protected TaskQueryManager() {
 		addNamedQueries("META-INF/Taskorm.xml");
 	}
 
 	public synchronized void addNamedQueries(String ormFile) {
 		try {
 			parse(ormFile);
 		} catch (Exception e) {
 			.debug("TaskQueryManager unable to read Taskorm file due to " + e.getMessage(), e);
 			.warn("TaskQueryManager unable to read Taskorm file due to " + e.getMessage());
 		}
 	}
 	
 	public String getQuery(String nameMap<StringObjectparams) {
 		String query = null;
 		if (!.containsKey(name)) {
 			return null;
 		}
 		StringBuilder buf = new StringBuilder(.get(name)); 
 		query = adaptQueryString(bufparams);
 		
 		return query;
 	}
 
 	public static String adaptQueryString(StringBuilder bufMap<StringObjectparams) { 
 	    StringBuilder query = null;
         if (params != null && params.containsKey(FILTER)) {
             buf.append(" and " + params.get(FILTER));
             query = buf;
         }
         if (params != null && params.containsKey(ORDER_BY)) {
             buf.append(" ORDER BY " + adaptOrderBy((Stringparams.get(ORDER_BY)));
             Object orderTypeObj = params.get(ORDER_TYPE);
             if (orderTypeObj != null ) { 
                 buf.append(" ").append(orderTypeObj);
             }
             query = buf;
         }
         return (query == null ? null : query.toString() );
 	}
 	
 	protected void parse(String ormFilethrows XMLStreamException {
 		String name = null;
 		StringBuilder tagContent = new StringBuilder();
 		XMLInputFactory factory = XMLInputFactory.newInstance();
 
 		while (reader.hasNext()) {
 			int event = reader.next();
 
 			switch (event) {
 				if ("named-query".equals(reader.getLocalName())) {
 
 					name = reader.getAttributeValue(0);
 				}
				break;
				if (name != null) {
					tagContent.append(" " + reader.getText().trim());
				}
				break;
				if ("named-query".equals(reader.getLocalName())) {
					String origQuery = tagContent.toString();
					String alteredQuery = origQuery;
					int orderByIndex = origQuery.toLowerCase().indexOf("order by");
					if (orderByIndex != -1) {
						// remove order by clause as it will be provided on request
						alteredQuery = origQuery.substring(0, orderByIndex);
					}
					.put(namealteredQuery);
					name = null;
					tagContent = new StringBuilder();
				}
				break;
			}
		}
	}
	private static String adaptOrderBy(String orderBy) {
		if (orderBy != null) {
			if (orderBy.equals("Task")) {
				return "t.name";
else if (orderBy.equals("Description")) {
				return "t.description";
else if (orderBy.equals("Id")) {
				return "t.id";
else if (orderBy.equals("Priority")) {
				return "t.priority";
else if (orderBy.equals("Status")) {
				return "t.taskData.status";
else if (orderBy.equals("CreatedOn")) {
				return "t.taskData.createdOn";
else if (orderBy.equals("CreatedBy")) {
				return "t.taskData.createdBy.id";
else if (orderBy.equals("DueOn")) {
				return "t.taskData.expirationTime";
else if (orderBy.equals("ProcessInstanceId")) {
				return "t.taskData.processInstanceId";
		}
		return orderBy;
	}
New to GrepCode? Check out our FAQ X