2015-12-25 22:42:14 +01:00
|
|
|
/*
|
|
|
|
This file is part of TALER
|
2016-01-10 20:07:42 +01:00
|
|
|
(C) 2016 GNUnet e.V.
|
2015-12-25 22:42:14 +01:00
|
|
|
|
|
|
|
TALER is free software; you can redistribute it and/or modify it under the
|
|
|
|
terms of the GNU General Public License as published by the Free Software
|
|
|
|
Foundation; either version 3, or (at your option) any later version.
|
|
|
|
|
|
|
|
TALER is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
|
|
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
|
|
A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License along with
|
2016-07-07 17:59:29 +02:00
|
|
|
TALER; see the file COPYING. If not, see <http://www.gnu.org/licenses/>
|
2015-12-25 22:42:14 +01:00
|
|
|
*/
|
|
|
|
|
2015-12-17 22:56:24 +01:00
|
|
|
"use strict";
|
2016-09-12 20:25:56 +02:00
|
|
|
import Dictionary = _.Dictionary;
|
2015-12-25 22:42:14 +01:00
|
|
|
|
2015-12-17 22:56:24 +01:00
|
|
|
/**
|
|
|
|
* Declarations and helpers for
|
|
|
|
* things that are stored in the wallet's
|
|
|
|
* database.
|
2016-01-05 15:42:46 +01:00
|
|
|
* @module Db
|
|
|
|
* @author Florian Dold
|
2015-12-17 22:56:24 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
const DB_NAME = "taler";
|
2016-05-25 21:24:21 +02:00
|
|
|
const DB_VERSION = 7;
|
2015-12-17 22:56:24 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return a promise that resolves
|
|
|
|
* to the taler wallet db.
|
|
|
|
*/
|
2016-01-10 20:07:42 +01:00
|
|
|
export function openTalerDb(): Promise<IDBDatabase> {
|
2015-12-17 22:56:24 +01:00
|
|
|
return new Promise((resolve, reject) => {
|
2016-01-24 02:29:13 +01:00
|
|
|
const req = indexedDB.open(DB_NAME, DB_VERSION);
|
2015-12-17 22:56:24 +01:00
|
|
|
req.onerror = (e) => {
|
|
|
|
reject(e);
|
|
|
|
};
|
|
|
|
req.onsuccess = (e) => {
|
|
|
|
resolve(req.result);
|
|
|
|
};
|
|
|
|
req.onupgradeneeded = (e) => {
|
2016-05-24 17:30:27 +02:00
|
|
|
const db = req.result;
|
2016-01-05 14:20:13 +01:00
|
|
|
console.log("DB: upgrade needed: oldVersion = " + e.oldVersion);
|
2015-12-17 22:56:24 +01:00
|
|
|
switch (e.oldVersion) {
|
|
|
|
case 0: // DB does not exist yet
|
2016-03-02 00:47:00 +01:00
|
|
|
const exchanges = db.createObjectStore("exchanges",
|
|
|
|
{keyPath: "baseUrl"});
|
2016-03-01 19:39:17 +01:00
|
|
|
exchanges.createIndex("pubKey", "masterPublicKey");
|
2016-01-05 14:20:13 +01:00
|
|
|
db.createObjectStore("reserves", {keyPath: "reserve_pub"});
|
2016-01-24 02:29:13 +01:00
|
|
|
const coins = db.createObjectStore("coins", {keyPath: "coinPub"});
|
2016-03-01 19:39:17 +01:00
|
|
|
coins.createIndex("exchangeBaseUrl", "exchangeBaseUrl");
|
2016-02-23 14:07:53 +01:00
|
|
|
const transactions = db.createObjectStore("transactions",
|
|
|
|
{keyPath: "contractHash"});
|
|
|
|
transactions.createIndex("repurchase",
|
|
|
|
[
|
|
|
|
"contract.merchant_pub",
|
|
|
|
"contract.repurchase_correlation_id"
|
|
|
|
]);
|
|
|
|
|
2016-01-05 14:20:13 +01:00
|
|
|
db.createObjectStore("precoins",
|
|
|
|
{keyPath: "coinPub", autoIncrement: true});
|
2016-02-23 14:07:53 +01:00
|
|
|
const history = db.createObjectStore("history",
|
|
|
|
{
|
|
|
|
keyPath: "id",
|
|
|
|
autoIncrement: true
|
|
|
|
});
|
2016-01-24 02:29:13 +01:00
|
|
|
history.createIndex("timestamp", "timestamp");
|
2015-12-17 22:56:24 +01:00
|
|
|
break;
|
2016-03-02 00:47:00 +01:00
|
|
|
default:
|
|
|
|
if (e.oldVersion != DB_VERSION) {
|
|
|
|
window.alert("Incompatible wallet dababase version, please reset" +
|
|
|
|
" db.");
|
|
|
|
chrome.browserAction.setBadgeText({text: "R!"});
|
|
|
|
chrome.browserAction.setBadgeBackgroundColor({color: "#F00"});
|
|
|
|
throw Error("incompatible DB");
|
|
|
|
}
|
|
|
|
break;
|
2015-12-17 22:56:24 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
});
|
|
|
|
}
|
2016-01-05 14:20:13 +01:00
|
|
|
|
|
|
|
|
2016-09-12 20:25:56 +02:00
|
|
|
export function exportDb(db: IDBDatabase): Promise<any> {
|
2016-01-05 14:20:13 +01:00
|
|
|
let dump = {
|
|
|
|
name: db.name,
|
|
|
|
version: db.version,
|
2016-09-12 20:25:56 +02:00
|
|
|
stores: {} as Dictionary<any>,
|
2016-01-05 14:20:13 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
|
|
|
|
let tx = db.transaction(db.objectStoreNames);
|
2016-09-12 20:25:56 +02:00
|
|
|
tx.addEventListener("complete", () => {
|
2016-01-05 14:20:13 +01:00
|
|
|
resolve(dump);
|
|
|
|
});
|
|
|
|
for (let i = 0; i < db.objectStoreNames.length; i++) {
|
|
|
|
let name = db.objectStoreNames[i];
|
2016-09-12 20:25:56 +02:00
|
|
|
let storeDump = {} as Dictionary<any>;
|
2016-01-05 14:20:13 +01:00
|
|
|
dump.stores[name] = storeDump;
|
|
|
|
let store = tx.objectStore(name)
|
|
|
|
.openCursor()
|
2016-09-12 20:25:56 +02:00
|
|
|
.addEventListener("success", (e: Event) => {
|
|
|
|
let cursor = (e.target as any).result;
|
2016-01-05 14:20:13 +01:00
|
|
|
if (cursor) {
|
|
|
|
storeDump[cursor.key] = cursor.value;
|
|
|
|
cursor.continue();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
2016-01-06 15:39:22 +01:00
|
|
|
}
|
2016-01-10 20:07:42 +01:00
|
|
|
|
|
|
|
export function deleteDb() {
|
|
|
|
indexedDB.deleteDatabase(DB_NAME);
|
|
|
|
}
|