2016-11-29 04:18:44 +00:00
|
|
|
import argparse
|
|
|
|
import os
|
|
|
|
import sqlite3
|
|
|
|
import sys
|
|
|
|
|
|
|
|
import phototagger
|
|
|
|
|
|
|
|
def upgrade_1_to_2(sql):
|
|
|
|
'''
|
|
|
|
In this version, a column `tagged_at` was added to the Photos table, to keep
|
|
|
|
track of the last time the photo's tags were edited (added or removed).
|
|
|
|
'''
|
|
|
|
cur = sql.cursor()
|
|
|
|
cur.execute('ALTER TABLE photos ADD COLUMN tagged_at INT')
|
|
|
|
|
2016-12-16 23:45:46 +00:00
|
|
|
def upgrade_2_to_3(sql):
|
|
|
|
'''
|
|
|
|
Preliminary support for user account management was added. This includes a `user` table
|
|
|
|
with id, username, password hash, and a timestamp.
|
|
|
|
Plus some indices.
|
|
|
|
'''
|
|
|
|
cur = sql.cursor()
|
|
|
|
cur.execute('''
|
|
|
|
CREATE TABLE IF NOT EXISTS users(
|
|
|
|
id TEXT,
|
|
|
|
username TEXT COLLATE NOCASE,
|
|
|
|
password BLOB,
|
|
|
|
created INT
|
|
|
|
)
|
|
|
|
''')
|
|
|
|
cur.execute('CREATE INDEX IF NOT EXISTS index_user_id ON users(id)')
|
|
|
|
cur.execute('CREATE INDEX IF NOT EXISTS index_user_username ON users(username COLLATE NOCASE)')
|
|
|
|
|
2016-12-20 22:54:23 +00:00
|
|
|
def upgrade_3_to_4(sql):
|
|
|
|
'''
|
|
|
|
Add an `author_id` column to Photos.
|
|
|
|
'''
|
|
|
|
cur = sql.cursor()
|
|
|
|
cur.execute('ALTER TABLE photos ADD COLUMN author_id TEXT')
|
|
|
|
cur.execute('CREATE INDEX IF NOT EXISTS index_photo_author on photos(author_id)')
|
2016-11-29 04:18:44 +00:00
|
|
|
|
2017-02-05 02:30:02 +00:00
|
|
|
def upgrade_4_to_5(sql):
|
|
|
|
'''
|
|
|
|
Add table `bookmarks` and its indices.
|
|
|
|
'''
|
|
|
|
cur = sql.cursor()
|
|
|
|
cur.execute('''
|
|
|
|
CREATE TABLE IF NOT EXISTS bookmarks(
|
|
|
|
id TEXT,
|
|
|
|
title TEXT,
|
|
|
|
url TEXT,
|
|
|
|
author_id TEXT
|
|
|
|
)
|
|
|
|
''')
|
|
|
|
cur.execute('CREATE INDEX IF NOT EXISTS index_bookmark_id on bookmarks(id)')
|
|
|
|
cur.execute('CREATE INDEX IF NOT EXISTS index_bookmark_author on bookmarks(author_id)')
|
|
|
|
|
2016-11-29 04:18:44 +00:00
|
|
|
def upgrade_all(database_filename):
|
|
|
|
'''
|
|
|
|
Given the filename of a phototagger database, apply all of the needed
|
|
|
|
upgrade_x_to_y functions in order.
|
|
|
|
'''
|
|
|
|
if not os.path.isfile(database_filename):
|
|
|
|
raise FileNotFoundError(database_filename)
|
|
|
|
|
|
|
|
sql = sqlite3.connect(database_filename)
|
|
|
|
cur = sql.cursor()
|
|
|
|
|
|
|
|
cur.execute('PRAGMA user_version')
|
|
|
|
current_version = cur.fetchone()[0]
|
|
|
|
needed_version = phototagger.DATABASE_VERSION
|
|
|
|
|
|
|
|
if current_version == needed_version:
|
2016-12-17 01:59:43 +00:00
|
|
|
print('Already up-to-date with version %d.' % needed_version)
|
2016-11-29 04:18:44 +00:00
|
|
|
return
|
|
|
|
|
|
|
|
for version_number in range(current_version + 1, needed_version + 1):
|
|
|
|
print('Upgrading from %d to %d' % (current_version, version_number))
|
|
|
|
upgrade_function = 'upgrade_%d_to_%d' % (current_version, version_number)
|
|
|
|
upgrade_function = eval(upgrade_function)
|
|
|
|
upgrade_function(sql)
|
2016-12-16 23:45:46 +00:00
|
|
|
sql.cursor().execute('PRAGMA user_version = %d' % version_number)
|
2016-11-29 04:18:44 +00:00
|
|
|
sql.commit()
|
|
|
|
current_version = version_number
|
|
|
|
print('Upgrades finished.')
|
|
|
|
|
|
|
|
|
|
|
|
def upgrade_all_argparse(args):
|
|
|
|
return upgrade_all(database_filename=args.database_filename)
|
|
|
|
|
|
|
|
def main(argv):
|
|
|
|
parser = argparse.ArgumentParser()
|
|
|
|
|
|
|
|
parser.add_argument('database_filename')
|
|
|
|
parser.set_defaults(func=upgrade_all_argparse)
|
|
|
|
|
|
|
|
args = parser.parse_args(argv)
|
|
|
|
args.func(args)
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main(sys.argv[1:])
|