2022-05-19 23:55:01 +05:30
|
|
|
import { constants } from 'fs';
|
|
|
|
import fs from 'fs/promises';
|
2023-06-21 16:08:39 +05:30
|
|
|
import { ConfigFile } 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';
|
2023-04-03 13:51:46 +05:30
|
|
|
import type { ConfigFilesWithModified } from 'utils/types';
|
2022-05-19 23:55:01 +05:30
|
|
|
|
|
|
|
export async function setAndGetCleanedConfigFiles() {
|
2023-06-21 16:08:39 +05:30
|
|
|
const files = config.get('files', []);
|
2022-05-19 23:55:01 +05:30
|
|
|
|
|
|
|
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);
|
|
|
|
|
2022-05-25 00:36:54 +05:30
|
|
|
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());
|
2023-06-21 16:08:39 +05:30
|
|
|
config.set('files', cleanedFiles);
|
2022-05-19 23:55:01 +05:30
|
|
|
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
|
|
|
|
2023-06-21 16:08:39 +05:30
|
|
|
export async function getErrorHandledReponse(
|
|
|
|
func: () => Promise<unknown> | 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);
|
|
|
|
}
|
2022-08-31 14:50:54 +05:30
|
|
|
|
|
|
|
export function isNetworkError(error: Error) {
|
|
|
|
switch (error?.message) {
|
|
|
|
case 'net::ERR_INTERNET_DISCONNECTED':
|
2022-09-20 21:17:43 +05:30
|
|
|
case 'net::ERR_NETWORK_CHANGED':
|
2022-08-31 14:50:54 +05:30
|
|
|
case 'net::ERR_PROXY_CONNECTION_FAILED':
|
|
|
|
case 'net::ERR_CONNECTION_RESET':
|
|
|
|
case 'net::ERR_CONNECTION_CLOSE':
|
|
|
|
case 'net::ERR_NAME_NOT_RESOLVED':
|
2022-09-20 21:17:43 +05:30
|
|
|
case 'net::ERR_TIMED_OUT':
|
2022-08-31 14:50:54 +05:30
|
|
|
case 'net::ERR_CONNECTION_TIMED_OUT':
|
|
|
|
return true;
|
|
|
|
default:
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|