diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2015-08-02 16:53:24 +1200 |
---|---|---|
committer | Anton Tananaev <anton.tananaev@gmail.com> | 2015-08-02 16:53:24 +1200 |
commit | 2617753615e47acb6600a7d551c4f6508f5af91f (patch) | |
tree | 33497cb97473da56ce339b5b0acc29628a913af5 | |
parent | 6f47747e6a438037392794f72ac91dbce6cc6683 (diff) | |
download | trackermap-server-2617753615e47acb6600a7d551c4f6508f5af91f.tar.gz trackermap-server-2617753615e47acb6600a7d551c4f6508f5af91f.tar.bz2 trackermap-server-2617753615e47acb6600a7d551c4f6508f5af91f.zip |
Add database schema version
-rw-r--r-- | debug.xml | 8 | ||||
-rw-r--r-- | src/org/traccar/database/DataManager.java | 18 | ||||
-rw-r--r-- | src/org/traccar/model/Schema.java | 29 |
3 files changed, 55 insertions, 0 deletions
@@ -45,6 +45,10 @@ <entry key='database.checkTable'>traccar</entry> + <entry key='database.selectSchemaVersion'> + SELECT * FROM traccar; + </entry> + <entry key='database.createSchema'> CREATE TABLE "user" ( id INT PRIMARY KEY AUTO_INCREMENT, @@ -79,6 +83,8 @@ FOREIGN KEY (userId) REFERENCES "user" (id) ON DELETE CASCADE, FOREIGN KEY (deviceId) REFERENCES device (id) ON DELETE CASCADE); + CREATE INDEX user_device_userId ON user_device(userId); + CREATE TABLE position ( id INT PRIMARY KEY AUTO_INCREMENT, protocol VARCHAR(128), @@ -126,6 +132,8 @@ CREATE TABLE traccar ( version INT DEFAULT 0 NOT NULL); + + INSERT INTO traccar (version) VALUES (301); </entry> <entry key='database.selectServers'> diff --git a/src/org/traccar/database/DataManager.java b/src/org/traccar/database/DataManager.java index 4c12ecd77..3cfeadae4 100644 --- a/src/org/traccar/database/DataManager.java +++ b/src/org/traccar/database/DataManager.java @@ -38,6 +38,7 @@ import org.traccar.model.Device; import org.traccar.model.MiscFormatter; import org.traccar.model.Permission; import org.traccar.model.Position; +import org.traccar.model.Schema; import org.traccar.model.Server; import org.traccar.model.User; import org.traccar.web.AsyncServlet; @@ -157,6 +158,23 @@ public class DataManager implements IdentityManager { } } if (exist) { + + String schemaVersionQuery = getQuery("database.selectSchemaVersion"); + if (schemaVersionQuery != null) { + + Schema schema = QueryBuilder.create(dataSource, schemaVersionQuery).executeQuerySingle(new Schema()); + + int version = 0; + if (schema != null) { + version = schema.getVersion(); + } + + if (version != 301) { + Log.error("Wrong database schema version (" + version + ")"); + throw new RuntimeException(); + } + } + return; } diff --git a/src/org/traccar/model/Schema.java b/src/org/traccar/model/Schema.java new file mode 100644 index 000000000..1878f0edb --- /dev/null +++ b/src/org/traccar/model/Schema.java @@ -0,0 +1,29 @@ +/* + * Copyright 2015 Anton Tananaev (anton.tananaev@gmail.com) + * + * 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.traccar.model; + +public class Schema implements Factory { + + @Override + public Schema create() { + return new Schema(); + } + + private int version; + public int getVersion() { return version; } + public void setVersion(int version) { this.version = version; } + +} |