/* This file is part of the Notesnook project (https://notesnook.com/) Copyright (C) 2023 Streetwriters (Private) Limited This program 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 of the License, or (at your option) any later version. This program 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 this program. If not, see . */ import "./logger"; import { database } from "@notesnook/common"; import { logger as dbLogger } from "@notesnook/core"; import { Platform } from "react-native"; import * as Gzip from "react-native-gzip"; import EventSource from "../../utils/sse/even-source-ios"; import AndroidEventSource from "../../utils/sse/event-source"; import { SqliteAdapter, SqliteIntrospector, SqliteQueryCompiler } from "@streetwriters/kysely"; import filesystem from "../filesystem"; import Storage from "./storage"; import { RNSqliteDriver } from "./sqlite.kysely"; import { getDatabaseKey } from "./encryption"; import SettingsService from "../../services/settings"; import { strings } from "@notesnook/intl"; export async function setupDatabase(password) { const key = await getDatabaseKey(password); if (!key) throw new Error(strings.databaseSetupFailed()); console.log("Opening database with key:", !!key); database.host({ API_HOST: "https://api.notesnook.com", AUTH_HOST: "https://auth.streetwriters.co", SSE_HOST: "https://events.streetwriters.co", SUBSCRIPTIONS_HOST: "https://subscriptions.streetwriters.co", ISSUES_HOST: "https://issues.streetwriters.co", ...(SettingsService.getProperty("serverUrls") || {}) }); database.setup({ storage: Storage, eventsource: Platform.OS === "ios" ? EventSource : AndroidEventSource, fs: filesystem, compressor: () => ({ compress: Gzip.deflate, decompress: Gzip.inflate }), batchSize: 100, sqliteOptions: { dialect: (name) => ({ createDriver: () => { return new RNSqliteDriver({ async: true, dbName: name }); }, createAdapter: () => new SqliteAdapter(), createIntrospector: (db) => new SqliteIntrospector(db), createQueryCompiler: () => new SqliteQueryCompiler() }), tempStore: "memory", journalMode: Platform.OS === "ios" ? "DELETE" : "WAL", password: key } }); } export const db = database; let DatabaseLogger = dbLogger.scope(Platform.OS); const setLogger = () => { DatabaseLogger = dbLogger.scope(Platform.OS); }; export { DatabaseLogger, setLogger };