Skip to content

JouriFledderman/ng-database-updater

Repository files navigation

ng-database-updater

Description

In the backend there are lots of tools helping you update your database safely to the next version, such as Liquibase or FlywayDB). When you look at the frontend frameworks there is significantly less tooling available. But it is not unthinkable to have an SQLite database running in an app, or on a website. And it is thus not unthinkable that this database should be updated as well at a certain moment. But how do you safely update a database that is running on a client? ng-database-updater is a plugin that helps you do this in a safe and secure way.

It will automatically create a schema_version table for your SQLite database and it will verify which of the sql updates is already executed and which of the updates is still pending. From the already executed scripts it will check if the checksum is still valid, to make sure that the updatescripts did not change over time and in that way to be sure that in case the database needs to be recreated, the same scripts are executed in the same manner. It will run all pending updates with a newer version then the current database version. And each update will be added to the schema_version table, so it will be verified for its checksum next time and it will not be executed again.

Installation

For both NPM and Bower: Do not forget to reference the installed plugin in your index.html file (for example: 'lib/ng-database-updater/ngDatabaseUpdater.js').

Bower

run: bower install git+https://github.com/JouriFledderman/ng-database-update.git

NPM

run: npm install ng-database-updater

Usage

When you add the ngDatabaseUpdate module to your angularJS project the $databaseupdater becomes available. It is then possible to inject this somewhere in your project. In order to check for and execute updates, run the initialize function. This async function needs the following arguments: database, set of updates, logger. The following code is an example of how you can run the $databaseupdater:

let updates = [{
    version: 201812040933,
    script: 'CREATE TABLE IF NOT EXISTS Person (id INTEGER PRIMARY KEY, firstname VARCHAR (255))'
}];

let logger = console;
let database = openDatabase('tutorial', '1.0', 'tutorial', 2 * 1024 * 1024);

$databaseupdater.initialize(database, updates, logger).then(function (schema_version) {
    // code that runs when schema is updated
    ...
}).catch(function (error) {
    logger.error(error.message);
});

Database

The first thing it needs is a database it can read from and write to. You can obtain a connection to an SQLite database in javascript by running the following command:

openDatabase('tutorial', '1.0', 'tutorial', 2 * 1024 * 1024)

Updates

The second thing it needs is an array of updates. An update has a specific format within this framework. It is a simple object that contains a version and a script field. The version is a number and is used to determine which script is newer, a good practice would be to add a timestamp (yyyyMMddHHmm -> 201811081506) as a version of the update. Chances are very slim that two scripts will be added at the same minute and the newest script is alway executed latest. The script is a string and contains the SQLite script.

Logger (Optional)

The third argument is a logger, in order for your application to log something about what is going on. You can use for example the default $log from angular or the one from console. If you do not provide a logger, the code still works, but it will simply not log about it.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published