@privateaim/server-kit 0.8.9 → 0.8.11

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/CHANGELOG.md CHANGED
@@ -1,5 +1,28 @@
1
1
  # Changelog
2
2
 
3
+ ## [0.8.11](https://github.com/PrivateAIM/hub/compare/v0.8.10...v0.8.11) (2025-04-24)
4
+
5
+
6
+ ### Dependencies
7
+
8
+ * The following workspace dependencies were updated
9
+ * dependencies
10
+ * @privateaim/kit bumped from ^0.8.10 to ^0.8.11
11
+
12
+ ## [0.8.10](https://github.com/PrivateAIM/hub/compare/v0.8.9...v0.8.10) (2025-04-23)
13
+
14
+
15
+ ### Features
16
+
17
+ * introduce safe publish method for domain-event-publisher ([cff0b35](https://github.com/PrivateAIM/hub/commit/cff0b3567ad11fb4a8ee42c58082122185c50c6c))
18
+
19
+
20
+ ### Dependencies
21
+
22
+ * The following workspace dependencies were updated
23
+ * dependencies
24
+ * @privateaim/kit bumped from ^0.8.9 to ^0.8.10
25
+
3
26
  ## [0.8.9](https://github.com/PrivateAIM/hub/compare/v0.8.8...v0.8.9) (2025-04-17)
4
27
 
5
28
 
package/dist/index.cjs CHANGED
@@ -469,9 +469,19 @@ class DomainEventPublisher {
469
469
  addPublisher(publisher) {
470
470
  this.publishers.add(publisher);
471
471
  }
472
+ async safePublish(ctx) {
473
+ try {
474
+ await this.publish(ctx);
475
+ } catch (e) {
476
+ if (isLoggerUsable()) {
477
+ useLogger().error(`Publishing event ${kit.buildDomainEventFullName(ctx.data.type, ctx.data.event)} failed`);
478
+ useLogger().error(e);
479
+ }
480
+ }
481
+ }
472
482
  async publish(ctx) {
473
483
  if (isLoggerUsable()) {
474
- useLogger().info(`Publishing event ${ctx.data.event} for ${ctx.data.type}`);
484
+ useLogger().info(`Publishing event ${kit.buildDomainEventFullName(ctx.data.type, ctx.data.event)}`);
475
485
  }
476
486
  const publishers = this.publishers.values();
477
487
  while(true){
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sources":["../src/core/component/error.ts","../src/core/component/helper.ts","../src/core/queue/utils.ts","../src/core/queue-router/constants.ts","../src/core/queue-router/helpers.ts","../src/services/amqp/module.ts","../src/services/vault/singleton.ts","../src/services/authup/helpers.ts","../src/services/authup-client-authentication-hook/singleton.ts","../src/services/authup/module.ts","../src/services/authup/singleton.ts","../src/services/redis/singleton.ts","../src/services/redis/singleton-publish.ts","../src/services/redis/singleton-subscribe.ts","../src/services/cache/adapters/memory.ts","../src/services/cache/adapters/redis.ts","../src/services/cache/adapters/factory.ts","../src/services/cache/helper.ts","../src/services/cache/module.ts","../src/services/cache/singleton.ts","../src/services/logger/module.ts","../src/services/logger/singleton.ts","../src/services/domain-event/module.ts","../src/services/domain-event/utils.ts","../src/services/domain-event/redis/module.ts","../src/services/domain-event/socket/module.ts","../src/services/domain-event/singleton.ts","../src/core/queue-router/module.ts","../src/core/queue-router/singleton.ts","../src/utils/has-property.ts"],"sourcesContent":["/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { ComponentErrorOptions } from './type';\n\nexport class ComponentError extends Error {\n public code?: string | null;\n\n constructor(input: ComponentErrorOptions) {\n super(input.message, { cause: input.cause });\n\n this.code = input.code;\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { isObject } from '@privateaim/kit';\nimport type { ComponentError } from './error';\n\nexport function isComponentError(input: unknown) : input is ComponentError {\n if (!isObject(input)) {\n return false;\n }\n\n if (\n typeof input.message !== 'undefined' &&\n typeof input.message !== 'string'\n ) {\n return false;\n }\n\n if (typeof input.code === 'undefined') {\n return true;\n }\n\n return typeof input.code === 'string' || input.code === null;\n}\n","/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { hasOwnProperty, isObject } from '@privateaim/kit';\nimport type { QueuePayload } from './type';\n\nexport function isQueuePayload(input: unknown) : input is QueuePayload {\n return isObject(input) &&\n hasOwnProperty(input, 'data') &&\n isObject(input.data) &&\n hasOwnProperty(input, 'metadata') &&\n isObject(input.metadata);\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nexport enum QueueRouterRoutingType {\n WORK = 'work',\n PUB_SUB = 'pubSub',\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { createNanoID, hasOwnProperty, isObject } from '@privateaim/kit';\nimport type { QueueRouterPayload, QueueRouterPayloadInput } from './types';\n\nexport function buildQueueRouterPublishPayload(\n input: QueueRouterPayloadInput,\n) : QueueRouterPayload {\n return {\n id: input.id || createNanoID(),\n type: input.type,\n data: input.data || {},\n metadata: {\n timestamp: Date.now(),\n ...input.metadata,\n },\n };\n}\n\nexport function isQueueRouterPayload(input: unknown) : input is QueueRouterPayload {\n return isObject(input) &&\n typeof input.id === 'string' &&\n typeof input.type === 'string' &&\n hasOwnProperty(input, 'data') &&\n isObject(input.data) &&\n hasOwnProperty(input, 'metadata') &&\n isObject(input.metadata);\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'amqp-extension';\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\n\nconst instance = singa<Client>({\n name: 'amqp',\n});\n\nexport function setAmqpClientFactory(factory: Factory<Client>) {\n instance.setFactory(factory);\n}\n\nexport function isAmqpClientUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function useAmqpClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\nimport type { VaultClient } from '@hapic/vault';\n\nconst instance = singa<VaultClient>({\n name: 'vault',\n});\n\nexport function setVaultFactory(factory: Factory<VaultClient>) {\n instance.setFactory(factory);\n}\n\nexport function isVaultClientUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function useVaultClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { TokenCreatorOptions } from '@authup/core-http-kit';\nimport { isVaultClientUsable, useVaultClient } from '../vault';\n\nexport function guessAuthupTokenCreatorOptions() : TokenCreatorOptions {\n let options : TokenCreatorOptions;\n if (isVaultClientUsable()) {\n options = {\n type: 'robotInVault',\n name: 'system',\n vault: useVaultClient(),\n };\n } else {\n options = {\n type: 'user',\n name: 'admin',\n password: 'start123',\n };\n }\n\n return options;\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { ClientAuthenticationHook } from '@authup/core-http-kit';\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\n\nconst instance = singa<ClientAuthenticationHook>({\n name: 'clientAuthenticationHook',\n});\n\nexport function setClientAuthenticationHookFactory(factory: Factory<ClientAuthenticationHook>) {\n instance.setFactory(factory);\n}\n\nexport function isClientAuthenticationHookUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function useClientAuthenticationHook() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport {\n Client,\n ClientAuthenticationHook,\n} from '@authup/core-http-kit';\nimport {\n isClientAuthenticationHookUsable,\n setClientAuthenticationHookFactory,\n useClientAuthenticationHook,\n} from '../authup-client-authentication-hook';\nimport { guessAuthupTokenCreatorOptions } from './helpers';\nimport type { AuthupClientOptions } from './types';\n\nexport class AuthupClient extends Client {\n constructor(options: AuthupClientOptions = {}) {\n super(options);\n\n if (!isClientAuthenticationHookUsable()) {\n setClientAuthenticationHookFactory(\n () => new ClientAuthenticationHook({\n baseURL: options.baseURL,\n tokenCreator: options.tokenCreator || guessAuthupTokenCreatorOptions(),\n }),\n );\n }\n\n const hook = useClientAuthenticationHook();\n hook.attach(this);\n }\n}\n","/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from '@authup/core-http-kit';\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\n\nconst instance = singa<Client>({\n name: 'authup',\n});\n\nexport function useAuthupClient() {\n return instance.use();\n}\n\nexport function isAuthupClientUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function setAuthupClientFactory(factory: Factory<Client>) {\n instance.setFactory(factory);\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\n\nconst instance = singa<Client>({\n name: 'redis',\n});\n\nexport function setRedisFactory(factory: Factory<Client>) {\n instance.setFactory(factory);\n}\n\nexport function isRedisClientUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function setRedisClient(input: Client) {\n instance.set(input);\n}\n\nexport function useRedisClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport { singa } from 'singa';\nimport { useRedisClient } from './singleton';\n\nconst instance = singa<Client>({\n name: 'redisPublish',\n factory: () => useRedisClient().duplicate(),\n});\n\nexport function useRedisPublishClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport { singa } from 'singa';\nimport { useRedisClient } from './singleton';\n\nconst instance = singa<Client>({\n name: 'redisSubscribe',\n factory: () => useRedisClient().duplicate(),\n});\n\nexport function useRedisSubscribeClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Options } from '@isaacs/ttlcache';\nimport TTLCache from '@isaacs/ttlcache';\nimport type { CacheClearOptions, CacheSetOptions } from '../types';\nimport type { CacheAdapter } from './types';\n\nexport class MemoryCacheAdapter<\n VALUE = any,\n> implements CacheAdapter {\n protected instance : TTLCache<string, VALUE>;\n\n constructor(options: Options<string, VALUE> = {}) {\n this.instance = new TTLCache<string, VALUE>({\n checkAgeOnGet: true,\n ttl: Infinity,\n ...(options || {}),\n });\n }\n\n async get(key: string): Promise<VALUE> {\n return this.instance.get(key);\n }\n\n async has(key: string) : Promise<boolean> {\n return this.instance.has(key);\n }\n\n async set(key: string, value: VALUE, options: CacheSetOptions): Promise<void> {\n this.instance.set(key, value, {\n ttl: options.ttl,\n });\n }\n\n async drop(key: string): Promise<void> {\n this.instance.delete(key);\n }\n\n async dropMany(keys: string[]) : Promise<void> {\n for (let i = 0; i < keys.length; i++) {\n this.instance.delete(keys[i]);\n }\n }\n\n async clear(options: CacheClearOptions = {}) : Promise<void> {\n if (options.prefix) {\n const keys = this.instance.keys();\n let iterator = keys.next();\n while (!iterator.done) {\n if (iterator.value.startsWith(options.prefix)) {\n this.instance.delete(iterator.value);\n }\n\n iterator = keys.next();\n }\n\n return;\n }\n\n this.instance.clear();\n }\n}\n","/*\n * Copyright (c) 2024-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport { JsonAdapter } from 'redis-extension';\nimport { useRedisClient } from '../../redis';\nimport type { CacheClearOptions, CacheSetOptions } from '../types';\nimport type { CacheAdapter } from './types';\n\nexport class RedisCacheAdapter implements CacheAdapter {\n protected client : Client;\n\n protected instance : JsonAdapter;\n\n constructor() {\n this.client = useRedisClient();\n this.instance = new JsonAdapter(this.client);\n }\n\n async get(key: string): Promise<any> {\n return this.instance.get(key);\n }\n\n async has(key: string) : Promise<boolean> {\n const exists = await this.client.exists(key);\n\n return !!exists;\n }\n\n async set(key: string, value: any, options: CacheSetOptions): Promise<void> {\n await this.instance.set(key, value, {\n milliseconds: options.ttl,\n });\n }\n\n async drop(key: string): Promise<void> {\n await this.instance.drop(key);\n }\n\n async dropMany(keys: string[]) : Promise<void> {\n const pipeline = this.client.pipeline();\n\n for (let i = 0; i < keys.length; i++) {\n pipeline.del(keys[i]);\n }\n\n await pipeline.exec();\n }\n\n async clear(options: CacheClearOptions = {}) : Promise<void> {\n if (options.prefix) {\n const pipeline = this.client.pipeline();\n\n const keys = await this.client.keys(`${options.prefix}*`);\n for (let i = 0; i < keys.length; i++) {\n pipeline.del(keys[i]);\n }\n\n await pipeline.exec();\n\n return;\n }\n await this.client.flushdb();\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { isRedisClientUsable } from '../../redis';\nimport { MemoryCacheAdapter } from './memory';\nimport { RedisCacheAdapter } from './redis';\n\nexport function createCacheAdapter() {\n if (isRedisClientUsable()) {\n return new RedisCacheAdapter();\n }\n\n return new MemoryCacheAdapter();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { buildRedisKeyPath } from '../redis';\nimport type { CacheKeyBuildOptions } from './types';\n\nexport function buildCacheKey(options: CacheKeyBuildOptions) {\n return buildRedisKeyPath(options);\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { CacheAdapter } from './adapters';\nimport type { CacheClearOptions, CacheSetOptions } from './types';\n\nexport class Cache {\n protected adapter : CacheAdapter;\n\n constructor(adapter: CacheAdapter) {\n this.adapter = adapter;\n }\n\n async set(key: string, value: any, options: CacheSetOptions = {}) : Promise<void> {\n await this.adapter.set(key, value, options);\n }\n\n async get(key: string) : Promise<any | undefined> {\n return this.adapter.get(key);\n }\n\n async has(key: string) : Promise<boolean> {\n return this.adapter.has(key);\n }\n\n async drop(key: string) : Promise<void> {\n return this.adapter.drop(key);\n }\n\n async dropMany(keys: string[]) : Promise<void> {\n return this.adapter.dropMany(keys);\n }\n\n async clear(options: CacheClearOptions = {}) : Promise<void> {\n return this.adapter.clear(options);\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { singa } from 'singa';\nimport { isRedisClientUsable } from '../redis';\nimport type { CacheAdapter } from './adapters';\nimport { MemoryCacheAdapter, RedisCacheAdapter } from './adapters';\nimport { Cache } from './module';\n\nconst instance = singa<Cache>({\n name: 'cache',\n factory: () => {\n let adapter : CacheAdapter;\n if (isRedisClientUsable()) {\n adapter = new RedisCacheAdapter();\n } else {\n adapter = new MemoryCacheAdapter();\n }\n\n return new Cache(adapter);\n },\n});\n\nexport function useCache() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { read } from 'envix';\nimport path from 'node:path';\nimport { EnvironmentName } from 'typeorm-extension';\nimport type { Logger } from 'winston';\nimport { createLogger as create, format, transports } from 'winston';\nimport type { LoggerCreateContext, LoggerTransports } from './types';\n\nexport function createLogger(ctx: LoggerCreateContext = {}) : Logger {\n const { directory, options = {} } = ctx;\n\n let loggerTransports : LoggerTransports;\n if (read('env') === EnvironmentName.PRODUCTION) {\n loggerTransports = [\n new transports.Console({\n level: 'info',\n }),\n new transports.File({\n filename: path.join(directory || process.cwd(), 'access.log'),\n level: 'http',\n maxsize: 10 * 1024 * 1024, // 10MB\n maxFiles: 5,\n }),\n new transports.File({\n filename: path.join(directory || process.cwd(), 'error.log'),\n level: 'warn',\n maxsize: 10 * 1024 * 1024, // 10MB\n maxFiles: 5,\n }),\n ];\n } else {\n loggerTransports = [\n new transports.Console({\n level: 'debug',\n }),\n ];\n }\n\n return create({\n format: format.combine(\n format.errors({ stack: true }),\n format.timestamp(),\n format.colorize(),\n format.simple(),\n ),\n level: 'debug',\n transports: loggerTransports,\n // todo: deeply merge options\n ...(options || {}),\n });\n}\n","/*\n * Copyright (c) 2023.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { type Factory, singa } from 'singa';\nimport type { Logger } from 'winston';\n\nconst instance = singa<Logger>({\n name: 'logger',\n});\n\nexport function setLoggerFactory(factory: Factory<Logger>) {\n instance.setFactory(factory);\n}\n\nexport function isLoggerUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function setLogger(input: Logger) {\n instance.set(input);\n}\n\nexport function useLogger() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { DomainEventRecord } from '@privateaim/kit';\nimport { isLoggerUsable, useLogger } from '../logger';\nimport type { DomainEventPublishContext, IDomainEventPublisher } from './type';\n\nexport class DomainEventPublisher implements IDomainEventPublisher {\n protected publishers : Set<IDomainEventPublisher>;\n\n constructor() {\n this.publishers = new Set<IDomainEventPublisher>();\n }\n\n addPublisher(publisher: IDomainEventPublisher) {\n this.publishers.add(publisher);\n }\n\n async publish<T extends DomainEventRecord>(\n ctx: DomainEventPublishContext<T>,\n ) : Promise<void> {\n if (isLoggerUsable()) {\n useLogger().info(`Publishing event ${ctx.data.event} for ${ctx.data.type}`);\n }\n\n const publishers = this.publishers.values();\n while (true) {\n const it = publishers.next();\n if (it.done) {\n return;\n }\n\n await it.value.publish(ctx);\n }\n }\n}\n","/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { isObject } from '@privateaim/kit';\nimport type { DomainEventChannelName } from './type';\n\nexport function transformEventData<T>(input: T) : T {\n if (isObject(input)) {\n const keys = Object.keys(input);\n for (let i = 0; i < keys.length; i++) {\n const value = input[keys[i]];\n if (value instanceof Date) {\n input[keys[i]] = value.toISOString();\n }\n }\n }\n\n return input;\n}\n\nexport function buildEventChannelName(\n input: DomainEventChannelName,\n id?: string | number,\n) : string {\n if (typeof input === 'string') {\n return input;\n }\n\n return input(id);\n}\n","/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport type { DomainEventPublishContext, IDomainEventPublisher } from '../type';\nimport { buildEventChannelName, transformEventData } from '../utils';\n\nexport class DomainEventRedisPublisher implements IDomainEventPublisher {\n protected driver : Client;\n\n constructor(client: Client) {\n this.driver = client;\n }\n\n async publish(ctx: DomainEventPublishContext) : Promise<void> {\n const data = JSON.stringify(transformEventData(ctx.data));\n\n const pipeline = this.driver.pipeline();\n for (let i = 0; i < ctx.destinations.length; i++) {\n const keyPrefix = (ctx.destinations[i].namespace ? `${ctx.destinations[i].namespace}:` : '');\n\n let key = keyPrefix + buildEventChannelName(ctx.destinations[i].channel);\n pipeline.publish(key, data);\n\n if (typeof ctx.destinations[i].channel === 'function') {\n key = keyPrefix + buildEventChannelName(ctx.destinations[i].channel, ctx.data.data.id);\n pipeline.publish(key, data);\n }\n }\n\n await pipeline.exec();\n }\n}\n","/*\n * Copyright (c) 2022-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { buildDomainEventFullName } from '@privateaim/kit';\nimport { Emitter } from '@socket.io/redis-emitter';\nimport type { Client } from 'redis-extension';\nimport type { DomainEventPublishContext, IDomainEventPublisher } from '../type';\nimport { buildEventChannelName, transformEventData } from '../utils';\n\nexport class DomainEventSocketPublisher implements IDomainEventPublisher {\n protected client : Client;\n\n constructor(client: Client) {\n this.client = client;\n }\n\n async publish(ctx: DomainEventPublishContext) : Promise<void> {\n ctx.data = transformEventData(ctx.data);\n\n for (let i = 0; i < ctx.destinations.length; i++) {\n let namespace : string;\n if (ctx.destinations[i].namespace) {\n namespace = ctx.destinations[i].namespace;\n } else {\n namespace = '/';\n }\n\n const emitter = new Emitter(this.client, {}, namespace);\n\n const fullEventName = buildDomainEventFullName(ctx.data.type, ctx.data.event);\n\n const rooms : string[] = [\n buildEventChannelName(ctx.destinations[i].channel),\n ];\n\n if (typeof ctx.destinations[i].channel === 'function') {\n rooms.push(buildEventChannelName(ctx.destinations[i].channel, ctx.data.data.id));\n }\n\n for (let j = 0; j < rooms.length; j++) {\n emitter\n .in(rooms[j])\n .emit(fullEventName, {\n ...ctx.data,\n meta: {\n namespace,\n roomName: rooms[j],\n },\n });\n }\n }\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { singa } from 'singa';\nimport { isRedisClientUsable, useRedisClient } from '../redis';\nimport { DomainEventPublisher } from './module';\nimport { DomainEventRedisPublisher } from './redis';\nimport { DomainEventSocketPublisher } from './socket';\n\nconst instance = singa<DomainEventPublisher>({\n name: 'domainEventPublisher',\n factory: () => {\n const publisher = new DomainEventPublisher();\n\n if (isRedisClientUsable()) {\n const client = useRedisClient();\n\n publisher.addPublisher(new DomainEventRedisPublisher(client));\n publisher.addPublisher(new DomainEventSocketPublisher(client));\n }\n\n return publisher;\n },\n});\n\nexport function useDomainEventPublisher() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { ExchangeType } from 'amqp-extension';\nimport type { Client } from 'amqp-extension';\nimport { isLoggerUsable, useLogger } from '../../services';\nimport { QueueRouterRoutingType } from './constants';\nimport { isQueueRouterPayload } from './helpers';\nimport type {\n QueueRouterHandler,\n QueueRouterHandlers,\n QueueRouterPayload, QueueRouterRouting,\n} from './types';\n\nexport class QueueRouter {\n protected driver : Client;\n\n //----------------------------------------------------------------\n\n constructor(driver: Client) {\n this.driver = driver;\n }\n\n //----------------------------------------------------------------\n\n publish(message: QueueRouterPayload) : Promise<boolean> {\n let exchange : Client;\n if (message.metadata.routing.type === 'work') {\n exchange = this.driver.of({\n type: ExchangeType.DIRECT,\n name: message.metadata.routing.namespace || '',\n });\n } else {\n exchange = this.driver.of({\n type: ExchangeType.TOPIC,\n name: message.metadata.routing.namespace || 'FLAME',\n });\n }\n\n if (isLoggerUsable()) {\n useLogger()\n .debug(`Publishing queue message ${message.type} in ${message.metadata.routing.key}`);\n }\n\n return exchange.publish(message.metadata.routing.key, message, {\n type: message.type,\n messageId: message.id,\n persistent: message.metadata.persistent ??\n message.metadata.routing.type === QueueRouterRoutingType.WORK,\n });\n }\n\n consume(routing: QueueRouterRouting, handlers: QueueRouterHandlers) : Promise<void> {\n let exchange : Client;\n if (routing.type === 'work') {\n exchange = this.driver.of({\n type: ExchangeType.DIRECT,\n name: routing.namespace || '',\n });\n } else {\n exchange = this.driver.of({\n type: ExchangeType.TOPIC,\n name: routing.namespace || 'FLAME',\n });\n }\n\n return exchange.consume(routing.key, {\n prefetchCount: routing.type === QueueRouterRoutingType.WORK ? 1 : undefined,\n // noAck: routing.type !== QueueRouterRoutingType.WORK,\n requeueOnFailure: routing.type === QueueRouterRoutingType.WORK,\n }, {\n $any: async (input) => {\n const payload = JSON.parse(input.content.toString('utf-8'));\n if (!isQueueRouterPayload(payload)) {\n return;\n }\n\n if (input.fields.redelivered) {\n if (isLoggerUsable()) {\n useLogger()\n .debug(`Queue message ${input.properties.type} in ${routing.key} is not processed again.`);\n }\n\n return;\n }\n\n if (isLoggerUsable()) {\n useLogger()\n .debug(`Consuming queue message ${input.properties.type} in ${routing.key}`);\n }\n\n let handler : QueueRouterHandler | undefined;\n\n if (\n typeof input.properties.type === 'string' &&\n handlers[input.properties.type]\n ) {\n handler = handlers[input.properties.type];\n } else {\n handler = handlers.$any;\n }\n\n if (typeof handler !== 'function') {\n if (isLoggerUsable()) {\n useLogger()\n .debug(`No queue handler to consume message ${input.properties.type} in ${routing.key}`);\n }\n\n return;\n }\n\n await handler(payload);\n },\n });\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { singa } from 'singa';\nimport { isAmqpClientUsable, useAmqpClient } from '../../services';\nimport { QueueRouter } from './module';\n\nconst instance = singa<QueueRouter>({\n name: 'queueRouter',\n factory: () => {\n const amqp = useAmqpClient();\n\n return new QueueRouter(amqp);\n },\n});\n\nexport function isQueueRouterUsable() {\n return instance.has() || isAmqpClientUsable();\n}\n\nexport function useQueueRouter() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2022-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nexport function hasOwnProperty<X extends Record<string, any>, Y extends PropertyKey>(\n obj: X,\n prop: Y,\n): obj is X & Record<Y, unknown> {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n"],"names":["_define_property","ComponentError","Error","constructor","input","message","cause","code","isComponentError","isObject","isQueuePayload","hasOwnProperty","data","metadata","QueueRouterRoutingType","buildQueueRouterPublishPayload","id","createNanoID","type","timestamp","Date","now","isQueueRouterPayload","instance","singa","name","setAmqpClientFactory","factory","setFactory","isAmqpClientUsable","has","hasFactory","useAmqpClient","use","setVaultFactory","isVaultClientUsable","useVaultClient","guessAuthupTokenCreatorOptions","options","vault","password","setClientAuthenticationHookFactory","isClientAuthenticationHookUsable","useClientAuthenticationHook","AuthupClient","Client","ClientAuthenticationHook","baseURL","tokenCreator","hook","attach","useAuthupClient","isAuthupClientUsable","setAuthupClientFactory","setRedisFactory","isRedisClientUsable","setRedisClient","set","useRedisClient","duplicate","useRedisPublishClient","useRedisSubscribeClient","MemoryCacheAdapter","get","key","value","ttl","drop","delete","dropMany","keys","i","length","clear","prefix","iterator","next","done","startsWith","TTLCache","checkAgeOnGet","Infinity","RedisCacheAdapter","exists","client","milliseconds","pipeline","del","exec","flushdb","JsonAdapter","createCacheAdapter","buildCacheKey","buildRedisKeyPath","Cache","adapter","useCache","createLogger","ctx","directory","loggerTransports","read","EnvironmentName","PRODUCTION","transports","Console","level","File","filename","path","join","process","cwd","maxsize","maxFiles","create","format","combine","errors","stack","colorize","simple","setLoggerFactory","isLoggerUsable","setLogger","useLogger","DomainEventPublisher","addPublisher","publisher","publishers","add","publish","info","event","values","it","Set","transformEventData","Object","toISOString","buildEventChannelName","DomainEventRedisPublisher","JSON","stringify","driver","destinations","keyPrefix","namespace","channel","DomainEventSocketPublisher","emitter","Emitter","fullEventName","buildDomainEventFullName","rooms","push","j","in","emit","meta","roomName","useDomainEventPublisher","QueueRouter","exchange","routing","of","ExchangeType","DIRECT","TOPIC","debug","messageId","persistent","WORK","consume","handlers","prefetchCount","undefined","requeueOnFailure","$any","payload","parse","content","toString","fields","redelivered","properties","handler","amqp","isQueueRouterUsable","useQueueRouter","obj","prop","prototype","call"],"mappings":"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"}
1
+ {"version":3,"file":"index.cjs","sources":["../src/core/component/error.ts","../src/core/component/helper.ts","../src/core/queue/utils.ts","../src/core/queue-router/constants.ts","../src/core/queue-router/helpers.ts","../src/services/amqp/module.ts","../src/services/vault/singleton.ts","../src/services/authup/helpers.ts","../src/services/authup-client-authentication-hook/singleton.ts","../src/services/authup/module.ts","../src/services/authup/singleton.ts","../src/services/redis/singleton.ts","../src/services/redis/singleton-publish.ts","../src/services/redis/singleton-subscribe.ts","../src/services/cache/adapters/memory.ts","../src/services/cache/adapters/redis.ts","../src/services/cache/adapters/factory.ts","../src/services/cache/helper.ts","../src/services/cache/module.ts","../src/services/cache/singleton.ts","../src/services/logger/module.ts","../src/services/logger/singleton.ts","../src/services/domain-event/module.ts","../src/services/domain-event/utils.ts","../src/services/domain-event/redis/module.ts","../src/services/domain-event/socket/module.ts","../src/services/domain-event/singleton.ts","../src/core/queue-router/module.ts","../src/core/queue-router/singleton.ts","../src/utils/has-property.ts"],"sourcesContent":["/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { ComponentErrorOptions } from './type';\n\nexport class ComponentError extends Error {\n public code?: string | null;\n\n constructor(input: ComponentErrorOptions) {\n super(input.message, { cause: input.cause });\n\n this.code = input.code;\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { isObject } from '@privateaim/kit';\nimport type { ComponentError } from './error';\n\nexport function isComponentError(input: unknown) : input is ComponentError {\n if (!isObject(input)) {\n return false;\n }\n\n if (\n typeof input.message !== 'undefined' &&\n typeof input.message !== 'string'\n ) {\n return false;\n }\n\n if (typeof input.code === 'undefined') {\n return true;\n }\n\n return typeof input.code === 'string' || input.code === null;\n}\n","/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { hasOwnProperty, isObject } from '@privateaim/kit';\nimport type { QueuePayload } from './type';\n\nexport function isQueuePayload(input: unknown) : input is QueuePayload {\n return isObject(input) &&\n hasOwnProperty(input, 'data') &&\n isObject(input.data) &&\n hasOwnProperty(input, 'metadata') &&\n isObject(input.metadata);\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nexport enum QueueRouterRoutingType {\n WORK = 'work',\n PUB_SUB = 'pubSub',\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { createNanoID, hasOwnProperty, isObject } from '@privateaim/kit';\nimport type { QueueRouterPayload, QueueRouterPayloadInput } from './types';\n\nexport function buildQueueRouterPublishPayload(\n input: QueueRouterPayloadInput,\n) : QueueRouterPayload {\n return {\n id: input.id || createNanoID(),\n type: input.type,\n data: input.data || {},\n metadata: {\n timestamp: Date.now(),\n ...input.metadata,\n },\n };\n}\n\nexport function isQueueRouterPayload(input: unknown) : input is QueueRouterPayload {\n return isObject(input) &&\n typeof input.id === 'string' &&\n typeof input.type === 'string' &&\n hasOwnProperty(input, 'data') &&\n isObject(input.data) &&\n hasOwnProperty(input, 'metadata') &&\n isObject(input.metadata);\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'amqp-extension';\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\n\nconst instance = singa<Client>({\n name: 'amqp',\n});\n\nexport function setAmqpClientFactory(factory: Factory<Client>) {\n instance.setFactory(factory);\n}\n\nexport function isAmqpClientUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function useAmqpClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\nimport type { VaultClient } from '@hapic/vault';\n\nconst instance = singa<VaultClient>({\n name: 'vault',\n});\n\nexport function setVaultFactory(factory: Factory<VaultClient>) {\n instance.setFactory(factory);\n}\n\nexport function isVaultClientUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function useVaultClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { TokenCreatorOptions } from '@authup/core-http-kit';\nimport { isVaultClientUsable, useVaultClient } from '../vault';\n\nexport function guessAuthupTokenCreatorOptions() : TokenCreatorOptions {\n let options : TokenCreatorOptions;\n if (isVaultClientUsable()) {\n options = {\n type: 'robotInVault',\n name: 'system',\n vault: useVaultClient(),\n };\n } else {\n options = {\n type: 'user',\n name: 'admin',\n password: 'start123',\n };\n }\n\n return options;\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { ClientAuthenticationHook } from '@authup/core-http-kit';\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\n\nconst instance = singa<ClientAuthenticationHook>({\n name: 'clientAuthenticationHook',\n});\n\nexport function setClientAuthenticationHookFactory(factory: Factory<ClientAuthenticationHook>) {\n instance.setFactory(factory);\n}\n\nexport function isClientAuthenticationHookUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function useClientAuthenticationHook() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport {\n Client,\n ClientAuthenticationHook,\n} from '@authup/core-http-kit';\nimport {\n isClientAuthenticationHookUsable,\n setClientAuthenticationHookFactory,\n useClientAuthenticationHook,\n} from '../authup-client-authentication-hook';\nimport { guessAuthupTokenCreatorOptions } from './helpers';\nimport type { AuthupClientOptions } from './types';\n\nexport class AuthupClient extends Client {\n constructor(options: AuthupClientOptions = {}) {\n super(options);\n\n if (!isClientAuthenticationHookUsable()) {\n setClientAuthenticationHookFactory(\n () => new ClientAuthenticationHook({\n baseURL: options.baseURL,\n tokenCreator: options.tokenCreator || guessAuthupTokenCreatorOptions(),\n }),\n );\n }\n\n const hook = useClientAuthenticationHook();\n hook.attach(this);\n }\n}\n","/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from '@authup/core-http-kit';\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\n\nconst instance = singa<Client>({\n name: 'authup',\n});\n\nexport function useAuthupClient() {\n return instance.use();\n}\n\nexport function isAuthupClientUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function setAuthupClientFactory(factory: Factory<Client>) {\n instance.setFactory(factory);\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\n\nconst instance = singa<Client>({\n name: 'redis',\n});\n\nexport function setRedisFactory(factory: Factory<Client>) {\n instance.setFactory(factory);\n}\n\nexport function isRedisClientUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function setRedisClient(input: Client) {\n instance.set(input);\n}\n\nexport function useRedisClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport { singa } from 'singa';\nimport { useRedisClient } from './singleton';\n\nconst instance = singa<Client>({\n name: 'redisPublish',\n factory: () => useRedisClient().duplicate(),\n});\n\nexport function useRedisPublishClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport { singa } from 'singa';\nimport { useRedisClient } from './singleton';\n\nconst instance = singa<Client>({\n name: 'redisSubscribe',\n factory: () => useRedisClient().duplicate(),\n});\n\nexport function useRedisSubscribeClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Options } from '@isaacs/ttlcache';\nimport TTLCache from '@isaacs/ttlcache';\nimport type { CacheClearOptions, CacheSetOptions } from '../types';\nimport type { CacheAdapter } from './types';\n\nexport class MemoryCacheAdapter<\n VALUE = any,\n> implements CacheAdapter {\n protected instance : TTLCache<string, VALUE>;\n\n constructor(options: Options<string, VALUE> = {}) {\n this.instance = new TTLCache<string, VALUE>({\n checkAgeOnGet: true,\n ttl: Infinity,\n ...(options || {}),\n });\n }\n\n async get(key: string): Promise<VALUE> {\n return this.instance.get(key);\n }\n\n async has(key: string) : Promise<boolean> {\n return this.instance.has(key);\n }\n\n async set(key: string, value: VALUE, options: CacheSetOptions): Promise<void> {\n this.instance.set(key, value, {\n ttl: options.ttl,\n });\n }\n\n async drop(key: string): Promise<void> {\n this.instance.delete(key);\n }\n\n async dropMany(keys: string[]) : Promise<void> {\n for (let i = 0; i < keys.length; i++) {\n this.instance.delete(keys[i]);\n }\n }\n\n async clear(options: CacheClearOptions = {}) : Promise<void> {\n if (options.prefix) {\n const keys = this.instance.keys();\n let iterator = keys.next();\n while (!iterator.done) {\n if (iterator.value.startsWith(options.prefix)) {\n this.instance.delete(iterator.value);\n }\n\n iterator = keys.next();\n }\n\n return;\n }\n\n this.instance.clear();\n }\n}\n","/*\n * Copyright (c) 2024-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport { JsonAdapter } from 'redis-extension';\nimport { useRedisClient } from '../../redis';\nimport type { CacheClearOptions, CacheSetOptions } from '../types';\nimport type { CacheAdapter } from './types';\n\nexport class RedisCacheAdapter implements CacheAdapter {\n protected client : Client;\n\n protected instance : JsonAdapter;\n\n constructor() {\n this.client = useRedisClient();\n this.instance = new JsonAdapter(this.client);\n }\n\n async get(key: string): Promise<any> {\n return this.instance.get(key);\n }\n\n async has(key: string) : Promise<boolean> {\n const exists = await this.client.exists(key);\n\n return !!exists;\n }\n\n async set(key: string, value: any, options: CacheSetOptions): Promise<void> {\n await this.instance.set(key, value, {\n milliseconds: options.ttl,\n });\n }\n\n async drop(key: string): Promise<void> {\n await this.instance.drop(key);\n }\n\n async dropMany(keys: string[]) : Promise<void> {\n const pipeline = this.client.pipeline();\n\n for (let i = 0; i < keys.length; i++) {\n pipeline.del(keys[i]);\n }\n\n await pipeline.exec();\n }\n\n async clear(options: CacheClearOptions = {}) : Promise<void> {\n if (options.prefix) {\n const pipeline = this.client.pipeline();\n\n const keys = await this.client.keys(`${options.prefix}*`);\n for (let i = 0; i < keys.length; i++) {\n pipeline.del(keys[i]);\n }\n\n await pipeline.exec();\n\n return;\n }\n await this.client.flushdb();\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { isRedisClientUsable } from '../../redis';\nimport { MemoryCacheAdapter } from './memory';\nimport { RedisCacheAdapter } from './redis';\n\nexport function createCacheAdapter() {\n if (isRedisClientUsable()) {\n return new RedisCacheAdapter();\n }\n\n return new MemoryCacheAdapter();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { buildRedisKeyPath } from '../redis';\nimport type { CacheKeyBuildOptions } from './types';\n\nexport function buildCacheKey(options: CacheKeyBuildOptions) {\n return buildRedisKeyPath(options);\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { CacheAdapter } from './adapters';\nimport type { CacheClearOptions, CacheSetOptions } from './types';\n\nexport class Cache {\n protected adapter : CacheAdapter;\n\n constructor(adapter: CacheAdapter) {\n this.adapter = adapter;\n }\n\n async set(key: string, value: any, options: CacheSetOptions = {}) : Promise<void> {\n await this.adapter.set(key, value, options);\n }\n\n async get(key: string) : Promise<any | undefined> {\n return this.adapter.get(key);\n }\n\n async has(key: string) : Promise<boolean> {\n return this.adapter.has(key);\n }\n\n async drop(key: string) : Promise<void> {\n return this.adapter.drop(key);\n }\n\n async dropMany(keys: string[]) : Promise<void> {\n return this.adapter.dropMany(keys);\n }\n\n async clear(options: CacheClearOptions = {}) : Promise<void> {\n return this.adapter.clear(options);\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { singa } from 'singa';\nimport { isRedisClientUsable } from '../redis';\nimport type { CacheAdapter } from './adapters';\nimport { MemoryCacheAdapter, RedisCacheAdapter } from './adapters';\nimport { Cache } from './module';\n\nconst instance = singa<Cache>({\n name: 'cache',\n factory: () => {\n let adapter : CacheAdapter;\n if (isRedisClientUsable()) {\n adapter = new RedisCacheAdapter();\n } else {\n adapter = new MemoryCacheAdapter();\n }\n\n return new Cache(adapter);\n },\n});\n\nexport function useCache() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { read } from 'envix';\nimport path from 'node:path';\nimport { EnvironmentName } from 'typeorm-extension';\nimport type { Logger } from 'winston';\nimport { createLogger as create, format, transports } from 'winston';\nimport type { LoggerCreateContext, LoggerTransports } from './types';\n\nexport function createLogger(ctx: LoggerCreateContext = {}) : Logger {\n const { directory, options = {} } = ctx;\n\n let loggerTransports : LoggerTransports;\n if (read('env') === EnvironmentName.PRODUCTION) {\n loggerTransports = [\n new transports.Console({\n level: 'info',\n }),\n new transports.File({\n filename: path.join(directory || process.cwd(), 'access.log'),\n level: 'http',\n maxsize: 10 * 1024 * 1024, // 10MB\n maxFiles: 5,\n }),\n new transports.File({\n filename: path.join(directory || process.cwd(), 'error.log'),\n level: 'warn',\n maxsize: 10 * 1024 * 1024, // 10MB\n maxFiles: 5,\n }),\n ];\n } else {\n loggerTransports = [\n new transports.Console({\n level: 'debug',\n }),\n ];\n }\n\n return create({\n format: format.combine(\n format.errors({ stack: true }),\n format.timestamp(),\n format.colorize(),\n format.simple(),\n ),\n level: 'debug',\n transports: loggerTransports,\n // todo: deeply merge options\n ...(options || {}),\n });\n}\n","/*\n * Copyright (c) 2023.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { type Factory, singa } from 'singa';\nimport type { Logger } from 'winston';\n\nconst instance = singa<Logger>({\n name: 'logger',\n});\n\nexport function setLoggerFactory(factory: Factory<Logger>) {\n instance.setFactory(factory);\n}\n\nexport function isLoggerUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function setLogger(input: Logger) {\n instance.set(input);\n}\n\nexport function useLogger() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { DomainEventRecord } from '@privateaim/kit';\nimport { buildDomainEventFullName } from '@privateaim/kit';\nimport { isLoggerUsable, useLogger } from '../logger';\nimport type { DomainEventPublishContext, IDomainEventPublisher } from './type';\n\nexport class DomainEventPublisher implements IDomainEventPublisher {\n protected publishers : Set<IDomainEventPublisher>;\n\n constructor() {\n this.publishers = new Set<IDomainEventPublisher>();\n }\n\n addPublisher(publisher: IDomainEventPublisher) {\n this.publishers.add(publisher);\n }\n\n async safePublish<T extends DomainEventRecord>(\n ctx: DomainEventPublishContext<T>,\n ) : Promise<void> {\n try {\n await this.publish(ctx);\n } catch (e) {\n if (isLoggerUsable()) {\n useLogger().error(`Publishing event ${buildDomainEventFullName(ctx.data.type, ctx.data.event)} failed`);\n useLogger().error(e);\n }\n }\n }\n\n async publish<T extends DomainEventRecord>(\n ctx: DomainEventPublishContext<T>,\n ) : Promise<void> {\n if (isLoggerUsable()) {\n useLogger().info(`Publishing event ${buildDomainEventFullName(ctx.data.type, ctx.data.event)}`);\n }\n\n const publishers = this.publishers.values();\n while (true) {\n const it = publishers.next();\n if (it.done) {\n return;\n }\n\n await it.value.publish(ctx);\n }\n }\n}\n","/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { isObject } from '@privateaim/kit';\nimport type { DomainEventChannelName } from './type';\n\nexport function transformEventData<T>(input: T) : T {\n if (isObject(input)) {\n const keys = Object.keys(input);\n for (let i = 0; i < keys.length; i++) {\n const value = input[keys[i]];\n if (value instanceof Date) {\n input[keys[i]] = value.toISOString();\n }\n }\n }\n\n return input;\n}\n\nexport function buildEventChannelName(\n input: DomainEventChannelName,\n id?: string | number,\n) : string {\n if (typeof input === 'string') {\n return input;\n }\n\n return input(id);\n}\n","/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport type { DomainEventPublishContext, IDomainEventPublisher } from '../type';\nimport { buildEventChannelName, transformEventData } from '../utils';\n\nexport class DomainEventRedisPublisher implements IDomainEventPublisher {\n protected driver : Client;\n\n constructor(client: Client) {\n this.driver = client;\n }\n\n async publish(ctx: DomainEventPublishContext) : Promise<void> {\n const data = JSON.stringify(transformEventData(ctx.data));\n\n const pipeline = this.driver.pipeline();\n for (let i = 0; i < ctx.destinations.length; i++) {\n const keyPrefix = (ctx.destinations[i].namespace ? `${ctx.destinations[i].namespace}:` : '');\n\n let key = keyPrefix + buildEventChannelName(ctx.destinations[i].channel);\n pipeline.publish(key, data);\n\n if (typeof ctx.destinations[i].channel === 'function') {\n key = keyPrefix + buildEventChannelName(ctx.destinations[i].channel, ctx.data.data.id);\n pipeline.publish(key, data);\n }\n }\n\n await pipeline.exec();\n }\n}\n","/*\n * Copyright (c) 2022-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { buildDomainEventFullName } from '@privateaim/kit';\nimport { Emitter } from '@socket.io/redis-emitter';\nimport type { Client } from 'redis-extension';\nimport type { DomainEventPublishContext, IDomainEventPublisher } from '../type';\nimport { buildEventChannelName, transformEventData } from '../utils';\n\nexport class DomainEventSocketPublisher implements IDomainEventPublisher {\n protected client : Client;\n\n constructor(client: Client) {\n this.client = client;\n }\n\n async publish(ctx: DomainEventPublishContext) : Promise<void> {\n ctx.data = transformEventData(ctx.data);\n\n for (let i = 0; i < ctx.destinations.length; i++) {\n let namespace : string;\n if (ctx.destinations[i].namespace) {\n namespace = ctx.destinations[i].namespace;\n } else {\n namespace = '/';\n }\n\n const emitter = new Emitter(this.client, {}, namespace);\n\n const fullEventName = buildDomainEventFullName(ctx.data.type, ctx.data.event);\n\n const rooms : string[] = [\n buildEventChannelName(ctx.destinations[i].channel),\n ];\n\n if (typeof ctx.destinations[i].channel === 'function') {\n rooms.push(buildEventChannelName(ctx.destinations[i].channel, ctx.data.data.id));\n }\n\n for (let j = 0; j < rooms.length; j++) {\n emitter\n .in(rooms[j])\n .emit(fullEventName, {\n ...ctx.data,\n meta: {\n namespace,\n roomName: rooms[j],\n },\n });\n }\n }\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { singa } from 'singa';\nimport { isRedisClientUsable, useRedisClient } from '../redis';\nimport { DomainEventPublisher } from './module';\nimport { DomainEventRedisPublisher } from './redis';\nimport { DomainEventSocketPublisher } from './socket';\n\nconst instance = singa<DomainEventPublisher>({\n name: 'domainEventPublisher',\n factory: () => {\n const publisher = new DomainEventPublisher();\n\n if (isRedisClientUsable()) {\n const client = useRedisClient();\n\n publisher.addPublisher(new DomainEventRedisPublisher(client));\n publisher.addPublisher(new DomainEventSocketPublisher(client));\n }\n\n return publisher;\n },\n});\n\nexport function useDomainEventPublisher() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { ExchangeType } from 'amqp-extension';\nimport type { Client } from 'amqp-extension';\nimport { isLoggerUsable, useLogger } from '../../services';\nimport { QueueRouterRoutingType } from './constants';\nimport { isQueueRouterPayload } from './helpers';\nimport type {\n QueueRouterHandler,\n QueueRouterHandlers,\n QueueRouterPayload, QueueRouterRouting,\n} from './types';\n\nexport class QueueRouter {\n protected driver : Client;\n\n //----------------------------------------------------------------\n\n constructor(driver: Client) {\n this.driver = driver;\n }\n\n //----------------------------------------------------------------\n\n publish(message: QueueRouterPayload) : Promise<boolean> {\n let exchange : Client;\n if (message.metadata.routing.type === 'work') {\n exchange = this.driver.of({\n type: ExchangeType.DIRECT,\n name: message.metadata.routing.namespace || '',\n });\n } else {\n exchange = this.driver.of({\n type: ExchangeType.TOPIC,\n name: message.metadata.routing.namespace || 'FLAME',\n });\n }\n\n if (isLoggerUsable()) {\n useLogger()\n .debug(`Publishing queue message ${message.type} in ${message.metadata.routing.key}`);\n }\n\n return exchange.publish(message.metadata.routing.key, message, {\n type: message.type,\n messageId: message.id,\n persistent: message.metadata.persistent ??\n message.metadata.routing.type === QueueRouterRoutingType.WORK,\n });\n }\n\n consume(routing: QueueRouterRouting, handlers: QueueRouterHandlers) : Promise<void> {\n let exchange : Client;\n if (routing.type === 'work') {\n exchange = this.driver.of({\n type: ExchangeType.DIRECT,\n name: routing.namespace || '',\n });\n } else {\n exchange = this.driver.of({\n type: ExchangeType.TOPIC,\n name: routing.namespace || 'FLAME',\n });\n }\n\n return exchange.consume(routing.key, {\n prefetchCount: routing.type === QueueRouterRoutingType.WORK ? 1 : undefined,\n // noAck: routing.type !== QueueRouterRoutingType.WORK,\n requeueOnFailure: routing.type === QueueRouterRoutingType.WORK,\n }, {\n $any: async (input) => {\n const payload = JSON.parse(input.content.toString('utf-8'));\n if (!isQueueRouterPayload(payload)) {\n return;\n }\n\n if (input.fields.redelivered) {\n if (isLoggerUsable()) {\n useLogger()\n .debug(`Queue message ${input.properties.type} in ${routing.key} is not processed again.`);\n }\n\n return;\n }\n\n if (isLoggerUsable()) {\n useLogger()\n .debug(`Consuming queue message ${input.properties.type} in ${routing.key}`);\n }\n\n let handler : QueueRouterHandler | undefined;\n\n if (\n typeof input.properties.type === 'string' &&\n handlers[input.properties.type]\n ) {\n handler = handlers[input.properties.type];\n } else {\n handler = handlers.$any;\n }\n\n if (typeof handler !== 'function') {\n if (isLoggerUsable()) {\n useLogger()\n .debug(`No queue handler to consume message ${input.properties.type} in ${routing.key}`);\n }\n\n return;\n }\n\n await handler(payload);\n },\n });\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { singa } from 'singa';\nimport { isAmqpClientUsable, useAmqpClient } from '../../services';\nimport { QueueRouter } from './module';\n\nconst instance = singa<QueueRouter>({\n name: 'queueRouter',\n factory: () => {\n const amqp = useAmqpClient();\n\n return new QueueRouter(amqp);\n },\n});\n\nexport function isQueueRouterUsable() {\n return instance.has() || isAmqpClientUsable();\n}\n\nexport function useQueueRouter() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2022-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nexport function hasOwnProperty<X extends Record<string, any>, Y extends PropertyKey>(\n obj: X,\n prop: Y,\n): obj is X & Record<Y, unknown> {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n"],"names":["_define_property","ComponentError","Error","constructor","input","message","cause","code","isComponentError","isObject","isQueuePayload","hasOwnProperty","data","metadata","QueueRouterRoutingType","buildQueueRouterPublishPayload","id","createNanoID","type","timestamp","Date","now","isQueueRouterPayload","instance","singa","name","setAmqpClientFactory","factory","setFactory","isAmqpClientUsable","has","hasFactory","useAmqpClient","use","setVaultFactory","isVaultClientUsable","useVaultClient","guessAuthupTokenCreatorOptions","options","vault","password","setClientAuthenticationHookFactory","isClientAuthenticationHookUsable","useClientAuthenticationHook","AuthupClient","Client","ClientAuthenticationHook","baseURL","tokenCreator","hook","attach","useAuthupClient","isAuthupClientUsable","setAuthupClientFactory","setRedisFactory","isRedisClientUsable","setRedisClient","set","useRedisClient","duplicate","useRedisPublishClient","useRedisSubscribeClient","MemoryCacheAdapter","get","key","value","ttl","drop","delete","dropMany","keys","i","length","clear","prefix","iterator","next","done","startsWith","TTLCache","checkAgeOnGet","Infinity","RedisCacheAdapter","exists","client","milliseconds","pipeline","del","exec","flushdb","JsonAdapter","createCacheAdapter","buildCacheKey","buildRedisKeyPath","Cache","adapter","useCache","createLogger","ctx","directory","loggerTransports","read","EnvironmentName","PRODUCTION","transports","Console","level","File","filename","path","join","process","cwd","maxsize","maxFiles","create","format","combine","errors","stack","colorize","simple","setLoggerFactory","isLoggerUsable","setLogger","useLogger","DomainEventPublisher","addPublisher","publisher","publishers","add","safePublish","publish","e","error","buildDomainEventFullName","event","info","values","it","Set","transformEventData","Object","toISOString","buildEventChannelName","DomainEventRedisPublisher","JSON","stringify","driver","destinations","keyPrefix","namespace","channel","DomainEventSocketPublisher","emitter","Emitter","fullEventName","rooms","push","j","in","emit","meta","roomName","useDomainEventPublisher","QueueRouter","exchange","routing","of","ExchangeType","DIRECT","TOPIC","debug","messageId","persistent","WORK","consume","handlers","prefetchCount","undefined","requeueOnFailure","$any","payload","parse","content","toString","fields","redelivered","properties","handler","amqp","isQueueRouterUsable","useQueueRouter","obj","prop","prototype","call"],"mappings":"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"}
package/dist/index.mjs CHANGED
@@ -468,9 +468,19 @@ class DomainEventPublisher {
468
468
  addPublisher(publisher) {
469
469
  this.publishers.add(publisher);
470
470
  }
471
+ async safePublish(ctx) {
472
+ try {
473
+ await this.publish(ctx);
474
+ } catch (e) {
475
+ if (isLoggerUsable()) {
476
+ useLogger().error(`Publishing event ${buildDomainEventFullName(ctx.data.type, ctx.data.event)} failed`);
477
+ useLogger().error(e);
478
+ }
479
+ }
480
+ }
471
481
  async publish(ctx) {
472
482
  if (isLoggerUsable()) {
473
- useLogger().info(`Publishing event ${ctx.data.event} for ${ctx.data.type}`);
483
+ useLogger().info(`Publishing event ${buildDomainEventFullName(ctx.data.type, ctx.data.event)}`);
474
484
  }
475
485
  const publishers = this.publishers.values();
476
486
  while(true){
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../src/core/component/error.ts","../src/core/component/helper.ts","../src/core/queue/utils.ts","../src/core/queue-router/constants.ts","../src/core/queue-router/helpers.ts","../src/services/amqp/module.ts","../src/services/vault/singleton.ts","../src/services/authup/helpers.ts","../src/services/authup-client-authentication-hook/singleton.ts","../src/services/authup/module.ts","../src/services/authup/singleton.ts","../src/services/redis/singleton.ts","../src/services/redis/singleton-publish.ts","../src/services/redis/singleton-subscribe.ts","../src/services/cache/adapters/memory.ts","../src/services/cache/adapters/redis.ts","../src/services/cache/adapters/factory.ts","../src/services/cache/helper.ts","../src/services/cache/module.ts","../src/services/cache/singleton.ts","../src/services/logger/module.ts","../src/services/logger/singleton.ts","../src/services/domain-event/module.ts","../src/services/domain-event/utils.ts","../src/services/domain-event/redis/module.ts","../src/services/domain-event/socket/module.ts","../src/services/domain-event/singleton.ts","../src/core/queue-router/module.ts","../src/core/queue-router/singleton.ts","../src/utils/has-property.ts"],"sourcesContent":["/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { ComponentErrorOptions } from './type';\n\nexport class ComponentError extends Error {\n public code?: string | null;\n\n constructor(input: ComponentErrorOptions) {\n super(input.message, { cause: input.cause });\n\n this.code = input.code;\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { isObject } from '@privateaim/kit';\nimport type { ComponentError } from './error';\n\nexport function isComponentError(input: unknown) : input is ComponentError {\n if (!isObject(input)) {\n return false;\n }\n\n if (\n typeof input.message !== 'undefined' &&\n typeof input.message !== 'string'\n ) {\n return false;\n }\n\n if (typeof input.code === 'undefined') {\n return true;\n }\n\n return typeof input.code === 'string' || input.code === null;\n}\n","/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { hasOwnProperty, isObject } from '@privateaim/kit';\nimport type { QueuePayload } from './type';\n\nexport function isQueuePayload(input: unknown) : input is QueuePayload {\n return isObject(input) &&\n hasOwnProperty(input, 'data') &&\n isObject(input.data) &&\n hasOwnProperty(input, 'metadata') &&\n isObject(input.metadata);\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nexport enum QueueRouterRoutingType {\n WORK = 'work',\n PUB_SUB = 'pubSub',\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { createNanoID, hasOwnProperty, isObject } from '@privateaim/kit';\nimport type { QueueRouterPayload, QueueRouterPayloadInput } from './types';\n\nexport function buildQueueRouterPublishPayload(\n input: QueueRouterPayloadInput,\n) : QueueRouterPayload {\n return {\n id: input.id || createNanoID(),\n type: input.type,\n data: input.data || {},\n metadata: {\n timestamp: Date.now(),\n ...input.metadata,\n },\n };\n}\n\nexport function isQueueRouterPayload(input: unknown) : input is QueueRouterPayload {\n return isObject(input) &&\n typeof input.id === 'string' &&\n typeof input.type === 'string' &&\n hasOwnProperty(input, 'data') &&\n isObject(input.data) &&\n hasOwnProperty(input, 'metadata') &&\n isObject(input.metadata);\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'amqp-extension';\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\n\nconst instance = singa<Client>({\n name: 'amqp',\n});\n\nexport function setAmqpClientFactory(factory: Factory<Client>) {\n instance.setFactory(factory);\n}\n\nexport function isAmqpClientUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function useAmqpClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\nimport type { VaultClient } from '@hapic/vault';\n\nconst instance = singa<VaultClient>({\n name: 'vault',\n});\n\nexport function setVaultFactory(factory: Factory<VaultClient>) {\n instance.setFactory(factory);\n}\n\nexport function isVaultClientUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function useVaultClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { TokenCreatorOptions } from '@authup/core-http-kit';\nimport { isVaultClientUsable, useVaultClient } from '../vault';\n\nexport function guessAuthupTokenCreatorOptions() : TokenCreatorOptions {\n let options : TokenCreatorOptions;\n if (isVaultClientUsable()) {\n options = {\n type: 'robotInVault',\n name: 'system',\n vault: useVaultClient(),\n };\n } else {\n options = {\n type: 'user',\n name: 'admin',\n password: 'start123',\n };\n }\n\n return options;\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { ClientAuthenticationHook } from '@authup/core-http-kit';\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\n\nconst instance = singa<ClientAuthenticationHook>({\n name: 'clientAuthenticationHook',\n});\n\nexport function setClientAuthenticationHookFactory(factory: Factory<ClientAuthenticationHook>) {\n instance.setFactory(factory);\n}\n\nexport function isClientAuthenticationHookUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function useClientAuthenticationHook() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport {\n Client,\n ClientAuthenticationHook,\n} from '@authup/core-http-kit';\nimport {\n isClientAuthenticationHookUsable,\n setClientAuthenticationHookFactory,\n useClientAuthenticationHook,\n} from '../authup-client-authentication-hook';\nimport { guessAuthupTokenCreatorOptions } from './helpers';\nimport type { AuthupClientOptions } from './types';\n\nexport class AuthupClient extends Client {\n constructor(options: AuthupClientOptions = {}) {\n super(options);\n\n if (!isClientAuthenticationHookUsable()) {\n setClientAuthenticationHookFactory(\n () => new ClientAuthenticationHook({\n baseURL: options.baseURL,\n tokenCreator: options.tokenCreator || guessAuthupTokenCreatorOptions(),\n }),\n );\n }\n\n const hook = useClientAuthenticationHook();\n hook.attach(this);\n }\n}\n","/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from '@authup/core-http-kit';\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\n\nconst instance = singa<Client>({\n name: 'authup',\n});\n\nexport function useAuthupClient() {\n return instance.use();\n}\n\nexport function isAuthupClientUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function setAuthupClientFactory(factory: Factory<Client>) {\n instance.setFactory(factory);\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\n\nconst instance = singa<Client>({\n name: 'redis',\n});\n\nexport function setRedisFactory(factory: Factory<Client>) {\n instance.setFactory(factory);\n}\n\nexport function isRedisClientUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function setRedisClient(input: Client) {\n instance.set(input);\n}\n\nexport function useRedisClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport { singa } from 'singa';\nimport { useRedisClient } from './singleton';\n\nconst instance = singa<Client>({\n name: 'redisPublish',\n factory: () => useRedisClient().duplicate(),\n});\n\nexport function useRedisPublishClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport { singa } from 'singa';\nimport { useRedisClient } from './singleton';\n\nconst instance = singa<Client>({\n name: 'redisSubscribe',\n factory: () => useRedisClient().duplicate(),\n});\n\nexport function useRedisSubscribeClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Options } from '@isaacs/ttlcache';\nimport TTLCache from '@isaacs/ttlcache';\nimport type { CacheClearOptions, CacheSetOptions } from '../types';\nimport type { CacheAdapter } from './types';\n\nexport class MemoryCacheAdapter<\n VALUE = any,\n> implements CacheAdapter {\n protected instance : TTLCache<string, VALUE>;\n\n constructor(options: Options<string, VALUE> = {}) {\n this.instance = new TTLCache<string, VALUE>({\n checkAgeOnGet: true,\n ttl: Infinity,\n ...(options || {}),\n });\n }\n\n async get(key: string): Promise<VALUE> {\n return this.instance.get(key);\n }\n\n async has(key: string) : Promise<boolean> {\n return this.instance.has(key);\n }\n\n async set(key: string, value: VALUE, options: CacheSetOptions): Promise<void> {\n this.instance.set(key, value, {\n ttl: options.ttl,\n });\n }\n\n async drop(key: string): Promise<void> {\n this.instance.delete(key);\n }\n\n async dropMany(keys: string[]) : Promise<void> {\n for (let i = 0; i < keys.length; i++) {\n this.instance.delete(keys[i]);\n }\n }\n\n async clear(options: CacheClearOptions = {}) : Promise<void> {\n if (options.prefix) {\n const keys = this.instance.keys();\n let iterator = keys.next();\n while (!iterator.done) {\n if (iterator.value.startsWith(options.prefix)) {\n this.instance.delete(iterator.value);\n }\n\n iterator = keys.next();\n }\n\n return;\n }\n\n this.instance.clear();\n }\n}\n","/*\n * Copyright (c) 2024-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport { JsonAdapter } from 'redis-extension';\nimport { useRedisClient } from '../../redis';\nimport type { CacheClearOptions, CacheSetOptions } from '../types';\nimport type { CacheAdapter } from './types';\n\nexport class RedisCacheAdapter implements CacheAdapter {\n protected client : Client;\n\n protected instance : JsonAdapter;\n\n constructor() {\n this.client = useRedisClient();\n this.instance = new JsonAdapter(this.client);\n }\n\n async get(key: string): Promise<any> {\n return this.instance.get(key);\n }\n\n async has(key: string) : Promise<boolean> {\n const exists = await this.client.exists(key);\n\n return !!exists;\n }\n\n async set(key: string, value: any, options: CacheSetOptions): Promise<void> {\n await this.instance.set(key, value, {\n milliseconds: options.ttl,\n });\n }\n\n async drop(key: string): Promise<void> {\n await this.instance.drop(key);\n }\n\n async dropMany(keys: string[]) : Promise<void> {\n const pipeline = this.client.pipeline();\n\n for (let i = 0; i < keys.length; i++) {\n pipeline.del(keys[i]);\n }\n\n await pipeline.exec();\n }\n\n async clear(options: CacheClearOptions = {}) : Promise<void> {\n if (options.prefix) {\n const pipeline = this.client.pipeline();\n\n const keys = await this.client.keys(`${options.prefix}*`);\n for (let i = 0; i < keys.length; i++) {\n pipeline.del(keys[i]);\n }\n\n await pipeline.exec();\n\n return;\n }\n await this.client.flushdb();\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { isRedisClientUsable } from '../../redis';\nimport { MemoryCacheAdapter } from './memory';\nimport { RedisCacheAdapter } from './redis';\n\nexport function createCacheAdapter() {\n if (isRedisClientUsable()) {\n return new RedisCacheAdapter();\n }\n\n return new MemoryCacheAdapter();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { buildRedisKeyPath } from '../redis';\nimport type { CacheKeyBuildOptions } from './types';\n\nexport function buildCacheKey(options: CacheKeyBuildOptions) {\n return buildRedisKeyPath(options);\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { CacheAdapter } from './adapters';\nimport type { CacheClearOptions, CacheSetOptions } from './types';\n\nexport class Cache {\n protected adapter : CacheAdapter;\n\n constructor(adapter: CacheAdapter) {\n this.adapter = adapter;\n }\n\n async set(key: string, value: any, options: CacheSetOptions = {}) : Promise<void> {\n await this.adapter.set(key, value, options);\n }\n\n async get(key: string) : Promise<any | undefined> {\n return this.adapter.get(key);\n }\n\n async has(key: string) : Promise<boolean> {\n return this.adapter.has(key);\n }\n\n async drop(key: string) : Promise<void> {\n return this.adapter.drop(key);\n }\n\n async dropMany(keys: string[]) : Promise<void> {\n return this.adapter.dropMany(keys);\n }\n\n async clear(options: CacheClearOptions = {}) : Promise<void> {\n return this.adapter.clear(options);\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { singa } from 'singa';\nimport { isRedisClientUsable } from '../redis';\nimport type { CacheAdapter } from './adapters';\nimport { MemoryCacheAdapter, RedisCacheAdapter } from './adapters';\nimport { Cache } from './module';\n\nconst instance = singa<Cache>({\n name: 'cache',\n factory: () => {\n let adapter : CacheAdapter;\n if (isRedisClientUsable()) {\n adapter = new RedisCacheAdapter();\n } else {\n adapter = new MemoryCacheAdapter();\n }\n\n return new Cache(adapter);\n },\n});\n\nexport function useCache() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { read } from 'envix';\nimport path from 'node:path';\nimport { EnvironmentName } from 'typeorm-extension';\nimport type { Logger } from 'winston';\nimport { createLogger as create, format, transports } from 'winston';\nimport type { LoggerCreateContext, LoggerTransports } from './types';\n\nexport function createLogger(ctx: LoggerCreateContext = {}) : Logger {\n const { directory, options = {} } = ctx;\n\n let loggerTransports : LoggerTransports;\n if (read('env') === EnvironmentName.PRODUCTION) {\n loggerTransports = [\n new transports.Console({\n level: 'info',\n }),\n new transports.File({\n filename: path.join(directory || process.cwd(), 'access.log'),\n level: 'http',\n maxsize: 10 * 1024 * 1024, // 10MB\n maxFiles: 5,\n }),\n new transports.File({\n filename: path.join(directory || process.cwd(), 'error.log'),\n level: 'warn',\n maxsize: 10 * 1024 * 1024, // 10MB\n maxFiles: 5,\n }),\n ];\n } else {\n loggerTransports = [\n new transports.Console({\n level: 'debug',\n }),\n ];\n }\n\n return create({\n format: format.combine(\n format.errors({ stack: true }),\n format.timestamp(),\n format.colorize(),\n format.simple(),\n ),\n level: 'debug',\n transports: loggerTransports,\n // todo: deeply merge options\n ...(options || {}),\n });\n}\n","/*\n * Copyright (c) 2023.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { type Factory, singa } from 'singa';\nimport type { Logger } from 'winston';\n\nconst instance = singa<Logger>({\n name: 'logger',\n});\n\nexport function setLoggerFactory(factory: Factory<Logger>) {\n instance.setFactory(factory);\n}\n\nexport function isLoggerUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function setLogger(input: Logger) {\n instance.set(input);\n}\n\nexport function useLogger() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { DomainEventRecord } from '@privateaim/kit';\nimport { isLoggerUsable, useLogger } from '../logger';\nimport type { DomainEventPublishContext, IDomainEventPublisher } from './type';\n\nexport class DomainEventPublisher implements IDomainEventPublisher {\n protected publishers : Set<IDomainEventPublisher>;\n\n constructor() {\n this.publishers = new Set<IDomainEventPublisher>();\n }\n\n addPublisher(publisher: IDomainEventPublisher) {\n this.publishers.add(publisher);\n }\n\n async publish<T extends DomainEventRecord>(\n ctx: DomainEventPublishContext<T>,\n ) : Promise<void> {\n if (isLoggerUsable()) {\n useLogger().info(`Publishing event ${ctx.data.event} for ${ctx.data.type}`);\n }\n\n const publishers = this.publishers.values();\n while (true) {\n const it = publishers.next();\n if (it.done) {\n return;\n }\n\n await it.value.publish(ctx);\n }\n }\n}\n","/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { isObject } from '@privateaim/kit';\nimport type { DomainEventChannelName } from './type';\n\nexport function transformEventData<T>(input: T) : T {\n if (isObject(input)) {\n const keys = Object.keys(input);\n for (let i = 0; i < keys.length; i++) {\n const value = input[keys[i]];\n if (value instanceof Date) {\n input[keys[i]] = value.toISOString();\n }\n }\n }\n\n return input;\n}\n\nexport function buildEventChannelName(\n input: DomainEventChannelName,\n id?: string | number,\n) : string {\n if (typeof input === 'string') {\n return input;\n }\n\n return input(id);\n}\n","/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport type { DomainEventPublishContext, IDomainEventPublisher } from '../type';\nimport { buildEventChannelName, transformEventData } from '../utils';\n\nexport class DomainEventRedisPublisher implements IDomainEventPublisher {\n protected driver : Client;\n\n constructor(client: Client) {\n this.driver = client;\n }\n\n async publish(ctx: DomainEventPublishContext) : Promise<void> {\n const data = JSON.stringify(transformEventData(ctx.data));\n\n const pipeline = this.driver.pipeline();\n for (let i = 0; i < ctx.destinations.length; i++) {\n const keyPrefix = (ctx.destinations[i].namespace ? `${ctx.destinations[i].namespace}:` : '');\n\n let key = keyPrefix + buildEventChannelName(ctx.destinations[i].channel);\n pipeline.publish(key, data);\n\n if (typeof ctx.destinations[i].channel === 'function') {\n key = keyPrefix + buildEventChannelName(ctx.destinations[i].channel, ctx.data.data.id);\n pipeline.publish(key, data);\n }\n }\n\n await pipeline.exec();\n }\n}\n","/*\n * Copyright (c) 2022-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { buildDomainEventFullName } from '@privateaim/kit';\nimport { Emitter } from '@socket.io/redis-emitter';\nimport type { Client } from 'redis-extension';\nimport type { DomainEventPublishContext, IDomainEventPublisher } from '../type';\nimport { buildEventChannelName, transformEventData } from '../utils';\n\nexport class DomainEventSocketPublisher implements IDomainEventPublisher {\n protected client : Client;\n\n constructor(client: Client) {\n this.client = client;\n }\n\n async publish(ctx: DomainEventPublishContext) : Promise<void> {\n ctx.data = transformEventData(ctx.data);\n\n for (let i = 0; i < ctx.destinations.length; i++) {\n let namespace : string;\n if (ctx.destinations[i].namespace) {\n namespace = ctx.destinations[i].namespace;\n } else {\n namespace = '/';\n }\n\n const emitter = new Emitter(this.client, {}, namespace);\n\n const fullEventName = buildDomainEventFullName(ctx.data.type, ctx.data.event);\n\n const rooms : string[] = [\n buildEventChannelName(ctx.destinations[i].channel),\n ];\n\n if (typeof ctx.destinations[i].channel === 'function') {\n rooms.push(buildEventChannelName(ctx.destinations[i].channel, ctx.data.data.id));\n }\n\n for (let j = 0; j < rooms.length; j++) {\n emitter\n .in(rooms[j])\n .emit(fullEventName, {\n ...ctx.data,\n meta: {\n namespace,\n roomName: rooms[j],\n },\n });\n }\n }\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { singa } from 'singa';\nimport { isRedisClientUsable, useRedisClient } from '../redis';\nimport { DomainEventPublisher } from './module';\nimport { DomainEventRedisPublisher } from './redis';\nimport { DomainEventSocketPublisher } from './socket';\n\nconst instance = singa<DomainEventPublisher>({\n name: 'domainEventPublisher',\n factory: () => {\n const publisher = new DomainEventPublisher();\n\n if (isRedisClientUsable()) {\n const client = useRedisClient();\n\n publisher.addPublisher(new DomainEventRedisPublisher(client));\n publisher.addPublisher(new DomainEventSocketPublisher(client));\n }\n\n return publisher;\n },\n});\n\nexport function useDomainEventPublisher() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { ExchangeType } from 'amqp-extension';\nimport type { Client } from 'amqp-extension';\nimport { isLoggerUsable, useLogger } from '../../services';\nimport { QueueRouterRoutingType } from './constants';\nimport { isQueueRouterPayload } from './helpers';\nimport type {\n QueueRouterHandler,\n QueueRouterHandlers,\n QueueRouterPayload, QueueRouterRouting,\n} from './types';\n\nexport class QueueRouter {\n protected driver : Client;\n\n //----------------------------------------------------------------\n\n constructor(driver: Client) {\n this.driver = driver;\n }\n\n //----------------------------------------------------------------\n\n publish(message: QueueRouterPayload) : Promise<boolean> {\n let exchange : Client;\n if (message.metadata.routing.type === 'work') {\n exchange = this.driver.of({\n type: ExchangeType.DIRECT,\n name: message.metadata.routing.namespace || '',\n });\n } else {\n exchange = this.driver.of({\n type: ExchangeType.TOPIC,\n name: message.metadata.routing.namespace || 'FLAME',\n });\n }\n\n if (isLoggerUsable()) {\n useLogger()\n .debug(`Publishing queue message ${message.type} in ${message.metadata.routing.key}`);\n }\n\n return exchange.publish(message.metadata.routing.key, message, {\n type: message.type,\n messageId: message.id,\n persistent: message.metadata.persistent ??\n message.metadata.routing.type === QueueRouterRoutingType.WORK,\n });\n }\n\n consume(routing: QueueRouterRouting, handlers: QueueRouterHandlers) : Promise<void> {\n let exchange : Client;\n if (routing.type === 'work') {\n exchange = this.driver.of({\n type: ExchangeType.DIRECT,\n name: routing.namespace || '',\n });\n } else {\n exchange = this.driver.of({\n type: ExchangeType.TOPIC,\n name: routing.namespace || 'FLAME',\n });\n }\n\n return exchange.consume(routing.key, {\n prefetchCount: routing.type === QueueRouterRoutingType.WORK ? 1 : undefined,\n // noAck: routing.type !== QueueRouterRoutingType.WORK,\n requeueOnFailure: routing.type === QueueRouterRoutingType.WORK,\n }, {\n $any: async (input) => {\n const payload = JSON.parse(input.content.toString('utf-8'));\n if (!isQueueRouterPayload(payload)) {\n return;\n }\n\n if (input.fields.redelivered) {\n if (isLoggerUsable()) {\n useLogger()\n .debug(`Queue message ${input.properties.type} in ${routing.key} is not processed again.`);\n }\n\n return;\n }\n\n if (isLoggerUsable()) {\n useLogger()\n .debug(`Consuming queue message ${input.properties.type} in ${routing.key}`);\n }\n\n let handler : QueueRouterHandler | undefined;\n\n if (\n typeof input.properties.type === 'string' &&\n handlers[input.properties.type]\n ) {\n handler = handlers[input.properties.type];\n } else {\n handler = handlers.$any;\n }\n\n if (typeof handler !== 'function') {\n if (isLoggerUsable()) {\n useLogger()\n .debug(`No queue handler to consume message ${input.properties.type} in ${routing.key}`);\n }\n\n return;\n }\n\n await handler(payload);\n },\n });\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { singa } from 'singa';\nimport { isAmqpClientUsable, useAmqpClient } from '../../services';\nimport { QueueRouter } from './module';\n\nconst instance = singa<QueueRouter>({\n name: 'queueRouter',\n factory: () => {\n const amqp = useAmqpClient();\n\n return new QueueRouter(amqp);\n },\n});\n\nexport function isQueueRouterUsable() {\n return instance.has() || isAmqpClientUsable();\n}\n\nexport function useQueueRouter() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2022-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nexport function hasOwnProperty<X extends Record<string, any>, Y extends PropertyKey>(\n obj: X,\n prop: Y,\n): obj is X & Record<Y, unknown> {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n"],"names":["_define_property","ComponentError","Error","constructor","input","message","cause","code","isComponentError","isObject","isQueuePayload","hasOwnProperty","data","metadata","QueueRouterRoutingType","buildQueueRouterPublishPayload","id","createNanoID","type","timestamp","Date","now","isQueueRouterPayload","instance","singa","name","setAmqpClientFactory","factory","setFactory","isAmqpClientUsable","has","hasFactory","useAmqpClient","use","setVaultFactory","isVaultClientUsable","useVaultClient","guessAuthupTokenCreatorOptions","options","vault","password","setClientAuthenticationHookFactory","isClientAuthenticationHookUsable","useClientAuthenticationHook","AuthupClient","Client","ClientAuthenticationHook","baseURL","tokenCreator","hook","attach","useAuthupClient","isAuthupClientUsable","setAuthupClientFactory","setRedisFactory","isRedisClientUsable","setRedisClient","set","useRedisClient","duplicate","useRedisPublishClient","useRedisSubscribeClient","MemoryCacheAdapter","get","key","value","ttl","drop","delete","dropMany","keys","i","length","clear","prefix","iterator","next","done","startsWith","TTLCache","checkAgeOnGet","Infinity","RedisCacheAdapter","exists","client","milliseconds","pipeline","del","exec","flushdb","JsonAdapter","createCacheAdapter","buildCacheKey","buildRedisKeyPath","Cache","adapter","useCache","createLogger","ctx","directory","loggerTransports","read","EnvironmentName","PRODUCTION","transports","Console","level","File","filename","path","join","process","cwd","maxsize","maxFiles","create","format","combine","errors","stack","colorize","simple","setLoggerFactory","isLoggerUsable","setLogger","useLogger","DomainEventPublisher","addPublisher","publisher","publishers","add","publish","info","event","values","it","Set","transformEventData","Object","toISOString","buildEventChannelName","DomainEventRedisPublisher","JSON","stringify","driver","destinations","keyPrefix","namespace","channel","DomainEventSocketPublisher","emitter","Emitter","fullEventName","buildDomainEventFullName","rooms","push","j","in","emit","meta","roomName","useDomainEventPublisher","QueueRouter","exchange","routing","of","ExchangeType","DIRECT","TOPIC","debug","messageId","persistent","WORK","consume","handlers","prefetchCount","undefined","requeueOnFailure","$any","payload","parse","content","toString","fields","redelivered","properties","handler","amqp","isQueueRouterUsable","useQueueRouter","obj","prop","prototype","call"],"mappings":"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"}
1
+ {"version":3,"file":"index.mjs","sources":["../src/core/component/error.ts","../src/core/component/helper.ts","../src/core/queue/utils.ts","../src/core/queue-router/constants.ts","../src/core/queue-router/helpers.ts","../src/services/amqp/module.ts","../src/services/vault/singleton.ts","../src/services/authup/helpers.ts","../src/services/authup-client-authentication-hook/singleton.ts","../src/services/authup/module.ts","../src/services/authup/singleton.ts","../src/services/redis/singleton.ts","../src/services/redis/singleton-publish.ts","../src/services/redis/singleton-subscribe.ts","../src/services/cache/adapters/memory.ts","../src/services/cache/adapters/redis.ts","../src/services/cache/adapters/factory.ts","../src/services/cache/helper.ts","../src/services/cache/module.ts","../src/services/cache/singleton.ts","../src/services/logger/module.ts","../src/services/logger/singleton.ts","../src/services/domain-event/module.ts","../src/services/domain-event/utils.ts","../src/services/domain-event/redis/module.ts","../src/services/domain-event/socket/module.ts","../src/services/domain-event/singleton.ts","../src/core/queue-router/module.ts","../src/core/queue-router/singleton.ts","../src/utils/has-property.ts"],"sourcesContent":["/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { ComponentErrorOptions } from './type';\n\nexport class ComponentError extends Error {\n public code?: string | null;\n\n constructor(input: ComponentErrorOptions) {\n super(input.message, { cause: input.cause });\n\n this.code = input.code;\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { isObject } from '@privateaim/kit';\nimport type { ComponentError } from './error';\n\nexport function isComponentError(input: unknown) : input is ComponentError {\n if (!isObject(input)) {\n return false;\n }\n\n if (\n typeof input.message !== 'undefined' &&\n typeof input.message !== 'string'\n ) {\n return false;\n }\n\n if (typeof input.code === 'undefined') {\n return true;\n }\n\n return typeof input.code === 'string' || input.code === null;\n}\n","/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { hasOwnProperty, isObject } from '@privateaim/kit';\nimport type { QueuePayload } from './type';\n\nexport function isQueuePayload(input: unknown) : input is QueuePayload {\n return isObject(input) &&\n hasOwnProperty(input, 'data') &&\n isObject(input.data) &&\n hasOwnProperty(input, 'metadata') &&\n isObject(input.metadata);\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nexport enum QueueRouterRoutingType {\n WORK = 'work',\n PUB_SUB = 'pubSub',\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { createNanoID, hasOwnProperty, isObject } from '@privateaim/kit';\nimport type { QueueRouterPayload, QueueRouterPayloadInput } from './types';\n\nexport function buildQueueRouterPublishPayload(\n input: QueueRouterPayloadInput,\n) : QueueRouterPayload {\n return {\n id: input.id || createNanoID(),\n type: input.type,\n data: input.data || {},\n metadata: {\n timestamp: Date.now(),\n ...input.metadata,\n },\n };\n}\n\nexport function isQueueRouterPayload(input: unknown) : input is QueueRouterPayload {\n return isObject(input) &&\n typeof input.id === 'string' &&\n typeof input.type === 'string' &&\n hasOwnProperty(input, 'data') &&\n isObject(input.data) &&\n hasOwnProperty(input, 'metadata') &&\n isObject(input.metadata);\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'amqp-extension';\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\n\nconst instance = singa<Client>({\n name: 'amqp',\n});\n\nexport function setAmqpClientFactory(factory: Factory<Client>) {\n instance.setFactory(factory);\n}\n\nexport function isAmqpClientUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function useAmqpClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\nimport type { VaultClient } from '@hapic/vault';\n\nconst instance = singa<VaultClient>({\n name: 'vault',\n});\n\nexport function setVaultFactory(factory: Factory<VaultClient>) {\n instance.setFactory(factory);\n}\n\nexport function isVaultClientUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function useVaultClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { TokenCreatorOptions } from '@authup/core-http-kit';\nimport { isVaultClientUsable, useVaultClient } from '../vault';\n\nexport function guessAuthupTokenCreatorOptions() : TokenCreatorOptions {\n let options : TokenCreatorOptions;\n if (isVaultClientUsable()) {\n options = {\n type: 'robotInVault',\n name: 'system',\n vault: useVaultClient(),\n };\n } else {\n options = {\n type: 'user',\n name: 'admin',\n password: 'start123',\n };\n }\n\n return options;\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { ClientAuthenticationHook } from '@authup/core-http-kit';\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\n\nconst instance = singa<ClientAuthenticationHook>({\n name: 'clientAuthenticationHook',\n});\n\nexport function setClientAuthenticationHookFactory(factory: Factory<ClientAuthenticationHook>) {\n instance.setFactory(factory);\n}\n\nexport function isClientAuthenticationHookUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function useClientAuthenticationHook() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport {\n Client,\n ClientAuthenticationHook,\n} from '@authup/core-http-kit';\nimport {\n isClientAuthenticationHookUsable,\n setClientAuthenticationHookFactory,\n useClientAuthenticationHook,\n} from '../authup-client-authentication-hook';\nimport { guessAuthupTokenCreatorOptions } from './helpers';\nimport type { AuthupClientOptions } from './types';\n\nexport class AuthupClient extends Client {\n constructor(options: AuthupClientOptions = {}) {\n super(options);\n\n if (!isClientAuthenticationHookUsable()) {\n setClientAuthenticationHookFactory(\n () => new ClientAuthenticationHook({\n baseURL: options.baseURL,\n tokenCreator: options.tokenCreator || guessAuthupTokenCreatorOptions(),\n }),\n );\n }\n\n const hook = useClientAuthenticationHook();\n hook.attach(this);\n }\n}\n","/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from '@authup/core-http-kit';\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\n\nconst instance = singa<Client>({\n name: 'authup',\n});\n\nexport function useAuthupClient() {\n return instance.use();\n}\n\nexport function isAuthupClientUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function setAuthupClientFactory(factory: Factory<Client>) {\n instance.setFactory(factory);\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport type { Factory } from 'singa';\nimport { singa } from 'singa';\n\nconst instance = singa<Client>({\n name: 'redis',\n});\n\nexport function setRedisFactory(factory: Factory<Client>) {\n instance.setFactory(factory);\n}\n\nexport function isRedisClientUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function setRedisClient(input: Client) {\n instance.set(input);\n}\n\nexport function useRedisClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport { singa } from 'singa';\nimport { useRedisClient } from './singleton';\n\nconst instance = singa<Client>({\n name: 'redisPublish',\n factory: () => useRedisClient().duplicate(),\n});\n\nexport function useRedisPublishClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport { singa } from 'singa';\nimport { useRedisClient } from './singleton';\n\nconst instance = singa<Client>({\n name: 'redisSubscribe',\n factory: () => useRedisClient().duplicate(),\n});\n\nexport function useRedisSubscribeClient() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Options } from '@isaacs/ttlcache';\nimport TTLCache from '@isaacs/ttlcache';\nimport type { CacheClearOptions, CacheSetOptions } from '../types';\nimport type { CacheAdapter } from './types';\n\nexport class MemoryCacheAdapter<\n VALUE = any,\n> implements CacheAdapter {\n protected instance : TTLCache<string, VALUE>;\n\n constructor(options: Options<string, VALUE> = {}) {\n this.instance = new TTLCache<string, VALUE>({\n checkAgeOnGet: true,\n ttl: Infinity,\n ...(options || {}),\n });\n }\n\n async get(key: string): Promise<VALUE> {\n return this.instance.get(key);\n }\n\n async has(key: string) : Promise<boolean> {\n return this.instance.has(key);\n }\n\n async set(key: string, value: VALUE, options: CacheSetOptions): Promise<void> {\n this.instance.set(key, value, {\n ttl: options.ttl,\n });\n }\n\n async drop(key: string): Promise<void> {\n this.instance.delete(key);\n }\n\n async dropMany(keys: string[]) : Promise<void> {\n for (let i = 0; i < keys.length; i++) {\n this.instance.delete(keys[i]);\n }\n }\n\n async clear(options: CacheClearOptions = {}) : Promise<void> {\n if (options.prefix) {\n const keys = this.instance.keys();\n let iterator = keys.next();\n while (!iterator.done) {\n if (iterator.value.startsWith(options.prefix)) {\n this.instance.delete(iterator.value);\n }\n\n iterator = keys.next();\n }\n\n return;\n }\n\n this.instance.clear();\n }\n}\n","/*\n * Copyright (c) 2024-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport { JsonAdapter } from 'redis-extension';\nimport { useRedisClient } from '../../redis';\nimport type { CacheClearOptions, CacheSetOptions } from '../types';\nimport type { CacheAdapter } from './types';\n\nexport class RedisCacheAdapter implements CacheAdapter {\n protected client : Client;\n\n protected instance : JsonAdapter;\n\n constructor() {\n this.client = useRedisClient();\n this.instance = new JsonAdapter(this.client);\n }\n\n async get(key: string): Promise<any> {\n return this.instance.get(key);\n }\n\n async has(key: string) : Promise<boolean> {\n const exists = await this.client.exists(key);\n\n return !!exists;\n }\n\n async set(key: string, value: any, options: CacheSetOptions): Promise<void> {\n await this.instance.set(key, value, {\n milliseconds: options.ttl,\n });\n }\n\n async drop(key: string): Promise<void> {\n await this.instance.drop(key);\n }\n\n async dropMany(keys: string[]) : Promise<void> {\n const pipeline = this.client.pipeline();\n\n for (let i = 0; i < keys.length; i++) {\n pipeline.del(keys[i]);\n }\n\n await pipeline.exec();\n }\n\n async clear(options: CacheClearOptions = {}) : Promise<void> {\n if (options.prefix) {\n const pipeline = this.client.pipeline();\n\n const keys = await this.client.keys(`${options.prefix}*`);\n for (let i = 0; i < keys.length; i++) {\n pipeline.del(keys[i]);\n }\n\n await pipeline.exec();\n\n return;\n }\n await this.client.flushdb();\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { isRedisClientUsable } from '../../redis';\nimport { MemoryCacheAdapter } from './memory';\nimport { RedisCacheAdapter } from './redis';\n\nexport function createCacheAdapter() {\n if (isRedisClientUsable()) {\n return new RedisCacheAdapter();\n }\n\n return new MemoryCacheAdapter();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { buildRedisKeyPath } from '../redis';\nimport type { CacheKeyBuildOptions } from './types';\n\nexport function buildCacheKey(options: CacheKeyBuildOptions) {\n return buildRedisKeyPath(options);\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { CacheAdapter } from './adapters';\nimport type { CacheClearOptions, CacheSetOptions } from './types';\n\nexport class Cache {\n protected adapter : CacheAdapter;\n\n constructor(adapter: CacheAdapter) {\n this.adapter = adapter;\n }\n\n async set(key: string, value: any, options: CacheSetOptions = {}) : Promise<void> {\n await this.adapter.set(key, value, options);\n }\n\n async get(key: string) : Promise<any | undefined> {\n return this.adapter.get(key);\n }\n\n async has(key: string) : Promise<boolean> {\n return this.adapter.has(key);\n }\n\n async drop(key: string) : Promise<void> {\n return this.adapter.drop(key);\n }\n\n async dropMany(keys: string[]) : Promise<void> {\n return this.adapter.dropMany(keys);\n }\n\n async clear(options: CacheClearOptions = {}) : Promise<void> {\n return this.adapter.clear(options);\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { singa } from 'singa';\nimport { isRedisClientUsable } from '../redis';\nimport type { CacheAdapter } from './adapters';\nimport { MemoryCacheAdapter, RedisCacheAdapter } from './adapters';\nimport { Cache } from './module';\n\nconst instance = singa<Cache>({\n name: 'cache',\n factory: () => {\n let adapter : CacheAdapter;\n if (isRedisClientUsable()) {\n adapter = new RedisCacheAdapter();\n } else {\n adapter = new MemoryCacheAdapter();\n }\n\n return new Cache(adapter);\n },\n});\n\nexport function useCache() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { read } from 'envix';\nimport path from 'node:path';\nimport { EnvironmentName } from 'typeorm-extension';\nimport type { Logger } from 'winston';\nimport { createLogger as create, format, transports } from 'winston';\nimport type { LoggerCreateContext, LoggerTransports } from './types';\n\nexport function createLogger(ctx: LoggerCreateContext = {}) : Logger {\n const { directory, options = {} } = ctx;\n\n let loggerTransports : LoggerTransports;\n if (read('env') === EnvironmentName.PRODUCTION) {\n loggerTransports = [\n new transports.Console({\n level: 'info',\n }),\n new transports.File({\n filename: path.join(directory || process.cwd(), 'access.log'),\n level: 'http',\n maxsize: 10 * 1024 * 1024, // 10MB\n maxFiles: 5,\n }),\n new transports.File({\n filename: path.join(directory || process.cwd(), 'error.log'),\n level: 'warn',\n maxsize: 10 * 1024 * 1024, // 10MB\n maxFiles: 5,\n }),\n ];\n } else {\n loggerTransports = [\n new transports.Console({\n level: 'debug',\n }),\n ];\n }\n\n return create({\n format: format.combine(\n format.errors({ stack: true }),\n format.timestamp(),\n format.colorize(),\n format.simple(),\n ),\n level: 'debug',\n transports: loggerTransports,\n // todo: deeply merge options\n ...(options || {}),\n });\n}\n","/*\n * Copyright (c) 2023.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { type Factory, singa } from 'singa';\nimport type { Logger } from 'winston';\n\nconst instance = singa<Logger>({\n name: 'logger',\n});\n\nexport function setLoggerFactory(factory: Factory<Logger>) {\n instance.setFactory(factory);\n}\n\nexport function isLoggerUsable() {\n return instance.has() || instance.hasFactory();\n}\n\nexport function setLogger(input: Logger) {\n instance.set(input);\n}\n\nexport function useLogger() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { DomainEventRecord } from '@privateaim/kit';\nimport { buildDomainEventFullName } from '@privateaim/kit';\nimport { isLoggerUsable, useLogger } from '../logger';\nimport type { DomainEventPublishContext, IDomainEventPublisher } from './type';\n\nexport class DomainEventPublisher implements IDomainEventPublisher {\n protected publishers : Set<IDomainEventPublisher>;\n\n constructor() {\n this.publishers = new Set<IDomainEventPublisher>();\n }\n\n addPublisher(publisher: IDomainEventPublisher) {\n this.publishers.add(publisher);\n }\n\n async safePublish<T extends DomainEventRecord>(\n ctx: DomainEventPublishContext<T>,\n ) : Promise<void> {\n try {\n await this.publish(ctx);\n } catch (e) {\n if (isLoggerUsable()) {\n useLogger().error(`Publishing event ${buildDomainEventFullName(ctx.data.type, ctx.data.event)} failed`);\n useLogger().error(e);\n }\n }\n }\n\n async publish<T extends DomainEventRecord>(\n ctx: DomainEventPublishContext<T>,\n ) : Promise<void> {\n if (isLoggerUsable()) {\n useLogger().info(`Publishing event ${buildDomainEventFullName(ctx.data.type, ctx.data.event)}`);\n }\n\n const publishers = this.publishers.values();\n while (true) {\n const it = publishers.next();\n if (it.done) {\n return;\n }\n\n await it.value.publish(ctx);\n }\n }\n}\n","/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { isObject } from '@privateaim/kit';\nimport type { DomainEventChannelName } from './type';\n\nexport function transformEventData<T>(input: T) : T {\n if (isObject(input)) {\n const keys = Object.keys(input);\n for (let i = 0; i < keys.length; i++) {\n const value = input[keys[i]];\n if (value instanceof Date) {\n input[keys[i]] = value.toISOString();\n }\n }\n }\n\n return input;\n}\n\nexport function buildEventChannelName(\n input: DomainEventChannelName,\n id?: string | number,\n) : string {\n if (typeof input === 'string') {\n return input;\n }\n\n return input(id);\n}\n","/*\n * Copyright (c) 2023-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport type { Client } from 'redis-extension';\nimport type { DomainEventPublishContext, IDomainEventPublisher } from '../type';\nimport { buildEventChannelName, transformEventData } from '../utils';\n\nexport class DomainEventRedisPublisher implements IDomainEventPublisher {\n protected driver : Client;\n\n constructor(client: Client) {\n this.driver = client;\n }\n\n async publish(ctx: DomainEventPublishContext) : Promise<void> {\n const data = JSON.stringify(transformEventData(ctx.data));\n\n const pipeline = this.driver.pipeline();\n for (let i = 0; i < ctx.destinations.length; i++) {\n const keyPrefix = (ctx.destinations[i].namespace ? `${ctx.destinations[i].namespace}:` : '');\n\n let key = keyPrefix + buildEventChannelName(ctx.destinations[i].channel);\n pipeline.publish(key, data);\n\n if (typeof ctx.destinations[i].channel === 'function') {\n key = keyPrefix + buildEventChannelName(ctx.destinations[i].channel, ctx.data.data.id);\n pipeline.publish(key, data);\n }\n }\n\n await pipeline.exec();\n }\n}\n","/*\n * Copyright (c) 2022-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { buildDomainEventFullName } from '@privateaim/kit';\nimport { Emitter } from '@socket.io/redis-emitter';\nimport type { Client } from 'redis-extension';\nimport type { DomainEventPublishContext, IDomainEventPublisher } from '../type';\nimport { buildEventChannelName, transformEventData } from '../utils';\n\nexport class DomainEventSocketPublisher implements IDomainEventPublisher {\n protected client : Client;\n\n constructor(client: Client) {\n this.client = client;\n }\n\n async publish(ctx: DomainEventPublishContext) : Promise<void> {\n ctx.data = transformEventData(ctx.data);\n\n for (let i = 0; i < ctx.destinations.length; i++) {\n let namespace : string;\n if (ctx.destinations[i].namespace) {\n namespace = ctx.destinations[i].namespace;\n } else {\n namespace = '/';\n }\n\n const emitter = new Emitter(this.client, {}, namespace);\n\n const fullEventName = buildDomainEventFullName(ctx.data.type, ctx.data.event);\n\n const rooms : string[] = [\n buildEventChannelName(ctx.destinations[i].channel),\n ];\n\n if (typeof ctx.destinations[i].channel === 'function') {\n rooms.push(buildEventChannelName(ctx.destinations[i].channel, ctx.data.data.id));\n }\n\n for (let j = 0; j < rooms.length; j++) {\n emitter\n .in(rooms[j])\n .emit(fullEventName, {\n ...ctx.data,\n meta: {\n namespace,\n roomName: rooms[j],\n },\n });\n }\n }\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { singa } from 'singa';\nimport { isRedisClientUsable, useRedisClient } from '../redis';\nimport { DomainEventPublisher } from './module';\nimport { DomainEventRedisPublisher } from './redis';\nimport { DomainEventSocketPublisher } from './socket';\n\nconst instance = singa<DomainEventPublisher>({\n name: 'domainEventPublisher',\n factory: () => {\n const publisher = new DomainEventPublisher();\n\n if (isRedisClientUsable()) {\n const client = useRedisClient();\n\n publisher.addPublisher(new DomainEventRedisPublisher(client));\n publisher.addPublisher(new DomainEventSocketPublisher(client));\n }\n\n return publisher;\n },\n});\n\nexport function useDomainEventPublisher() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { ExchangeType } from 'amqp-extension';\nimport type { Client } from 'amqp-extension';\nimport { isLoggerUsable, useLogger } from '../../services';\nimport { QueueRouterRoutingType } from './constants';\nimport { isQueueRouterPayload } from './helpers';\nimport type {\n QueueRouterHandler,\n QueueRouterHandlers,\n QueueRouterPayload, QueueRouterRouting,\n} from './types';\n\nexport class QueueRouter {\n protected driver : Client;\n\n //----------------------------------------------------------------\n\n constructor(driver: Client) {\n this.driver = driver;\n }\n\n //----------------------------------------------------------------\n\n publish(message: QueueRouterPayload) : Promise<boolean> {\n let exchange : Client;\n if (message.metadata.routing.type === 'work') {\n exchange = this.driver.of({\n type: ExchangeType.DIRECT,\n name: message.metadata.routing.namespace || '',\n });\n } else {\n exchange = this.driver.of({\n type: ExchangeType.TOPIC,\n name: message.metadata.routing.namespace || 'FLAME',\n });\n }\n\n if (isLoggerUsable()) {\n useLogger()\n .debug(`Publishing queue message ${message.type} in ${message.metadata.routing.key}`);\n }\n\n return exchange.publish(message.metadata.routing.key, message, {\n type: message.type,\n messageId: message.id,\n persistent: message.metadata.persistent ??\n message.metadata.routing.type === QueueRouterRoutingType.WORK,\n });\n }\n\n consume(routing: QueueRouterRouting, handlers: QueueRouterHandlers) : Promise<void> {\n let exchange : Client;\n if (routing.type === 'work') {\n exchange = this.driver.of({\n type: ExchangeType.DIRECT,\n name: routing.namespace || '',\n });\n } else {\n exchange = this.driver.of({\n type: ExchangeType.TOPIC,\n name: routing.namespace || 'FLAME',\n });\n }\n\n return exchange.consume(routing.key, {\n prefetchCount: routing.type === QueueRouterRoutingType.WORK ? 1 : undefined,\n // noAck: routing.type !== QueueRouterRoutingType.WORK,\n requeueOnFailure: routing.type === QueueRouterRoutingType.WORK,\n }, {\n $any: async (input) => {\n const payload = JSON.parse(input.content.toString('utf-8'));\n if (!isQueueRouterPayload(payload)) {\n return;\n }\n\n if (input.fields.redelivered) {\n if (isLoggerUsable()) {\n useLogger()\n .debug(`Queue message ${input.properties.type} in ${routing.key} is not processed again.`);\n }\n\n return;\n }\n\n if (isLoggerUsable()) {\n useLogger()\n .debug(`Consuming queue message ${input.properties.type} in ${routing.key}`);\n }\n\n let handler : QueueRouterHandler | undefined;\n\n if (\n typeof input.properties.type === 'string' &&\n handlers[input.properties.type]\n ) {\n handler = handlers[input.properties.type];\n } else {\n handler = handlers.$any;\n }\n\n if (typeof handler !== 'function') {\n if (isLoggerUsable()) {\n useLogger()\n .debug(`No queue handler to consume message ${input.properties.type} in ${routing.key}`);\n }\n\n return;\n }\n\n await handler(payload);\n },\n });\n }\n}\n","/*\n * Copyright (c) 2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nimport { singa } from 'singa';\nimport { isAmqpClientUsable, useAmqpClient } from '../../services';\nimport { QueueRouter } from './module';\n\nconst instance = singa<QueueRouter>({\n name: 'queueRouter',\n factory: () => {\n const amqp = useAmqpClient();\n\n return new QueueRouter(amqp);\n },\n});\n\nexport function isQueueRouterUsable() {\n return instance.has() || isAmqpClientUsable();\n}\n\nexport function useQueueRouter() {\n return instance.use();\n}\n","/*\n * Copyright (c) 2022-2024.\n * Author Peter Placzek (tada5hi)\n * For the full copyright and license information,\n * view the LICENSE file that was distributed with this source code.\n */\n\nexport function hasOwnProperty<X extends Record<string, any>, Y extends PropertyKey>(\n obj: X,\n prop: Y,\n): obj is X & Record<Y, unknown> {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n"],"names":["_define_property","ComponentError","Error","constructor","input","message","cause","code","isComponentError","isObject","isQueuePayload","hasOwnProperty","data","metadata","QueueRouterRoutingType","buildQueueRouterPublishPayload","id","createNanoID","type","timestamp","Date","now","isQueueRouterPayload","instance","singa","name","setAmqpClientFactory","factory","setFactory","isAmqpClientUsable","has","hasFactory","useAmqpClient","use","setVaultFactory","isVaultClientUsable","useVaultClient","guessAuthupTokenCreatorOptions","options","vault","password","setClientAuthenticationHookFactory","isClientAuthenticationHookUsable","useClientAuthenticationHook","AuthupClient","Client","ClientAuthenticationHook","baseURL","tokenCreator","hook","attach","useAuthupClient","isAuthupClientUsable","setAuthupClientFactory","setRedisFactory","isRedisClientUsable","setRedisClient","set","useRedisClient","duplicate","useRedisPublishClient","useRedisSubscribeClient","MemoryCacheAdapter","get","key","value","ttl","drop","delete","dropMany","keys","i","length","clear","prefix","iterator","next","done","startsWith","TTLCache","checkAgeOnGet","Infinity","RedisCacheAdapter","exists","client","milliseconds","pipeline","del","exec","flushdb","JsonAdapter","createCacheAdapter","buildCacheKey","buildRedisKeyPath","Cache","adapter","useCache","createLogger","ctx","directory","loggerTransports","read","EnvironmentName","PRODUCTION","transports","Console","level","File","filename","path","join","process","cwd","maxsize","maxFiles","create","format","combine","errors","stack","colorize","simple","setLoggerFactory","isLoggerUsable","setLogger","useLogger","DomainEventPublisher","addPublisher","publisher","publishers","add","safePublish","publish","e","error","buildDomainEventFullName","event","info","values","it","Set","transformEventData","Object","toISOString","buildEventChannelName","DomainEventRedisPublisher","JSON","stringify","driver","destinations","keyPrefix","namespace","channel","DomainEventSocketPublisher","emitter","Emitter","fullEventName","rooms","push","j","in","emit","meta","roomName","useDomainEventPublisher","QueueRouter","exchange","routing","of","ExchangeType","DIRECT","TOPIC","debug","messageId","persistent","WORK","consume","handlers","prefetchCount","undefined","requeueOnFailure","$any","payload","parse","content","toString","fields","redelivered","properties","handler","amqp","isQueueRouterUsable","useQueueRouter","obj","prop","prototype","call"],"mappings":"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"}
@@ -4,6 +4,7 @@ export declare class DomainEventPublisher implements IDomainEventPublisher {
4
4
  protected publishers: Set<IDomainEventPublisher>;
5
5
  constructor();
6
6
  addPublisher(publisher: IDomainEventPublisher): void;
7
+ safePublish<T extends DomainEventRecord>(ctx: DomainEventPublishContext<T>): Promise<void>;
7
8
  publish<T extends DomainEventRecord>(ctx: DomainEventPublishContext<T>): Promise<void>;
8
9
  }
9
10
  //# sourceMappingURL=module.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"module.d.ts","sourceRoot":"","sources":["../../../src/services/domain-event/module.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAEzD,OAAO,KAAK,EAAE,yBAAyB,EAAE,qBAAqB,EAAE,MAAM,QAAQ,CAAC;AAE/E,qBAAa,oBAAqB,YAAW,qBAAqB;IAC9D,SAAS,CAAC,UAAU,EAAG,GAAG,CAAC,qBAAqB,CAAC,CAAC;;IAMlD,YAAY,CAAC,SAAS,EAAE,qBAAqB;IAIvC,OAAO,CAAC,CAAC,SAAS,iBAAiB,EACrC,GAAG,EAAE,yBAAyB,CAAC,CAAC,CAAC,GACjC,OAAO,CAAC,IAAI,CAAC;CAepB"}
1
+ {"version":3,"file":"module.d.ts","sourceRoot":"","sources":["../../../src/services/domain-event/module.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAGzD,OAAO,KAAK,EAAE,yBAAyB,EAAE,qBAAqB,EAAE,MAAM,QAAQ,CAAC;AAE/E,qBAAa,oBAAqB,YAAW,qBAAqB;IAC9D,SAAS,CAAC,UAAU,EAAG,GAAG,CAAC,qBAAqB,CAAC,CAAC;;IAMlD,YAAY,CAAC,SAAS,EAAE,qBAAqB;IAIvC,WAAW,CAAC,CAAC,SAAS,iBAAiB,EACzC,GAAG,EAAE,yBAAyB,CAAC,CAAC,CAAC,GACjC,OAAO,CAAC,IAAI,CAAC;IAWX,OAAO,CAAC,CAAC,SAAS,iBAAiB,EACrC,GAAG,EAAE,yBAAyB,CAAC,CAAC,CAAC,GACjC,OAAO,CAAC,IAAI,CAAC;CAepB"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@privateaim/server-kit",
3
- "version": "0.8.9",
3
+ "version": "0.8.11",
4
4
  "exports": {
5
5
  "./package.json": "./package.json",
6
6
  ".": {
@@ -29,7 +29,7 @@
29
29
  "dependencies": {
30
30
  "@ebec/http": "^2.3.0",
31
31
  "@isaacs/ttlcache": "^1.4.1",
32
- "@privateaim/kit": "^0.8.9",
32
+ "@privateaim/kit": "^0.8.11",
33
33
  "@socket.io/redis-emitter": "^5.1.0",
34
34
  "envix": "^1.5.0",
35
35
  "hapic": "^2.5.2",
@@ -6,6 +6,7 @@
6
6
  */
7
7
 
8
8
  import type { DomainEventRecord } from '@privateaim/kit';
9
+ import { buildDomainEventFullName } from '@privateaim/kit';
9
10
  import { isLoggerUsable, useLogger } from '../logger';
10
11
  import type { DomainEventPublishContext, IDomainEventPublisher } from './type';
11
12
 
@@ -20,11 +21,24 @@ export class DomainEventPublisher implements IDomainEventPublisher {
20
21
  this.publishers.add(publisher);
21
22
  }
22
23
 
24
+ async safePublish<T extends DomainEventRecord>(
25
+ ctx: DomainEventPublishContext<T>,
26
+ ) : Promise<void> {
27
+ try {
28
+ await this.publish(ctx);
29
+ } catch (e) {
30
+ if (isLoggerUsable()) {
31
+ useLogger().error(`Publishing event ${buildDomainEventFullName(ctx.data.type, ctx.data.event)} failed`);
32
+ useLogger().error(e);
33
+ }
34
+ }
35
+ }
36
+
23
37
  async publish<T extends DomainEventRecord>(
24
38
  ctx: DomainEventPublishContext<T>,
25
39
  ) : Promise<void> {
26
40
  if (isLoggerUsable()) {
27
- useLogger().info(`Publishing event ${ctx.data.event} for ${ctx.data.type}`);
41
+ useLogger().info(`Publishing event ${buildDomainEventFullName(ctx.data.type, ctx.data.event)}`);
28
42
  }
29
43
 
30
44
  const publishers = this.publishers.values();