repositories
/
e-mobility-charging-stations-simulator.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
build(deps-dev): apply updates
[e-mobility-charging-stations-simulator.git]
/
src
/
performance
/
storage
/
JsonFileStorage.ts
diff --git
a/src/performance/storage/JsonFileStorage.ts
b/src/performance/storage/JsonFileStorage.ts
index 2a712a6008f61722ef21dddaac5acd2e3ba14d53..c4a9f7483e30060047607bdbad5a97e15fb7c91c 100644
(file)
--- a/
src/performance/storage/JsonFileStorage.ts
+++ b/
src/performance/storage/JsonFileStorage.ts
@@
-1,12
+1,19
@@
// Copyright Jerome Benoit. 2021-2023. All Rights Reserved.
// Copyright Jerome Benoit. 2021-2023. All Rights Reserved.
-import
fs
from 'node:fs';
-import
path
from 'node:path';
+import
{ closeSync, existsSync, mkdirSync, openSync, readFileSync, writeFileSync }
from 'node:fs';
+import
{ dirname }
from 'node:path';
import { Storage } from './Storage';
import { BaseError } from '../../exception';
import { FileType, type Statistics } from '../../types';
import { Storage } from './Storage';
import { BaseError } from '../../exception';
import { FileType, type Statistics } from '../../types';
-import { AsyncLock, AsyncLockType, Constants, ErrorUtils, Utils } from '../../utils';
+import {
+ AsyncLock,
+ AsyncLockType,
+ Constants,
+ JSONStringifyWithMapSupport,
+ handleFileException,
+ isNullOrUndefined,
+} from '../../utils';
export class JsonFileStorage extends Storage {
private fd: number | null = null;
export class JsonFileStorage extends Storage {
private fd: number | null = null;
@@
-20,19
+27,15
@@
export class JsonFileStorage extends Storage {
this.checkPerformanceRecordsFile();
AsyncLock.acquire(AsyncLockType.performance)
.then(() => {
this.checkPerformanceRecordsFile();
AsyncLock.acquire(AsyncLockType.performance)
.then(() => {
- const fileData =
fs.
readFileSync(this.dbName, 'utf8');
+ const fileData = readFileSync(this.dbName, 'utf8');
const performanceRecords: Statistics[] = fileData
? (JSON.parse(fileData) as Statistics[])
: [];
performanceRecords.push(performanceStatistics);
const performanceRecords: Statistics[] = fileData
? (JSON.parse(fileData) as Statistics[])
: [];
performanceRecords.push(performanceStatistics);
- fs.writeFileSync(
- this.dbName,
- Utils.JSONStringifyWithMapSupport(performanceRecords, 2),
- 'utf8'
- );
+ writeFileSync(this.dbName, JSONStringifyWithMapSupport(performanceRecords, 2), 'utf8');
})
.catch((error) => {
})
.catch((error) => {
-
ErrorUtils.
handleFileException(
+ handleFileException(
this.dbName,
FileType.PerformanceRecords,
error as NodeJS.ErrnoException,
this.dbName,
FileType.PerformanceRecords,
error as NodeJS.ErrnoException,
@@
-46,14
+49,14
@@
export class JsonFileStorage extends Storage {
public open(): void {
try {
public open(): void {
try {
- if (
Utils.
isNullOrUndefined(this?.fd)) {
- if (!
fs.existsSync(path.
dirname(this.dbName))) {
-
fs.mkdirSync(path.
dirname(this.dbName), { recursive: true });
+ if (isNullOrUndefined(this?.fd)) {
+ if (!
existsSync(
dirname(this.dbName))) {
+
mkdirSync(
dirname(this.dbName), { recursive: true });
}
}
- this.fd =
fs.
openSync(this.dbName, 'a+');
+ this.fd = openSync(this.dbName, 'a+');
}
} catch (error) {
}
} catch (error) {
-
ErrorUtils.
handleFileException(
+ handleFileException(
this.dbName,
FileType.PerformanceRecords,
error as NodeJS.ErrnoException,
this.dbName,
FileType.PerformanceRecords,
error as NodeJS.ErrnoException,
@@
-65,11
+68,11
@@
export class JsonFileStorage extends Storage {
public close(): void {
try {
if (this?.fd) {
public close(): void {
try {
if (this?.fd) {
-
fs.
closeSync(this.fd);
+ closeSync(this.fd);
this.fd = null;
}
} catch (error) {
this.fd = null;
}
} catch (error) {
-
ErrorUtils.
handleFileException(
+ handleFileException(
this.dbName,
FileType.PerformanceRecords,
error as NodeJS.ErrnoException,
this.dbName,
FileType.PerformanceRecords,
error as NodeJS.ErrnoException,