1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34 package info.magnolia.cms.util;
35
36 import info.magnolia.cms.core.Content;
37 import info.magnolia.cms.core.ItemType;
38 import info.magnolia.cms.core.search.Query;
39 import info.magnolia.cms.core.search.QueryManager;
40 import info.magnolia.cms.core.search.QueryResult;
41 import info.magnolia.context.MgnlContext;
42 import org.apache.commons.lang.time.DateFormatUtils;
43 import org.apache.commons.lang.time.DateUtils;
44 import org.slf4j.Logger;
45 import org.slf4j.LoggerFactory;
46
47 import javax.jcr.RepositoryException;
48 import java.util.Calendar;
49 import java.util.Collection;
50 import java.util.Collections;
51
52
53
54
55
56
57
58 public class QueryUtil {
59 private static Logger log = LoggerFactory.getLogger(QueryUtil.class);
60
61
62
63
64 public static Collection<Content> query(String repository, String statement){
65 return query(repository,statement, Query.SQL);
66 }
67
68
69
70
71 public static Collection<Content> query(String repository, String statement, String language){
72 return query(repository,statement,language, ItemType.NT_BASE);
73 }
74
75
76
77
78 public static Collection<Content> exceptionThrowingQuery(String repository, String statement, String language, String returnItemType) throws RepositoryException {
79 QueryManager qm = MgnlContext.getQueryManager(repository);
80 Query query= qm.createQuery(statement, language);
81 QueryResult result = query.execute();
82 return result.getContent(returnItemType);
83 }
84
85
86
87
88 @SuppressWarnings("unchecked")
89 public static Collection<Content> query(String repository, String statement, String language, String returnItemType) {
90 try {
91 return exceptionThrowingQuery(repository, statement, language, returnItemType);
92 } catch (Exception e) {
93 log.error("can't execute query [" + statement + "], will return empty collection", e);
94 }
95 return Collections.EMPTY_LIST;
96 }
97
98
99
100
101 public static String createDateExpression(int year, int month, int day) {
102 Calendar cal = Calendar.getInstance();
103 cal.set(year, month - 1, day);
104 return createDateExpression(cal);
105 }
106
107
108
109
110 public static String createDateExpression(Calendar calendar) {
111 return "DATE '" + DateFormatUtils.format(calendar.getTimeInMillis(), "yyyy-MM-dd", calendar.getTimeZone()) + "'";
112 }
113
114
115
116
117 public static String createDateTimeExpression(int year, int month, int day, int hour, int minutes, int seconds) {
118 Calendar cal = Calendar.getInstance();
119 cal.set(year, month - 1, day, hour, minutes, seconds);
120 return createDateTimeExpression(cal);
121 }
122
123
124
125
126 public static String createDateTimeExpression(Calendar calendar) {
127 calendar.set(Calendar.MILLISECOND, 0);
128 StringBuffer str = new StringBuffer("TIMESTAMP '");
129 str.append(DateFormatUtils.format(calendar.getTime(), "yyyy-MM-dd'T'HH:mm:ss.SSSZ", calendar.getTimeZone()));
130 str.insert(str.length()-2, ":");
131 str.append("'");
132 return str.toString();
133 }
134
135
136
137
138 public static String createDateTimeExpressionIgnoreTimeZone(int year, int month, int day, int hour, int minutes, int seconds) {
139 Calendar cal = Calendar.getInstance(DateUtils.UTC_TIME_ZONE);
140 cal.set(year, month - 1, day, hour, minutes, seconds);
141 return createDateTimeExpression(cal);
142 }
143
144
145
146
147 public static String createDateTimeExpressionIgnoreTimeZone(Calendar calendar) {
148 Calendar utc = Calendar.getInstance(DateUtils.UTC_TIME_ZONE);
149 utc.setTimeInMillis(calendar.getTimeInMillis() + calendar.getTimeZone().getRawOffset());
150 return createDateTimeExpression(utc);
151 }
152 }