mirror of
https://github.com/vrtmrz/obsidian-livesync.git
synced 2026-03-31 06:05:17 +00:00
87 lines
3.0 KiB
TypeScript
87 lines
3.0 KiB
TypeScript
import { LOG_LEVEL_NOTICE, LOG_LEVEL_VERBOSE, Logger } from "octagonal-wheels/common/logger";
|
|
import type { AnyEntry, FilePathWithPrefix } from "@lib/common/types";
|
|
import type { LiveSyncCore } from "@/main";
|
|
import { __$checkInstanceBinding } from "@lib/dev/checks";
|
|
import { stripAllPrefixes } from "@lib/string_and_binary/path";
|
|
import { createInstanceLogFunction } from "@/lib/src/services/lib/logUtils";
|
|
|
|
export abstract class AbstractModule {
|
|
_log = createInstanceLogFunction(this.constructor.name, this.services.API);
|
|
get services() {
|
|
if (!this.core._services) {
|
|
throw new Error("Services are not ready yet.");
|
|
}
|
|
return this.core._services;
|
|
}
|
|
|
|
addCommand = this.services.API.addCommand.bind(this.services.API);
|
|
registerView = this.services.API.registerWindow.bind(this.services.API);
|
|
addRibbonIcon = this.services.API.addRibbonIcon.bind(this.services.API);
|
|
registerObsidianProtocolHandler = this.services.API.registerProtocolHandler.bind(this.services.API);
|
|
|
|
get localDatabase() {
|
|
return this.core.localDatabase;
|
|
}
|
|
get settings() {
|
|
return this.core.settings;
|
|
}
|
|
set settings(value) {
|
|
this.core.settings = value;
|
|
}
|
|
|
|
getPath(entry: AnyEntry): FilePathWithPrefix {
|
|
return this.services.path.getPath(entry);
|
|
}
|
|
|
|
getPathWithoutPrefix(entry: AnyEntry): FilePathWithPrefix {
|
|
return stripAllPrefixes(this.services.path.getPath(entry));
|
|
}
|
|
|
|
onBindFunction(core: LiveSyncCore, services: typeof core.services) {
|
|
// Override if needed.
|
|
}
|
|
constructor(public core: LiveSyncCore) {
|
|
this.onBindFunction(core, core.services);
|
|
Logger(`[${this.constructor.name}] Loaded`, LOG_LEVEL_VERBOSE);
|
|
__$checkInstanceBinding(this);
|
|
}
|
|
saveSettings = this.core.saveSettings.bind(this.core);
|
|
|
|
addTestResult(key: string, value: boolean, summary?: string, message?: string) {
|
|
this.services.test.addTestResult(`${this.constructor.name}`, key, value, summary, message);
|
|
}
|
|
testDone(result: boolean = true) {
|
|
return Promise.resolve(result);
|
|
}
|
|
testFail(message: string) {
|
|
this._log(message, LOG_LEVEL_NOTICE);
|
|
return this.testDone(false);
|
|
}
|
|
|
|
async _test(key: string, process: () => Promise<any>) {
|
|
this._log(`Testing ${key}`, LOG_LEVEL_VERBOSE);
|
|
try {
|
|
const ret = await process();
|
|
if (ret !== true) {
|
|
this.addTestResult(key, false, ret.toString());
|
|
return this.testFail(`${key} failed: ${ret}`);
|
|
}
|
|
this.addTestResult(key, true, "");
|
|
} catch (ex: any) {
|
|
this.addTestResult(key, false, "Failed by Exception", ex.toString());
|
|
return this.testFail(`${key} failed: ${ex}`);
|
|
}
|
|
return this.testDone();
|
|
}
|
|
|
|
isMainReady() {
|
|
return this.services.appLifecycle.isReady();
|
|
}
|
|
isMainSuspended() {
|
|
return this.services.appLifecycle.isSuspended();
|
|
}
|
|
isDatabaseReady() {
|
|
return this.services.database.isDatabaseReady();
|
|
}
|
|
}
|