@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.
@@ -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
- JsonFileReader: FileReaderJsonPort;
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
- JsonFileReader: FileReaderJsonPort;
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.JsonFileReader.read("package.json");
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(config: CacheRepositoryTtlType);
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,CAAC;gBAEX,MAAM,EAAE,sBAAsB;IAQpC,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;IAI9B,MAAM,CAAC,OAAO,EAAE,IAAI;IAIpB,KAAK;CAGZ"}
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
- import { LRUCache } from "lru-cache";
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(config) {
5
- this.store = new LRUCache({
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":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAKrC,MAAM,OAAO,8BAA8B;IACxB,KAAK,CAAC;IAEvB,YAAY,MAA8B;QACxC,IAAI,CAAC,KAAK,GAAG,IAAI,QAAQ,CAAqB;YAC5C,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;IACL,CAAC;IAED,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
+ {"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 JsonFileReaderBunAdapter implements FileReaderJsonPort {
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
@@ -1,4 +1,4 @@
1
- export class JsonFileReaderBunAdapter {
1
+ export class FileReaderJsonBunAdapter {
2
2
  async read(path) {
3
3
  return Bun.file(typeof path === "string" ? path : path.get()).json();
4
4
  }
@@ -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
- JsonFileReader: FileReaderJsonPort;
11
+ FileReaderJson: FileReaderJsonPort;
12
12
  Logger: LoggerPort;
13
13
  };
14
14
  export declare class Healthcheck {
@@ -14,7 +14,7 @@ export type I18nConfigType = {
14
14
  defaultLanguage?: string;
15
15
  };
16
16
  type Dependencies = {
17
- JsonFileReader: FileReaderJsonPort;
17
+ FileReaderJson: FileReaderJsonPort;
18
18
  Logger: LoggerPort;
19
19
  };
20
20
  export declare class I18n {
@@ -9,7 +9,7 @@ export class I18n {
9
9
  this.translationsPath = translationsPath;
10
10
  }
11
11
  async getTranslations(language) {
12
- return this.deps.JsonFileReader.read(this.getTranslationPathForLanguage(language));
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
- JsonFileReader: FileReaderJsonPort;
8
+ FileReaderJson: FileReaderJsonPort;
9
9
  };
10
10
  export declare class PrerequisiteVerifierTranslationsAdapter implements PrerequisiteVerifierPort {
11
11
  private readonly config;
@@ -19,7 +19,7 @@ type Dependencies = {
19
19
  IdProvider: IdProviderPort;
20
20
  I18n: I18nConfigType;
21
21
  Clock: ClockPort;
22
- JsonFileReader: FileReaderJsonPort;
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<{
@@ -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, JsonFileReader: deps.JsonFileReader }),
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
- JsonFileReader: FileReaderJsonPort;
6
+ FileReaderJson: FileReaderJsonPort;
7
7
  Logger: LoggerPort;
8
8
  };
9
9
  export declare class Translations {