annotate src/main/java/org/mpi/openmind/cache/WrapperService.java @ 1:615d27dce9b3

(none)
author jurzua
date Wed, 29 Oct 2014 13:28:45 +0000
parents
children ac2fd7a4378d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
jurzua
parents:
diff changeset
1 package org.mpi.openmind.cache;
jurzua
parents:
diff changeset
2
jurzua
parents:
diff changeset
3 import java.io.Serializable;
jurzua
parents:
diff changeset
4 import java.lang.management.ManagementFactory;
jurzua
parents:
diff changeset
5 import java.util.ArrayList;
jurzua
parents:
diff changeset
6 import java.util.Collection;
jurzua
parents:
diff changeset
7 import java.util.Collections;
jurzua
parents:
diff changeset
8 import java.util.HashMap;
jurzua
parents:
diff changeset
9 import java.util.List;
jurzua
parents:
diff changeset
10 import java.util.Map;
jurzua
parents:
diff changeset
11
jurzua
parents:
diff changeset
12 import org.apache.commons.lang.StringUtils;
jurzua
parents:
diff changeset
13 import org.apache.log4j.Logger;
jurzua
parents:
diff changeset
14 import org.mpi.openmind.repository.bo.Attribute;
jurzua
parents:
diff changeset
15 import org.mpi.openmind.repository.bo.Entity;
jurzua
parents:
diff changeset
16 import org.mpi.openmind.repository.bo.Node;
jurzua
parents:
diff changeset
17 import org.mpi.openmind.repository.bo.Relation;
jurzua
parents:
diff changeset
18 import org.mpi.openmind.repository.bo.ViewerAttribute;
jurzua
parents:
diff changeset
19 import org.mpi.openmind.repository.bo.ViewerPage;
jurzua
parents:
diff changeset
20 import org.mpi.openmind.repository.bo.utils.EntitySortByNormalizedOwnValue;
jurzua
parents:
diff changeset
21 import org.mpi.openmind.repository.bo.utils.EntitySortByVersion;
jurzua
parents:
diff changeset
22 import org.mpi.openmind.repository.bo.utils.RelationSortBySourceOW;
jurzua
parents:
diff changeset
23 import org.mpi.openmind.repository.bo.utils.RelationSortByTargetOW;
jurzua
parents:
diff changeset
24 import org.mpi.openmind.repository.services.PersistenceService;
jurzua
parents:
diff changeset
25 import org.mpi.openmind.repository.services.utils.AttributeFilter;
jurzua
parents:
diff changeset
26 import org.mpi.openmind.repository.utils.ImportOM3Util;
jurzua
parents:
diff changeset
27 import org.mpi.openmind.repository.utils.NormalizerUtils;
jurzua
parents:
diff changeset
28
jurzua
parents:
diff changeset
29 public class WrapperService implements Serializable{
jurzua
parents:
diff changeset
30
jurzua
parents:
diff changeset
31 private static final long serialVersionUID = 2578074607841626396L;
jurzua
parents:
diff changeset
32
jurzua
parents:
diff changeset
33 public static final String IS_TYPE_OF = "is_type_of";
jurzua
parents:
diff changeset
34
jurzua
parents:
diff changeset
35 private static Logger logger = Logger.getLogger(WrapperService.class);
jurzua
parents:
diff changeset
36
jurzua
parents:
diff changeset
37 private transient CacheService cache;
jurzua
parents:
diff changeset
38
jurzua
parents:
diff changeset
39 public long getSourceRelationsCount(Entity entity, String relationName,
jurzua
parents:
diff changeset
40 String tarObjClass) {
jurzua
parents:
diff changeset
41 return this.getPS().getSourceRelationsCount(entity, relationName,
jurzua
parents:
diff changeset
42 tarObjClass);
jurzua
parents:
diff changeset
43 }
jurzua
parents:
diff changeset
44
jurzua
parents:
diff changeset
45 public Long getTargetRelationsCount(Entity entity, String relationName,
jurzua
parents:
diff changeset
46 String srcObjClass) {
jurzua
parents:
diff changeset
47 return this.getPS().getTargetRelationsCount(entity, relationName,
jurzua
parents:
diff changeset
48 srcObjClass);
jurzua
parents:
diff changeset
49 }
jurzua
parents:
diff changeset
50
jurzua
parents:
diff changeset
51 public Map<Entity, Attribute> searchEntityByAttributeFilter(
jurzua
parents:
diff changeset
52 List<AttributeFilter> filters, int maxResult) {
jurzua
parents:
diff changeset
53 return this.getPS().searchEntityByAttributeFilter(filters, maxResult);
jurzua
parents:
diff changeset
54 }
jurzua
parents:
diff changeset
55
jurzua
parents:
diff changeset
56 public Map<Attribute, Entity> searchAttEntityByAttributeFilter(
jurzua
parents:
diff changeset
57 List<AttributeFilter> filters, int maxResult) {
jurzua
parents:
diff changeset
58 return this.getPS()
jurzua
parents:
diff changeset
59 .searchAttEntityByAttributeFilter(filters, maxResult);
jurzua
parents:
diff changeset
60 }
jurzua
parents:
diff changeset
61
jurzua
parents:
diff changeset
62 public List<Entity> searchEntityByOwnValue(String oc, String term){
jurzua
parents:
diff changeset
63 List<Entity> rs = new ArrayList<Entity>();
jurzua
parents:
diff changeset
64 if(StringUtils.isEmpty(term))
jurzua
parents:
diff changeset
65 return rs;
jurzua
parents:
diff changeset
66
jurzua
parents:
diff changeset
67 List<Entity> entList = this.cache.getEntitiesByDef(oc);
jurzua
parents:
diff changeset
68 term = NormalizerUtils.normalize(term);
jurzua
parents:
diff changeset
69
jurzua
parents:
diff changeset
70 for(Entity ent : entList){
jurzua
parents:
diff changeset
71 if(StringUtils.isNotEmpty(ent.getNormalizedOwnValue()) &&
jurzua
parents:
diff changeset
72 StringUtils.contains(ent.getNormalizedOwnValue(), term)){
jurzua
parents:
diff changeset
73 rs.add(ent);
jurzua
parents:
diff changeset
74 }
jurzua
parents:
diff changeset
75 }
jurzua
parents:
diff changeset
76 return rs;
jurzua
parents:
diff changeset
77 }
jurzua
parents:
diff changeset
78
jurzua
parents:
diff changeset
79 // ************************************************************
jurzua
parents:
diff changeset
80 // ************************************************************
jurzua
parents:
diff changeset
81 // ************************************************************
jurzua
parents:
diff changeset
82 // ************************************************************
jurzua
parents:
diff changeset
83
jurzua
parents:
diff changeset
84 public List<Entity> getPreviousEntitiesById(Long id) {
jurzua
parents:
diff changeset
85 List<Entity> list = this.getPS().getEntities(id,
jurzua
parents:
diff changeset
86 Node.SYS_STATUS_PREVIOUS_VERSION, null, null);
jurzua
parents:
diff changeset
87 Collections.sort(list, new EntitySortByVersion());
jurzua
parents:
diff changeset
88 return list;
jurzua
parents:
diff changeset
89 }
jurzua
parents:
diff changeset
90
jurzua
parents:
diff changeset
91 public void initCache() {
jurzua
parents:
diff changeset
92 logger.info("##### Initializing Cache #####");
jurzua
parents:
diff changeset
93 logger.info(ManagementFactory.getRuntimeMXBean().getName());
jurzua
parents:
diff changeset
94
jurzua
parents:
diff changeset
95 try {
jurzua
parents:
diff changeset
96 int mb = 1024 * 1024;
jurzua
parents:
diff changeset
97
jurzua
parents:
diff changeset
98 // Getting the runtime reference from system
jurzua
parents:
diff changeset
99 Runtime runtime = Runtime.getRuntime();
jurzua
parents:
diff changeset
100
jurzua
parents:
diff changeset
101 logger.info("##### Heap utilization statistics [MB] #####");
jurzua
parents:
diff changeset
102
jurzua
parents:
diff changeset
103 // Print used memory
jurzua
parents:
diff changeset
104 logger.info("Used Memory:"
jurzua
parents:
diff changeset
105 + (runtime.totalMemory() - runtime.freeMemory()) / mb);
jurzua
parents:
diff changeset
106
jurzua
parents:
diff changeset
107 // Print free memory
jurzua
parents:
diff changeset
108 logger.info("Free Memory:" + runtime.freeMemory() / mb);
jurzua
parents:
diff changeset
109
jurzua
parents:
diff changeset
110 // Print total available memory
jurzua
parents:
diff changeset
111 logger.info("Total Memory:" + runtime.totalMemory() / mb);
jurzua
parents:
diff changeset
112
jurzua
parents:
diff changeset
113 // Print Maximum available memory
jurzua
parents:
diff changeset
114 logger.info("Max Memory:" + runtime.maxMemory() / mb + "\n");
jurzua
parents:
diff changeset
115 } catch (Exception e) {
jurzua
parents:
diff changeset
116 e.printStackTrace();
jurzua
parents:
diff changeset
117 }
jurzua
parents:
diff changeset
118
jurzua
parents:
diff changeset
119 if (!this.cache.areDefsLoaded()) {
jurzua
parents:
diff changeset
120 // List<Entity> list = this.searchServ.getEntities(null,
jurzua
parents:
diff changeset
121 // Node.SYS_STATUS_CURRENT_VERSION, Node.TYPE_TBOX, null);
jurzua
parents:
diff changeset
122 // this.cache.initDefs(list);
jurzua
parents:
diff changeset
123 try {
jurzua
parents:
diff changeset
124 this.cache.initDefinitions(getPS().getLWDefinitions(), getPS()
jurzua
parents:
diff changeset
125 .getDefAttributes(), getPS().getDefRelations());
jurzua
parents:
diff changeset
126 } catch (Exception e) {
jurzua
parents:
diff changeset
127 e.printStackTrace();
jurzua
parents:
diff changeset
128 }
jurzua
parents:
diff changeset
129 }
jurzua
parents:
diff changeset
130 }
jurzua
parents:
diff changeset
131
jurzua
parents:
diff changeset
132 public void removeCurrentVersionEntity(Entity entity) throws Exception {
jurzua
parents:
diff changeset
133 logger.info("removeCurrentVersionEntity " + entity);
jurzua
parents:
diff changeset
134 this.cache.deleteEntity(entity.getId(), entity.getObjectClass());
jurzua
parents:
diff changeset
135 this.getPS().removeEntCurrentVersion(entity.getId(), entity.getType());
jurzua
parents:
diff changeset
136 System.gc();
jurzua
parents:
diff changeset
137 }
jurzua
parents:
diff changeset
138
jurzua
parents:
diff changeset
139 public Map<Entity, Attribute> searchEntityByAttributeFilter0(String term,
jurzua
parents:
diff changeset
140 List<AttributeFilter> filters, int maxResults) {
jurzua
parents:
diff changeset
141 Map<Entity, Attribute> map = new HashMap<Entity, Attribute>();
jurzua
parents:
diff changeset
142 List<Long> usedIds = new ArrayList<Long>();
jurzua
parents:
diff changeset
143
jurzua
parents:
diff changeset
144 boolean mustBreak = false;
jurzua
parents:
diff changeset
145 int count = 0;
jurzua
parents:
diff changeset
146 if (StringUtils.isNotEmpty(term)) {
jurzua
parents:
diff changeset
147 String normalizedTerm = NormalizerUtils.normalize(term);
jurzua
parents:
diff changeset
148 for (AttributeFilter filter : filters) {
jurzua
parents:
diff changeset
149 if (mustBreak) {
jurzua
parents:
diff changeset
150 break;
jurzua
parents:
diff changeset
151 }
jurzua
parents:
diff changeset
152 for (Attribute att : getAttributesByDefByAttName(
jurzua
parents:
diff changeset
153 filter.getEntObjectClass(), filter.getName(), -1)) {
jurzua
parents:
diff changeset
154 if (!usedIds.contains(att.getSourceId())
jurzua
parents:
diff changeset
155 && StringUtils.isNotEmpty(att
jurzua
parents:
diff changeset
156 .getNormalizedOwnValue())
jurzua
parents:
diff changeset
157 && att.getNormalizedOwnValue().contains(
jurzua
parents:
diff changeset
158 normalizedTerm)) {
jurzua
parents:
diff changeset
159 map.put(getEntityById(att.getSourceId()), att);
jurzua
parents:
diff changeset
160 usedIds.add(att.getSourceId());
jurzua
parents:
diff changeset
161 count++;
jurzua
parents:
diff changeset
162 if (maxResults > 0 && count == maxResults) {
jurzua
parents:
diff changeset
163 mustBreak = true;
jurzua
parents:
diff changeset
164 break;
jurzua
parents:
diff changeset
165 }
jurzua
parents:
diff changeset
166 }
jurzua
parents:
diff changeset
167 }
jurzua
parents:
diff changeset
168 }
jurzua
parents:
diff changeset
169 }
jurzua
parents:
diff changeset
170 return map;
jurzua
parents:
diff changeset
171 }
jurzua
parents:
diff changeset
172
jurzua
parents:
diff changeset
173 public int getEntitiesCount(String def) {
jurzua
parents:
diff changeset
174 int count = this.cache.getEntitiesCount(def);
jurzua
parents:
diff changeset
175 return count;
jurzua
parents:
diff changeset
176 }
jurzua
parents:
diff changeset
177
jurzua
parents:
diff changeset
178 public List<Entity> getEntityByDefSubList(String def, int fromIndex,
jurzua
parents:
diff changeset
179 int toIndex) {
jurzua
parents:
diff changeset
180 List<Entity> list = new ArrayList<Entity>();
jurzua
parents:
diff changeset
181 List<Entity> all = getEntitiesByDef(def);
jurzua
parents:
diff changeset
182 if (all != null && all.size() >= toIndex) {
jurzua
parents:
diff changeset
183
jurzua
parents:
diff changeset
184 long start = System.currentTimeMillis();
jurzua
parents:
diff changeset
185 Collections.sort(list, new EntitySortByNormalizedOwnValue());
jurzua
parents:
diff changeset
186 long diff = System.currentTimeMillis() - start;
jurzua
parents:
diff changeset
187 logger.info("Sorting entities time[ms] " + diff);
jurzua
parents:
diff changeset
188
jurzua
parents:
diff changeset
189 for (Entity ent : all.subList(fromIndex, toIndex)) {
jurzua
parents:
diff changeset
190 list.add(ent);
jurzua
parents:
diff changeset
191 }
jurzua
parents:
diff changeset
192 }
jurzua
parents:
diff changeset
193 return list;
jurzua
parents:
diff changeset
194 }
jurzua
parents:
diff changeset
195
jurzua
parents:
diff changeset
196 public List<Entity> getEntitiesByDef(String def) {
jurzua
parents:
diff changeset
197 List<Entity> list = this.cache.getEntitiesByDef(def);
jurzua
parents:
diff changeset
198 return list;
jurzua
parents:
diff changeset
199 }
jurzua
parents:
diff changeset
200
jurzua
parents:
diff changeset
201 public List<Entity> getEntityByDefAndOW(String def, String ow,
jurzua
parents:
diff changeset
202 int maxResults) {
jurzua
parents:
diff changeset
203 List<Entity> result = new ArrayList<Entity>();
jurzua
parents:
diff changeset
204 if (StringUtils.isNotEmpty(ow)) {
jurzua
parents:
diff changeset
205 List<Entity> list = this.cache.getEntitiesByDef(def);
jurzua
parents:
diff changeset
206
jurzua
parents:
diff changeset
207 int count = 0;
jurzua
parents:
diff changeset
208 ow = NormalizerUtils.normalize(ow);
jurzua
parents:
diff changeset
209 for (Entity e : list) {
jurzua
parents:
diff changeset
210 // String eow = (StringUtils.isNotEmpty(e.getOwnValue())) ?
jurzua
parents:
diff changeset
211 // e.getOwnValue().toLowerCase() : "";
jurzua
parents:
diff changeset
212 if (StringUtils.isNotBlank(e.getNormalizedOwnValue())
jurzua
parents:
diff changeset
213 && e.getNormalizedOwnValue().contains(ow)) {
jurzua
parents:
diff changeset
214 result.add((Entity) e.clone());
jurzua
parents:
diff changeset
215 count++;
jurzua
parents:
diff changeset
216 }
jurzua
parents:
diff changeset
217
jurzua
parents:
diff changeset
218 if (maxResults > 0 && maxResults == count) {
jurzua
parents:
diff changeset
219 break;
jurzua
parents:
diff changeset
220 }
jurzua
parents:
diff changeset
221 }
jurzua
parents:
diff changeset
222 }
jurzua
parents:
diff changeset
223 return result;
jurzua
parents:
diff changeset
224 }
jurzua
parents:
diff changeset
225
jurzua
parents:
diff changeset
226 /**
jurzua
parents:
diff changeset
227 * this method does not execute: - ownValue generation - new version
jurzua
parents:
diff changeset
228 * generation This method only save the entity in the current state.
jurzua
parents:
diff changeset
229 *
jurzua
parents:
diff changeset
230 * @param nodeList
jurzua
parents:
diff changeset
231 * @param user
jurzua
parents:
diff changeset
232 */
jurzua
parents:
diff changeset
233 public void saveEntityListAsNode(List<Entity> entList, String user) {
jurzua
parents:
diff changeset
234 for (Entity ent : entList) {
jurzua
parents:
diff changeset
235 ent.setUser(user);
jurzua
parents:
diff changeset
236 }
jurzua
parents:
diff changeset
237 getPS().saveEntityListAsNode(entList);
jurzua
parents:
diff changeset
238 for (Entity ent : entList) {
jurzua
parents:
diff changeset
239 cache.saveEntity(ent);
jurzua
parents:
diff changeset
240 }
jurzua
parents:
diff changeset
241 }
jurzua
parents:
diff changeset
242
jurzua
parents:
diff changeset
243 public void saveEntityListAsNodeWithoutContent(List<Entity> nodeList,
jurzua
parents:
diff changeset
244 String user) throws Exception {
jurzua
parents:
diff changeset
245 this.cache.saveEntityListAsNodeWithoutContent(nodeList);
jurzua
parents:
diff changeset
246 }
jurzua
parents:
diff changeset
247
jurzua
parents:
diff changeset
248 public boolean existEntity(Long entId) {
jurzua
parents:
diff changeset
249 return getCache().getEntityByIdReadOnly(entId) != null;
jurzua
parents:
diff changeset
250 }
jurzua
parents:
diff changeset
251
jurzua
parents:
diff changeset
252 public boolean existRelation(Long srcId, Long tarId, String relName) {
jurzua
parents:
diff changeset
253
jurzua
parents:
diff changeset
254 try {
jurzua
parents:
diff changeset
255 if (srcId == null || tarId == null) {
jurzua
parents:
diff changeset
256 throw new Exception("srcId and tarId can not be null.");
jurzua
parents:
diff changeset
257 }
jurzua
parents:
diff changeset
258
jurzua
parents:
diff changeset
259 List<Relation> relList = this.cache.getRelsBySrcId(srcId);
jurzua
parents:
diff changeset
260
jurzua
parents:
diff changeset
261 for (Relation rel : relList) {
jurzua
parents:
diff changeset
262 if (rel.getTargetId().equals(tarId)
jurzua
parents:
diff changeset
263 && rel.getOwnValue().equals(relName))
jurzua
parents:
diff changeset
264 return true;
jurzua
parents:
diff changeset
265 }
jurzua
parents:
diff changeset
266 } catch (Exception e) {
jurzua
parents:
diff changeset
267 e.printStackTrace();
jurzua
parents:
diff changeset
268 }
jurzua
parents:
diff changeset
269
jurzua
parents:
diff changeset
270 return false;
jurzua
parents:
diff changeset
271 }
jurzua
parents:
diff changeset
272
jurzua
parents:
diff changeset
273 public void saveRelationAsNode(Relation rel, String user) throws Exception {
jurzua
parents:
diff changeset
274
jurzua
parents:
diff changeset
275 if (rel.getAttributes() != null && rel.getAttributes().size() > 0) {
jurzua
parents:
diff changeset
276 throw new Exception(
jurzua
parents:
diff changeset
277 "This method can be only used if the relation does not contains attributes, this is not the case.");
jurzua
parents:
diff changeset
278 }
jurzua
parents:
diff changeset
279
jurzua
parents:
diff changeset
280 rel.setUser(user);
jurzua
parents:
diff changeset
281 this.getPS().saveNode(rel);
jurzua
parents:
diff changeset
282 this.cache.updateRelationAsNode(rel);
jurzua
parents:
diff changeset
283 }
jurzua
parents:
diff changeset
284
jurzua
parents:
diff changeset
285 public List<Entity> searchEntityByAttributeOfTarRelation(String objClass,
jurzua
parents:
diff changeset
286 String relName, String objClassSrc, String attName,
jurzua
parents:
diff changeset
287 String attValue, int maxResults) throws Exception {
jurzua
parents:
diff changeset
288 List<Entity> list = new ArrayList<Entity>();
jurzua
parents:
diff changeset
289
jurzua
parents:
diff changeset
290 List<Attribute> attList = getAttributesByDefByAttName(objClassSrc,
jurzua
parents:
diff changeset
291 attName, attValue, -1);
jurzua
parents:
diff changeset
292 int count = 0;
jurzua
parents:
diff changeset
293 for (Attribute att : attList) {
jurzua
parents:
diff changeset
294 Relation rel = getFirstRelationByTargetOCByName(
jurzua
parents:
diff changeset
295 cache.getRelsBySrcId(att.getSourceId()), objClass, relName);
jurzua
parents:
diff changeset
296 if (rel != null) {
jurzua
parents:
diff changeset
297 list.add(getEntityById(rel.getTargetId()));
jurzua
parents:
diff changeset
298 count++;
jurzua
parents:
diff changeset
299 if (maxResults > 0 && maxResults == count) {
jurzua
parents:
diff changeset
300 break;
jurzua
parents:
diff changeset
301 }
jurzua
parents:
diff changeset
302 }
jurzua
parents:
diff changeset
303 }
jurzua
parents:
diff changeset
304
jurzua
parents:
diff changeset
305 return list;
jurzua
parents:
diff changeset
306 }
jurzua
parents:
diff changeset
307
jurzua
parents:
diff changeset
308 private static Relation getFirstRelationByTargetOCByName(
jurzua
parents:
diff changeset
309 List<Relation> list, String tarOC, String name) {
jurzua
parents:
diff changeset
310 if (StringUtils.isNotEmpty(name)) {
jurzua
parents:
diff changeset
311 name = name.toLowerCase();
jurzua
parents:
diff changeset
312 for (Relation rel : list) {
jurzua
parents:
diff changeset
313 if (rel.getTargetObjectClass().equals(tarOC)) {
jurzua
parents:
diff changeset
314 if (StringUtils.isNotEmpty(rel.getOwnValue())
jurzua
parents:
diff changeset
315 && name.equals(rel.getOwnValue().toLowerCase())) {
jurzua
parents:
diff changeset
316 return rel;
jurzua
parents:
diff changeset
317 }
jurzua
parents:
diff changeset
318 }
jurzua
parents:
diff changeset
319 }
jurzua
parents:
diff changeset
320 }
jurzua
parents:
diff changeset
321 return null;
jurzua
parents:
diff changeset
322 }
jurzua
parents:
diff changeset
323
jurzua
parents:
diff changeset
324 public List<Attribute> getAttributeByEntId(Long entId) {
jurzua
parents:
diff changeset
325 List<Attribute> list = cache.getAttsBySrcId(entId);
jurzua
parents:
diff changeset
326 return list;
jurzua
parents:
diff changeset
327 }
jurzua
parents:
diff changeset
328
jurzua
parents:
diff changeset
329 public Attribute getAttributeByName(Long entId, String name) {
jurzua
parents:
diff changeset
330 List<Attribute> list = cache.getAttsBySrcId(entId);
jurzua
parents:
diff changeset
331
jurzua
parents:
diff changeset
332 for (Attribute att : list) {
jurzua
parents:
diff changeset
333 if (att.getName().equals(name)) {
jurzua
parents:
diff changeset
334 return (Attribute) att.clone();
jurzua
parents:
diff changeset
335 }
jurzua
parents:
diff changeset
336 }
jurzua
parents:
diff changeset
337 return null;
jurzua
parents:
diff changeset
338 }
jurzua
parents:
diff changeset
339
jurzua
parents:
diff changeset
340 public List<Attribute> searchAttribute(String firstName, String firstValue,
jurzua
parents:
diff changeset
341 String secondName, String secondValue, String def, int maxResults) {
jurzua
parents:
diff changeset
342 List<Attribute> list = new ArrayList<Attribute>();
jurzua
parents:
diff changeset
343
jurzua
parents:
diff changeset
344 List<Attribute> firstAttList = cache.getAttsByOCAndName(def, firstName);
jurzua
parents:
diff changeset
345
jurzua
parents:
diff changeset
346 firstValue = StringUtils.isNotEmpty(firstValue) ? NormalizerUtils
jurzua
parents:
diff changeset
347 .normalize(firstValue) : null;
jurzua
parents:
diff changeset
348 secondValue = StringUtils.isNotEmpty(secondValue) ? NormalizerUtils
jurzua
parents:
diff changeset
349 .normalize(secondValue) : null;
jurzua
parents:
diff changeset
350
jurzua
parents:
diff changeset
351 if (StringUtils.isNotEmpty(firstValue)) {
jurzua
parents:
diff changeset
352 for (Attribute firstAtt : firstAttList) {
jurzua
parents:
diff changeset
353 String attValue1 = (StringUtils.isNotEmpty(firstAtt
jurzua
parents:
diff changeset
354 .getNormalizedOwnValue())) ? firstAtt
jurzua
parents:
diff changeset
355 .getNormalizedOwnValue() : "";
jurzua
parents:
diff changeset
356 // (StringUtils.isNotEmpty(firstAtt.getValue())) ?
jurzua
parents:
diff changeset
357 // firstAtt.getValue().toLowerCase() : "";
jurzua
parents:
diff changeset
358 if (StringUtils.isNotEmpty(firstValue)
jurzua
parents:
diff changeset
359 && attValue1.contains(firstValue)) {
jurzua
parents:
diff changeset
360 Attribute secondAtt = getAttributeByName(
jurzua
parents:
diff changeset
361 firstAtt.getSourceId(), secondName);
jurzua
parents:
diff changeset
362 if (secondAtt != null) {
jurzua
parents:
diff changeset
363 String attValue2 = (StringUtils.isNotEmpty(secondAtt
jurzua
parents:
diff changeset
364 .getNormalizedOwnValue())) ? secondAtt
jurzua
parents:
diff changeset
365 .getNormalizedOwnValue() : "";
jurzua
parents:
diff changeset
366 // (StringUtils.isNotEmpty(secondAtt.getValue())) ?
jurzua
parents:
diff changeset
367 // secondAtt.getValue().toLowerCase() : "";
jurzua
parents:
diff changeset
368 if (StringUtils.isNotEmpty(secondValue)
jurzua
parents:
diff changeset
369 && attValue2.contains(attValue2)) {
jurzua
parents:
diff changeset
370 list.add((Attribute) firstAtt.clone());
jurzua
parents:
diff changeset
371 }
jurzua
parents:
diff changeset
372 }
jurzua
parents:
diff changeset
373 }
jurzua
parents:
diff changeset
374 }
jurzua
parents:
diff changeset
375 }
jurzua
parents:
diff changeset
376
jurzua
parents:
diff changeset
377 return list;
jurzua
parents:
diff changeset
378 }
jurzua
parents:
diff changeset
379
jurzua
parents:
diff changeset
380 private List<Attribute> getAttributesByDefByAttName(String def,
jurzua
parents:
diff changeset
381 String attName, int maxResults) {
jurzua
parents:
diff changeset
382 List<Attribute> list = cache.getAttsByOCAndName(def, attName);
jurzua
parents:
diff changeset
383 return list;
jurzua
parents:
diff changeset
384 }
jurzua
parents:
diff changeset
385
jurzua
parents:
diff changeset
386 /**
jurzua
parents:
diff changeset
387 * Returns a list of attributes by objectClass of the entity, the att Name
jurzua
parents:
diff changeset
388 * and its value.
jurzua
parents:
diff changeset
389 *
jurzua
parents:
diff changeset
390 * @param def
jurzua
parents:
diff changeset
391 * @param attName
jurzua
parents:
diff changeset
392 * @param attValue
jurzua
parents:
diff changeset
393 * sub string and ignores case sensitive.
jurzua
parents:
diff changeset
394 * @param maxResults
jurzua
parents:
diff changeset
395 * @return
jurzua
parents:
diff changeset
396 */
jurzua
parents:
diff changeset
397 public List<Attribute> getAttributesByDefByAttName(String def,
jurzua
parents:
diff changeset
398 String attName, String attValue, int maxResults) {
jurzua
parents:
diff changeset
399
jurzua
parents:
diff changeset
400 List<Attribute> list = getAttributesByDefByAttName0(def, attName, attValue, maxResults);
jurzua
parents:
diff changeset
401 Collections.sort(list);
jurzua
parents:
diff changeset
402 return list;
jurzua
parents:
diff changeset
403 }
jurzua
parents:
diff changeset
404
jurzua
parents:
diff changeset
405 public List<Attribute> getAttributes(String oc, String attName){
jurzua
parents:
diff changeset
406 return cache.getAttsByOCAndName(oc, attName);
jurzua
parents:
diff changeset
407 }
jurzua
parents:
diff changeset
408
jurzua
parents:
diff changeset
409 /**
jurzua
parents:
diff changeset
410 *
jurzua
parents:
diff changeset
411 * @param attName
jurzua
parents:
diff changeset
412 * @param attValue
jurzua
parents:
diff changeset
413 * @return
jurzua
parents:
diff changeset
414 */
jurzua
parents:
diff changeset
415 public List<Attribute> getAttributesByExactValue(String attName, String attValue){
jurzua
parents:
diff changeset
416 List<Attribute> list = new ArrayList<Attribute>();
jurzua
parents:
diff changeset
417
jurzua
parents:
diff changeset
418 if(StringUtils.isNotEmpty(attValue)){
jurzua
parents:
diff changeset
419 for(Entity def : cache.getLWDefinitions()){
jurzua
parents:
diff changeset
420
jurzua
parents:
diff changeset
421 List<Attribute> attList = cache.getAttsByOCAndName(def.getOwnValue(), attName);
jurzua
parents:
diff changeset
422 attValue = NormalizerUtils.normalize(attValue);
jurzua
parents:
diff changeset
423
jurzua
parents:
diff changeset
424 for(Attribute att : attList){
jurzua
parents:
diff changeset
425 if(StringUtils.equals(attValue, att.getNormalizedOwnValue())){
jurzua
parents:
diff changeset
426 list.add(att);
jurzua
parents:
diff changeset
427 }
jurzua
parents:
diff changeset
428 }
jurzua
parents:
diff changeset
429
jurzua
parents:
diff changeset
430 }
jurzua
parents:
diff changeset
431 Collections.sort(list);
jurzua
parents:
diff changeset
432 }
jurzua
parents:
diff changeset
433 return list;
jurzua
parents:
diff changeset
434 }
jurzua
parents:
diff changeset
435
jurzua
parents:
diff changeset
436 private List<Attribute> getAttributesByDefByAttName0(String def,
jurzua
parents:
diff changeset
437 String attName, String attValue, int maxResults) {
jurzua
parents:
diff changeset
438 List<Attribute> list = new ArrayList<Attribute>();
jurzua
parents:
diff changeset
439 List<Attribute> attList = cache.getAttsByOCAndName(def, attName);
jurzua
parents:
diff changeset
440 attValue = NormalizerUtils.normalize(attValue);
jurzua
parents:
diff changeset
441 int count = 0;
jurzua
parents:
diff changeset
442 if (StringUtils.isEmpty(attValue)) {
jurzua
parents:
diff changeset
443 for (Attribute att : attList) {
jurzua
parents:
diff changeset
444 list.add((Attribute) att.clone());
jurzua
parents:
diff changeset
445 count++;
jurzua
parents:
diff changeset
446 if (maxResults > 0 && maxResults == count) {
jurzua
parents:
diff changeset
447 break;
jurzua
parents:
diff changeset
448 }
jurzua
parents:
diff changeset
449 }
jurzua
parents:
diff changeset
450 } else {
jurzua
parents:
diff changeset
451 for (Attribute att : attList) {
jurzua
parents:
diff changeset
452 String attValue0 = StringUtils.isNotEmpty(att
jurzua
parents:
diff changeset
453 .getNormalizedOwnValue()) ? att.getNormalizedOwnValue()
jurzua
parents:
diff changeset
454 : "";
jurzua
parents:
diff changeset
455 if (StringUtils.isNotEmpty(attValue)
jurzua
parents:
diff changeset
456 && attValue0.contains(attValue)) {
jurzua
parents:
diff changeset
457 list.add((Attribute) att.clone());
jurzua
parents:
diff changeset
458 count++;
jurzua
parents:
diff changeset
459 if (maxResults > 0 && maxResults == count) {
jurzua
parents:
diff changeset
460 break;
jurzua
parents:
diff changeset
461 }
jurzua
parents:
diff changeset
462 }
jurzua
parents:
diff changeset
463 }
jurzua
parents:
diff changeset
464 }
jurzua
parents:
diff changeset
465 return list;
jurzua
parents:
diff changeset
466 }
jurzua
parents:
diff changeset
467
jurzua
parents:
diff changeset
468 /**
jurzua
parents:
diff changeset
469 * Returns a list of entities.
jurzua
parents:
diff changeset
470 *
jurzua
parents:
diff changeset
471 * @param def
jurzua
parents:
diff changeset
472 * @param attName
jurzua
parents:
diff changeset
473 * @param attValue
jurzua
parents:
diff changeset
474 * ignores case sensitive
jurzua
parents:
diff changeset
475 * @param maxResults
jurzua
parents:
diff changeset
476 * @param subString
jurzua
parents:
diff changeset
477 * if true the attValue is searching as substring
jurzua
parents:
diff changeset
478 * @return
jurzua
parents:
diff changeset
479 */
jurzua
parents:
diff changeset
480 public List<Entity> getEntitiesByAtt(String def, String attName,
jurzua
parents:
diff changeset
481 String attValue, int maxResults, boolean subString) {
jurzua
parents:
diff changeset
482 List<Entity> list = new ArrayList<Entity>();
jurzua
parents:
diff changeset
483
jurzua
parents:
diff changeset
484 List<Attribute> attList = cache.getAttsByOCAndName(def, attName);
jurzua
parents:
diff changeset
485
jurzua
parents:
diff changeset
486 int count = 0;
jurzua
parents:
diff changeset
487 if (StringUtils.isEmpty(attValue)) {
jurzua
parents:
diff changeset
488 for (Attribute att : attList) {
jurzua
parents:
diff changeset
489 list.add(getEntityById(att.getSourceId()));
jurzua
parents:
diff changeset
490 count++;
jurzua
parents:
diff changeset
491 if (maxResults > 0 && maxResults == count) {
jurzua
parents:
diff changeset
492 break;
jurzua
parents:
diff changeset
493 }
jurzua
parents:
diff changeset
494 }
jurzua
parents:
diff changeset
495 } else {
jurzua
parents:
diff changeset
496 attValue = (StringUtils.isNotEmpty(attValue)) ? NormalizerUtils
jurzua
parents:
diff changeset
497 .normalize(attValue) : "";
jurzua
parents:
diff changeset
498 for (Attribute att : attList) {
jurzua
parents:
diff changeset
499 String attValue0 = (StringUtils.isNotEmpty(att
jurzua
parents:
diff changeset
500 .getNormalizedOwnValue())) ? att
jurzua
parents:
diff changeset
501 .getNormalizedOwnValue() : "";
jurzua
parents:
diff changeset
502 if ((subString && attValue0.contains(attValue))
jurzua
parents:
diff changeset
503 || (!subString && attValue.equals(attValue0))) {
jurzua
parents:
diff changeset
504 list.add(getEntityById(att.getSourceId()));
jurzua
parents:
diff changeset
505 count++;
jurzua
parents:
diff changeset
506 if (maxResults > 0 && maxResults == count) {
jurzua
parents:
diff changeset
507 break;
jurzua
parents:
diff changeset
508 }
jurzua
parents:
diff changeset
509 }
jurzua
parents:
diff changeset
510 }
jurzua
parents:
diff changeset
511 }
jurzua
parents:
diff changeset
512 return list;
jurzua
parents:
diff changeset
513 }
jurzua
parents:
diff changeset
514
jurzua
parents:
diff changeset
515 public void removeDefAttribute(Attribute att) throws Exception {
jurzua
parents:
diff changeset
516 this.cache.deleteDefAttribute(att);
jurzua
parents:
diff changeset
517 att.setSystemStatus(Node.SYS_STATUS_PREVIOUS_VERSION);
jurzua
parents:
diff changeset
518 this.getPS().saveNode(att);
jurzua
parents:
diff changeset
519 }
jurzua
parents:
diff changeset
520
jurzua
parents:
diff changeset
521 public void removeDefRelation(Relation rel) throws Exception {
jurzua
parents:
diff changeset
522 this.cache.deleteDefRelation(rel);
jurzua
parents:
diff changeset
523 rel.setSystemStatus(Node.SYS_STATUS_PREVIOUS_VERSION);
jurzua
parents:
diff changeset
524 this.getPS().saveNode(rel);
jurzua
parents:
diff changeset
525 }
jurzua
parents:
diff changeset
526
jurzua
parents:
diff changeset
527 public Entity saveLWDefinition(Entity def, String user) throws Exception {
jurzua
parents:
diff changeset
528 boolean isNew = !def.isPersistent();
jurzua
parents:
diff changeset
529 def.setUser(user);
jurzua
parents:
diff changeset
530 def.increaseVersion();
jurzua
parents:
diff changeset
531 def.setModificationTime(System.currentTimeMillis());
jurzua
parents:
diff changeset
532 def.setType(Node.TYPE_TBOX);
jurzua
parents:
diff changeset
533 def.setObjectClass(Node.TYPE_TBOX);
jurzua
parents:
diff changeset
534 def.setSystemStatus(Node.SYS_STATUS_CURRENT_VERSION);
jurzua
parents:
diff changeset
535 this.getPS().saveNode(def);
jurzua
parents:
diff changeset
536
jurzua
parents:
diff changeset
537 if (isNew) {
jurzua
parents:
diff changeset
538 this.cache.createLWDefinition(def);
jurzua
parents:
diff changeset
539 } else {
jurzua
parents:
diff changeset
540 this.cache.saveLWDefinition(def);
jurzua
parents:
diff changeset
541 }
jurzua
parents:
diff changeset
542
jurzua
parents:
diff changeset
543 return def;
jurzua
parents:
diff changeset
544 }
jurzua
parents:
diff changeset
545
jurzua
parents:
diff changeset
546 public Attribute saveDefAttribute(Attribute att, String user)
jurzua
parents:
diff changeset
547 throws Exception {
jurzua
parents:
diff changeset
548 att.setUser(user);
jurzua
parents:
diff changeset
549 att.increaseVersion();
jurzua
parents:
diff changeset
550 att.setModificationTime(System.currentTimeMillis());
jurzua
parents:
diff changeset
551 att.setObjectClass(Node.TYPE_TBOX);
jurzua
parents:
diff changeset
552 att.setType(Node.TYPE_TBOX);
jurzua
parents:
diff changeset
553 att.getPossibleValues();
jurzua
parents:
diff changeset
554 this.getPS().saveNode(att);
jurzua
parents:
diff changeset
555 this.cache.saveDefAttribute(att);
jurzua
parents:
diff changeset
556 return att;
jurzua
parents:
diff changeset
557 }
jurzua
parents:
diff changeset
558
jurzua
parents:
diff changeset
559 public Relation saveDefRelation(Relation rel, String user) throws Exception {
jurzua
parents:
diff changeset
560 rel.setUser(user);
jurzua
parents:
diff changeset
561 rel.increaseVersion();
jurzua
parents:
diff changeset
562 rel.setModificationTime(System.currentTimeMillis());
jurzua
parents:
diff changeset
563 rel.setObjectClass(Node.TYPE_TBOX);
jurzua
parents:
diff changeset
564 rel.setType(Node.TYPE_TBOX);
jurzua
parents:
diff changeset
565 this.getPS().saveNode(rel);
jurzua
parents:
diff changeset
566 this.cache.saveDefRelation(rel);
jurzua
parents:
diff changeset
567 return rel;
jurzua
parents:
diff changeset
568 }
jurzua
parents:
diff changeset
569
jurzua
parents:
diff changeset
570 /*
jurzua
parents:
diff changeset
571 * public Entity saveDefinition(Entity def, String user){ long start =
jurzua
parents:
diff changeset
572 * System.currentTimeMillis(); def.setObjectClass(Node.TYPE_TBOX);
jurzua
parents:
diff changeset
573 * def.setUser(user);
jurzua
parents:
diff changeset
574 *
jurzua
parents:
diff changeset
575 * boolean b = this.searchServ.saveEntity(def);
jurzua
parents:
diff changeset
576 * this.cache.saveDefinition(def);
jurzua
parents:
diff changeset
577 * logger.info("saveEntityAsNew - execution time[ms]: " +
jurzua
parents:
diff changeset
578 * (System.currentTimeMillis() - start)); return (Entity)def.clone(); }
jurzua
parents:
diff changeset
579 */
jurzua
parents:
diff changeset
580 public Entity saveEntityAsNew(Entity entity, String user) throws Exception {
jurzua
parents:
diff changeset
581 long start = System.currentTimeMillis();
jurzua
parents:
diff changeset
582 entity.resetRowId();
jurzua
parents:
diff changeset
583 entity.resetId();
jurzua
parents:
diff changeset
584 entity.setType(Node.TYPE_ABOX);
jurzua
parents:
diff changeset
585 entity.setUser(user);
jurzua
parents:
diff changeset
586
jurzua
parents:
diff changeset
587 this.getPS().saveEntity(entity);
jurzua
parents:
diff changeset
588 cache.saveEntity(entity);
jurzua
parents:
diff changeset
589 logger.info("[U=" + user + "] SaveEntityAsNew - execution time[ms]: " + (System.currentTimeMillis() - start));
jurzua
parents:
diff changeset
590 return (Entity) entity.clone();
jurzua
parents:
diff changeset
591 }
jurzua
parents:
diff changeset
592
jurzua
parents:
diff changeset
593 public Entity saveEntity(Entity entity, String user) throws Exception {
jurzua
parents:
diff changeset
594 long start = System.currentTimeMillis();
jurzua
parents:
diff changeset
595 if (StringUtils.isEmpty(entity.getType())) {
jurzua
parents:
diff changeset
596 entity.setType(Node.TYPE_ABOX);
jurzua
parents:
diff changeset
597 }
jurzua
parents:
diff changeset
598 entity.setUser(user);
jurzua
parents:
diff changeset
599
jurzua
parents:
diff changeset
600 entity = removeWrongRelations(entity);
jurzua
parents:
diff changeset
601 entity = removeEmptyAttributes(entity);
jurzua
parents:
diff changeset
602
jurzua
parents:
diff changeset
603 this.getPS().saveEntity(entity);
jurzua
parents:
diff changeset
604 cache.saveEntity(entity);
jurzua
parents:
diff changeset
605 System.gc();
jurzua
parents:
diff changeset
606 logger.info("[U=" + user + "] SaveEntity - execution time[ms]: " + (System.currentTimeMillis() - start));
jurzua
parents:
diff changeset
607 Entity clone = (Entity) entity.clone();
jurzua
parents:
diff changeset
608 // logger.info(clone.toString());
jurzua
parents:
diff changeset
609 return clone;
jurzua
parents:
diff changeset
610 }
jurzua
parents:
diff changeset
611
jurzua
parents:
diff changeset
612 public void saveEntityList(List<Entity> list, String user) throws Exception{
jurzua
parents:
diff changeset
613 long start = System.currentTimeMillis();
jurzua
parents:
diff changeset
614 for(Entity entity : list){
jurzua
parents:
diff changeset
615 if (StringUtils.isEmpty(entity.getType())) {
jurzua
parents:
diff changeset
616 entity.setType(Node.TYPE_ABOX);
jurzua
parents:
diff changeset
617 }
jurzua
parents:
diff changeset
618 entity.setUser(user);
jurzua
parents:
diff changeset
619
jurzua
parents:
diff changeset
620 entity = removeWrongRelations(entity);
jurzua
parents:
diff changeset
621 entity = removeEmptyAttributes(entity);
jurzua
parents:
diff changeset
622 }
jurzua
parents:
diff changeset
623 this.getPS().saveEntityList(list);
jurzua
parents:
diff changeset
624 for(Entity entity : list){
jurzua
parents:
diff changeset
625 cache.saveEntity(entity);
jurzua
parents:
diff changeset
626 }
jurzua
parents:
diff changeset
627 logger.info("[U=" + user + "] SaveEntityList - execution time[ms]: " + (System.currentTimeMillis() - start));
jurzua
parents:
diff changeset
628 }
jurzua
parents:
diff changeset
629
jurzua
parents:
diff changeset
630 private Entity removeEmptyAttributes(Entity ent){
jurzua
parents:
diff changeset
631
jurzua
parents:
diff changeset
632 for(Attribute att : new ArrayList<Attribute>(ent.getAttributes())){
jurzua
parents:
diff changeset
633 if(StringUtils.isEmpty(att.getValue())){
jurzua
parents:
diff changeset
634 ent.getAttributes().remove(att);
jurzua
parents:
diff changeset
635 }
jurzua
parents:
diff changeset
636 }
jurzua
parents:
diff changeset
637 return ent;
jurzua
parents:
diff changeset
638
jurzua
parents:
diff changeset
639 }
jurzua
parents:
diff changeset
640
jurzua
parents:
diff changeset
641 private boolean hasWrongRelations(Entity ent) {
jurzua
parents:
diff changeset
642 for (Relation srcRel : ent.getSourceRelations()) {
jurzua
parents:
diff changeset
643 if (getEntityById(srcRel.getTargetId()) == null) {
jurzua
parents:
diff changeset
644 return true;
jurzua
parents:
diff changeset
645 }
jurzua
parents:
diff changeset
646 }
jurzua
parents:
diff changeset
647
jurzua
parents:
diff changeset
648 for (Relation tarRel : ent.getTargetRelations()) {
jurzua
parents:
diff changeset
649 if (getEntityById(tarRel.getSourceId()) == null) {
jurzua
parents:
diff changeset
650 return true;
jurzua
parents:
diff changeset
651 }
jurzua
parents:
diff changeset
652 }
jurzua
parents:
diff changeset
653 return false;
jurzua
parents:
diff changeset
654 }
jurzua
parents:
diff changeset
655
jurzua
parents:
diff changeset
656 private Entity removeWrongRelations(Entity ent) {
jurzua
parents:
diff changeset
657
jurzua
parents:
diff changeset
658 for (Relation srcRel : new ArrayList<Relation>(ent.getSourceRelations())) {
jurzua
parents:
diff changeset
659 if (srcRel.getTargetId() == null || getEntityByIdReadOnly(srcRel.getTargetId()) == null) {
jurzua
parents:
diff changeset
660 ent.getSourceRelations().remove(srcRel);
jurzua
parents:
diff changeset
661 logger.error(
jurzua
parents:
diff changeset
662 "Inconsistency detected saving entity ["
jurzua
parents:
diff changeset
663 + ent.getId() + "] " + srcRel.toString());
jurzua
parents:
diff changeset
664 }
jurzua
parents:
diff changeset
665 }
jurzua
parents:
diff changeset
666
jurzua
parents:
diff changeset
667 for (Relation tarRel : new ArrayList<Relation>(ent.getTargetRelations())) {
jurzua
parents:
diff changeset
668 if (tarRel.getSourceId() == null || getEntityByIdReadOnly(tarRel.getSourceId()) == null) {
jurzua
parents:
diff changeset
669 ent.getTargetRelations().remove(tarRel);
jurzua
parents:
diff changeset
670 logger.error(
jurzua
parents:
diff changeset
671 "Inconsistency detected saving entity ["
jurzua
parents:
diff changeset
672 + ent.getId() + "] " + tarRel.toString());
jurzua
parents:
diff changeset
673 }
jurzua
parents:
diff changeset
674 }
jurzua
parents:
diff changeset
675
jurzua
parents:
diff changeset
676 return ent;
jurzua
parents:
diff changeset
677 }
jurzua
parents:
diff changeset
678
jurzua
parents:
diff changeset
679 public Attribute getDefAttributeByOwnValue(String defOC, String attOW) {
jurzua
parents:
diff changeset
680 for (Attribute att : this.cache.getDefAttributes(defOC)) {
jurzua
parents:
diff changeset
681 if (att.getOwnValue().equals(attOW)) {
jurzua
parents:
diff changeset
682 return att;
jurzua
parents:
diff changeset
683 }
jurzua
parents:
diff changeset
684 }
jurzua
parents:
diff changeset
685 return null;
jurzua
parents:
diff changeset
686 }
jurzua
parents:
diff changeset
687
jurzua
parents:
diff changeset
688 public List<Attribute> getDefRelationAttributes(Long id) {
jurzua
parents:
diff changeset
689 return this.cache.getDefAttributesById(id);
jurzua
parents:
diff changeset
690 }
jurzua
parents:
diff changeset
691
jurzua
parents:
diff changeset
692 public List<Attribute> getDefAttributes(String ow) {
jurzua
parents:
diff changeset
693 return this.cache.getDefAttributes(ow);
jurzua
parents:
diff changeset
694 }
jurzua
parents:
diff changeset
695
jurzua
parents:
diff changeset
696 public List<Relation> getDefSourceRelations(String ow) {
jurzua
parents:
diff changeset
697 return this.cache.getDefSourceRelations(ow);
jurzua
parents:
diff changeset
698 }
jurzua
parents:
diff changeset
699
jurzua
parents:
diff changeset
700 public List<Relation> getDefTargetRelations(String ow) {
jurzua
parents:
diff changeset
701 return this.cache.getDefTargetRelations(ow);
jurzua
parents:
diff changeset
702 }
jurzua
parents:
diff changeset
703
jurzua
parents:
diff changeset
704 public Entity getDefinitionById(Long id) {
jurzua
parents:
diff changeset
705 return this.cache.getLWDefinitionById(id);
jurzua
parents:
diff changeset
706 /*
jurzua
parents:
diff changeset
707 * Entity def = cache.getDefinitionById(id); if(def == null){
jurzua
parents:
diff changeset
708 * List<Entity> list = this.searchServ.getEntities(id,
jurzua
parents:
diff changeset
709 * Node.SYS_STATUS_CURRENT_VERSION, Node.TYPE_TBOX, null); if
jurzua
parents:
diff changeset
710 * (list.size() > 0) { def = list.get(0); cache.saveDefinition(def); } }
jurzua
parents:
diff changeset
711 * return def;
jurzua
parents:
diff changeset
712 */
jurzua
parents:
diff changeset
713 }
jurzua
parents:
diff changeset
714
jurzua
parents:
diff changeset
715 public List<Entity> getLWDefinitions() {
jurzua
parents:
diff changeset
716 return this.cache.getLWDefinitions();
jurzua
parents:
diff changeset
717 /*
jurzua
parents:
diff changeset
718 * List<Entity> defs = this.cache.getDefinitions();
jurzua
parents:
diff changeset
719 * Collections.sort(defs, new EntitySortByNormalizedOwnValue()); return
jurzua
parents:
diff changeset
720 * defs;
jurzua
parents:
diff changeset
721 */
jurzua
parents:
diff changeset
722 }
jurzua
parents:
diff changeset
723
jurzua
parents:
diff changeset
724 public Entity getDefinition(String ownValue) {
jurzua
parents:
diff changeset
725 return this.cache.getLWDefinition(ownValue);
jurzua
parents:
diff changeset
726 }
jurzua
parents:
diff changeset
727
jurzua
parents:
diff changeset
728 public List<Relation> getRelation(String name, String srcOC, String tarOC)
jurzua
parents:
diff changeset
729 throws Exception {
jurzua
parents:
diff changeset
730 // TODO read only???
jurzua
parents:
diff changeset
731 List<Relation> list = new ArrayList<Relation>();
jurzua
parents:
diff changeset
732 if (StringUtils.isNotEmpty(name)) {
jurzua
parents:
diff changeset
733 List<Relation> list0 = cache.getRelsByName(name);
jurzua
parents:
diff changeset
734 if (StringUtils.isEmpty(srcOC) && StringUtils.isEmpty(tarOC)) {
jurzua
parents:
diff changeset
735 list = list0;
jurzua
parents:
diff changeset
736 } else {
jurzua
parents:
diff changeset
737 for (Relation rel : list0) {
jurzua
parents:
diff changeset
738 if ((StringUtils.isEmpty(srcOC) || srcOC.equals(rel
jurzua
parents:
diff changeset
739 .getSourceObjectClass()))
jurzua
parents:
diff changeset
740 && (StringUtils.isEmpty(tarOC) || tarOC.equals(rel
jurzua
parents:
diff changeset
741 .getTargetObjectClass()))) {
jurzua
parents:
diff changeset
742 list.add(rel);
jurzua
parents:
diff changeset
743 }
jurzua
parents:
diff changeset
744 }
jurzua
parents:
diff changeset
745 }
jurzua
parents:
diff changeset
746 }
jurzua
parents:
diff changeset
747
jurzua
parents:
diff changeset
748 return list;
jurzua
parents:
diff changeset
749 }
jurzua
parents:
diff changeset
750
jurzua
parents:
diff changeset
751 public List<Entity> getSourcesForTargetRelation(Entity tar,
jurzua
parents:
diff changeset
752 String relationName, String srcObjClass, int maxResult) {
jurzua
parents:
diff changeset
753 return getSourcesForTargetRelation(tar.getId(), relationName,
jurzua
parents:
diff changeset
754 srcObjClass, maxResult);
jurzua
parents:
diff changeset
755 }
jurzua
parents:
diff changeset
756
jurzua
parents:
diff changeset
757 public List<Entity> getSourcesForTargetRelation(Long tarId,
jurzua
parents:
diff changeset
758 String relationName, String srcObjClass, int maxResult) {
jurzua
parents:
diff changeset
759 List<Entity> rs = new ArrayList<Entity>();
jurzua
parents:
diff changeset
760
jurzua
parents:
diff changeset
761 List<Relation> tarRelList = this.cache.getRelsByTarId(tarId);
jurzua
parents:
diff changeset
762
jurzua
parents:
diff changeset
763 long start = System.currentTimeMillis();
jurzua
parents:
diff changeset
764 int count = 0;
jurzua
parents:
diff changeset
765 for (Relation rel : tarRelList) {
jurzua
parents:
diff changeset
766 if (stringEquals(relationName, rel.getOwnValue())
jurzua
parents:
diff changeset
767 && stringEquals(srcObjClass, rel.getSourceObjectClass())) {
jurzua
parents:
diff changeset
768 Entity ent = getEntityByIdReadOnly(rel.getSourceId());
jurzua
parents:
diff changeset
769 if (ent != null) {
jurzua
parents:
diff changeset
770 rs.add(ent);
jurzua
parents:
diff changeset
771 count++;
jurzua
parents:
diff changeset
772 if (maxResult > 0 && count == maxResult) {
jurzua
parents:
diff changeset
773 break;
jurzua
parents:
diff changeset
774 }
jurzua
parents:
diff changeset
775 }
jurzua
parents:
diff changeset
776 }
jurzua
parents:
diff changeset
777 }
jurzua
parents:
diff changeset
778 logger.debug("getSourcesForTargetRelation (loading sources) - execution time[ms]: "
jurzua
parents:
diff changeset
779 + (System.currentTimeMillis() - start));
jurzua
parents:
diff changeset
780 Collections.sort(rs, new EntitySortByNormalizedOwnValue());
jurzua
parents:
diff changeset
781 return rs;
jurzua
parents:
diff changeset
782 }
jurzua
parents:
diff changeset
783
jurzua
parents:
diff changeset
784 public List<Entity> getTargetsForSourceRelation(Entity src,
jurzua
parents:
diff changeset
785 String relationName, String tarObjClass, int maxResult) {
jurzua
parents:
diff changeset
786 return getTargetsForSourceRelation(src.getId(), relationName,
jurzua
parents:
diff changeset
787 tarObjClass, maxResult);
jurzua
parents:
diff changeset
788 }
jurzua
parents:
diff changeset
789
jurzua
parents:
diff changeset
790 public List<Entity> getTargetsForSourceRelation(Long srcId,
jurzua
parents:
diff changeset
791 String relationName, String tarObjClass, int maxResult) {
jurzua
parents:
diff changeset
792 List<Entity> rs = new ArrayList<Entity>();
jurzua
parents:
diff changeset
793
jurzua
parents:
diff changeset
794 try {
jurzua
parents:
diff changeset
795 Collection<Relation> srcRelList = this.cache.getRelsBySrcId(srcId);
jurzua
parents:
diff changeset
796
jurzua
parents:
diff changeset
797 int count = 0;
jurzua
parents:
diff changeset
798 for (Relation rel : srcRelList) {
jurzua
parents:
diff changeset
799 if (stringEquals(relationName, rel.getOwnValue())
jurzua
parents:
diff changeset
800 && stringEquals(tarObjClass, rel.getTargetObjectClass())) {
jurzua
parents:
diff changeset
801 rs.add(getEntityByIdReadOnly(rel.getTargetId()));
jurzua
parents:
diff changeset
802 count++;
jurzua
parents:
diff changeset
803 if (maxResult > 0 && count == maxResult) {
jurzua
parents:
diff changeset
804 break;
jurzua
parents:
diff changeset
805 }
jurzua
parents:
diff changeset
806 }
jurzua
parents:
diff changeset
807 }
jurzua
parents:
diff changeset
808 Collections.sort(rs, new EntitySortByNormalizedOwnValue());
jurzua
parents:
diff changeset
809 } catch (Exception e) {
jurzua
parents:
diff changeset
810 logger.error(e.getMessage(), e);
jurzua
parents:
diff changeset
811 }
jurzua
parents:
diff changeset
812
jurzua
parents:
diff changeset
813 return rs;
jurzua
parents:
diff changeset
814 }
jurzua
parents:
diff changeset
815
jurzua
parents:
diff changeset
816 public List<Relation> getTargetRelations(Entity target,
jurzua
parents:
diff changeset
817 String relationName, String srcObjClass, int maxResult) {
jurzua
parents:
diff changeset
818 long start = System.currentTimeMillis();
jurzua
parents:
diff changeset
819 List<Relation> list = new ArrayList<Relation>();
jurzua
parents:
diff changeset
820
jurzua
parents:
diff changeset
821 List<Relation> tarRelList = this.cache.getRelsByTarId(target.getId());
jurzua
parents:
diff changeset
822 /*
jurzua
parents:
diff changeset
823 * if(coll == null){ coll = this.getPS().getTargetRelations(target,
jurzua
parents:
diff changeset
824 * null, null, -1, false); cache.setRelsForTar(target.getId(), coll); }
jurzua
parents:
diff changeset
825 */
jurzua
parents:
diff changeset
826
jurzua
parents:
diff changeset
827 int count = 0;
jurzua
parents:
diff changeset
828 for (Relation rel : tarRelList) {
jurzua
parents:
diff changeset
829 if (stringEquals(relationName, rel.getOwnValue())
jurzua
parents:
diff changeset
830 && stringEquals(srcObjClass, rel.getSourceObjectClass())) {
jurzua
parents:
diff changeset
831 Entity source = getEntityById(rel.getSourceId());
jurzua
parents:
diff changeset
832 if (source != null) {
jurzua
parents:
diff changeset
833 rel.setTarget(target);
jurzua
parents:
diff changeset
834 rel.setSource(source);
jurzua
parents:
diff changeset
835 list.add(rel);
jurzua
parents:
diff changeset
836 count++;
jurzua
parents:
diff changeset
837 if (maxResult > 0 && count == maxResult) {
jurzua
parents:
diff changeset
838 break;
jurzua
parents:
diff changeset
839 }
jurzua
parents:
diff changeset
840 } else {
jurzua
parents:
diff changeset
841 logger.error("#########ERROR: Relation without source "
jurzua
parents:
diff changeset
842 + rel.toString());
jurzua
parents:
diff changeset
843 }
jurzua
parents:
diff changeset
844
jurzua
parents:
diff changeset
845 }
jurzua
parents:
diff changeset
846 }
jurzua
parents:
diff changeset
847 Collections.sort(list, new RelationSortBySourceOW());
jurzua
parents:
diff changeset
848 logger.debug("getTargetRelations - execution time[ms]: "
jurzua
parents:
diff changeset
849 + (System.currentTimeMillis() - start));
jurzua
parents:
diff changeset
850 return list;
jurzua
parents:
diff changeset
851 }
jurzua
parents:
diff changeset
852
jurzua
parents:
diff changeset
853 /**
jurzua
parents:
diff changeset
854 * Returns a list of relations found by entity source.
jurzua
parents:
diff changeset
855 *
jurzua
parents:
diff changeset
856 * @param source
jurzua
parents:
diff changeset
857 * @param relationName
jurzua
parents:
diff changeset
858 * @param tarObjClass
jurzua
parents:
diff changeset
859 * @param maxResult
jurzua
parents:
diff changeset
860 * @return
jurzua
parents:
diff changeset
861 */
jurzua
parents:
diff changeset
862 public List<Relation> getSourceRelations(Entity source,
jurzua
parents:
diff changeset
863 String relationName, String tarObjClass, int maxResult)
jurzua
parents:
diff changeset
864 throws Exception {
jurzua
parents:
diff changeset
865
jurzua
parents:
diff changeset
866 long start = System.currentTimeMillis();
jurzua
parents:
diff changeset
867 List<Relation> list = new ArrayList<Relation>();
jurzua
parents:
diff changeset
868
jurzua
parents:
diff changeset
869 // the collection coll should not be modified
jurzua
parents:
diff changeset
870 // otherwise java.util.ConcurrentModificationException will be thrown.
jurzua
parents:
diff changeset
871 // be carefully using getEntityContent, cause it changes the cache
jurzua
parents:
diff changeset
872
jurzua
parents:
diff changeset
873 List<Relation> srcRelList = this.cache.getRelsBySrcId(source.getId());
jurzua
parents:
diff changeset
874
jurzua
parents:
diff changeset
875 int count = 0;
jurzua
parents:
diff changeset
876 for (Relation rel : srcRelList) {
jurzua
parents:
diff changeset
877 if (stringEquals(relationName, rel.getOwnValue())
jurzua
parents:
diff changeset
878 && stringEquals(tarObjClass, rel.getTargetObjectClass())) {
jurzua
parents:
diff changeset
879 rel.setSource(source);
jurzua
parents:
diff changeset
880 rel.setTarget(getEntityById(rel.getTargetId()));
jurzua
parents:
diff changeset
881 list.add(rel);
jurzua
parents:
diff changeset
882 count++;
jurzua
parents:
diff changeset
883 if (maxResult > 0 && count == maxResult) {
jurzua
parents:
diff changeset
884 break;
jurzua
parents:
diff changeset
885 }
jurzua
parents:
diff changeset
886 }
jurzua
parents:
diff changeset
887 }
jurzua
parents:
diff changeset
888 Collections.sort(list, new RelationSortByTargetOW());
jurzua
parents:
diff changeset
889 logger.debug("getSourceRelations - execution time[ms]: "
jurzua
parents:
diff changeset
890 + (System.currentTimeMillis() - start));
jurzua
parents:
diff changeset
891
jurzua
parents:
diff changeset
892 return list;
jurzua
parents:
diff changeset
893 }
jurzua
parents:
diff changeset
894
jurzua
parents:
diff changeset
895 /**
jurzua
parents:
diff changeset
896 * This method should not be used inside this Wrapper class, because it
jurzua
parents:
diff changeset
897 * could throws an java.util.ConcurrentModificationException.
jurzua
parents:
diff changeset
898 *
jurzua
parents:
diff changeset
899 * @param ent
jurzua
parents:
diff changeset
900 * @return
jurzua
parents:
diff changeset
901 */
jurzua
parents:
diff changeset
902 public Entity getEntityContent(Entity ent) {
jurzua
parents:
diff changeset
903 try {
jurzua
parents:
diff changeset
904 if (ent.isLightweight()) {
jurzua
parents:
diff changeset
905 Entity e = this.cache.getEntityContent(ent);
jurzua
parents:
diff changeset
906 if (e == null) {
jurzua
parents:
diff changeset
907 e = this.getPS().getEntityContent(ent);
jurzua
parents:
diff changeset
908 this.cache.saveEntity(e);
jurzua
parents:
diff changeset
909 } else {
jurzua
parents:
diff changeset
910 ent = e;
jurzua
parents:
diff changeset
911 }
jurzua
parents:
diff changeset
912 }
jurzua
parents:
diff changeset
913 return (Entity) ent.clone();
jurzua
parents:
diff changeset
914 } catch (Exception e) {
jurzua
parents:
diff changeset
915 logger.error(e.getMessage(), e);
jurzua
parents:
diff changeset
916 }
jurzua
parents:
diff changeset
917 return null;
jurzua
parents:
diff changeset
918 }
jurzua
parents:
diff changeset
919
jurzua
parents:
diff changeset
920 public Entity getEntityContentReadOnly(Entity ent) throws Exception {
jurzua
parents:
diff changeset
921 if (ent.isLightweight()) {
jurzua
parents:
diff changeset
922 Entity e = this.cache.getEntityContent(ent);
jurzua
parents:
diff changeset
923 if (e == null) {
jurzua
parents:
diff changeset
924 e = this.getPS().getEntityContent(ent);
jurzua
parents:
diff changeset
925 this.cache.saveEntity(e);
jurzua
parents:
diff changeset
926 } else {
jurzua
parents:
diff changeset
927 ent = e;
jurzua
parents:
diff changeset
928 }
jurzua
parents:
diff changeset
929 }
jurzua
parents:
diff changeset
930 return ent;
jurzua
parents:
diff changeset
931 }
jurzua
parents:
diff changeset
932
jurzua
parents:
diff changeset
933 /**
jurzua
parents:
diff changeset
934 * The entity returned could be LW or not, it depends on the cache.
jurzua
parents:
diff changeset
935 * additionally, it will be always a clone of the version in cache,
jurzua
parents:
diff changeset
936 * therefore it method is thought for editing's issues.
jurzua
parents:
diff changeset
937 *
jurzua
parents:
diff changeset
938 * @param id
jurzua
parents:
diff changeset
939 * @return
jurzua
parents:
diff changeset
940 */
jurzua
parents:
diff changeset
941 public Entity getEntityById(Long id) {
jurzua
parents:
diff changeset
942 Entity ent = this.cache.getEntityById(id);
jurzua
parents:
diff changeset
943 return ent;
jurzua
parents:
diff changeset
944 }
jurzua
parents:
diff changeset
945
jurzua
parents:
diff changeset
946 public Entity getEntityByIdReadOnly(Long id) {
jurzua
parents:
diff changeset
947 Entity ent = this.cache.getEntityByIdReadOnly(id);
jurzua
parents:
diff changeset
948 return ent;
jurzua
parents:
diff changeset
949 }
jurzua
parents:
diff changeset
950
jurzua
parents:
diff changeset
951 public Entity getClonedEntityById(Long id) {
jurzua
parents:
diff changeset
952 return (Entity) getEntityById(id).clone();
jurzua
parents:
diff changeset
953 }
jurzua
parents:
diff changeset
954
jurzua
parents:
diff changeset
955 /**
jurzua
parents:
diff changeset
956 * This method should not be used inside this Wrapper class, because it
jurzua
parents:
diff changeset
957 * could throws an java.util.ConcurrentModificationException.
jurzua
parents:
diff changeset
958 *
jurzua
parents:
diff changeset
959 * @param id
jurzua
parents:
diff changeset
960 * @return
jurzua
parents:
diff changeset
961 */
jurzua
parents:
diff changeset
962 public Entity getEntityByIdWithContent(Long id) {
jurzua
parents:
diff changeset
963 try {
jurzua
parents:
diff changeset
964 Entity ent = getEntityById(id);
jurzua
parents:
diff changeset
965 if (ent != null && ent.isLightweight()) {
jurzua
parents:
diff changeset
966 ent = getEntityContent(ent);
jurzua
parents:
diff changeset
967 }
jurzua
parents:
diff changeset
968 return ent;
jurzua
parents:
diff changeset
969 } catch (Exception e) {
jurzua
parents:
diff changeset
970 logger.error(e.getMessage(), e);
jurzua
parents:
diff changeset
971 }
jurzua
parents:
diff changeset
972 return null;
jurzua
parents:
diff changeset
973 }
jurzua
parents:
diff changeset
974
jurzua
parents:
diff changeset
975 public Entity getEntityByIdWithContentReadOnly(Long id) throws Exception {
jurzua
parents:
diff changeset
976 Entity ent = getEntityByIdReadOnly(id);
jurzua
parents:
diff changeset
977 if (ent.isLightweight()) {
jurzua
parents:
diff changeset
978 ent = getEntityContentReadOnly(ent);
jurzua
parents:
diff changeset
979 }
jurzua
parents:
diff changeset
980 return ent;
jurzua
parents:
diff changeset
981 }
jurzua
parents:
diff changeset
982
jurzua
parents:
diff changeset
983 public static boolean stringEquals(String term, String ow) {
jurzua
parents:
diff changeset
984 if (StringUtils.isEmpty(term))
jurzua
parents:
diff changeset
985 return true;
jurzua
parents:
diff changeset
986 return term.equals(ow);
jurzua
parents:
diff changeset
987 }
jurzua
parents:
diff changeset
988
jurzua
parents:
diff changeset
989 // ////****
jurzua
parents:
diff changeset
990 public Entity getLightweightEntityById(Long id) {
jurzua
parents:
diff changeset
991 Entity entity = null;
jurzua
parents:
diff changeset
992 if (id != null) {
jurzua
parents:
diff changeset
993 List<Entity> list = this.getPS().getLightweightEntities(
jurzua
parents:
diff changeset
994 Node.SYS_STATUS_CURRENT_VERSION, id, null, null, null,
jurzua
parents:
diff changeset
995 true, -1);
jurzua
parents:
diff changeset
996 if (list.size() > 0) {
jurzua
parents:
diff changeset
997 entity = list.get(0);
jurzua
parents:
diff changeset
998 }
jurzua
parents:
diff changeset
999 }
jurzua
parents:
diff changeset
1000 return entity;
jurzua
parents:
diff changeset
1001 }
jurzua
parents:
diff changeset
1002
jurzua
parents:
diff changeset
1003 public List<Entity> getLightweightAssertions(String objectClass,
jurzua
parents:
diff changeset
1004 String ownValue, int maxResult) {
jurzua
parents:
diff changeset
1005 return getPS().getLightweightEntities(Node.SYS_STATUS_CURRENT_VERSION,
jurzua
parents:
diff changeset
1006 null, Node.TYPE_ABOX, objectClass, ownValue, true, maxResult);
jurzua
parents:
diff changeset
1007 }
jurzua
parents:
diff changeset
1008
jurzua
parents:
diff changeset
1009 public void saveAssertion(Entity entity, String user) throws Exception {
jurzua
parents:
diff changeset
1010 this.saveEntity(entity, user);
jurzua
parents:
diff changeset
1011 }
jurzua
parents:
diff changeset
1012
jurzua
parents:
diff changeset
1013 /**
jurzua
parents:
diff changeset
1014 * <p>
jurzua
parents:
diff changeset
1015 * This method saves a non-persistent entity.
jurzua
parents:
diff changeset
1016 * </p>
jurzua
parents:
diff changeset
1017 * <p>
jurzua
parents:
diff changeset
1018 * The reason of this is that nodes are stored only in the DB and not in the
jurzua
parents:
diff changeset
1019 * cache.
jurzua
parents:
diff changeset
1020 * </p>
jurzua
parents:
diff changeset
1021 * <p>
jurzua
parents:
diff changeset
1022 * Later, when the nodes are required, they will be loaded from the BD to
jurzua
parents:
diff changeset
1023 * the cache automatically. However there are some structures like
jurzua
parents:
diff changeset
1024 * attributes by entId that become inconsistent using this method.
jurzua
parents:
diff changeset
1025 * </p>
jurzua
parents:
diff changeset
1026 *
jurzua
parents:
diff changeset
1027 * @param node
jurzua
parents:
diff changeset
1028 * non-persistent node.
jurzua
parents:
diff changeset
1029 * @param user
jurzua
parents:
diff changeset
1030 * @throws Exception
jurzua
parents:
diff changeset
1031 */
jurzua
parents:
diff changeset
1032 public void saveNodeOnlyForScripts(Node node, String user) throws Exception {
jurzua
parents:
diff changeset
1033 if (node.isPersistent()) {
jurzua
parents:
diff changeset
1034 throw new Exception(
jurzua
parents:
diff changeset
1035 "This method can save only non-persistent nodes. Because the nodes are stored only in the DB in not in the Cache.");
jurzua
parents:
diff changeset
1036 }
jurzua
parents:
diff changeset
1037 if (StringUtils.isEmpty(node.getType())) {
jurzua
parents:
diff changeset
1038 throw new Exception("The type of the node can not be empty");
jurzua
parents:
diff changeset
1039 }
jurzua
parents:
diff changeset
1040 node.setUser(user);
jurzua
parents:
diff changeset
1041 this.getPS().saveNode(node);
jurzua
parents:
diff changeset
1042
jurzua
parents:
diff changeset
1043 // if(StringUtils.isNotEmpty(node.getType())){
jurzua
parents:
diff changeset
1044 // if(node.getType().equals(Node.TYPE_ABOX)){
jurzua
parents:
diff changeset
1045 //
jurzua
parents:
diff changeset
1046 // }else if(node.getType().equals(Node.TYPE_TBOX)){
jurzua
parents:
diff changeset
1047 //
jurzua
parents:
diff changeset
1048 // }
jurzua
parents:
diff changeset
1049 // }
jurzua
parents:
diff changeset
1050 }
jurzua
parents:
diff changeset
1051
jurzua
parents:
diff changeset
1052 public void removeNode(Node node) {
jurzua
parents:
diff changeset
1053 this.getPS().removeNode(node);
jurzua
parents:
diff changeset
1054 }
jurzua
parents:
diff changeset
1055
jurzua
parents:
diff changeset
1056 public Map<Long, Long> saveEntityListAsNew(List<Entity> entities, String user,
jurzua
parents:
diff changeset
1057 boolean testWrongRelations) throws Exception {
jurzua
parents:
diff changeset
1058 logger.info("\n ### Making persistent Entities size total "
jurzua
parents:
diff changeset
1059 + entities.size() + " ### \n");
jurzua
parents:
diff changeset
1060 int sizePart = 1000;
jurzua
parents:
diff changeset
1061 List<Entity> tmpList = null;
jurzua
parents:
diff changeset
1062
jurzua
parents:
diff changeset
1063 Map<Long, Long> idMap = new HashMap<Long, Long>();
jurzua
parents:
diff changeset
1064
jurzua
parents:
diff changeset
1065 for (int j = 0; j <= (entities.size() / sizePart); j++) {
jurzua
parents:
diff changeset
1066 tmpList = new ArrayList<Entity>(sizePart);
jurzua
parents:
diff changeset
1067 for (int i = (j * sizePart); i < ((j + 1) * sizePart); i++) {
jurzua
parents:
diff changeset
1068
jurzua
parents:
diff changeset
1069 if (i < entities.size()) {
jurzua
parents:
diff changeset
1070 if (StringUtils.isNotEmpty(user)) {
jurzua
parents:
diff changeset
1071 entities.get(i).setUser(user);
jurzua
parents:
diff changeset
1072 }
jurzua
parents:
diff changeset
1073
jurzua
parents:
diff changeset
1074 if (testWrongRelations
jurzua
parents:
diff changeset
1075 && hasWrongRelations(entities.get(i))) {
jurzua
parents:
diff changeset
1076 throw new Exception("Wrong relations "
jurzua
parents:
diff changeset
1077 + entities.get(i));
jurzua
parents:
diff changeset
1078 }
jurzua
parents:
diff changeset
1079
jurzua
parents:
diff changeset
1080 tmpList.add(entities.get(i));
jurzua
parents:
diff changeset
1081 } else {
jurzua
parents:
diff changeset
1082 break;
jurzua
parents:
diff changeset
1083 }
jurzua
parents:
diff changeset
1084 }
jurzua
parents:
diff changeset
1085
jurzua
parents:
diff changeset
1086 logger.info("\nMaking persistent Entities part " + (j + 1) + " of "
jurzua
parents:
diff changeset
1087 + ((entities.size() / sizePart) + 1) + " size="
jurzua
parents:
diff changeset
1088 + tmpList.size());
jurzua
parents:
diff changeset
1089 idMap = this.getPS().saveEntityListAsNew(tmpList, idMap);
jurzua
parents:
diff changeset
1090 }
jurzua
parents:
diff changeset
1091 return idMap;
jurzua
parents:
diff changeset
1092 }
jurzua
parents:
diff changeset
1093
jurzua
parents:
diff changeset
1094 /*
jurzua
parents:
diff changeset
1095 public void saveEntityList(List<Entity> entities, String user,
jurzua
parents:
diff changeset
1096 boolean testWrongRelations) throws Exception {
jurzua
parents:
diff changeset
1097 logger.info("\n ### Making persistent Entities size total "
jurzua
parents:
diff changeset
1098 + entities.size() + " ### \n");
jurzua
parents:
diff changeset
1099 int sizePart = 1000;
jurzua
parents:
diff changeset
1100 List<Entity> tmpList = null;
jurzua
parents:
diff changeset
1101
jurzua
parents:
diff changeset
1102 for (int j = 0; j <= (entities.size() / sizePart); j++) {
jurzua
parents:
diff changeset
1103 tmpList = new ArrayList<Entity>(sizePart);
jurzua
parents:
diff changeset
1104 for (int i = (j * sizePart); i < ((j + 1) * sizePart); i++) {
jurzua
parents:
diff changeset
1105
jurzua
parents:
diff changeset
1106 if (i < entities.size()) {
jurzua
parents:
diff changeset
1107 if (StringUtils.isNotEmpty(user)) {
jurzua
parents:
diff changeset
1108 entities.get(i).setUser(user);
jurzua
parents:
diff changeset
1109 }
jurzua
parents:
diff changeset
1110
jurzua
parents:
diff changeset
1111 if (testWrongRelations
jurzua
parents:
diff changeset
1112 && hasWrongRelations(entities.get(i))) {
jurzua
parents:
diff changeset
1113 throw new Exception("Wrong relations "
jurzua
parents:
diff changeset
1114 + entities.get(i));
jurzua
parents:
diff changeset
1115 }
jurzua
parents:
diff changeset
1116
jurzua
parents:
diff changeset
1117 tmpList.add(entities.get(i));
jurzua
parents:
diff changeset
1118 } else {
jurzua
parents:
diff changeset
1119 break;
jurzua
parents:
diff changeset
1120 }
jurzua
parents:
diff changeset
1121 }
jurzua
parents:
diff changeset
1122
jurzua
parents:
diff changeset
1123 logger.info("\nMaking persistent Entities part " + (j + 1) + " of "
jurzua
parents:
diff changeset
1124 + ((entities.size() / sizePart) + 1) + " size="
jurzua
parents:
diff changeset
1125 + tmpList.size());
jurzua
parents:
diff changeset
1126 this.getPS().saveEntityList(tmpList);
jurzua
parents:
diff changeset
1127
jurzua
parents:
diff changeset
1128 for(Entity ent : tmpList){
jurzua
parents:
diff changeset
1129 logger.info("[U=" + user + "] SaveEntity " + ent.toSmallString());
jurzua
parents:
diff changeset
1130 }
jurzua
parents:
diff changeset
1131
jurzua
parents:
diff changeset
1132 }
jurzua
parents:
diff changeset
1133 }*/
jurzua
parents:
diff changeset
1134
jurzua
parents:
diff changeset
1135 public void saveConcept(Entity entity) throws Exception {
jurzua
parents:
diff changeset
1136 entity.setType(Node.TYPE_TBOX);
jurzua
parents:
diff changeset
1137 entity.setObjectClass(Node.TYPE_TBOX);
jurzua
parents:
diff changeset
1138 this.getPS().saveEntity(entity);
jurzua
parents:
diff changeset
1139 }
jurzua
parents:
diff changeset
1140
jurzua
parents:
diff changeset
1141 public void saveNodeListOnlyForScripts(List<Node> nodeList, String user)
jurzua
parents:
diff changeset
1142 throws Exception {
jurzua
parents:
diff changeset
1143 logger.debug("### Making persistent Nodes size total "
jurzua
parents:
diff changeset
1144 + nodeList.size() + " ###");
jurzua
parents:
diff changeset
1145 List<Node> list = null;
jurzua
parents:
diff changeset
1146 int sizePart = 1000;
jurzua
parents:
diff changeset
1147 for (int j = 0; j <= (nodeList.size() / sizePart); j++) {
jurzua
parents:
diff changeset
1148 list = new ArrayList<Node>();
jurzua
parents:
diff changeset
1149 for (int i = (j * sizePart); i < ((j + 1) * sizePart); i++) {
jurzua
parents:
diff changeset
1150 if (i < nodeList.size()) {
jurzua
parents:
diff changeset
1151 nodeList.get(i).setUser(user);
jurzua
parents:
diff changeset
1152 list.add(nodeList.get(i));
jurzua
parents:
diff changeset
1153 }
jurzua
parents:
diff changeset
1154 }
jurzua
parents:
diff changeset
1155 logger.debug("Making persistent Nodes part " + (j + 1) + " of "
jurzua
parents:
diff changeset
1156 + ((nodeList.size() / sizePart) + 1) + " size="
jurzua
parents:
diff changeset
1157 + list.size());
jurzua
parents:
diff changeset
1158 this.getPS().saveNodeList(list);
jurzua
parents:
diff changeset
1159 }
jurzua
parents:
diff changeset
1160 }
jurzua
parents:
diff changeset
1161
jurzua
parents:
diff changeset
1162 public void saveNodeListOnlyForScripts(List<Node> nodeList)
jurzua
parents:
diff changeset
1163 throws Exception {
jurzua
parents:
diff changeset
1164 logger.info("\n ### Making persistent Nodes size total "
jurzua
parents:
diff changeset
1165 + nodeList.size() + " ### \n");
jurzua
parents:
diff changeset
1166 int sizePart = 1000;
jurzua
parents:
diff changeset
1167 List<Node> list = null;
jurzua
parents:
diff changeset
1168 for (int j = 0; j <= (nodeList.size() / sizePart); j++) {
jurzua
parents:
diff changeset
1169 list = new ArrayList<Node>();
jurzua
parents:
diff changeset
1170 for (int i = (j * sizePart); i < ((j + 1) * sizePart); i++) {
jurzua
parents:
diff changeset
1171 if (i < nodeList.size()) {
jurzua
parents:
diff changeset
1172 list.add(nodeList.get(i));
jurzua
parents:
diff changeset
1173 }
jurzua
parents:
diff changeset
1174 }
jurzua
parents:
diff changeset
1175 logger.info("Making persistent Nodes part " + (j + 1) + " of "
jurzua
parents:
diff changeset
1176 + ((nodeList.size() / sizePart) + 1) + " size="
jurzua
parents:
diff changeset
1177 + list.size());
jurzua
parents:
diff changeset
1178 this.getPS().saveNodeList(list);
jurzua
parents:
diff changeset
1179 }
jurzua
parents:
diff changeset
1180 // this.persistenceService.saveNodeList(nodeList);
jurzua
parents:
diff changeset
1181 }
jurzua
parents:
diff changeset
1182
jurzua
parents:
diff changeset
1183 public List<Entity> getConcepts() {
jurzua
parents:
diff changeset
1184 return this.getPS().getEntities(null, Node.SYS_STATUS_CURRENT_VERSION,
jurzua
parents:
diff changeset
1185 Node.TYPE_TBOX, null);
jurzua
parents:
diff changeset
1186 }
jurzua
parents:
diff changeset
1187
jurzua
parents:
diff changeset
1188 public List<Entity> getAssertion() {
jurzua
parents:
diff changeset
1189 return this.getPS().getEntities(null, Node.SYS_STATUS_CURRENT_VERSION,
jurzua
parents:
diff changeset
1190 Node.TYPE_ABOX, null);
jurzua
parents:
diff changeset
1191 }
jurzua
parents:
diff changeset
1192
jurzua
parents:
diff changeset
1193 public List<Entity> getLightweightAssertionsByExactOwnValue(
jurzua
parents:
diff changeset
1194 String objectClass, String ownValue, int maxResult) {
jurzua
parents:
diff changeset
1195 return getPS().getLightweightEntities(Node.SYS_STATUS_CURRENT_VERSION,
jurzua
parents:
diff changeset
1196 null, Node.TYPE_ABOX, objectClass, ownValue, false, maxResult);
jurzua
parents:
diff changeset
1197 }
jurzua
parents:
diff changeset
1198
jurzua
parents:
diff changeset
1199 public void removeNodeList(List<Node> nodeList) {
jurzua
parents:
diff changeset
1200 System.out.println("\n ### Deleting Nodes size total "
jurzua
parents:
diff changeset
1201 + nodeList.size() + " ### \n");
jurzua
parents:
diff changeset
1202 this.getPS().removeNodeList(nodeList);
jurzua
parents:
diff changeset
1203 }
jurzua
parents:
diff changeset
1204
jurzua
parents:
diff changeset
1205 public void deleteAllConcepts() {
jurzua
parents:
diff changeset
1206 // persistenceService.deleteEntities(null, Node.TYPE_TBOX, true);
jurzua
parents:
diff changeset
1207 getPS().dropDefinitions();
jurzua
parents:
diff changeset
1208 }
jurzua
parents:
diff changeset
1209
jurzua
parents:
diff changeset
1210 public void importOM3Concepts(String fileName, Boolean dropConcepts) {
jurzua
parents:
diff changeset
1211 getPS().setImportModus(true);
jurzua
parents:
diff changeset
1212 ImportOM3Util.importConcepts(this, fileName, dropConcepts);
jurzua
parents:
diff changeset
1213 getPS().setImportModus(false);
jurzua
parents:
diff changeset
1214 }
jurzua
parents:
diff changeset
1215
jurzua
parents:
diff changeset
1216 // ///
jurzua
parents:
diff changeset
1217
jurzua
parents:
diff changeset
1218 public PersistenceService getPS() {
jurzua
parents:
diff changeset
1219 return this.cache.getPs();
jurzua
parents:
diff changeset
1220 }
jurzua
parents:
diff changeset
1221
jurzua
parents:
diff changeset
1222 public CacheService getCache() {
jurzua
parents:
diff changeset
1223 return cache;
jurzua
parents:
diff changeset
1224 }
jurzua
parents:
diff changeset
1225
jurzua
parents:
diff changeset
1226 public void setCache(CacheService cache) {
jurzua
parents:
diff changeset
1227 this.cache = cache;
jurzua
parents:
diff changeset
1228 }
jurzua
parents:
diff changeset
1229
jurzua
parents:
diff changeset
1230 public List<ViewerAttribute> getViewerAttributes(Long page){
jurzua
parents:
diff changeset
1231 List<ViewerAttribute> list = cache.getViewerAttributes(page);
jurzua
parents:
diff changeset
1232 Collections.sort(list);
jurzua
parents:
diff changeset
1233 return list;
jurzua
parents:
diff changeset
1234 }
jurzua
parents:
diff changeset
1235
jurzua
parents:
diff changeset
1236 public List<ViewerAttribute> getViewerAttributes4Edition(Long page) throws CloneNotSupportedException{
jurzua
parents:
diff changeset
1237 List<ViewerAttribute> list = new ArrayList<ViewerAttribute>();
jurzua
parents:
diff changeset
1238 for(ViewerAttribute att : cache.getViewerAttributes(page)){
jurzua
parents:
diff changeset
1239 list.add((ViewerAttribute)att.clone());
jurzua
parents:
diff changeset
1240 }
jurzua
parents:
diff changeset
1241 Collections.sort(list);
jurzua
parents:
diff changeset
1242 return list;
jurzua
parents:
diff changeset
1243 }
jurzua
parents:
diff changeset
1244
jurzua
parents:
diff changeset
1245 public Collection<ViewerPage> getViewerPages(){
jurzua
parents:
diff changeset
1246 return cache.getViewerPages();
jurzua
parents:
diff changeset
1247 }
jurzua
parents:
diff changeset
1248
jurzua
parents:
diff changeset
1249 public ViewerPage getViewerPage(Long id){
jurzua
parents:
diff changeset
1250 return cache.getViewerPageMap().get(id);
jurzua
parents:
diff changeset
1251 }
jurzua
parents:
diff changeset
1252
jurzua
parents:
diff changeset
1253 public ViewerPage getViewerPage(String definition){
jurzua
parents:
diff changeset
1254 for(ViewerPage page : cache.getViewerPages()){
jurzua
parents:
diff changeset
1255 if(page.getDefinition().equals(definition)){
jurzua
parents:
diff changeset
1256 return page;
jurzua
parents:
diff changeset
1257 }
jurzua
parents:
diff changeset
1258 }
jurzua
parents:
diff changeset
1259 return null;
jurzua
parents:
diff changeset
1260 }
jurzua
parents:
diff changeset
1261
jurzua
parents:
diff changeset
1262 public ViewerPage getViewerPage4Edition(Long id) throws CloneNotSupportedException{
jurzua
parents:
diff changeset
1263 ViewerPage page = cache.getViewerPageMap().get(id);
jurzua
parents:
diff changeset
1264 return (page != null) ? (ViewerPage) page.clone() : null;
jurzua
parents:
diff changeset
1265 }
jurzua
parents:
diff changeset
1266
jurzua
parents:
diff changeset
1267 public ViewerPage saveViewerPage(ViewerPage page, String user){
jurzua
parents:
diff changeset
1268 page.setUser(user);
jurzua
parents:
diff changeset
1269 return cache.saveViewerPage(page);
jurzua
parents:
diff changeset
1270
jurzua
parents:
diff changeset
1271 }
jurzua
parents:
diff changeset
1272
jurzua
parents:
diff changeset
1273 public ViewerAttribute saveViewerAttribute(ViewerPage page, ViewerAttribute att, String user) throws Exception{
jurzua
parents:
diff changeset
1274 att.setUser(user);
jurzua
parents:
diff changeset
1275 return cache.saveViewerAttribute(page, att);
jurzua
parents:
diff changeset
1276 }
jurzua
parents:
diff changeset
1277
jurzua
parents:
diff changeset
1278 /**
jurzua
parents:
diff changeset
1279 * Removes a page and all attributes associated with it.
jurzua
parents:
diff changeset
1280 * @param page
jurzua
parents:
diff changeset
1281 * @return
jurzua
parents:
diff changeset
1282 */
jurzua
parents:
diff changeset
1283 public int removeViewerPage(ViewerPage page){
jurzua
parents:
diff changeset
1284
jurzua
parents:
diff changeset
1285 return (page.getId() != null) ? cache.removeViewerPage(page.getId()) : 0;
jurzua
parents:
diff changeset
1286 }
jurzua
parents:
diff changeset
1287
jurzua
parents:
diff changeset
1288 public boolean removeViewerAnttribute(ViewerAttribute att){
jurzua
parents:
diff changeset
1289 return (att.getId() != null) ? cache.removeAtt(att.getId()) : false;
jurzua
parents:
diff changeset
1290 }
jurzua
parents:
diff changeset
1291 }