2
0
mirror of https://github.com/frappe/books.git synced 2025-01-25 16:18:33 +00:00
books/main/helpers.ts

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

92 lines
2.4 KiB
TypeScript
Raw Normal View History

2022-05-19 23:55:01 +05:30
import { constants } from 'fs';
import fs from 'fs/promises';
import { ConfigFile, ConfigKeys } from 'fyo/core/types';
2022-05-27 14:00:25 +05:30
import { Main } from 'main';
2022-05-19 23:55:01 +05:30
import config from 'utils/config';
2022-07-30 17:17:37 +05:30
import { BackendResponse } from 'utils/ipc/types';
2022-05-27 14:00:25 +05:30
import { IPC_CHANNELS } from 'utils/messages';
2022-05-19 23:55:01 +05:30
interface ConfigFilesWithModified extends ConfigFile {
modified: string;
}
export async function setAndGetCleanedConfigFiles() {
const files = config.get(ConfigKeys.Files, []) as ConfigFile[];
const cleanedFileMap: Map<string, ConfigFile> = new Map();
for (const file of files) {
const exists = await fs
.access(file.dbPath, constants.W_OK)
.then(() => true)
.catch(() => false);
if (!file.companyName) {
continue;
}
2022-05-19 23:55:01 +05:30
const key = `${file.companyName}-${file.dbPath}`;
if (!exists || cleanedFileMap.has(key)) {
continue;
}
cleanedFileMap.set(key, file);
}
const cleanedFiles = Array.from(cleanedFileMap.values());
config.set(ConfigKeys.Files, cleanedFiles);
return cleanedFiles;
}
export async function getConfigFilesWithModified(files: ConfigFile[]) {
const filesWithModified: ConfigFilesWithModified[] = [];
2022-05-23 11:51:06 +05:30
for (const { dbPath, id, companyName, openCount } of files) {
2022-05-19 23:55:01 +05:30
const { mtime } = await fs.stat(dbPath);
filesWithModified.push({
id,
dbPath,
companyName,
modified: mtime.toISOString(),
2022-05-23 11:51:06 +05:30
openCount,
2022-05-19 23:55:01 +05:30
});
}
return filesWithModified;
}
2022-05-20 15:36:38 +05:30
export async function getErrorHandledReponse(func: () => Promise<unknown>) {
2022-07-30 17:17:37 +05:30
const response: BackendResponse = {};
2022-05-20 15:36:38 +05:30
try {
response.data = await func();
} catch (err) {
response.error = {
2022-07-30 17:17:37 +05:30
name: (err as NodeJS.ErrnoException).name,
message: (err as NodeJS.ErrnoException).message,
stack: (err as NodeJS.ErrnoException).stack,
code: (err as NodeJS.ErrnoException).code,
2022-05-20 15:36:38 +05:30
};
}
return response;
}
2022-05-27 14:00:25 +05:30
export function rendererLog(main: Main, ...args: unknown[]) {
main.mainWindow?.webContents.send(IPC_CHANNELS.CONSOLE_LOG, ...args);
}
export function isNetworkError(error: Error) {
switch (error?.message) {
case 'net::ERR_INTERNET_DISCONNECTED':
case 'net::ERR_NETWORK_CHANGED':
case 'net::ERR_PROXY_CONNECTION_FAILED':
case 'net::ERR_CONNECTION_RESET':
case 'net::ERR_CONNECTION_CLOSE':
case 'net::ERR_NAME_NOT_RESOLVED':
case 'net::ERR_TIMED_OUT':
case 'net::ERR_CONNECTION_TIMED_OUT':
return true;
default:
return false;
}
}