embedded: add missing DB remove call in reset
This commit is contained in:
parent
7985b0a33f
commit
339080e014
@ -23,6 +23,7 @@ export interface QjsOsLib {
|
|||||||
postMessageToHost(s: string): void;
|
postMessageToHost(s: string): void;
|
||||||
setMessageFromHostHandler(h: (s: string) => void): void;
|
setMessageFromHostHandler(h: (s: string) => void): void;
|
||||||
rename(oldPath: string, newPath: string): number;
|
rename(oldPath: string, newPath: string): number;
|
||||||
|
remove(path: string): number;
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface QjsStdLib {
|
export interface QjsStdLib {
|
||||||
|
@ -30,6 +30,7 @@ import {
|
|||||||
Logger,
|
Logger,
|
||||||
setGlobalLogLevelFromString,
|
setGlobalLogLevelFromString,
|
||||||
setPRNG,
|
setPRNG,
|
||||||
|
TalerErrorCode,
|
||||||
WalletNotification,
|
WalletNotification,
|
||||||
} from "@gnu-taler/taler-util";
|
} from "@gnu-taler/taler-util";
|
||||||
import { createPlatformHttpLib } from "@gnu-taler/taler-util/http";
|
import { createPlatformHttpLib } from "@gnu-taler/taler-util/http";
|
||||||
@ -74,7 +75,7 @@ class NativeWalletMessageHandler {
|
|||||||
id: string,
|
id: string,
|
||||||
args: any,
|
args: any,
|
||||||
): Promise<CoreApiResponse> {
|
): Promise<CoreApiResponse> {
|
||||||
const wrapResponse = (result: unknown): CoreApiResponseSuccess => {
|
const wrapSuccessResponse = (result: unknown): CoreApiResponseSuccess => {
|
||||||
return {
|
return {
|
||||||
type: "response",
|
type: "response",
|
||||||
id,
|
id,
|
||||||
@ -120,7 +121,7 @@ class NativeWalletMessageHandler {
|
|||||||
setGlobalLogLevelFromString(logLevel);
|
setGlobalLogLevelFromString(logLevel);
|
||||||
}
|
}
|
||||||
await reinit();
|
await reinit();
|
||||||
return wrapResponse({
|
return wrapSuccessResponse({
|
||||||
...initResponse,
|
...initResponse,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -137,14 +138,22 @@ class NativeWalletMessageHandler {
|
|||||||
throw Error("not implemented");
|
throw Error("not implemented");
|
||||||
}
|
}
|
||||||
case "reset": {
|
case "reset": {
|
||||||
|
logger.info("resetting wallet");
|
||||||
const oldArgs = this.walletArgs;
|
const oldArgs = this.walletArgs;
|
||||||
this.walletArgs = { ...oldArgs };
|
this.walletArgs = { ...oldArgs };
|
||||||
if (oldArgs && oldArgs.persistentStoragePath) {
|
if (oldArgs && oldArgs.persistentStoragePath) {
|
||||||
try {
|
const ret = qjsOs.remove(oldArgs.persistentStoragePath);
|
||||||
logger.error("FIXME: reset not implemented");
|
if (ret != null) {
|
||||||
// fs.unlinkSync(oldArgs.persistentStoragePath);
|
return {
|
||||||
} catch (e) {
|
type: "error",
|
||||||
logger.error("Error while deleting the wallet db:", e);
|
id,
|
||||||
|
operation,
|
||||||
|
error: {
|
||||||
|
code: TalerErrorCode.GENERIC_UNEXPECTED_REQUEST_ERROR,
|
||||||
|
hint: `path ${oldArgs.persistentStoragePath}`,
|
||||||
|
message: "removing DB file failed",
|
||||||
|
},
|
||||||
|
};
|
||||||
}
|
}
|
||||||
// Prevent further storage!
|
// Prevent further storage!
|
||||||
this.walletArgs.persistentStoragePath = undefined;
|
this.walletArgs.persistentStoragePath = undefined;
|
||||||
@ -154,7 +163,8 @@ class NativeWalletMessageHandler {
|
|||||||
this.wp = openPromise<Wallet>();
|
this.wp = openPromise<Wallet>();
|
||||||
this.maybeWallet = undefined;
|
this.maybeWallet = undefined;
|
||||||
await reinit();
|
await reinit();
|
||||||
return wrapResponse({});
|
logger.info("wallet re-initialized after reset");
|
||||||
|
return wrapSuccessResponse({});
|
||||||
}
|
}
|
||||||
default: {
|
default: {
|
||||||
const wallet = await this.wp.promise;
|
const wallet = await this.wp.promise;
|
||||||
|
Loading…
Reference in New Issue
Block a user