@bgord/bun 1.7.0 → 1.7.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/api-version.middleware.d.ts +1 -1
- package/dist/build-info-repository.service.d.ts +1 -1
- package/dist/build-info-repository.service.js +1 -1
- package/dist/cache-repository-lru-cache.adapter.d.ts +5 -1
- package/dist/cache-repository-lru-cache.adapter.d.ts.map +1 -1
- package/dist/cache-repository-lru-cache.adapter.js +19 -3
- package/dist/cache-repository-lru-cache.adapter.js.map +1 -1
- package/dist/file-reader-json-bun.adapter.d.ts +1 -1
- package/dist/file-reader-json-bun.adapter.js +1 -1
- package/dist/healthcheck.service.d.ts +1 -1
- package/dist/i18n.service.d.ts +1 -1
- package/dist/i18n.service.js +1 -1
- package/dist/prerequisite-verifier-translations.adapter.d.ts +1 -1
- package/dist/setup.service.d.ts +1 -1
- package/dist/setup.service.js +1 -1
- package/dist/translations.service.d.ts +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
- package/src/api-version.middleware.ts +1 -1
- package/src/build-info-repository.service.ts +2 -2
- package/src/cache-repository-lru-cache.adapter.ts +29 -7
- package/src/file-reader-json-bun.adapter.ts +1 -1
- package/src/healthcheck.service.ts +1 -1
- package/src/i18n.service.ts +2 -2
- package/src/prerequisite-verifier-translations.adapter.ts +1 -1
- package/src/setup.service.ts +2 -2
- package/src/translations.service.ts +1 -1
|
@@ -2,7 +2,7 @@ import type { ClockPort } from "./clock.port";
|
|
|
2
2
|
import type { FileReaderJsonPort } from "./file-reader-json.port";
|
|
3
3
|
type Dependencies = {
|
|
4
4
|
Clock: ClockPort;
|
|
5
|
-
|
|
5
|
+
FileReaderJson: FileReaderJsonPort;
|
|
6
6
|
};
|
|
7
7
|
export declare class ApiVersion {
|
|
8
8
|
static readonly HEADER_NAME = "api-version";
|
|
@@ -7,7 +7,7 @@ export type BuildInfoType = {
|
|
|
7
7
|
};
|
|
8
8
|
type Dependencies = {
|
|
9
9
|
Clock: ClockPort;
|
|
10
|
-
|
|
10
|
+
FileReaderJson: FileReaderJsonPort;
|
|
11
11
|
};
|
|
12
12
|
export declare class BuildInfoRepository {
|
|
13
13
|
static extract(deps: Dependencies): Promise<BuildInfoType>;
|
|
@@ -3,7 +3,7 @@ export class BuildInfoRepository {
|
|
|
3
3
|
static async extract(deps) {
|
|
4
4
|
const BUILD_DATE = deps.Clock.now().ms;
|
|
5
5
|
try {
|
|
6
|
-
const packageJson = await deps.
|
|
6
|
+
const packageJson = await deps.FileReaderJson.read("package.json");
|
|
7
7
|
return { BUILD_DATE, BUILD_VERSION: tools.PackageVersion.fromString(packageJson.version).toString() };
|
|
8
8
|
}
|
|
9
9
|
catch {
|
|
@@ -1,8 +1,12 @@
|
|
|
1
1
|
import type { CacheRepositoryPort, CacheRepositoryTtlType } from "./cache-repository.port";
|
|
2
2
|
import type { Hash } from "./hash.vo";
|
|
3
|
+
export declare const CacheRepositoryLruCacheAdapterError: {
|
|
4
|
+
MissingDependency: string;
|
|
5
|
+
};
|
|
3
6
|
export declare class CacheRepositoryLruCacheAdapter implements CacheRepositoryPort {
|
|
4
7
|
private readonly store;
|
|
5
|
-
constructor(
|
|
8
|
+
private constructor();
|
|
9
|
+
static build(config: CacheRepositoryTtlType): Promise<CacheRepositoryLruCacheAdapter>;
|
|
6
10
|
get<T>(subject: Hash): Promise<T | null>;
|
|
7
11
|
set<T>(subject: Hash, value: T): Promise<void>;
|
|
8
12
|
delete(subject: Hash): Promise<void>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cache-repository-lru-cache.adapter.d.ts","sourceRoot":"","sources":["../src/cache-repository-lru-cache.adapter.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,mBAAmB,EAAE,sBAAsB,EAAE,MAAM,yBAAyB,CAAC;AAC3F,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAGtC,qBAAa,8BAA+B,YAAW,mBAAmB;IACxE,OAAO,CAAC,QAAQ,CAAC,KAAK,
|
|
1
|
+
{"version":3,"file":"cache-repository-lru-cache.adapter.d.ts","sourceRoot":"","sources":["../src/cache-repository-lru-cache.adapter.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,mBAAmB,EAAE,sBAAsB,EAAE,MAAM,yBAAyB,CAAC;AAC3F,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAGtC,eAAO,MAAM,mCAAmC;;CAE/C,CAAC;AAEF,qBAAa,8BAA+B,YAAW,mBAAmB;IACxE,OAAO,CAAC,QAAQ,CAAC,KAAK,CAA+B;IAErD,OAAO;WAIM,KAAK,CAAC,MAAM,EAAE,sBAAsB,GAAG,OAAO,CAAC,8BAA8B,CAAC;IAsBrF,GAAG,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAIxC,GAAG,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAI9C,MAAM,CAAC,OAAO,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpC,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAG7B"}
|
|
@@ -1,13 +1,29 @@
|
|
|
1
|
-
|
|
1
|
+
export const CacheRepositoryLruCacheAdapterError = {
|
|
2
|
+
MissingDependency: "cache.repository.lru.cache.adapter.error.missing.dependency",
|
|
3
|
+
};
|
|
2
4
|
export class CacheRepositoryLruCacheAdapter {
|
|
3
5
|
store;
|
|
4
|
-
constructor(
|
|
5
|
-
this.store =
|
|
6
|
+
constructor(store) {
|
|
7
|
+
this.store = store;
|
|
8
|
+
}
|
|
9
|
+
static async build(config) {
|
|
10
|
+
// biome-ignore lint: lint/suspicious/noAssignInExpressions
|
|
11
|
+
let LRUCacheConstructor;
|
|
12
|
+
try {
|
|
13
|
+
const module = await import("lru-cache");
|
|
14
|
+
LRUCacheConstructor = module.LRUCache;
|
|
15
|
+
}
|
|
16
|
+
catch {
|
|
17
|
+
throw new Error(CacheRepositoryLruCacheAdapterError.MissingDependency);
|
|
18
|
+
}
|
|
19
|
+
const store = new LRUCacheConstructor({
|
|
6
20
|
max: 100_000,
|
|
7
21
|
ttl: config.type === "finite" ? config.ttl.ms : undefined,
|
|
8
22
|
ttlAutopurge: true,
|
|
9
23
|
});
|
|
24
|
+
return new CacheRepositoryLruCacheAdapter(store);
|
|
10
25
|
}
|
|
26
|
+
// 5. Clean implementation without null checks
|
|
11
27
|
async get(subject) {
|
|
12
28
|
return this.store.get(subject.get()) ?? null;
|
|
13
29
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cache-repository-lru-cache.adapter.js","sourceRoot":"","sources":["../src/cache-repository-lru-cache.adapter.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"cache-repository-lru-cache.adapter.js","sourceRoot":"","sources":["../src/cache-repository-lru-cache.adapter.ts"],"names":[],"mappings":"AAKA,MAAM,CAAC,MAAM,mCAAmC,GAAG;IACjD,iBAAiB,EAAE,6DAA6D;CACjF,CAAC;AAEF,MAAM,OAAO,8BAA8B;IACxB,KAAK,CAA+B;IAErD,YAAoB,KAAmC;QACrD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,MAA8B;QAC/C,2DAA2D;QAC3D,IAAI,mBAAmB,CAAC;QAExB,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,WAAW,CAAC,CAAC;YAEzC,mBAAmB,GAAG,MAAM,CAAC,QAAQ,CAAC;QACxC,CAAC;QAAC,MAAM,CAAC;YACP,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,iBAAiB,CAAC,CAAC;QACzE,CAAC;QAED,MAAM,KAAK,GAAG,IAAI,mBAAmB,CAAqB;YACxD,GAAG,EAAE,OAAO;YACZ,GAAG,EAAE,MAAM,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS;YACzD,YAAY,EAAE,IAAI;SACnB,CAAC,CAAC;QAEH,OAAO,IAAI,8BAA8B,CAAC,KAAK,CAAC,CAAC;IACnD,CAAC;IAED,8CAA8C;IAC9C,KAAK,CAAC,GAAG,CAAI,OAAa;QACxB,OAAQ,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,EAAE,CAAO,IAAI,IAAI,CAAC;IACtD,CAAC;IAED,KAAK,CAAC,GAAG,CAAI,OAAa,EAAE,KAAQ;QAClC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,KAAK,CAAC,CAAC;IACvC,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,OAAa;QACxB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC;IACnC,CAAC;IAED,KAAK,CAAC,KAAK;QACT,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;CACF"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type * as tools from "@bgord/tools";
|
|
2
2
|
import type { FileReaderJsonOutputType, FileReaderJsonPort } from "./file-reader-json.port";
|
|
3
|
-
export declare class
|
|
3
|
+
export declare class FileReaderJsonBunAdapter implements FileReaderJsonPort {
|
|
4
4
|
read(path: tools.FilePathRelative | tools.FilePathAbsolute | string): Promise<FileReaderJsonOutputType>;
|
|
5
5
|
}
|
|
6
6
|
//# sourceMappingURL=file-reader-json-bun.adapter.d.ts.map
|
|
@@ -8,7 +8,7 @@ import { Prerequisite, type PrerequisiteLabelType } from "./prerequisite.vo";
|
|
|
8
8
|
import { PrerequisiteVerificationOutcome } from "./prerequisite-verifier.port";
|
|
9
9
|
type Dependencies = {
|
|
10
10
|
Clock: ClockPort;
|
|
11
|
-
|
|
11
|
+
FileReaderJson: FileReaderJsonPort;
|
|
12
12
|
Logger: LoggerPort;
|
|
13
13
|
};
|
|
14
14
|
export declare class Healthcheck {
|
package/dist/i18n.service.d.ts
CHANGED
package/dist/i18n.service.js
CHANGED
|
@@ -9,7 +9,7 @@ export class I18n {
|
|
|
9
9
|
this.translationsPath = translationsPath;
|
|
10
10
|
}
|
|
11
11
|
async getTranslations(language) {
|
|
12
|
-
return this.deps.
|
|
12
|
+
return this.deps.FileReaderJson.read(this.getTranslationPathForLanguage(language));
|
|
13
13
|
}
|
|
14
14
|
useTranslations(translations) {
|
|
15
15
|
const that = this;
|
|
@@ -5,7 +5,7 @@ import type { LoggerPort } from "./logger.port";
|
|
|
5
5
|
import { type PrerequisiteVerifierPort } from "./prerequisite-verifier.port";
|
|
6
6
|
type Dependencies = {
|
|
7
7
|
Logger: LoggerPort;
|
|
8
|
-
|
|
8
|
+
FileReaderJson: FileReaderJsonPort;
|
|
9
9
|
};
|
|
10
10
|
export declare class PrerequisiteVerifierTranslationsAdapter implements PrerequisiteVerifierPort {
|
|
11
11
|
private readonly config;
|
package/dist/setup.service.d.ts
CHANGED
|
@@ -19,7 +19,7 @@ type Dependencies = {
|
|
|
19
19
|
IdProvider: IdProviderPort;
|
|
20
20
|
I18n: I18nConfigType;
|
|
21
21
|
Clock: ClockPort;
|
|
22
|
-
|
|
22
|
+
FileReaderJson: FileReaderJsonPort;
|
|
23
23
|
};
|
|
24
24
|
export declare class Setup {
|
|
25
25
|
static essentials(deps: Dependencies, overrides?: SetupOverridesType): (import("hono").MiddlewareHandler<any, string, {}, Response> | import("hono").MiddlewareHandler<{
|
package/dist/setup.service.js
CHANGED
|
@@ -22,7 +22,7 @@ export class Setup {
|
|
|
22
22
|
MaintenanceMode.build(overrides?.maintenanceMode),
|
|
23
23
|
secureHeaders(secureHeadersOptions),
|
|
24
24
|
bodyLimit({ maxSize: BODY_LIMIT_MAX_SIZE }),
|
|
25
|
-
ApiVersion.build({ Clock: deps.Clock,
|
|
25
|
+
ApiVersion.build({ Clock: deps.Clock, FileReaderJson: deps.FileReaderJson }),
|
|
26
26
|
cors(corsOptions),
|
|
27
27
|
languageDetector({
|
|
28
28
|
supportedLanguages: Object.keys(deps.I18n.supportedLanguages),
|
|
@@ -3,7 +3,7 @@ import { type TranslationsSupportedLanguagesType } from "./i18n.service";
|
|
|
3
3
|
import type { LoggerPort } from "./logger.port";
|
|
4
4
|
type Config = TranslationsSupportedLanguagesType;
|
|
5
5
|
type Dependencies = {
|
|
6
|
-
|
|
6
|
+
FileReaderJson: FileReaderJsonPort;
|
|
7
7
|
Logger: LoggerPort;
|
|
8
8
|
};
|
|
9
9
|
export declare class Translations {
|