Merge pull request #2422 from NoelDeMartin/MOBILE-3401

MOBILE-3401: Wait database to be ready in xapi offline provider
main
Juan Leyva 2020-06-22 19:34:01 +02:00 committed by GitHub
commit 2ddb8fda69
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 28 additions and 14 deletions

View File

@ -14,7 +14,7 @@
import { Injectable } from '@angular/core'; import { Injectable } from '@angular/core';
import { CoreSites, CoreSiteSchema } from '@providers/sites'; import { CoreSites, CoreSiteSchema } from '@providers/sites';
import { SQLiteDB } from '@classes/sqlitedb';
import { makeSingleton } from '@singletons/core.singletons'; import { makeSingleton } from '@singletons/core.singletons';
/** /**
@ -68,8 +68,10 @@ export class CoreXAPIOfflineProvider {
] ]
}; };
protected dbReady: Promise<any>; // Promise resolved when the DB schema is ready.
constructor() { constructor() {
CoreSites.instance.registerSiteSchema(this.siteSchema); this.dbReady = CoreSites.instance.registerSiteSchema(this.siteSchema);
} }
/** /**
@ -93,9 +95,9 @@ export class CoreXAPIOfflineProvider {
* @return Promise resolved if stored, rejected if failure. * @return Promise resolved if stored, rejected if failure.
*/ */
async deleteStatements(id: number, siteId?: string): Promise<void> { async deleteStatements(id: number, siteId?: string): Promise<void> {
const site = await CoreSites.instance.getSite(siteId); const db = await this.getSiteDB(siteId);
await site.getDb().deleteRecords(CoreXAPIOfflineProvider.STATEMENTS_TABLE, {id}); await db.deleteRecords(CoreXAPIOfflineProvider.STATEMENTS_TABLE, {id});
} }
/** /**
@ -106,9 +108,9 @@ export class CoreXAPIOfflineProvider {
* @return Promise resolved if stored, rejected if failure. * @return Promise resolved if stored, rejected if failure.
*/ */
async deleteStatementsForContext(contextId: number, siteId?: string): Promise<void> { async deleteStatementsForContext(contextId: number, siteId?: string): Promise<void> {
const site = await CoreSites.instance.getSite(siteId); const db = await this.getSiteDB(siteId);
await site.getDb().deleteRecords(CoreXAPIOfflineProvider.STATEMENTS_TABLE, {contextid: contextId}); await db.deleteRecords(CoreXAPIOfflineProvider.STATEMENTS_TABLE, {contextid: contextId});
} }
/** /**
@ -118,9 +120,9 @@ export class CoreXAPIOfflineProvider {
* @return Promise resolved with all the data. * @return Promise resolved with all the data.
*/ */
async getAllStatements(siteId?: string): Promise<CoreXAPIOfflineStatementsDBData[]> { async getAllStatements(siteId?: string): Promise<CoreXAPIOfflineStatementsDBData[]> {
const site = await CoreSites.instance.getSite(siteId); const db = await this.getSiteDB(siteId);
return site.getDb().getRecords(CoreXAPIOfflineProvider.STATEMENTS_TABLE, undefined, 'timecreated ASC'); return db.getRecords(CoreXAPIOfflineProvider.STATEMENTS_TABLE, undefined, 'timecreated ASC');
} }
/** /**
@ -131,9 +133,9 @@ export class CoreXAPIOfflineProvider {
* @return Promise resolved with the data. * @return Promise resolved with the data.
*/ */
async getContextStatements(contextId: number, siteId?: string): Promise<CoreXAPIOfflineStatementsDBData[]> { async getContextStatements(contextId: number, siteId?: string): Promise<CoreXAPIOfflineStatementsDBData[]> {
const site = await CoreSites.instance.getSite(siteId); const db = await this.getSiteDB(siteId);
return site.getDb().getRecords(CoreXAPIOfflineProvider.STATEMENTS_TABLE, {contextid: contextId}, 'timecreated ASC'); return db.getRecords(CoreXAPIOfflineProvider.STATEMENTS_TABLE, {contextid: contextId}, 'timecreated ASC');
} }
/** /**
@ -144,9 +146,9 @@ export class CoreXAPIOfflineProvider {
* @return Promise resolved with the data. * @return Promise resolved with the data.
*/ */
async getStatements(id: number, siteId?: string): Promise<CoreXAPIOfflineStatementsDBData> { async getStatements(id: number, siteId?: string): Promise<CoreXAPIOfflineStatementsDBData> {
const site = await CoreSites.instance.getSite(siteId); const db = await this.getSiteDB(siteId);
return site.getDb().getRecord(CoreXAPIOfflineProvider.STATEMENTS_TABLE, {id}); return db.getRecord(CoreXAPIOfflineProvider.STATEMENTS_TABLE, {id});
} }
/** /**
@ -161,7 +163,7 @@ export class CoreXAPIOfflineProvider {
async saveStatements(contextId: number, component: string, statements: string, options?: CoreXAPIOfflineSaveStatementsOptions) async saveStatements(contextId: number, component: string, statements: string, options?: CoreXAPIOfflineSaveStatementsOptions)
: Promise<void> { : Promise<void> {
const site = await CoreSites.instance.getSite(options.siteId); const db = await this.getSiteDB(options.siteId);
const entry = { const entry = {
contextid: contextId, contextid: contextId,
@ -172,7 +174,19 @@ export class CoreXAPIOfflineProvider {
extra: options.extra, extra: options.extra,
}; };
await site.getDb().insertRecord(CoreXAPIOfflineProvider.STATEMENTS_TABLE, entry); await db.insertRecord(CoreXAPIOfflineProvider.STATEMENTS_TABLE, entry);
}
/**
* Get Site database when ready.
*
* @param siteId Site id.
* @return SQLiteDB Site database.
*/
protected async getSiteDB(siteId: string): Promise<SQLiteDB> {
await this.dbReady;
return CoreSites.instance.getSiteDb(siteId);
} }
} }