aboutsummaryrefslogtreecommitdiff
path: root/src/main/kotlin/moe/nea/ledger/database/Database.kt
blob: 025888c34f231ff50dd075dc1b7526b5cf716a4c (plain)
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
package moe.nea.ledger.database

import moe.nea.ledger.Ledger
import moe.nea.ledger.database.columns.DBString
import java.sql.Connection
import java.sql.DriverManager

class Database {
	lateinit var connection: Connection

	object MetaTable : Table("LedgerMeta") {
		val key = column("key", DBString)
		val value = column("value", DBString)

		init {
			unique(key)
		}
	}

	data class MetaKey(val name: String) {
		companion object {
			val DATABASE_VERSION = MetaKey("databaseVersion")
			val LAST_LAUNCH = MetaKey("lastLaunch")
		}
	}

	fun setMetaKey(key: MetaKey, value: String) {
		MetaTable.insert(connection, Table.OnConflict.REPLACE) {
			it[MetaTable.key] = key.name
			it[MetaTable.value] = value
		}
	}

	val databaseVersion: Long = 1

	fun loadAndUpgrade() {
		connection = DriverManager.getConnection("jdbc:sqlite:${Ledger.dataFolder.resolve("database.db")}")
		MetaTable.createIfNotExists(connection)
		val meta = MetaTable.selectAll(connection).associate { MetaKey(it[MetaTable.key]) to it[MetaTable.value] }
		val lastLaunch = meta[MetaKey.LAST_LAUNCH]?.toLong() ?: 0L
		println("Last launch $lastLaunch")
		setMetaKey(MetaKey.LAST_LAUNCH, System.currentTimeMillis().toString())

		val oldVersion = meta[MetaKey.DATABASE_VERSION]?.toLong() ?: -1
		println("Old Database Version: $oldVersion; Current version: $databaseVersion")
		if (oldVersion > databaseVersion)
			error("Outdated software. Database is newer than me!")
		// TODO: create a backup if there is a db version upgrade happening
		DBUpgrade.performUpgradeChain(
			connection, oldVersion, databaseVersion,
			Upgrades().upgrades
		) { version ->
			setMetaKey(MetaKey.DATABASE_VERSION, version.toString())
		}
	}

}