annotate src/main/java/org/mpi/openmind/scripts/CodexOwnValueGenerator.java @ 90:4b6c0b368f46

new UpdateMpiwgDigitalizations script.
author Robert Casties <casties@mpiwg-berlin.mpg.de>
date Tue, 29 May 2018 21:15:06 +0200
parents 615d27dce9b3
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
jurzua
parents:
diff changeset
1 package org.mpi.openmind.scripts;
jurzua
parents:
diff changeset
2
jurzua
parents:
diff changeset
3 import java.text.SimpleDateFormat;
jurzua
parents:
diff changeset
4 import java.util.ArrayList;
jurzua
parents:
diff changeset
5 import java.util.Date;
jurzua
parents:
diff changeset
6 import java.util.List;
jurzua
parents:
diff changeset
7
jurzua
parents:
diff changeset
8 import org.apache.log4j.ConsoleAppender;
jurzua
parents:
diff changeset
9 import org.apache.log4j.Level;
jurzua
parents:
diff changeset
10 import org.apache.log4j.Logger;
jurzua
parents:
diff changeset
11 import org.apache.log4j.PatternLayout;
jurzua
parents:
diff changeset
12 import org.mpi.openmind.cache.WrapperService;
jurzua
parents:
diff changeset
13 import org.mpi.openmind.repository.bo.Attribute;
jurzua
parents:
diff changeset
14 import org.mpi.openmind.repository.bo.Entity;
jurzua
parents:
diff changeset
15 import org.mpi.openmind.repository.bo.Node;
jurzua
parents:
diff changeset
16 import org.mpi.openmind.repository.services.PersistenceService;
jurzua
parents:
diff changeset
17 import org.mpi.openmind.repository.services.ServiceRegistry;
jurzua
parents:
diff changeset
18 import org.mpi.openmind.repository.utils.OMUtils;
jurzua
parents:
diff changeset
19
jurzua
parents:
diff changeset
20 public class CodexOwnValueGenerator {
jurzua
parents:
diff changeset
21
jurzua
parents:
diff changeset
22 private static Logger logger = Logger.getLogger(CodexOwnValueGenerator.class);
jurzua
parents:
diff changeset
23
jurzua
parents:
diff changeset
24 private WrapperService ot;
jurzua
parents:
diff changeset
25 private PersistenceService ss;
jurzua
parents:
diff changeset
26
jurzua
parents:
diff changeset
27 public CodexOwnValueGenerator(WrapperService ot){
jurzua
parents:
diff changeset
28 this.ot = ot;
jurzua
parents:
diff changeset
29 this.ss = ot.getPS();
jurzua
parents:
diff changeset
30 }
jurzua
parents:
diff changeset
31
jurzua
parents:
diff changeset
32
jurzua
parents:
diff changeset
33 public void execute(){
jurzua
parents:
diff changeset
34 try {
jurzua
parents:
diff changeset
35 logger.info("Starting CodexOwnValueGenerator");
jurzua
parents:
diff changeset
36 List<Entity> codexList = ot.getLightweightAssertions("CODEX", null, -1);
jurzua
parents:
diff changeset
37 logger.info("Codices="+ codexList.size());
jurzua
parents:
diff changeset
38 List<Node> dirtyEntities = new ArrayList<Node>();
jurzua
parents:
diff changeset
39 int count = 0;
jurzua
parents:
diff changeset
40 int countCodicesNonCollection = 0;
jurzua
parents:
diff changeset
41 for(Entity codex : codexList){
jurzua
parents:
diff changeset
42
jurzua
parents:
diff changeset
43 Attribute codexIdAtt = ss.getAttributeByName(codex, "identifier");
jurzua
parents:
diff changeset
44 if(codexIdAtt == null){
jurzua
parents:
diff changeset
45 throw new Exception("identifier is null for " + codex);
jurzua
parents:
diff changeset
46 }
jurzua
parents:
diff changeset
47 String ov = new String();
jurzua
parents:
diff changeset
48
jurzua
parents:
diff changeset
49 List<Entity> list0 = this.ss.getTargetsForSourceRelation(codex, "is_part_of", "COLLECTION", 1);
jurzua
parents:
diff changeset
50
jurzua
parents:
diff changeset
51
jurzua
parents:
diff changeset
52 Entity collection;
jurzua
parents:
diff changeset
53 if(list0.size() > 0){
jurzua
parents:
diff changeset
54 collection = list0.get(0);
jurzua
parents:
diff changeset
55 if(collection != null){
jurzua
parents:
diff changeset
56 ov = collection.getOwnValue() + "_" + codexIdAtt.getValue();
jurzua
parents:
diff changeset
57 }else{
jurzua
parents:
diff changeset
58 ov = "empty_" + codexIdAtt.getValue();
jurzua
parents:
diff changeset
59 countCodicesNonCollection++;
jurzua
parents:
diff changeset
60 }
jurzua
parents:
diff changeset
61 if(count % 100 == 0){
jurzua
parents:
diff changeset
62 int size = codexList.size();
jurzua
parents:
diff changeset
63
jurzua
parents:
diff changeset
64 logger.info("* " + OMUtils.percentage(count, size) + " %");
jurzua
parents:
diff changeset
65 }
jurzua
parents:
diff changeset
66 count++;
jurzua
parents:
diff changeset
67 codex.setOwnValue(ov);
jurzua
parents:
diff changeset
68 dirtyEntities.add(codex);
jurzua
parents:
diff changeset
69 }
jurzua
parents:
diff changeset
70 }
jurzua
parents:
diff changeset
71 ot.saveNodeListOnlyForScripts(dirtyEntities);
jurzua
parents:
diff changeset
72
jurzua
parents:
diff changeset
73 logger.info("Summary");
jurzua
parents:
diff changeset
74 logger.info("Codices without collection=" + countCodicesNonCollection);
jurzua
parents:
diff changeset
75 logger.info("Total=" + count);
jurzua
parents:
diff changeset
76
jurzua
parents:
diff changeset
77
jurzua
parents:
diff changeset
78 } catch (Exception e) {
jurzua
parents:
diff changeset
79 e.printStackTrace();
jurzua
parents:
diff changeset
80 }
jurzua
parents:
diff changeset
81 }
jurzua
parents:
diff changeset
82
jurzua
parents:
diff changeset
83 public static void main(String[] args) {
jurzua
parents:
diff changeset
84 ServiceRegistry services = new ServiceRegistry();
jurzua
parents:
diff changeset
85 CodexOwnValueGenerator script = new CodexOwnValueGenerator(services.getWrapper());
jurzua
parents:
diff changeset
86 script.execute();
jurzua
parents:
diff changeset
87 System.exit(0);
jurzua
parents:
diff changeset
88 }
jurzua
parents:
diff changeset
89 }