1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22 package org.bitrepository.pillar.cache;
23
24 import java.util.Map;
25 import org.bitrepository.common.settings.Settings;
26 import org.bitrepository.service.database.DBConnector;
27 import org.bitrepository.service.database.DatabaseMigrator;
28 import org.bitrepository.service.database.DatabaseUtils;
29 import org.slf4j.Logger;
30 import org.slf4j.LoggerFactory;
31
32 import static org.bitrepository.pillar.cache.database.DatabaseConstants.CHECKSUM_TABLE;
33 import static org.bitrepository.pillar.cache.database.DatabaseConstants.CS_COLLECTION_ID;
34
35
36
37
38 public class ChecksumDBMigrator extends DatabaseMigrator {
39
40 private static Logger log = LoggerFactory.getLogger(DatabaseUtils.class);
41
42 private final Settings settings;
43
44 private final Integer currentVersion = 2;
45
46
47
48
49
50
51
52 public ChecksumDBMigrator(DBConnector connector, Settings settings) {
53 super(connector);
54 this.settings = settings;
55 }
56
57 @Override
58 public void migrate() {
59 Map<String, Integer> versions = getTableVersions();
60
61 if(!versions.containsKey(CHECKSUM_TABLE)) {
62 throw new IllegalStateException("The database does not contain '" + CHECKSUM_TABLE
63 + "' table as required.");
64 }
65 if(versions.get(CHECKSUM_TABLE) == 1) {
66 migrateChecksumsTableFromVersion1To2();
67 }
68 }
69
70
71
72
73
74 private void migrateChecksumsTableFromVersion1To2() {
75 log.warn("Migrating the " + CHECKSUM_TABLE + " table from version 1 to 2 in the ChecksumDatabase.");
76
77 String alterSql = "ALTER TABLE " + CHECKSUM_TABLE + " ADD COLUMN " + CS_COLLECTION_ID + " VARCHAR(255)";
78 updateTable(CHECKSUM_TABLE, 2, alterSql, new Object[0]);
79
80 String updateAfterwards = "UPDATE " + CHECKSUM_TABLE + " SET " + CS_COLLECTION_ID + " = ? WHERE "
81 + CS_COLLECTION_ID + " IS NULL";
82 DatabaseUtils.executeStatement(connector, updateAfterwards, settings.getCollections().get(0).getID());
83 }
84
85 @Override
86 public boolean needsMigration() {
87 Map<String, Integer> versions = getTableVersions();
88
89 if(!versions.containsKey(CHECKSUM_TABLE)) {
90 throw new IllegalStateException("The database does not contain '" + CHECKSUM_TABLE
91 + "' table as required.");
92 }
93
94 if(versions.get(CHECKSUM_TABLE) < currentVersion) {
95 return true;
96 } else {
97 return false;
98 }
99 }
100 }