@authup/server-kit 1.0.0-beta.4 → 1.0.0-beta.41
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/LICENSE +1 -1
- package/README.md +1 -1
- package/dist/crypto/hash/hash.d.ts +1 -1
- package/dist/crypto/hash/hash.d.ts.map +1 -1
- package/dist/crypto/index.d.ts +1 -1
- package/dist/crypto/index.d.ts.map +1 -1
- package/dist/crypto/json-web-token/extract.d.ts +16 -0
- package/dist/crypto/json-web-token/extract.d.ts.map +1 -0
- package/dist/crypto/json-web-token/index.d.ts +1 -1
- package/dist/crypto/json-web-token/index.d.ts.map +1 -1
- package/dist/crypto/json-web-token/sign/index.d.ts +3 -0
- package/dist/crypto/json-web-token/sign/index.d.ts.map +1 -0
- package/dist/crypto/json-web-token/sign/module.d.ts +4 -0
- package/dist/crypto/json-web-token/sign/module.d.ts.map +1 -0
- package/dist/crypto/json-web-token/sign/types.d.ts +28 -0
- package/dist/crypto/json-web-token/sign/types.d.ts.map +1 -0
- package/dist/crypto/json-web-token/type.d.ts +4 -33
- package/dist/crypto/json-web-token/type.d.ts.map +1 -1
- package/dist/crypto/json-web-token/utils.d.ts +5 -2
- package/dist/crypto/json-web-token/utils.d.ts.map +1 -1
- package/dist/crypto/json-web-token/verify/index.d.ts +3 -0
- package/dist/crypto/json-web-token/verify/index.d.ts.map +1 -0
- package/dist/crypto/json-web-token/verify/module.d.ts +12 -0
- package/dist/crypto/json-web-token/verify/module.d.ts.map +1 -0
- package/dist/crypto/json-web-token/verify/types.d.ts +25 -0
- package/dist/crypto/json-web-token/verify/types.d.ts.map +1 -0
- package/dist/crypto/key/asymmetric/check.d.ts +3 -0
- package/dist/crypto/key/asymmetric/check.d.ts.map +1 -0
- package/dist/crypto/key/asymmetric/constants.d.ts +8 -0
- package/dist/crypto/key/asymmetric/constants.d.ts.map +1 -0
- package/dist/crypto/key/asymmetric/create.d.ts +3 -0
- package/dist/crypto/key/asymmetric/create.d.ts.map +1 -0
- package/dist/crypto/key/asymmetric/helpers/index.d.ts +2 -0
- package/dist/crypto/key/asymmetric/helpers/index.d.ts.map +1 -0
- package/dist/crypto/key/asymmetric/helpers/wrap.d.ts +5 -0
- package/dist/crypto/key/asymmetric/helpers/wrap.d.ts.map +1 -0
- package/dist/crypto/key/asymmetric/index.d.ts +9 -0
- package/dist/crypto/key/asymmetric/index.d.ts.map +1 -0
- package/dist/crypto/key/asymmetric/key-usages.d.ts +5 -0
- package/dist/crypto/key/asymmetric/key-usages.d.ts.map +1 -0
- package/dist/crypto/key/asymmetric/module.d.ts +20 -0
- package/dist/crypto/key/asymmetric/module.d.ts.map +1 -0
- package/dist/crypto/key/asymmetric/normalize.d.ts +4 -0
- package/dist/crypto/key/asymmetric/normalize.d.ts.map +1 -0
- package/dist/crypto/key/asymmetric/types.d.ts +35 -0
- package/dist/crypto/key/asymmetric/types.d.ts.map +1 -0
- package/dist/crypto/key/base.d.ts +9 -0
- package/dist/crypto/key/base.d.ts.map +1 -0
- package/dist/crypto/key/index.d.ts +4 -0
- package/dist/crypto/key/index.d.ts.map +1 -0
- package/dist/crypto/key/symmetric/check.d.ts +3 -0
- package/dist/crypto/key/symmetric/check.d.ts.map +1 -0
- package/dist/crypto/key/symmetric/constants.d.ts +7 -0
- package/dist/crypto/key/symmetric/constants.d.ts.map +1 -0
- package/dist/crypto/key/symmetric/create.d.ts +3 -0
- package/dist/crypto/key/symmetric/create.d.ts.map +1 -0
- package/dist/crypto/key/symmetric/index.d.ts +7 -0
- package/dist/crypto/key/symmetric/index.d.ts.map +1 -0
- package/dist/crypto/key/symmetric/key-usages.d.ts +2 -0
- package/dist/crypto/key/symmetric/key-usages.d.ts.map +1 -0
- package/dist/crypto/key/symmetric/module.d.ts +13 -0
- package/dist/crypto/key/symmetric/module.d.ts.map +1 -0
- package/dist/crypto/key/symmetric/normalize.d.ts +4 -0
- package/dist/crypto/key/symmetric/normalize.d.ts.map +1 -0
- package/dist/crypto/key/symmetric/types.d.ts +32 -0
- package/dist/crypto/key/symmetric/types.d.ts.map +1 -0
- package/dist/domain-event/index.d.ts +1 -1
- package/dist/domain-event/index.d.ts.map +1 -1
- package/dist/domain-event/module.d.ts +9 -0
- package/dist/domain-event/module.d.ts.map +1 -0
- package/dist/domain-event/redis/index.d.ts +1 -1
- package/dist/domain-event/redis/index.d.ts.map +1 -1
- package/dist/domain-event/redis/module.d.ts +9 -0
- package/dist/domain-event/redis/module.d.ts.map +1 -0
- package/dist/domain-event/socket/index.d.ts +1 -2
- package/dist/domain-event/socket/index.d.ts.map +1 -1
- package/dist/domain-event/socket/module.d.ts +9 -0
- package/dist/domain-event/socket/module.d.ts.map +1 -0
- package/dist/domain-event/type.d.ts +8 -0
- package/dist/domain-event/type.d.ts.map +1 -1
- package/dist/domain-event/utils.d.ts +2 -1
- package/dist/domain-event/utils.d.ts.map +1 -1
- package/dist/index.d.mts +379 -0
- package/dist/index.d.mts.map +1 -0
- package/dist/index.d.ts +1 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.mjs +704 -579
- package/dist/index.mjs.map +1 -1
- package/dist/services/cache/adapters/index.d.ts +3 -0
- package/dist/services/cache/adapters/index.d.ts.map +1 -0
- package/dist/services/cache/adapters/memory.d.ts +15 -0
- package/dist/services/cache/adapters/memory.d.ts.map +1 -0
- package/dist/services/cache/adapters/redis.d.ts +17 -0
- package/dist/services/cache/adapters/redis.d.ts.map +1 -0
- package/dist/services/cache/helper.d.ts +3 -0
- package/dist/services/cache/helper.d.ts.map +1 -0
- package/dist/services/cache/index.d.ts +4 -0
- package/dist/services/cache/index.d.ts.map +1 -0
- package/dist/services/cache/types.d.ts +25 -0
- package/dist/services/cache/types.d.ts.map +1 -0
- package/dist/services/index.d.ts +5 -0
- package/dist/services/index.d.ts.map +1 -0
- package/dist/services/logger/index.d.ts +4 -0
- package/dist/services/logger/index.d.ts.map +1 -0
- package/dist/services/logger/module.d.ts +4 -0
- package/dist/services/logger/module.d.ts.map +1 -0
- package/dist/services/logger/singleton.d.ts +7 -0
- package/dist/services/logger/singleton.d.ts.map +1 -0
- package/dist/services/logger/types.d.ts +7 -0
- package/dist/services/logger/types.d.ts.map +1 -0
- package/dist/services/redis/check.d.ts +3 -0
- package/dist/services/redis/check.d.ts.map +1 -0
- package/dist/services/redis/factory.d.ts +4 -0
- package/dist/services/redis/factory.d.ts.map +1 -0
- package/dist/services/redis/index.d.ts +4 -0
- package/dist/services/redis/index.d.ts.map +1 -0
- package/dist/services/redis/module.d.ts +5 -0
- package/dist/services/redis/module.d.ts.map +1 -0
- package/dist/services/vault/index.d.ts +3 -0
- package/dist/services/vault/index.d.ts.map +1 -0
- package/dist/services/vault/module.d.ts +3 -0
- package/dist/services/vault/module.d.ts.map +1 -0
- package/dist/services/vault/singleton.d.ts +6 -0
- package/dist/services/vault/singleton.d.ts.map +1 -0
- package/package.json +45 -34
- package/dist/crypto/json-web-token/decode.d.ts +0 -15
- package/dist/crypto/json-web-token/decode.d.ts.map +0 -1
- package/dist/crypto/json-web-token/sign.d.ts +0 -4
- package/dist/crypto/json-web-token/sign.d.ts.map +0 -1
- package/dist/crypto/json-web-token/verify.d.ts +0 -15
- package/dist/crypto/json-web-token/verify.d.ts.map +0 -1
- package/dist/crypto/key-pair/constants.d.ts +0 -5
- package/dist/crypto/key-pair/constants.d.ts.map +0 -1
- package/dist/crypto/key-pair/create.d.ts +0 -3
- package/dist/crypto/key-pair/create.d.ts.map +0 -1
- package/dist/crypto/key-pair/delete.d.ts +0 -3
- package/dist/crypto/key-pair/delete.d.ts.map +0 -1
- package/dist/crypto/key-pair/index.d.ts +0 -9
- package/dist/crypto/key-pair/index.d.ts.map +0 -1
- package/dist/crypto/key-pair/load.d.ts +0 -3
- package/dist/crypto/key-pair/load.d.ts.map +0 -1
- package/dist/crypto/key-pair/module.d.ts +0 -3
- package/dist/crypto/key-pair/module.d.ts.map +0 -1
- package/dist/crypto/key-pair/save.d.ts +0 -3
- package/dist/crypto/key-pair/save.d.ts.map +0 -1
- package/dist/crypto/key-pair/type.d.ts +0 -65
- package/dist/crypto/key-pair/type.d.ts.map +0 -1
- package/dist/crypto/key-pair/utils/check.d.ts +0 -4
- package/dist/crypto/key-pair/utils/check.d.ts.map +0 -1
- package/dist/crypto/key-pair/utils/file-name.d.ts +0 -4
- package/dist/crypto/key-pair/utils/file-name.d.ts.map +0 -1
- package/dist/crypto/key-pair/utils/index.d.ts +0 -5
- package/dist/crypto/key-pair/utils/index.d.ts.map +0 -1
- package/dist/crypto/key-pair/utils/options.d.ts +0 -3
- package/dist/crypto/key-pair/utils/options.d.ts.map +0 -1
- package/dist/crypto/key-pair/utils/private-key.d.ts +0 -4
- package/dist/crypto/key-pair/utils/private-key.d.ts.map +0 -1
- package/dist/domain-event/publish.d.ts +0 -4
- package/dist/domain-event/publish.d.ts.map +0 -1
- package/dist/domain-event/redis/publish.d.ts +0 -4
- package/dist/domain-event/redis/publish.d.ts.map +0 -1
- package/dist/domain-event/socket/publish.d.ts +0 -4
- package/dist/domain-event/socket/publish.d.ts.map +0 -1
- package/dist/domain-event/socket/singleton.d.ts +0 -4
- package/dist/domain-event/socket/singleton.d.ts.map +0 -1
- package/dist/domain-event/socket/type.d.ts +0 -5
- package/dist/domain-event/socket/type.d.ts.map +0 -1
- package/dist/index.cjs +0 -642
- package/dist/index.cjs.map +0 -1
- package/dist/logger/index.d.ts +0 -4
- package/dist/logger/index.d.ts.map +0 -1
- package/dist/logger/module.d.ts +0 -4
- package/dist/logger/module.d.ts.map +0 -1
- package/dist/logger/presets/index.d.ts +0 -2
- package/dist/logger/presets/index.d.ts.map +0 -1
- package/dist/logger/presets/void.d.ts +0 -16
- package/dist/logger/presets/void.d.ts.map +0 -1
- package/dist/logger/type.d.ts +0 -14
- package/dist/logger/type.d.ts.map +0 -1
- package/dist/smtp/config/index.d.ts +0 -2
- package/dist/smtp/config/index.d.ts.map +0 -1
- package/dist/smtp/config/singleton.d.ts +0 -5
- package/dist/smtp/config/singleton.d.ts.map +0 -1
- package/dist/smtp/index.d.ts +0 -5
- package/dist/smtp/index.d.ts.map +0 -1
- package/dist/smtp/module.d.ts +0 -4
- package/dist/smtp/module.d.ts.map +0 -1
- package/dist/smtp/singleton.d.ts +0 -3
- package/dist/smtp/singleton.d.ts.map +0 -1
- package/dist/smtp/type.d.ts +0 -14
- package/dist/smtp/type.d.ts.map +0 -1
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../src/crypto/hash/compare.ts","../src/crypto/hash/hash.ts","../src/crypto/key-pair/constants.ts","../src/crypto/key-pair/utils/check.ts","../src/crypto/key-pair/utils/options.ts","../src/crypto/key-pair/utils/file-name.ts","../src/crypto/key-pair/utils/private-key.ts","../src/crypto/key-pair/save.ts","../src/crypto/key-pair/create.ts","../src/crypto/key-pair/delete.ts","../src/crypto/key-pair/load.ts","../src/crypto/key-pair/module.ts","../src/crypto/json-web-token/utils.ts","../src/crypto/json-web-token/decode.ts","../src/crypto/json-web-token/sign.ts","../src/crypto/json-web-token/verify.ts","../src/domain-event/utils.ts","../src/domain-event/redis/publish.ts","../src/domain-event/socket/singleton.ts","../src/domain-event/socket/publish.ts","../src/domain-event/publish.ts","../src/logger/presets/void.ts","../src/logger/module.ts","../src/smtp/config/singleton.ts","../src/smtp/module.ts","../src/smtp/singleton.ts","../src/utils/has-property.ts"],"sourcesContent":["/*\n * Copyright (c) 2022.\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 { compare as compareMethod } from 'bcrypt';\n\nexport async function compare(value: string, hashedValue: string) : Promise<boolean> {\n return compareMethod(value, hashedValue);\n}\n","/*\n * Copyright (c) 2022.\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 { hash as hashMethod } from 'bcrypt';\n\nexport async function hash(str: string, saltOrRounds: number | string = 10) : Promise<string> {\n return hashMethod(str, saltOrRounds);\n}\n","/*\n * Copyright (c) 2022.\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 KeyPairKind {\n PRIVATE = 'private',\n PUBLIC = 'public',\n}\n","/*\n * Copyright (c) 2022.\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 '@authup/core';\nimport type { KeyPair } from '../type';\n\nexport function isKeyPair(data: unknown) : data is KeyPair {\n return isObject(data) &&\n typeof (data as KeyPair).privateKey !== 'undefined' &&\n typeof (data as KeyPair).publicKey !== 'undefined';\n}\n\nexport function isKeyPairWithPublicKey(data: unknown) : data is Omit<KeyPair, 'privateKey'> {\n return isObject(data) &&\n typeof (data as KeyPair).publicKey !== 'undefined';\n}\n","/*\n * Copyright (c) 2022.\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 path from 'node:path';\nimport type { KeyPairOptions } from '../type';\n\nexport function extendKeyPairOptions(\n options?: Partial<KeyPairOptions>,\n) : KeyPairOptions {\n options = options ?? {};\n\n options.directory = options.directory || process.cwd();\n options.directory = path.isAbsolute(options.directory) ?\n options.directory :\n path.resolve(process.cwd(), options.directory);\n\n options.type ??= 'rsa';\n\n if (\n options.type === 'rsa' ||\n options.type === 'rsa-pss' ||\n options.type === 'dsa'\n ) {\n options.modulusLength = 2048;\n }\n\n if (!options.privateKeyEncoding) {\n options.privateKeyEncoding = {\n type: 'pkcs8',\n format: 'pem',\n };\n }\n\n if (!options.publicKeyEncoding) {\n options.publicKeyEncoding = {\n type: 'spki',\n format: 'pem',\n };\n }\n\n if (\n options.privateKeyEncoding.passphrase &&\n !options.privateKeyEncoding.cipher\n ) {\n options.privateKeyEncoding.cipher = 'aes-256-cbc';\n }\n\n return options as KeyPairOptions;\n}\n","/*\n * Copyright (c) 2022.\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 { KeyPairKind } from '../constants';\nimport type { KeyPairOptions } from '../type';\nimport { extendKeyPairOptions } from './options';\n\nexport function buildKeyFileName(\n type: `${KeyPairKind}`,\n context?: Partial<KeyPairOptions>,\n) {\n const options = extendKeyPairOptions(context);\n\n const parts : string[] = [];\n\n switch (type) {\n case KeyPairKind.PRIVATE: {\n if (options.privateName) {\n parts.push(options.privateName);\n } else {\n parts.push(type);\n }\n\n if (options.privateExtension) {\n if (options.privateExtension.startsWith('.')) {\n options.privateExtension = options.privateExtension.slice(1);\n }\n\n parts.push(options.privateExtension);\n } else {\n parts.push('pem');\n }\n break;\n }\n case KeyPairKind.PUBLIC: {\n if (options.publicName) {\n parts.push(options.publicName);\n } else {\n parts.push(type);\n }\n\n if (options.publicExtension) {\n if (options.publicExtension.startsWith('.')) {\n options.publicExtension = options.publicExtension.slice(1);\n }\n\n parts.push(options.publicExtension);\n } else {\n parts.push('pem');\n }\n break;\n }\n }\n\n return parts.join('.');\n}\n","/*\n * Copyright (c) 2022.\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 { createPrivateKey } from 'node:crypto';\nimport type { KeyPairOptions } from '../type';\n\nexport function decryptRSAPrivateKey(\n context: KeyPairOptions,\n key: string | Buffer,\n) : string {\n const privateKey = createPrivateKey({\n type: context.privateKeyEncoding.type,\n format: context.privateKeyEncoding.format,\n key,\n passphrase: context.privateKeyEncoding.passphrase || context.passphrase,\n });\n\n let content = privateKey.export({\n type: context.privateKeyEncoding.type,\n format: context.privateKeyEncoding.format,\n });\n\n if (typeof content !== 'string') {\n content = Buffer.from(content).toString('utf-8');\n }\n\n return content;\n}\n","/*\n * Copyright (c) 2022.\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 path from 'node:path';\nimport fs from 'node:fs';\nimport type { KeyPair, KeyPairOptions } from './type';\nimport { buildKeyFileName, extendKeyPairOptions } from './utils';\nimport { KeyPairKind } from './constants';\n\nexport async function saveKeyPair(keyPair: KeyPair, context?: KeyPairOptions) : Promise<KeyPair> {\n context = extendKeyPairOptions(context);\n\n await fs.promises.mkdir(context.directory, { recursive: true });\n\n await Promise.all(\n [\n {\n path: path.resolve(context.directory, buildKeyFileName(KeyPairKind.PRIVATE, context)),\n content: keyPair.privateKey,\n },\n {\n path: path.resolve(context.directory, buildKeyFileName(KeyPairKind.PUBLIC, context)),\n content: keyPair.publicKey,\n },\n ]\n .map((file) => fs.promises.writeFile(file.path, file.content)),\n );\n\n return keyPair;\n}\n","/*\n * Copyright (c) 2022.\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 { generateKeyPair } from 'node:crypto';\nimport type { KeyPair, KeyPairOptions } from './type';\nimport { decryptRSAPrivateKey, extendKeyPairOptions } from './utils';\nimport { saveKeyPair } from './save';\n\nexport async function createKeyPair(context?: Partial<KeyPairOptions>) : Promise<KeyPair> {\n const options = extendKeyPairOptions(context);\n\n const keyPair : KeyPair = await new Promise((resolve: (value: KeyPair) => void, reject) => {\n const callback = (err: (Error | null), publicKey: string, privateKey: string) => {\n if (err) reject(err);\n\n resolve({\n privateKey,\n publicKey,\n });\n };\n switch (options.type) {\n case 'dsa':\n generateKeyPair(\n options.type,\n options,\n callback,\n );\n break;\n case 'ec':\n generateKeyPair(\n options.type,\n options,\n callback,\n );\n break;\n case 'rsa':\n generateKeyPair(\n options.type,\n options,\n callback,\n );\n break;\n case 'rsa-pss':\n generateKeyPair(\n options.type,\n options,\n callback,\n );\n break;\n }\n });\n\n if (options.save) {\n await saveKeyPair(keyPair, options);\n }\n\n if (\n options.passphrase ||\n options.privateKeyEncoding.passphrase\n ) {\n keyPair.privateKey = decryptRSAPrivateKey(\n options,\n keyPair.privateKey,\n );\n }\n\n return keyPair;\n}\n","/*\n * Copyright (c) 2022.\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 path from 'node:path';\nimport fs from 'node:fs';\nimport type { KeyPairOptions } from './type';\nimport { buildKeyFileName, extendKeyPairOptions } from './utils';\nimport { KeyPairKind } from './constants';\n\nexport async function deleteKeyPair(context?: Partial<KeyPairOptions>) : Promise<void> {\n const options = extendKeyPairOptions(context);\n\n const privateKeyPath : string = path.resolve(options.directory, buildKeyFileName(KeyPairKind.PRIVATE, options));\n const publicKeyPath : string = path.resolve(options.directory, buildKeyFileName(KeyPairKind.PUBLIC, options));\n\n try {\n await Promise.all([privateKeyPath, publicKeyPath]\n .map((filePath) => fs.promises.stat(filePath)));\n } catch (e) {\n return;\n }\n\n await Promise.all([\n privateKeyPath,\n publicKeyPath,\n ].map((filePath) => fs.promises.rm(filePath)));\n}\n","/*\n * Copyright (c) 2022.\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 { createPublicKey } from 'node:crypto';\nimport path from 'node:path';\nimport fs from 'node:fs';\nimport type { KeyPair, KeyPairOptions } from './type';\nimport { buildKeyFileName, decryptRSAPrivateKey, extendKeyPairOptions } from './utils';\nimport { KeyPairKind } from './constants';\nimport { saveKeyPair } from './save';\n\nexport async function loadKeyPair(context?: Partial<KeyPairOptions>) : Promise<KeyPair | undefined> {\n const options = extendKeyPairOptions(context);\n\n const privateKeyPath : string = path.resolve(options.directory, buildKeyFileName(KeyPairKind.PRIVATE, options));\n\n try {\n await fs.promises.stat(privateKeyPath);\n } catch (e) {\n return undefined;\n }\n\n const privateKeyBuffer = await fs.promises.readFile(privateKeyPath);\n let privateKey = privateKeyBuffer.toString();\n if (\n options.passphrase ||\n options.privateKeyEncoding.passphrase\n ) {\n privateKey = decryptRSAPrivateKey(\n options,\n privateKey,\n );\n }\n\n const publicKeyPath : string = path.resolve(options.directory, buildKeyFileName(KeyPairKind.PUBLIC, options));\n\n let publicKey : string;\n\n try {\n await fs.promises.stat(publicKeyPath);\n const publicKeyBuffer = await fs.promises.readFile(publicKeyPath);\n publicKey = publicKeyBuffer.toString();\n } catch (e) {\n const publicKeyObject = createPublicKey({\n key: privateKey,\n format: options.privateKeyEncoding.format,\n type: options.publicKeyEncoding.type,\n });\n\n const stringOrBuffer = publicKeyObject.export({\n format: options.publicKeyEncoding.format,\n type: options.publicKeyEncoding.type,\n });\n if (typeof stringOrBuffer !== 'string') {\n publicKey = stringOrBuffer.toString();\n } else {\n publicKey = stringOrBuffer;\n }\n\n if (options.save) {\n await saveKeyPair({\n privateKey,\n publicKey,\n }, options);\n }\n }\n\n return {\n privateKey,\n publicKey,\n };\n}\n","/*\n * Copyright (c) 2022.\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 */\nimport type { KeyPair, KeyPairOptions } from './type';\nimport { extendKeyPairOptions } from './utils';\nimport { loadKeyPair } from './load';\nimport { createKeyPair } from './create';\n\nconst keyPairCache : Record<string, KeyPair> = {};\n\nexport async function useKeyPair(value?: Partial<KeyPairOptions> | string) : Promise<KeyPair> {\n let options : KeyPairOptions;\n\n if (typeof value === 'string') {\n options = extendKeyPairOptions({\n privateName: value,\n });\n } else {\n options = extendKeyPairOptions(value || {});\n }\n\n if (Object.prototype.hasOwnProperty.call(keyPairCache, options.privateName)) {\n return keyPairCache[options.privateName];\n }\n\n let keyPair = await loadKeyPair(options);\n if (typeof keyPair === 'undefined') {\n keyPair = await createKeyPair(options);\n }\n\n keyPairCache[options.privateName] = keyPair;\n\n return keyPair;\n}\n","/*\n * Copyright (c) 2022.\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 { TokenError } from '@authup/core';\nimport { isObject } from 'smob';\n\nexport function createErrorForJWTError(e: unknown) : TokenError {\n if (\n isObject(e) &&\n typeof e.name === 'string'\n ) {\n switch (e.name) {\n case 'TokenExpiredError': {\n return TokenError.expired();\n }\n case 'NotBeforeError': {\n if (typeof e.date === 'string' || e.date instanceof Date) {\n return TokenError.notActiveBefore(e.date);\n }\n break;\n }\n case 'JsonWebTokenError': {\n if (typeof e.message === 'string') {\n return TokenError.payloadInvalid(e.message);\n }\n\n break;\n }\n }\n }\n\n return new TokenError({\n cause: e as Error,\n logMessage: true,\n message: 'The JWT error could not be determined.',\n });\n}\n","/*\n * Copyright (c) 2022.\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 {\n Jwt,\n JwtPayload,\n} from 'jsonwebtoken';\nimport {\n decode,\n} from 'jsonwebtoken';\nimport { TokenError } from '@authup/core';\nimport type { TokenDecodeOptions } from './type';\nimport { createErrorForJWTError } from './utils';\n\n/**\n * Decode a JWT token with no verification.\n *\n * @param token\n * @param options\n *\n * @throws TokenError\n */\nexport function decodeToken(token: string, options: TokenDecodeOptions & { complete: true }): Jwt;\nexport function decodeToken(token: string, options?: TokenDecodeOptions): JwtPayload | string;\nexport function decodeToken(\n token: string,\n options?: TokenDecodeOptions,\n): JwtPayload | string {\n options ??= {};\n\n let output : string | JwtPayload | null;\n\n try {\n output = decode(token, {\n ...options,\n });\n } catch (e) {\n throw createErrorForJWTError(e);\n }\n\n if (output === null) {\n throw TokenError.payloadInvalid('The token could not be decoded.');\n }\n\n return output;\n}\n","/*\n * Copyright (c) 2022.\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 { sign } from 'jsonwebtoken';\nimport { KeyType, TokenError } from '@authup/core';\nimport { isKeyPair, useKeyPair } from '../key-pair';\nimport type { TokenSignOptions } from './type';\n\nexport async function signToken(\n payload: string | object | Buffer | Record<string, any>,\n context: TokenSignOptions,\n): Promise<string> {\n context.expiresIn = context.expiresIn || 3600;\n\n switch (context.type) {\n case KeyType.RSA:\n case KeyType.EC: {\n const { type, keyPair, ...options } = context;\n const { privateKey } = isKeyPair(keyPair) ?\n keyPair :\n await useKeyPair(keyPair);\n\n if (type === KeyType.RSA) {\n options.algorithm = options.algorithm || 'RS256';\n } else {\n options.algorithm = options.algorithm || 'ES256';\n }\n\n return sign(payload, privateKey, options);\n }\n case KeyType.OCT: {\n const { type, secret, ...options } = context;\n options.algorithm = options.algorithm || 'HS256';\n\n return sign(payload, secret, options);\n }\n }\n\n throw new TokenError();\n}\n","/*\n * Copyright (c) 2022.\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 { Jwt, JwtPayload } from 'jsonwebtoken';\nimport { verify } from 'jsonwebtoken';\nimport { KeyType, TokenError } from '@authup/core';\nimport { isKeyPairWithPublicKey, useKeyPair } from '../key-pair';\nimport type { TokenVerifyOptions } from './type';\nimport { createErrorForJWTError } from './utils';\n\n/**\n * Verify JWT.\n *\n * @param token\n * @param context\n *\n * @throws TokenError\n */\nexport async function verifyToken(token: string, context: TokenVerifyOptions & { complete: true }): Promise<string | Jwt>;\nexport async function verifyToken(token: string, context: TokenVerifyOptions): Promise<JwtPayload | string>;\nexport async function verifyToken(\n token: string,\n context: TokenVerifyOptions,\n) : Promise<JwtPayload | Jwt | string> {\n let promise : Promise<JwtPayload | Jwt | string | undefined>;\n\n let output : Jwt | JwtPayload | string | undefined;\n\n try {\n switch (context.type) {\n case KeyType.RSA:\n case KeyType.EC: {\n const { type, keyPair, ...options } = context;\n const { publicKey } = isKeyPairWithPublicKey(keyPair) ?\n keyPair :\n await useKeyPair(keyPair);\n\n if (type === KeyType.RSA) {\n options.algorithms = options.algorithms || ['RS256', 'RS384', 'RS512', 'PS256', 'PS384', 'PS512'];\n } else {\n options.algorithms = options.algorithms || ['ES256', 'ES384', 'ES512'];\n }\n\n promise = new Promise<Jwt | JwtPayload | string>((resolve, reject) => {\n verify(token, publicKey, options, (err, decoded) => {\n if (err) {\n reject(err);\n return;\n }\n\n resolve(decoded);\n });\n });\n break;\n }\n case KeyType.OCT: {\n const { type, secret, ...options } = context;\n\n options.algorithms = options.algorithms || ['HS256', 'HS384', 'HS512'];\n\n promise = new Promise<Jwt | JwtPayload | string>((resolve, reject) => {\n verify(token, secret, options, (err, decoded) => {\n if (err) {\n reject(err);\n return;\n }\n\n resolve(decoded);\n });\n });\n }\n }\n\n output = await promise;\n } catch (e) {\n throw createErrorForJWTError(e);\n }\n\n if (typeof output === 'undefined') {\n throw new TokenError({ message: 'Invalid type.' });\n }\n\n return output;\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 { isObject } from '@authup/core';\nimport type { DomainEventChannelName } from './type';\n\nexport function transformDomainEventData<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 buildDomainEventChannelName(\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-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 { DomainEventName } from '@authup/core';\nimport type { DomainsEventContext } from '@authup/core';\nimport { hasClient, hasConfig, useClient } from 'redis-extension';\nimport type { DomainEventDestinations } from '../type';\nimport { buildDomainEventChannelName, transformDomainEventData } from '../utils';\n\nexport async function publishDomainRedisEvent(\n context: DomainsEventContext,\n destinations: DomainEventDestinations,\n) : Promise<any> {\n if (!hasClient() && !hasConfig()) {\n return Promise.resolve();\n }\n\n context = transformDomainEventData(context);\n\n const json = JSON.stringify(context);\n\n const client = useClient();\n const pipeline = client.pipeline();\n for (let i = 0; i < destinations.length; i++) {\n const { namespace } = destinations[i];\n const keyPrefix = (namespace ? `${namespace}:` : '');\n\n let key = keyPrefix + buildDomainEventChannelName(destinations[i].channel);\n pipeline.publish(key, json);\n\n if (\n context.event !== DomainEventName.CREATED &&\n typeof destinations[i].channel === 'function'\n ) {\n key = keyPrefix + buildDomainEventChannelName(destinations[i].channel, context.data.id);\n pipeline.publish(key, json);\n }\n }\n\n return pipeline.exec();\n}\n","/*\n * Copyright (c) 2022-2022.\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 { Emitter } from '@socket.io/redis-emitter';\nimport { useClient } from 'redis-extension';\nimport type { SocketServerToClientEvents } from './type';\n\nlet instance : undefined | Emitter<SocketServerToClientEvents>;\n\nexport function useSocketEmitter() : Emitter<SocketServerToClientEvents> {\n if (typeof instance !== 'undefined') {\n return instance;\n }\n\n instance = new Emitter<SocketServerToClientEvents>(useClient());\n\n return instance;\n}\n","/*\n * Copyright (c) 2022-2022.\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 { DomainsEventContext } from '@authup/core';\nimport { DomainEventName, buildDomainEventFullName } from '@authup/core';\nimport { hasClient, hasConfig } from 'redis-extension';\nimport type { DomainEventDestinations } from '../type';\nimport { buildDomainEventChannelName, transformDomainEventData } from '../utils';\nimport { useSocketEmitter } from './singleton';\n\nexport function publishDomainSocketEvent(\n context: DomainsEventContext,\n destinations: DomainEventDestinations,\n) {\n if (!hasClient() && !hasConfig()) {\n return;\n }\n\n context = transformDomainEventData(context);\n\n for (let i = 0; i < destinations.length; i++) {\n let emitter = useSocketEmitter();\n if (destinations[i].namespace) {\n emitter = emitter.of(destinations[i].namespace);\n }\n\n let roomName = buildDomainEventChannelName(destinations[i].channel);\n\n const fullEventName = buildDomainEventFullName(context.type, context.event);\n\n emitter\n .in(roomName)\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n .emit(fullEventName, {\n ...context,\n meta: {\n roomName,\n },\n });\n\n if (\n context.event !== DomainEventName.CREATED &&\n typeof destinations[i].channel === 'function'\n ) {\n roomName = buildDomainEventChannelName(destinations[i].channel, context.data.id);\n emitter\n .in(roomName)\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n .emit(fullEventName, {\n ...context,\n meta: {\n roomName,\n roomId: context.data.id,\n },\n });\n }\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 { DomainsEventContext } from '@authup/core';\nimport { publishDomainRedisEvent } from './redis';\nimport { publishDomainSocketEvent } from './socket';\nimport type { DomainEventDestinations } from './type';\n\nexport async function publishDomainEvent(\n context: DomainsEventContext,\n destinations: DomainEventDestinations,\n) {\n await publishDomainRedisEvent(context, destinations);\n publishDomainSocketEvent(context, destinations);\n}\n","/*\n * Copyright (c) 2022.\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 { Logger } from '../type';\n\nexport class VoidLogger implements Logger {\n error(message: any) : any;\n\n error(message: string, ...meta: any[]) : any;\n\n error() {\n return this;\n }\n\n // ---------------------------------------------\n\n warn(message: any) : any;\n\n warn(message: string, ...meta: any[]) : any;\n\n warn() {\n return this;\n }\n\n // ---------------------------------------------\n\n info(message: any) : any;\n\n info(message: string, ...meta: any[]) : any;\n\n info() {\n return this;\n }\n\n // ---------------------------------------------\n\n http(message: any) : any;\n\n http(message: string, ...meta: any[]) : any;\n\n http() {\n return this;\n }\n\n // ---------------------------------------------\n\n verbose(message: any) : any;\n\n verbose(message: string, ...meta: any[]) : any;\n\n verbose() {\n return this;\n }\n\n // ---------------------------------------------\n\n debug(message: any) : any;\n\n debug(message: string, ...meta: any[]) : any;\n\n debug() {\n return this;\n }\n\n // ---------------------------------------------\n}\n","/*\n * Copyright (c) 2022.\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 { VoidLogger } from './presets';\nimport type { Logger } from './type';\n\nlet instance: Logger | undefined;\n\nexport function useLogger() : Logger {\n if (typeof instance !== 'undefined') {\n return instance;\n }\n\n instance = new VoidLogger();\n\n return instance;\n}\n\nexport function setLogger(logger: Logger) {\n instance = logger;\n}\n","/*\n * Copyright (c) 2022.\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 { SmtpConfig } from '../type';\n\nlet instance : SmtpConfig | string | undefined;\n\nexport function hasSmtpConfig() {\n return !!instance;\n}\n\nexport function setSmtpConfig(value: SmtpConfig | string | undefined) {\n instance = value;\n}\n\nexport function useSmtpConfig() : SmtpConfig | string {\n if (typeof instance !== 'undefined') {\n return instance;\n }\n\n instance = {};\n\n return instance;\n}\n","/*\n * Copyright (c) 2022.\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 { Transporter } from 'nodemailer';\nimport { createTransport } from 'nodemailer';\nimport type { SmtpConfig } from './type';\nimport { useLogger } from '../logger';\n\nexport function createSmtpClient(options?: SmtpConfig | string) : Transporter {\n let transport : Transporter;\n\n options = options || {};\n\n if (typeof options === 'string') {\n transport = createTransport(options);\n } else if (options.connectionString) {\n transport = createTransport(options.connectionString);\n } else {\n let auth: Record<string, any> | undefined;\n if (options.user && options.password) {\n auth = {\n type: 'login',\n user: options.user,\n pass: options.password,\n };\n }\n\n transport = createTransport({\n host: options.host,\n port: options.port,\n auth,\n secure: options.ssl,\n opportunisticTLS: options.starttls,\n tls: {\n rejectUnauthorized: false,\n },\n });\n }\n\n transport.on('error', (e) => {\n useLogger().error(e.message);\n });\n\n return transport;\n}\n","/*\n * Copyright (c) 2022.\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 { Transporter } from 'nodemailer';\nimport { createTestAccount } from 'nodemailer';\nimport { createSmtpClient } from './module';\nimport { useSmtpConfig } from './config';\nimport type { SmtpConfig } from './type';\n\nlet instance : Transporter | undefined;\n\nexport async function useSMTPClient() : Promise<Transporter> {\n if (typeof instance !== 'undefined') {\n return instance;\n }\n\n let options : SmtpConfig | string;\n if (process.env.NODE_ENV === 'test') {\n const testAccount = await createTestAccount();\n\n options = {\n host: 'smtp.ethereal.email',\n port: 587,\n ssl: false,\n user: testAccount.user,\n password: testAccount.pass,\n };\n } else {\n options = useSmtpConfig();\n }\n\n instance = createSmtpClient(options);\n\n return instance;\n}\n","/*\n * Copyright (c) 2022.\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":["compare","value","hashedValue","compareMethod","hash","str","saltOrRounds","hashMethod","KeyPairKind","isKeyPair","data","isObject","privateKey","publicKey","isKeyPairWithPublicKey","extendKeyPairOptions","options","directory","process","cwd","path","isAbsolute","resolve","type","modulusLength","privateKeyEncoding","format","publicKeyEncoding","passphrase","cipher","buildKeyFileName","context","parts","PRIVATE","privateName","push","privateExtension","startsWith","slice","PUBLIC","publicName","publicExtension","join","decryptRSAPrivateKey","key","createPrivateKey","content","export","Buffer","from","toString","saveKeyPair","keyPair","fs","promises","mkdir","recursive","Promise","all","map","file","writeFile","createKeyPair","reject","callback","err","generateKeyPair","save","deleteKeyPair","privateKeyPath","publicKeyPath","filePath","stat","e","rm","loadKeyPair","undefined","privateKeyBuffer","readFile","publicKeyBuffer","publicKeyObject","createPublicKey","stringOrBuffer","keyPairCache","useKeyPair","Object","prototype","hasOwnProperty","call","createErrorForJWTError","name","TokenError","expired","date","Date","notActiveBefore","message","payloadInvalid","cause","logMessage","decodeToken","token","output","decode","signToken","payload","expiresIn","KeyType","RSA","EC","algorithm","sign","OCT","secret","verifyToken","promise","algorithms","verify","decoded","transformDomainEventData","input","keys","i","length","toISOString","buildDomainEventChannelName","id","publishDomainRedisEvent","destinations","hasClient","hasConfig","json","JSON","stringify","client","useClient","pipeline","namespace","keyPrefix","channel","publish","event","DomainEventName","CREATED","exec","instance","useSocketEmitter","Emitter","publishDomainSocketEvent","emitter","of","roomName","fullEventName","buildDomainEventFullName","in","emit","meta","roomId","publishDomainEvent","VoidLogger","error","warn","info","http","verbose","debug","useLogger","setLogger","logger","hasSmtpConfig","setSmtpConfig","useSmtpConfig","createSmtpClient","transport","createTransport","connectionString","auth","user","password","pass","host","port","secure","ssl","opportunisticTLS","starttls","tls","rejectUnauthorized","on","useSMTPClient","env","NODE_ENV","testAccount","createTestAccount","obj","prop"],"mappings":";;;;;;;;;;;AASO,eAAeA,OAAAA,CAAQC,KAAa,EAAEC,WAAmB,EAAA;AAC5D,IAAA,OAAOC,UAAcF,KAAOC,EAAAA,WAAAA,CAAAA,CAAAA;AAChC;;ACFO,eAAeE,IAAAA,CAAKC,GAAW,EAAEC,eAAgC,EAAE,EAAA;AACtE,IAAA,OAAOC,OAAWF,GAAKC,EAAAA,YAAAA,CAAAA,CAAAA;AAC3B;;ACXA;;;;;AAKC,IAAA,IAAA,YAAA;AAEWE,CAAAA,SAAAA,WAAAA,EAAAA;;;GAAAA,WAAAA,KAAAA,WAAAA,GAAAA,EAAAA,CAAAA,CAAAA;;ACGL,SAASC,UAAUC,IAAa,EAAA;AACnC,IAAA,OAAOC,QAASD,CAAAA,IAAAA,CAAAA,IACZ,OAAQA,IAAiBE,CAAAA,UAAU,KAAK,WAAA,IACxC,OAAQF,IAAiBG,CAAAA,SAAS,KAAK,WAAA,CAAA;AAC/C,CAAA;AAEO,SAASC,uBAAuBJ,IAAa,EAAA;AAChD,IAAA,OAAOC,SAASD,IACZ,CAAA,IAAA,OAAO,IAACA,CAAiBG,SAAS,KAAK,WAAA,CAAA;AAC/C;;ACTO,SAASE,qBACZC,OAAiC,EAAA;AASjCA,IAAAA,IAAAA,QAAAA,CAAAA;AAPAA,IAAAA,OAAAA,GAAUA,WAAW,EAAC,CAAA;AAEtBA,IAAAA,OAAAA,CAAQC,SAAS,GAAGD,OAAAA,CAAQC,SAAS,IAAIC,QAAQC,GAAG,EAAA,CAAA;AACpDH,IAAAA,OAAAA,CAAQC,SAAS,GAAGG,IAAAA,CAAKC,UAAU,CAACL,OAAAA,CAAQC,SAAS,CACjDD,GAAAA,OAAAA,CAAQC,SAAS,GACjBG,KAAKE,OAAO,CAACJ,QAAQC,GAAG,EAAA,EAAIH,QAAQC,SAAS,CAAA,CAAA;AAEjDD,IAAAA,CAAAA,QAAAA,GAAAA,OAAAA,EAAQO,IAARP,KAAAA,QAAAA,CAAQO,IAAS,GAAA,KAAA,CAAA,CAAA;IAEjB,IACIP,OAAAA,CAAQO,IAAI,KAAK,KACjBP,IAAAA,OAAAA,CAAQO,IAAI,KAAK,SACjBP,IAAAA,OAAAA,CAAQO,IAAI,KAAK,KACnB,EAAA;AACEP,QAAAA,OAAAA,CAAQQ,aAAa,GAAG,IAAA,CAAA;AAC5B,KAAA;IAEA,IAAI,CAACR,OAAQS,CAAAA,kBAAkB,EAAE;AAC7BT,QAAAA,OAAAA,CAAQS,kBAAkB,GAAG;YACzBF,IAAM,EAAA,OAAA;YACNG,MAAQ,EAAA,KAAA;AACZ,SAAA,CAAA;AACJ,KAAA;IAEA,IAAI,CAACV,OAAQW,CAAAA,iBAAiB,EAAE;AAC5BX,QAAAA,OAAAA,CAAQW,iBAAiB,GAAG;YACxBJ,IAAM,EAAA,MAAA;YACNG,MAAQ,EAAA,KAAA;AACZ,SAAA,CAAA;AACJ,KAAA;IAEA,IACIV,OAAAA,CAAQS,kBAAkB,CAACG,UAAU,IACrC,CAACZ,OAAQS,CAAAA,kBAAkB,CAACI,MAAM,EACpC;QACEb,OAAQS,CAAAA,kBAAkB,CAACI,MAAM,GAAG,aAAA,CAAA;AACxC,KAAA;IAEA,OAAOb,OAAAA,CAAAA;AACX;;ACzCO,SAASc,gBAAAA,CACZP,IAAsB,EACtBQ,OAAiC,EAAA;AAEjC,IAAA,MAAMf,UAAUD,oBAAqBgB,CAAAA,OAAAA,CAAAA,CAAAA;AAErC,IAAA,MAAMC,QAAmB,EAAE,CAAA;IAE3B,OAAQT,IAAAA;AACJ,QAAA,KAAKf,YAAYyB,OAAO;AAAE,YAAA;gBACtB,IAAIjB,OAAAA,CAAQkB,WAAW,EAAE;oBACrBF,KAAMG,CAAAA,IAAI,CAACnB,OAAAA,CAAQkB,WAAW,CAAA,CAAA;iBAC3B,MAAA;AACHF,oBAAAA,KAAAA,CAAMG,IAAI,CAACZ,IAAAA,CAAAA,CAAAA;AACf,iBAAA;gBAEA,IAAIP,OAAAA,CAAQoB,gBAAgB,EAAE;AAC1B,oBAAA,IAAIpB,OAAQoB,CAAAA,gBAAgB,CAACC,UAAU,CAAC,GAAM,CAAA,EAAA;AAC1CrB,wBAAAA,OAAAA,CAAQoB,gBAAgB,GAAGpB,OAAAA,CAAQoB,gBAAgB,CAACE,KAAK,CAAC,CAAA,CAAA,CAAA;AAC9D,qBAAA;oBAEAN,KAAMG,CAAAA,IAAI,CAACnB,OAAAA,CAAQoB,gBAAgB,CAAA,CAAA;iBAChC,MAAA;AACHJ,oBAAAA,KAAAA,CAAMG,IAAI,CAAC,KAAA,CAAA,CAAA;AACf,iBAAA;AACA,gBAAA,MAAA;AACJ,aAAA;AACA,QAAA,KAAK3B,YAAY+B,MAAM;AAAE,YAAA;gBACrB,IAAIvB,OAAAA,CAAQwB,UAAU,EAAE;oBACpBR,KAAMG,CAAAA,IAAI,CAACnB,OAAAA,CAAQwB,UAAU,CAAA,CAAA;iBAC1B,MAAA;AACHR,oBAAAA,KAAAA,CAAMG,IAAI,CAACZ,IAAAA,CAAAA,CAAAA;AACf,iBAAA;gBAEA,IAAIP,OAAAA,CAAQyB,eAAe,EAAE;AACzB,oBAAA,IAAIzB,OAAQyB,CAAAA,eAAe,CAACJ,UAAU,CAAC,GAAM,CAAA,EAAA;AACzCrB,wBAAAA,OAAAA,CAAQyB,eAAe,GAAGzB,OAAAA,CAAQyB,eAAe,CAACH,KAAK,CAAC,CAAA,CAAA,CAAA;AAC5D,qBAAA;oBAEAN,KAAMG,CAAAA,IAAI,CAACnB,OAAAA,CAAQyB,eAAe,CAAA,CAAA;iBAC/B,MAAA;AACHT,oBAAAA,KAAAA,CAAMG,IAAI,CAAC,KAAA,CAAA,CAAA;AACf,iBAAA;AACA,gBAAA,MAAA;AACJ,aAAA;AACJ,KAAA;IAEA,OAAOH,KAAAA,CAAMU,IAAI,CAAC,GAAA,CAAA,CAAA;AACtB;;ACjDO,SAASC,oBAAAA,CACZZ,OAAuB,EACvBa,GAAoB,EAAA;AAEpB,IAAA,MAAMhC,aAAaiC,gBAAiB,CAAA;QAChCtB,IAAMQ,EAAAA,OAAAA,CAAQN,kBAAkB,CAACF,IAAI;QACrCG,MAAQK,EAAAA,OAAAA,CAAQN,kBAAkB,CAACC,MAAM;AACzCkB,QAAAA,GAAAA;AACAhB,QAAAA,UAAAA,EAAYG,QAAQN,kBAAkB,CAACG,UAAU,IAAIG,QAAQH,UAAU;AAC3E,KAAA,CAAA,CAAA;IAEA,IAAIkB,OAAAA,GAAUlC,UAAWmC,CAAAA,MAAM,CAAC;QAC5BxB,IAAMQ,EAAAA,OAAAA,CAAQN,kBAAkB,CAACF,IAAI;QACrCG,MAAQK,EAAAA,OAAAA,CAAQN,kBAAkB,CAACC,MAAM;AAC7C,KAAA,CAAA,CAAA;IAEA,IAAI,OAAOoB,YAAY,QAAU,EAAA;AAC7BA,QAAAA,OAAAA,GAAUE,MAAOC,CAAAA,IAAI,CAACH,OAAAA,CAAAA,CAASI,QAAQ,CAAC,OAAA,CAAA,CAAA;AAC5C,KAAA;IAEA,OAAOJ,OAAAA,CAAAA;AACX;;AClBO,eAAeK,WAAAA,CAAYC,OAAgB,EAAErB,OAAwB,EAAA;AACxEA,IAAAA,OAAAA,GAAUhB,oBAAqBgB,CAAAA,OAAAA,CAAAA,CAAAA;AAE/B,IAAA,MAAMsB,GAAGC,QAAQ,CAACC,KAAK,CAACxB,OAAAA,CAAQd,SAAS,EAAE;QAAEuC,SAAW,EAAA,IAAA;AAAK,KAAA,CAAA,CAAA;IAE7D,MAAMC,OAAAA,CAAQC,GAAG,CACb;AACI,QAAA;YACItC,IAAMA,EAAAA,IAAAA,CAAKE,OAAO,CAACS,OAAAA,CAAQd,SAAS,EAAEa,gBAAAA,CAAiBtB,WAAYyB,CAAAA,OAAO,EAAEF,OAAAA,CAAAA,CAAAA;AAC5Ee,YAAAA,OAAAA,EAASM,QAAQxC,UAAU;AAC/B,SAAA;AACA,QAAA;YACIQ,IAAMA,EAAAA,IAAAA,CAAKE,OAAO,CAACS,OAAAA,CAAQd,SAAS,EAAEa,gBAAAA,CAAiBtB,WAAY+B,CAAAA,MAAM,EAAER,OAAAA,CAAAA,CAAAA;AAC3Ee,YAAAA,OAAAA,EAASM,QAAQvC,SAAS;AAC9B,SAAA;AACH,KAAA,CACI8C,GAAG,CAAC,CAACC,IAAAA,GAASP,EAAGC,CAAAA,QAAQ,CAACO,SAAS,CAACD,IAAAA,CAAKxC,IAAI,EAAEwC,KAAKd,OAAO,CAAA,CAAA,CAAA,CAAA;IAGpE,OAAOM,OAAAA,CAAAA;AACX;;ACrBO,eAAeU,cAAc/B,OAAiC,EAAA;AACjE,IAAA,MAAMf,UAAUD,oBAAqBgB,CAAAA,OAAAA,CAAAA,CAAAA;AAErC,IAAA,MAAMqB,OAAoB,GAAA,MAAM,IAAIK,OAAAA,CAAQ,CAACnC,OAAmCyC,EAAAA,MAAAA,GAAAA;QAC5E,MAAMC,QAAAA,GAAW,CAACC,GAAAA,EAAqBpD,SAAmBD,EAAAA,UAAAA,GAAAA;AACtD,YAAA,IAAIqD,KAAKF,MAAOE,CAAAA,GAAAA,CAAAA,CAAAA;YAEhB3C,OAAQ,CAAA;AACJV,gBAAAA,UAAAA;AACAC,gBAAAA,SAAAA;AACJ,aAAA,CAAA,CAAA;AACJ,SAAA,CAAA;AACA,QAAA,OAAQG,QAAQO,IAAI;YAChB,KAAK,KAAA;gBACD2C,eACIlD,CAAAA,OAAAA,CAAQO,IAAI,EACZP,OACAgD,EAAAA,QAAAA,CAAAA,CAAAA;AAEJ,gBAAA,MAAA;YACJ,KAAK,IAAA;gBACDE,eACIlD,CAAAA,OAAAA,CAAQO,IAAI,EACZP,OACAgD,EAAAA,QAAAA,CAAAA,CAAAA;AAEJ,gBAAA,MAAA;YACJ,KAAK,KAAA;gBACDE,eACIlD,CAAAA,OAAAA,CAAQO,IAAI,EACZP,OACAgD,EAAAA,QAAAA,CAAAA,CAAAA;AAEJ,gBAAA,MAAA;YACJ,KAAK,SAAA;gBACDE,eACIlD,CAAAA,OAAAA,CAAQO,IAAI,EACZP,OACAgD,EAAAA,QAAAA,CAAAA,CAAAA;AAEJ,gBAAA,MAAA;AACR,SAAA;AACJ,KAAA,CAAA,CAAA;IAEA,IAAIhD,OAAAA,CAAQmD,IAAI,EAAE;AACd,QAAA,MAAMhB,YAAYC,OAASpC,EAAAA,OAAAA,CAAAA,CAAAA;AAC/B,KAAA;AAEA,IAAA,IACIA,QAAQY,UAAU,IAClBZ,QAAQS,kBAAkB,CAACG,UAAU,EACvC;AACEwB,QAAAA,OAAAA,CAAQxC,UAAU,GAAG+B,oBACjB3B,CAAAA,OAAAA,EACAoC,QAAQxC,UAAU,CAAA,CAAA;AAE1B,KAAA;IAEA,OAAOwC,OAAAA,CAAAA;AACX;;AC1DO,eAAegB,cAAcrC,OAAiC,EAAA;AACjE,IAAA,MAAMf,UAAUD,oBAAqBgB,CAAAA,OAAAA,CAAAA,CAAAA;IAErC,MAAMsC,cAAAA,GAA0BjD,IAAKE,CAAAA,OAAO,CAACN,OAAAA,CAAQC,SAAS,EAAEa,gBAAAA,CAAiBtB,WAAYyB,CAAAA,OAAO,EAAEjB,OAAAA,CAAAA,CAAAA,CAAAA;IACtG,MAAMsD,aAAAA,GAAyBlD,IAAKE,CAAAA,OAAO,CAACN,OAAAA,CAAQC,SAAS,EAAEa,gBAAAA,CAAiBtB,WAAY+B,CAAAA,MAAM,EAAEvB,OAAAA,CAAAA,CAAAA,CAAAA;IAEpG,IAAI;QACA,MAAMyC,OAAAA,CAAQC,GAAG,CAAC;AAACW,YAAAA,cAAAA;AAAgBC,YAAAA,aAAAA;SAAc,CAC5CX,GAAG,CAAC,CAACY,QAAAA,GAAalB,GAAGC,QAAQ,CAACkB,IAAI,CAACD,QAAAA,CAAAA,CAAAA,CAAAA,CAAAA;AAC5C,KAAA,CAAE,OAAOE,CAAG,EAAA;AACR,QAAA,OAAA;AACJ,KAAA;IAEA,MAAMhB,OAAAA,CAAQC,GAAG,CAAC;AACdW,QAAAA,cAAAA;AACAC,QAAAA,aAAAA;KACH,CAACX,GAAG,CAAC,CAACY,QAAAA,GAAalB,GAAGC,QAAQ,CAACoB,EAAE,CAACH,QAAAA,CAAAA,CAAAA,CAAAA,CAAAA;AACvC;;ACfO,eAAeI,YAAY5C,OAAiC,EAAA;AAC/D,IAAA,MAAMf,UAAUD,oBAAqBgB,CAAAA,OAAAA,CAAAA,CAAAA;IAErC,MAAMsC,cAAAA,GAA0BjD,IAAKE,CAAAA,OAAO,CAACN,OAAAA,CAAQC,SAAS,EAAEa,gBAAAA,CAAiBtB,WAAYyB,CAAAA,OAAO,EAAEjB,OAAAA,CAAAA,CAAAA,CAAAA;IAEtG,IAAI;AACA,QAAA,MAAMqC,EAAGC,CAAAA,QAAQ,CAACkB,IAAI,CAACH,cAAAA,CAAAA,CAAAA;AAC3B,KAAA,CAAE,OAAOI,CAAG,EAAA;QACR,OAAOG,SAAAA,CAAAA;AACX,KAAA;AAEA,IAAA,MAAMC,mBAAmB,MAAMxB,EAAAA,CAAGC,QAAQ,CAACwB,QAAQ,CAACT,cAAAA,CAAAA,CAAAA;IACpD,IAAIzD,UAAAA,GAAaiE,iBAAiB3B,QAAQ,EAAA,CAAA;AAC1C,IAAA,IACIlC,QAAQY,UAAU,IAClBZ,QAAQS,kBAAkB,CAACG,UAAU,EACvC;AACEhB,QAAAA,UAAAA,GAAa+B,qBACT3B,OACAJ,EAAAA,UAAAA,CAAAA,CAAAA;AAER,KAAA;IAEA,MAAM0D,aAAAA,GAAyBlD,IAAKE,CAAAA,OAAO,CAACN,OAAAA,CAAQC,SAAS,EAAEa,gBAAAA,CAAiBtB,WAAY+B,CAAAA,MAAM,EAAEvB,OAAAA,CAAAA,CAAAA,CAAAA;IAEpG,IAAIH,SAAAA,CAAAA;IAEJ,IAAI;AACA,QAAA,MAAMwC,EAAGC,CAAAA,QAAQ,CAACkB,IAAI,CAACF,aAAAA,CAAAA,CAAAA;AACvB,QAAA,MAAMS,kBAAkB,MAAM1B,EAAAA,CAAGC,QAAQ,CAACwB,QAAQ,CAACR,aAAAA,CAAAA,CAAAA;AACnDzD,QAAAA,SAAAA,GAAYkE,gBAAgB7B,QAAQ,EAAA,CAAA;AACxC,KAAA,CAAE,OAAOuB,CAAG,EAAA;AACR,QAAA,MAAMO,kBAAkBC,eAAgB,CAAA;YACpCrC,GAAKhC,EAAAA,UAAAA;YACLc,MAAQV,EAAAA,OAAAA,CAAQS,kBAAkB,CAACC,MAAM;YACzCH,IAAMP,EAAAA,OAAAA,CAAQW,iBAAiB,CAACJ,IAAI;AACxC,SAAA,CAAA,CAAA;QAEA,MAAM2D,cAAAA,GAAiBF,eAAgBjC,CAAAA,MAAM,CAAC;YAC1CrB,MAAQV,EAAAA,OAAAA,CAAQW,iBAAiB,CAACD,MAAM;YACxCH,IAAMP,EAAAA,OAAAA,CAAQW,iBAAiB,CAACJ,IAAI;AACxC,SAAA,CAAA,CAAA;QACA,IAAI,OAAO2D,mBAAmB,QAAU,EAAA;AACpCrE,YAAAA,SAAAA,GAAYqE,eAAehC,QAAQ,EAAA,CAAA;SAChC,MAAA;YACHrC,SAAYqE,GAAAA,cAAAA,CAAAA;AAChB,SAAA;QAEA,IAAIlE,OAAAA,CAAQmD,IAAI,EAAE;AACd,YAAA,MAAMhB,WAAY,CAAA;AACdvC,gBAAAA,UAAAA;AACAC,gBAAAA,SAAAA;aACDG,EAAAA,OAAAA,CAAAA,CAAAA;AACP,SAAA;AACJ,KAAA;IAEA,OAAO;AACHJ,QAAAA,UAAAA;AACAC,QAAAA,SAAAA;AACJ,KAAA,CAAA;AACJ;;AChEA,MAAMsE,eAAyC,EAAC,CAAA;AAEzC,eAAeC,WAAWnF,KAAwC,EAAA;IACrE,IAAIe,OAAAA,CAAAA;IAEJ,IAAI,OAAOf,UAAU,QAAU,EAAA;AAC3Be,QAAAA,OAAAA,GAAUD,oBAAqB,CAAA;YAC3BmB,WAAajC,EAAAA,KAAAA;AACjB,SAAA,CAAA,CAAA;KACG,MAAA;QACHe,OAAUD,GAAAA,oBAAAA,CAAqBd,SAAS,EAAC,CAAA,CAAA;AAC7C,KAAA;IAEA,IAAIoF,MAAAA,CAAOC,SAAS,CAACC,cAAc,CAACC,IAAI,CAACL,YAAAA,EAAcnE,OAAQkB,CAAAA,WAAW,CAAG,EAAA;AACzE,QAAA,OAAOiD,YAAY,CAACnE,OAAQkB,CAAAA,WAAW,CAAC,CAAA;AAC5C,KAAA;IAEA,IAAIkB,OAAAA,GAAU,MAAMuB,WAAY3D,CAAAA,OAAAA,CAAAA,CAAAA;IAChC,IAAI,OAAOoC,YAAY,WAAa,EAAA;AAChCA,QAAAA,OAAAA,GAAU,MAAMU,aAAc9C,CAAAA,OAAAA,CAAAA,CAAAA;AAClC,KAAA;AAEAmE,IAAAA,YAAY,CAACnE,OAAAA,CAAQkB,WAAW,CAAC,GAAGkB,OAAAA,CAAAA;IAEpC,OAAOA,OAAAA,CAAAA;AACX;;AC1BO,SAASqC,uBAAuBhB,CAAU,EAAA;AAC7C,IAAA,IACI9D,WAAS8D,CACT,CAAA,IAAA,OAAOA,CAAEiB,CAAAA,IAAI,KAAK,QACpB,EAAA;AACE,QAAA,OAAQjB,EAAEiB,IAAI;YACV,KAAK,mBAAA;AAAqB,gBAAA;AACtB,oBAAA,OAAOC,WAAWC,OAAO,EAAA,CAAA;AAC7B,iBAAA;YACA,KAAK,gBAAA;AAAkB,gBAAA;oBACnB,IAAI,OAAOnB,EAAEoB,IAAI,KAAK,YAAYpB,CAAEoB,CAAAA,IAAI,YAAYC,IAAM,EAAA;AACtD,wBAAA,OAAOH,UAAWI,CAAAA,eAAe,CAACtB,CAAAA,CAAEoB,IAAI,CAAA,CAAA;AAC5C,qBAAA;AACA,oBAAA,MAAA;AACJ,iBAAA;YACA,KAAK,mBAAA;AAAqB,gBAAA;AACtB,oBAAA,IAAI,OAAOpB,CAAAA,CAAEuB,OAAO,KAAK,QAAU,EAAA;AAC/B,wBAAA,OAAOL,UAAWM,CAAAA,cAAc,CAACxB,CAAAA,CAAEuB,OAAO,CAAA,CAAA;AAC9C,qBAAA;AAEA,oBAAA,MAAA;AACJ,iBAAA;AACJ,SAAA;AACJ,KAAA;AAEA,IAAA,OAAO,IAAIL,UAAW,CAAA;QAClBO,KAAOzB,EAAAA,CAAAA;QACP0B,UAAY,EAAA,IAAA;QACZH,OAAS,EAAA,wCAAA;AACb,KAAA,CAAA,CAAA;AACJ;;ACZO,SAASI,WAAAA,CACZC,KAAa,EACbrF,OAA4B,EAAA;AAE5BA,IAAAA,OAAAA,KAAAA,UAAY,EAAC,CAAA,CAAA;IAEb,IAAIsF,MAAAA,CAAAA;IAEJ,IAAI;AACAA,QAAAA,MAAAA,GAASC,OAAOF,KAAO,EAAA;AACnB,YAAA,GAAGrF,OAAO;AACd,SAAA,CAAA,CAAA;AACJ,KAAA,CAAE,OAAOyD,CAAG,EAAA;AACR,QAAA,MAAMgB,sBAAuBhB,CAAAA,CAAAA,CAAAA,CAAAA;AACjC,KAAA;AAEA,IAAA,IAAI6B,WAAW,IAAM,EAAA;QACjB,MAAMX,UAAAA,CAAWM,cAAc,CAAC,iCAAA,CAAA,CAAA;AACpC,KAAA;IAEA,OAAOK,MAAAA,CAAAA;AACX;;ACrCO,eAAeE,SAAAA,CAClBC,OAAuD,EACvD1E,OAAyB,EAAA;AAEzBA,IAAAA,OAAAA,CAAQ2E,SAAS,GAAG3E,OAAQ2E,CAAAA,SAAS,IAAI,IAAA,CAAA;AAEzC,IAAA,OAAQ3E,QAAQR,IAAI;AAChB,QAAA,KAAKoF,QAAQC,GAAG,CAAA;AAChB,QAAA,KAAKD,QAAQE,EAAE;AAAE,YAAA;AACb,gBAAA,MAAM,EAAEtF,IAAI,EAAE6B,OAAO,EAAE,GAAGpC,SAAS,GAAGe,OAAAA,CAAAA;gBACtC,MAAM,EAAEnB,UAAU,EAAE,GAAGH,UAAU2C,OAC7BA,CAAAA,GAAAA,OAAAA,GACA,MAAMgC,UAAWhC,CAAAA,OAAAA,CAAAA,CAAAA;gBAErB,IAAI7B,IAAAA,KAASoF,OAAQC,CAAAA,GAAG,EAAE;AACtB5F,oBAAAA,OAAAA,CAAQ8F,SAAS,GAAG9F,OAAQ8F,CAAAA,SAAS,IAAI,OAAA,CAAA;iBACtC,MAAA;AACH9F,oBAAAA,OAAAA,CAAQ8F,SAAS,GAAG9F,OAAQ8F,CAAAA,SAAS,IAAI,OAAA,CAAA;AAC7C,iBAAA;gBAEA,OAAOC,IAAAA,CAAKN,SAAS7F,UAAYI,EAAAA,OAAAA,CAAAA,CAAAA;AACrC,aAAA;AACA,QAAA,KAAK2F,QAAQK,GAAG;AAAE,YAAA;AACd,gBAAA,MAAM,EAAEzF,IAAI,EAAE0F,MAAM,EAAE,GAAGjG,SAAS,GAAGe,OAAAA,CAAAA;AACrCf,gBAAAA,OAAAA,CAAQ8F,SAAS,GAAG9F,OAAQ8F,CAAAA,SAAS,IAAI,OAAA,CAAA;gBAEzC,OAAOC,IAAAA,CAAKN,SAASQ,MAAQjG,EAAAA,OAAAA,CAAAA,CAAAA;AACjC,aAAA;AACJ,KAAA;AAEA,IAAA,MAAM,IAAI2E,UAAAA,EAAAA,CAAAA;AACd;;ACnBO,eAAeuB,WAAAA,CAClBb,KAAa,EACbtE,OAA2B,EAAA;IAE3B,IAAIoF,OAAAA,CAAAA;IAEJ,IAAIb,MAAAA,CAAAA;IAEJ,IAAI;AACA,QAAA,OAAQvE,QAAQR,IAAI;AAChB,YAAA,KAAKoF,QAAQC,GAAG,CAAA;AAChB,YAAA,KAAKD,QAAQE,EAAE;AAAE,gBAAA;AACb,oBAAA,MAAM,EAAEtF,IAAI,EAAE6B,OAAO,EAAE,GAAGpC,SAAS,GAAGe,OAAAA,CAAAA;oBACtC,MAAM,EAAElB,SAAS,EAAE,GAAGC,uBAAuBsC,OACzCA,CAAAA,GAAAA,OAAAA,GACA,MAAMgC,UAAWhC,CAAAA,OAAAA,CAAAA,CAAAA;oBAErB,IAAI7B,IAAAA,KAASoF,OAAQC,CAAAA,GAAG,EAAE;AACtB5F,wBAAAA,OAAAA,CAAQoG,UAAU,GAAGpG,OAAQoG,CAAAA,UAAU,IAAI;AAAC,4BAAA,OAAA;AAAS,4BAAA,OAAA;AAAS,4BAAA,OAAA;AAAS,4BAAA,OAAA;AAAS,4BAAA,OAAA;AAAS,4BAAA,OAAA;AAAQ,yBAAA,CAAA;qBAC9F,MAAA;AACHpG,wBAAAA,OAAAA,CAAQoG,UAAU,GAAGpG,OAAQoG,CAAAA,UAAU,IAAI;AAAC,4BAAA,OAAA;AAAS,4BAAA,OAAA;AAAS,4BAAA,OAAA;AAAQ,yBAAA,CAAA;AAC1E,qBAAA;oBAEAD,OAAU,GAAA,IAAI1D,OAAmC,CAAA,CAACnC,OAASyC,EAAAA,MAAAA,GAAAA;AACvDsD,wBAAAA,MAAAA,CAAOhB,KAAOxF,EAAAA,SAAAA,EAAWG,OAAS,EAAA,CAACiD,GAAKqD,EAAAA,OAAAA,GAAAA;AACpC,4BAAA,IAAIrD,GAAK,EAAA;gCACLF,MAAOE,CAAAA,GAAAA,CAAAA,CAAAA;AACP,gCAAA,OAAA;AACJ,6BAAA;4BAEA3C,OAAQgG,CAAAA,OAAAA,CAAAA,CAAAA;AACZ,yBAAA,CAAA,CAAA;AACJ,qBAAA,CAAA,CAAA;AACA,oBAAA,MAAA;AACJ,iBAAA;AACA,YAAA,KAAKX,QAAQK,GAAG;AAAE,gBAAA;AACd,oBAAA,MAAM,EAAEzF,IAAI,EAAE0F,MAAM,EAAE,GAAGjG,SAAS,GAAGe,OAAAA,CAAAA;AAErCf,oBAAAA,OAAAA,CAAQoG,UAAU,GAAGpG,OAAQoG,CAAAA,UAAU,IAAI;AAAC,wBAAA,OAAA;AAAS,wBAAA,OAAA;AAAS,wBAAA,OAAA;AAAQ,qBAAA,CAAA;oBAEtED,OAAU,GAAA,IAAI1D,OAAmC,CAAA,CAACnC,OAASyC,EAAAA,MAAAA,GAAAA;AACvDsD,wBAAAA,MAAAA,CAAOhB,KAAOY,EAAAA,MAAAA,EAAQjG,OAAS,EAAA,CAACiD,GAAKqD,EAAAA,OAAAA,GAAAA;AACjC,4BAAA,IAAIrD,GAAK,EAAA;gCACLF,MAAOE,CAAAA,GAAAA,CAAAA,CAAAA;AACP,gCAAA,OAAA;AACJ,6BAAA;4BAEA3C,OAAQgG,CAAAA,OAAAA,CAAAA,CAAAA;AACZ,yBAAA,CAAA,CAAA;AACJ,qBAAA,CAAA,CAAA;AACJ,iBAAA;AACJ,SAAA;AAEAhB,QAAAA,MAAAA,GAAS,MAAMa,OAAAA,CAAAA;AACnB,KAAA,CAAE,OAAO1C,CAAG,EAAA;AACR,QAAA,MAAMgB,sBAAuBhB,CAAAA,CAAAA,CAAAA,CAAAA;AACjC,KAAA;IAEA,IAAI,OAAO6B,WAAW,WAAa,EAAA;AAC/B,QAAA,MAAM,IAAIX,UAAW,CAAA;YAAEK,OAAS,EAAA,eAAA;AAAgB,SAAA,CAAA,CAAA;AACpD,KAAA;IAEA,OAAOM,MAAAA,CAAAA;AACX;;AC7EO,SAASiB,yBAA4BC,KAAQ,EAAA;AAChD,IAAA,IAAI7G,SAAS6G,KAAQ,CAAA,EAAA;QACjB,MAAMC,IAAAA,GAAOpC,MAAOoC,CAAAA,IAAI,CAACD,KAAAA,CAAAA,CAAAA;AACzB,QAAA,IAAK,IAAIE,CAAI,GAAA,CAAA,EAAGA,IAAID,IAAKE,CAAAA,MAAM,EAAED,CAAK,EAAA,CAAA;AAClC,YAAA,MAAMzH,QAAQuH,KAAK,CAACC,IAAI,CAACC,EAAE,CAAC,CAAA;AAC5B,YAAA,IAAIzH,iBAAiB6F,IAAM,EAAA;AACvB0B,gBAAAA,KAAK,CAACC,IAAI,CAACC,EAAE,CAAC,GAAGzH,MAAM2H,WAAW,EAAA,CAAA;AACtC,aAAA;AACJ,SAAA;AACJ,KAAA;IAEA,OAAOJ,KAAAA,CAAAA;AACX,CAAA;AAEO,SAASK,2BAAAA,CACZL,KAA6B,EAC7BM,EAAoB,EAAA;IAEpB,IAAI,OAAON,UAAU,QAAU,EAAA;QAC3B,OAAOA,KAAAA,CAAAA;AACX,KAAA;AAEA,IAAA,OAAOA,KAAMM,CAAAA,EAAAA,CAAAA,CAAAA;AACjB;;ACpBO,eAAeC,uBAAAA,CAClBhG,OAA4B,EAC5BiG,YAAqC,EAAA;IAErC,IAAI,CAACC,SAAe,EAAA,IAAA,CAACC,SAAa,EAAA,EAAA;AAC9B,QAAA,OAAOzE,QAAQnC,OAAO,EAAA,CAAA;AAC1B,KAAA;AAEAS,IAAAA,OAAAA,GAAUwF,wBAAyBxF,CAAAA,OAAAA,CAAAA,CAAAA;IAEnC,MAAMoG,IAAAA,GAAOC,IAAKC,CAAAA,SAAS,CAACtG,OAAAA,CAAAA,CAAAA;AAE5B,IAAA,MAAMuG,MAASC,GAAAA,SAAAA,EAAAA,CAAAA;IACf,MAAMC,QAAAA,GAAWF,OAAOE,QAAQ,EAAA,CAAA;AAChC,IAAA,IAAK,IAAId,CAAI,GAAA,CAAA,EAAGA,IAAIM,YAAaL,CAAAA,MAAM,EAAED,CAAK,EAAA,CAAA;AAC1C,QAAA,MAAM,EAAEe,SAAS,EAAE,GAAGT,YAAY,CAACN,CAAE,CAAA,CAAA;AACrC,QAAA,MAAMgB,YAAaD,SAAY,GAAA,CAAC,EAAEA,SAAU,CAAA,CAAC,CAAC,GAAG,EAAA,CAAA;AAEjD,QAAA,IAAI7F,MAAM8F,SAAYb,GAAAA,2BAAAA,CAA4BG,YAAY,CAACN,CAAAA,CAAE,CAACiB,OAAO,CAAA,CAAA;QACzEH,QAASI,CAAAA,OAAO,CAAChG,GAAKuF,EAAAA,IAAAA,CAAAA,CAAAA;AAEtB,QAAA,IACIpG,OAAQ8G,CAAAA,KAAK,KAAKC,eAAAA,CAAgBC,OAAO,IACzC,OAAOf,YAAY,CAACN,CAAAA,CAAE,CAACiB,OAAO,KAAK,UACrC,EAAA;YACE/F,GAAM8F,GAAAA,SAAAA,GAAYb,2BAA4BG,CAAAA,YAAY,CAACN,CAAAA,CAAE,CAACiB,OAAO,EAAE5G,OAAAA,CAAQrB,IAAI,CAACoH,EAAE,CAAA,CAAA;YACtFU,QAASI,CAAAA,OAAO,CAAChG,GAAKuF,EAAAA,IAAAA,CAAAA,CAAAA;AAC1B,SAAA;AACJ,KAAA;AAEA,IAAA,OAAOK,SAASQ,IAAI,EAAA,CAAA;AACxB;;ACjCA,IAAIC,UAAAA,CAAAA;AAEG,SAASC,gBAAAA,GAAAA;IACZ,IAAI,OAAOD,eAAa,WAAa,EAAA;QACjC,OAAOA,UAAAA,CAAAA;AACX,KAAA;AAEAA,IAAAA,UAAAA,GAAW,IAAIE,OAAoCZ,CAAAA,SAAAA,EAAAA,CAAAA,CAAAA;IAEnD,OAAOU,UAAAA,CAAAA;AACX;;ACPO,SAASG,wBAAAA,CACZrH,OAA4B,EAC5BiG,YAAqC,EAAA;IAErC,IAAI,CAACC,SAAe,EAAA,IAAA,CAACC,SAAa,EAAA,EAAA;AAC9B,QAAA,OAAA;AACJ,KAAA;AAEAnG,IAAAA,OAAAA,GAAUwF,wBAAyBxF,CAAAA,OAAAA,CAAAA,CAAAA;AAEnC,IAAA,IAAK,IAAI2F,CAAI,GAAA,CAAA,EAAGA,IAAIM,YAAaL,CAAAA,MAAM,EAAED,CAAK,EAAA,CAAA;AAC1C,QAAA,IAAI2B,OAAUH,GAAAA,gBAAAA,EAAAA,CAAAA;AACd,QAAA,IAAIlB,YAAY,CAACN,CAAE,CAAA,CAACe,SAAS,EAAE;AAC3BY,YAAAA,OAAAA,GAAUA,QAAQC,EAAE,CAACtB,YAAY,CAACN,CAAAA,CAAE,CAACe,SAAS,CAAA,CAAA;AAClD,SAAA;AAEA,QAAA,IAAIc,WAAW1B,2BAA4BG,CAAAA,YAAY,CAACN,CAAAA,CAAE,CAACiB,OAAO,CAAA,CAAA;AAElE,QAAA,MAAMa,gBAAgBC,wBAAyB1H,CAAAA,OAAAA,CAAQR,IAAI,EAAEQ,QAAQ8G,KAAK,CAAA,CAAA;QAE1EQ,OACKK,CAAAA,EAAE,CAACH,QAAAA,CACJ;;AAECI,SAAAA,IAAI,CAACH,aAAe,EAAA;AACjB,YAAA,GAAGzH,OAAO;YACV6H,IAAM,EAAA;AACFL,gBAAAA,QAAAA;AACJ,aAAA;AACJ,SAAA,CAAA,CAAA;AAEJ,QAAA,IACIxH,OAAQ8G,CAAAA,KAAK,KAAKC,eAAAA,CAAgBC,OAAO,IACzC,OAAOf,YAAY,CAACN,CAAAA,CAAE,CAACiB,OAAO,KAAK,UACrC,EAAA;YACEY,QAAW1B,GAAAA,2BAAAA,CAA4BG,YAAY,CAACN,CAAE,CAAA,CAACiB,OAAO,EAAE5G,OAAAA,CAAQrB,IAAI,CAACoH,EAAE,CAAA,CAAA;YAC/EuB,OACKK,CAAAA,EAAE,CAACH,QAAAA,CACJ;;AAECI,aAAAA,IAAI,CAACH,aAAe,EAAA;AACjB,gBAAA,GAAGzH,OAAO;gBACV6H,IAAM,EAAA;AACFL,oBAAAA,QAAAA;oBACAM,MAAQ9H,EAAAA,OAAAA,CAAQrB,IAAI,CAACoH,EAAE;AAC3B,iBAAA;AACJ,aAAA,CAAA,CAAA;AACR,SAAA;AACJ,KAAA;AACJ;;ACnDO,eAAegC,kBAAAA,CAClB/H,OAA4B,EAC5BiG,YAAqC,EAAA;AAErC,IAAA,MAAMD,wBAAwBhG,OAASiG,EAAAA,YAAAA,CAAAA,CAAAA;AACvCoB,IAAAA,wBAAAA,CAAyBrH,OAASiG,EAAAA,YAAAA,CAAAA,CAAAA;AACtC;;AClBA;;;;;AAKC,IAIM,MAAM+B,UAAAA,CAAAA;IAKTC,KAAQ,GAAA;AACJ,QAAA,OAAO,IAAI,CAAA;AACf,KAAA;IAQAC,IAAO,GAAA;AACH,QAAA,OAAO,IAAI,CAAA;AACf,KAAA;IAQAC,IAAO,GAAA;AACH,QAAA,OAAO,IAAI,CAAA;AACf,KAAA;IAQAC,IAAO,GAAA;AACH,QAAA,OAAO,IAAI,CAAA;AACf,KAAA;IAQAC,OAAU,GAAA;AACN,QAAA,OAAO,IAAI,CAAA;AACf,KAAA;IAQAC,KAAQ,GAAA;AACJ,QAAA,OAAO,IAAI,CAAA;AACf,KAAA;AAGJ;;AC3DA,IAAIpB,UAAAA,CAAAA;AAEG,SAASqB,SAAAA,GAAAA;IACZ,IAAI,OAAOrB,eAAa,WAAa,EAAA;QACjC,OAAOA,UAAAA,CAAAA;AACX,KAAA;AAEAA,IAAAA,UAAAA,GAAW,IAAIc,UAAAA,EAAAA,CAAAA;IAEf,OAAOd,UAAAA,CAAAA;AACX,CAAA;AAEO,SAASsB,UAAUC,MAAc,EAAA;IACpCvB,UAAWuB,GAAAA,MAAAA,CAAAA;AACf;;ACxBA;;;;;AAKC,IAID,IAAIvB,UAAAA,CAAAA;AAEG,SAASwB,aAAAA,GAAAA;AACZ,IAAA,OAAO,CAAC,CAACxB,UAAAA,CAAAA;AACb,CAAA;AAEO,SAASyB,cAAczK,KAAsC,EAAA;IAChEgJ,UAAWhJ,GAAAA,KAAAA,CAAAA;AACf,CAAA;AAEO,SAAS0K,aAAAA,GAAAA;IACZ,IAAI,OAAO1B,eAAa,WAAa,EAAA;QACjC,OAAOA,UAAAA,CAAAA;AACX,KAAA;AAEAA,IAAAA,UAAAA,GAAW,EAAC,CAAA;IAEZ,OAAOA,UAAAA,CAAAA;AACX;;ACfO,SAAS2B,iBAAiB5J,OAA6B,EAAA;IAC1D,IAAI6J,SAAAA,CAAAA;AAEJ7J,IAAAA,OAAAA,GAAUA,WAAW,EAAC,CAAA;IAEtB,IAAI,OAAOA,YAAY,QAAU,EAAA;AAC7B6J,QAAAA,SAAAA,GAAYC,eAAgB9J,CAAAA,OAAAA,CAAAA,CAAAA;KACzB,MAAA,IAAIA,OAAQ+J,CAAAA,gBAAgB,EAAE;QACjCF,SAAYC,GAAAA,eAAAA,CAAgB9J,QAAQ+J,gBAAgB,CAAA,CAAA;KACjD,MAAA;QACH,IAAIC,IAAAA,CAAAA;AACJ,QAAA,IAAIhK,OAAQiK,CAAAA,IAAI,IAAIjK,OAAAA,CAAQkK,QAAQ,EAAE;YAClCF,IAAO,GAAA;gBACHzJ,IAAM,EAAA,OAAA;AACN0J,gBAAAA,IAAAA,EAAMjK,QAAQiK,IAAI;AAClBE,gBAAAA,IAAAA,EAAMnK,QAAQkK,QAAQ;AAC1B,aAAA,CAAA;AACJ,SAAA;AAEAL,QAAAA,SAAAA,GAAYC,eAAgB,CAAA;AACxBM,YAAAA,IAAAA,EAAMpK,QAAQoK,IAAI;AAClBC,YAAAA,IAAAA,EAAMrK,QAAQqK,IAAI;AAClBL,YAAAA,IAAAA;AACAM,YAAAA,MAAAA,EAAQtK,QAAQuK,GAAG;AACnBC,YAAAA,gBAAAA,EAAkBxK,QAAQyK,QAAQ;YAClCC,GAAK,EAAA;gBACDC,kBAAoB,EAAA,KAAA;AACxB,aAAA;AACJ,SAAA,CAAA,CAAA;AACJ,KAAA;IAEAd,SAAUe,CAAAA,EAAE,CAAC,OAAA,EAAS,CAACnH,CAAAA,GAAAA;QACnB6F,SAAYN,EAAAA,CAAAA,KAAK,CAACvF,CAAAA,CAAEuB,OAAO,CAAA,CAAA;AAC/B,KAAA,CAAA,CAAA;IAEA,OAAO6E,SAAAA,CAAAA;AACX;;ACnCA,IAAI5B,QAAAA,CAAAA;AAEG,eAAe4C,aAAAA,GAAAA;IAClB,IAAI,OAAO5C,aAAa,WAAa,EAAA;QACjC,OAAOA,QAAAA,CAAAA;AACX,KAAA;IAEA,IAAIjI,OAAAA,CAAAA;AACJ,IAAA,IAAIE,OAAQ4K,CAAAA,GAAG,CAACC,QAAQ,KAAK,MAAQ,EAAA;AACjC,QAAA,MAAMC,cAAc,MAAMC,iBAAAA,EAAAA,CAAAA;QAE1BjL,OAAU,GAAA;YACNoK,IAAM,EAAA,qBAAA;YACNC,IAAM,EAAA,GAAA;YACNE,GAAK,EAAA,KAAA;AACLN,YAAAA,IAAAA,EAAMe,YAAYf,IAAI;AACtBC,YAAAA,QAAAA,EAAUc,YAAYb,IAAI;AAC9B,SAAA,CAAA;KACG,MAAA;QACHnK,OAAU2J,GAAAA,aAAAA,EAAAA,CAAAA;AACd,KAAA;AAEA1B,IAAAA,QAAAA,GAAW2B,gBAAiB5J,CAAAA,OAAAA,CAAAA,CAAAA;IAE5B,OAAOiI,QAAAA,CAAAA;AACX;;ACtCA;;;;;AAKC,IAEM,SAAS1D,cACZ2G,CAAAA,GAAM,EACNC,IAAO,EAAA;AAEP,IAAA,OAAO9G,OAAOC,SAAS,CAACC,cAAc,CAACC,IAAI,CAAC0G,GAAKC,EAAAA,IAAAA,CAAAA,CAAAA;AACrD;;;;"}
|
|
1
|
+
{"version":3,"file":"index.mjs","names":["compareMethod","hashMethod","isObject","isObject","create","instance"],"sources":["../src/crypto/hash/compare.ts","../src/crypto/hash/hash.ts","../src/crypto/key/asymmetric/constants.ts","../src/crypto/key/base.ts","../src/crypto/key/asymmetric/helpers/wrap.ts","../src/crypto/key/asymmetric/key-usages.ts","../src/crypto/key/asymmetric/normalize.ts","../src/crypto/key/asymmetric/module.ts","../src/crypto/key/asymmetric/check.ts","../src/crypto/key/asymmetric/create.ts","../src/crypto/key/symmetric/constants.ts","../src/crypto/key/symmetric/check.ts","../src/crypto/key/symmetric/key-usages.ts","../src/crypto/key/symmetric/normalize.ts","../src/crypto/key/symmetric/module.ts","../src/crypto/key/symmetric/create.ts","../src/crypto/json-web-token/extract.ts","../src/crypto/json-web-token/utils.ts","../src/crypto/json-web-token/sign/module.ts","../src/crypto/json-web-token/verify/module.ts","../src/domain-event/module.ts","../src/services/cache/adapters/memory.ts","../src/services/redis/check.ts","../src/services/redis/factory.ts","../src/services/cache/adapters/redis.ts","../src/services/cache/helper.ts","../src/services/logger/module.ts","../src/services/logger/singleton.ts","../src/services/vault/singleton.ts","../src/domain-event/utils.ts","../src/domain-event/redis/module.ts","../src/domain-event/socket/module.ts","../src/utils/has-property.ts"],"sourcesContent":["/*\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 { compare as compareMethod } from '@node-rs/bcrypt';\n\nexport async function compare(value: string, hashedValue: string) : Promise<boolean> {\n return compareMethod(value, hashedValue);\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 { hash as hashMethod } from '@node-rs/bcrypt';\n\nexport async function hash(str: string, rounds: number = 10) : Promise<string> {\n return hashMethod(str, rounds);\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 enum CryptoAsymmetricAlgorithm {\n RSA_PSS = 'RSA-PSS',\n RSASSA_PKCS1_V1_5 = 'RSASSA-PKCS1-v1_5',\n RSA_OAEP = 'RSA-OAEP',\n ECDSA = 'ECDSA',\n ECDH = 'ECDH',\n}\n","/*\n * Copyright (c) 2025-2026.\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 { arrayBufferToBase64 } from '@authup/kit';\nimport { subtle } from 'uncrypto';\n\nexport abstract class BaseKey {\n protected key : CryptoKey;\n\n // ----------------------------------------------\n\n constructor(cryptoKey : CryptoKey) {\n this.key = cryptoKey;\n }\n\n // ----------------------------------------------\n\n async toArrayBuffer(): Promise<ArrayBuffer> {\n if (this.key.type === 'private') {\n return subtle.exportKey('pkcs8', this.key);\n }\n\n if (this.key.type === 'public') {\n return subtle.exportKey('spki', this.key);\n }\n\n return subtle.exportKey('raw', this.key);\n }\n\n async toUint8Array(): Promise<Uint8Array> {\n const arrayBuffer = await this.toArrayBuffer();\n return new Uint8Array(arrayBuffer);\n }\n\n async toBase64() : Promise<string> {\n const arrayBuffer = await this.toArrayBuffer();\n return arrayBufferToBase64(arrayBuffer);\n }\n\n async toJWK() : Promise<JsonWebKey> {\n return subtle.exportKey('jwk', this.key);\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\nfunction enc(\n type: 'PRIVATE KEY' | 'PUBLIC KEY',\n input: string,\n) {\n return `-----BEGIN ${type}-----\\n${input}\\n-----END ${type}-----`;\n}\n\nexport function encodePKCS8ToPEM(base64: string) {\n return enc('PRIVATE KEY', base64);\n}\n\nexport function encodeSPKIToPem(input: string) {\n return enc('PUBLIC KEY', input);\n}\n\n// ------------------------------------------------------------\n\nfunction dec(\n type: 'PRIVATE KEY' | 'PUBLIC KEY',\n input: string,\n) {\n input = input.replace(`-----BEGIN ${type}-----\\n`, '');\n\n input = input.replace(`\\n-----END ${type}-----\\n`, '');\n input = input.replace(`-----END ${type}-----\\n`, '');\n input = input.replace(`\\n-----END ${type}-----`, '');\n\n return input;\n}\n\nexport function decodePemToPKCS8(input: string) {\n return dec('PRIVATE KEY', input);\n}\n\nexport function decodePemToSpki(input: string) {\n return dec('PUBLIC KEY', input);\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 { CryptoAsymmetricAlgorithm } from './constants';\n\n/**\n * @see https://nodejs.org/api/webcrypto.html#cryptokeyusages\n */\nexport function getKeyUsagesForAsymmetricAlgorithm(\n name: string,\n format?: Exclude<KeyFormat, 'jwk'>,\n) : KeyUsage[] {\n if (\n name === CryptoAsymmetricAlgorithm.RSA_PSS ||\n name === CryptoAsymmetricAlgorithm.ECDSA ||\n name === CryptoAsymmetricAlgorithm.RSASSA_PKCS1_V1_5\n ) {\n if (format === 'spki') {\n return ['verify'];\n } if (format === 'pkcs8') {\n return ['sign'];\n }\n\n return ['sign', 'verify'];\n }\n\n if (name === CryptoAsymmetricAlgorithm.ECDH) {\n if (format === 'spki') {\n return [];\n }\n\n return [\n 'deriveKey',\n 'deriveBits',\n ];\n }\n\n if (name === CryptoAsymmetricAlgorithm.RSA_OAEP) {\n if (format === 'spki') {\n return ['encrypt'];\n } if (format === 'pkcs8') {\n return ['decrypt'];\n }\n\n return ['encrypt', 'decrypt'];\n }\n\n throw new SyntaxError(`Key usages can not be determined for asymmetric algorithm: ${name}`);\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 { CryptoAsymmetricAlgorithm } from './constants';\nimport type {\n AsymmetricKeyImportOptionsInput,\n AsymmetricKeyPairCreateOptions,\n AsymmetricKeyPairCreateOptionsInput,\n AsymmetricKeyPairImportOptions,\n} from './types';\n\nexport function normalizeAsymmetricKeyPairCreateOptions(\n options: AsymmetricKeyPairCreateOptionsInput,\n) : AsymmetricKeyPairCreateOptions {\n let optionsNormalized : AsymmetricKeyPairCreateOptions;\n switch (options.name) {\n case CryptoAsymmetricAlgorithm.RSASSA_PKCS1_V1_5:\n case CryptoAsymmetricAlgorithm.RSA_PSS:\n case CryptoAsymmetricAlgorithm.RSA_OAEP: {\n optionsNormalized = {\n modulusLength: 2048,\n publicExponent: new Uint8Array([0x01, 0x00, 0x01]),\n hash: 'SHA-256',\n ...options,\n };\n break;\n }\n case CryptoAsymmetricAlgorithm.ECDSA:\n case CryptoAsymmetricAlgorithm.ECDH: {\n optionsNormalized = {\n namedCurve: 'P-256',\n ...options,\n };\n }\n }\n\n return optionsNormalized;\n}\n\nexport function normalizeAsymmetricKeyImportOptions(\n options: AsymmetricKeyImportOptionsInput,\n) : AsymmetricKeyPairImportOptions {\n let optionsNormalized : AsymmetricKeyPairImportOptions;\n switch (options.name) {\n case CryptoAsymmetricAlgorithm.RSASSA_PKCS1_V1_5:\n case CryptoAsymmetricAlgorithm.RSA_PSS:\n case CryptoAsymmetricAlgorithm.RSA_OAEP: {\n optionsNormalized = {\n hash: 'SHA-256',\n ...options,\n };\n break;\n }\n case CryptoAsymmetricAlgorithm.ECDSA:\n case CryptoAsymmetricAlgorithm.ECDH: {\n optionsNormalized = {\n namedCurve: 'P-256',\n ...options,\n };\n }\n }\n\n return optionsNormalized;\n}\n","/*\n * Copyright (c) 2025.\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 { base64ToArrayBuffer } from '@authup/kit';\nimport { JWTAlgorithm } from '@authup/specs';\nimport { subtle } from 'uncrypto';\nimport { BaseKey } from '../base';\nimport { CryptoAsymmetricAlgorithm } from './constants';\nimport type { AsymmetricKeyImportContext } from './types';\nimport {\n decodePemToPKCS8, \n decodePemToSpki, \n encodePKCS8ToPEM, \n encodeSPKIToPem,\n} from './helpers';\nimport { getKeyUsagesForAsymmetricAlgorithm } from './key-usages';\nimport { normalizeAsymmetricKeyImportOptions } from './normalize';\n\nexport class AsymmetricKey extends BaseKey {\n async toPem(): Promise<string> {\n const base64 = await this.toBase64();\n\n if (this.key.type === 'public') {\n return encodeSPKIToPem(base64);\n }\n\n if (this.key.type === 'private') {\n return encodePKCS8ToPEM(base64);\n }\n\n throw new Error(`${this.key.type} can not be converted to pem.`);\n }\n\n // ----------------------------------------------------------------\n\n static async fromPem(ctx: AsymmetricKeyImportContext<string>): Promise<AsymmetricKey> {\n if (ctx.format === 'pkcs8') {\n return AsymmetricKey.fromBase64({\n ...ctx,\n key: decodePemToPKCS8(ctx.key), \n });\n }\n return AsymmetricKey.fromBase64({\n ...ctx,\n key: decodePemToSpki(ctx.key), \n });\n }\n\n static async fromBase64(\n ctx: AsymmetricKeyImportContext<string>,\n ) : Promise<AsymmetricKey> {\n const arrayBuffer = base64ToArrayBuffer(ctx.key);\n\n return AsymmetricKey.fromArrayBuffer({\n ...ctx,\n key: arrayBuffer,\n });\n }\n\n static async fromArrayBuffer(\n ctx: AsymmetricKeyImportContext<ArrayBuffer>,\n ) : Promise<AsymmetricKey> {\n const normalizedOptions = normalizeAsymmetricKeyImportOptions(ctx.options);\n\n const cryptoKey = await subtle.importKey(\n ctx.format,\n ctx.key,\n normalizedOptions,\n true,\n getKeyUsagesForAsymmetricAlgorithm(normalizedOptions.name, ctx.format),\n );\n\n return new AsymmetricKey(cryptoKey);\n }\n\n // ----------------------------------------------------------------\n\n static buildImportOptionsForJWTAlgorithm(alg: `${JWTAlgorithm}`) {\n if (alg === JWTAlgorithm.RS256) {\n return {\n name: CryptoAsymmetricAlgorithm.RSASSA_PKCS1_V1_5,\n hash: 'SHA-256',\n };\n }\n\n if (alg === JWTAlgorithm.RS384) {\n return {\n name: CryptoAsymmetricAlgorithm.RSASSA_PKCS1_V1_5,\n hash: 'SHA-384',\n };\n }\n\n if (alg === JWTAlgorithm.RS512) {\n return {\n name: CryptoAsymmetricAlgorithm.RSASSA_PKCS1_V1_5,\n hash: 'SHA-512',\n };\n }\n\n if (alg === JWTAlgorithm.ES256) {\n return {\n name: CryptoAsymmetricAlgorithm.ECDSA,\n namedCurve: 'P-256',\n };\n }\n\n if (alg === JWTAlgorithm.ES384) {\n return {\n name: CryptoAsymmetricAlgorithm.ECDSA,\n namedCurve: 'P-384',\n };\n }\n\n if (alg === JWTAlgorithm.ES512) {\n return {\n name: CryptoAsymmetricAlgorithm.ECDSA,\n namedCurve: 'P-521',\n };\n }\n\n throw new Error(`Signature algorithm ${alg} is not supported.`);\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 { CryptoAsymmetricAlgorithm } from './constants';\n\nexport function isAsymmetricAlgorithm(input: string) : input is CryptoAsymmetricAlgorithm {\n return (Object.values(CryptoAsymmetricAlgorithm) as string[]).includes(input);\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 { subtle } from 'uncrypto';\nimport { getKeyUsagesForAsymmetricAlgorithm } from './key-usages';\nimport { normalizeAsymmetricKeyPairCreateOptions } from './normalize';\nimport type { AsymmetricKeyPairCreateOptionsInput } from './types';\n\nexport async function createAsymmetricKeyPair(options: AsymmetricKeyPairCreateOptionsInput) : Promise<CryptoKeyPair> {\n const optionsNormalized = normalizeAsymmetricKeyPairCreateOptions(options);\n return subtle.generateKey(\n optionsNormalized,\n true,\n getKeyUsagesForAsymmetricAlgorithm(optionsNormalized.name),\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\nexport enum SymmetricAlgorithm {\n HMAC = 'HMAC',\n AES_CTR = 'AES-CTR',\n AES_CBC = 'AES-CBC',\n AES_GCM = 'AES-GCM',\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 { SymmetricAlgorithm } from './constants';\n\nexport function isSymmetricAlgorithm(input: string) : input is SymmetricAlgorithm {\n return (Object.values(SymmetricAlgorithm) as string[]).includes(input);\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 { SymmetricAlgorithm } from './constants';\n\nexport function getKeyUsagesForSymmetricAlgorithm(name: string) : KeyUsage[] {\n /**\n * @see https://nodejs.org/api/webcrypto.html#cryptokeyusages\n */\n if (name === SymmetricAlgorithm.HMAC) {\n return [\n 'sign',\n 'verify',\n ];\n }\n\n if (\n name === SymmetricAlgorithm.AES_CBC ||\n name === SymmetricAlgorithm.AES_GCM ||\n name === SymmetricAlgorithm.AES_CTR\n ) {\n return [\n 'encrypt',\n 'decrypt',\n ];\n }\n\n throw new SyntaxError(`Key usages can not be determined for symmetric algorithm: ${name}`);\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 { SymmetricAlgorithm } from './constants';\nimport type {\n SymmetricKeyCreateOptions, \n SymmetricKeyCreateOptionsInput, \n SymmetricKeyImportOptions, \n SymmetricKeyImportOptionsInput,\n} from './types';\n\nexport function normalizeSymmetricKeyCreateOptions(\n input: SymmetricKeyCreateOptionsInput,\n) : SymmetricKeyCreateOptions {\n if (input.name === SymmetricAlgorithm.HMAC) {\n return {\n hash: 'SHA-256',\n ...input,\n };\n }\n\n return {\n length: 256,\n name: input.name,\n };\n}\n\nexport function normalizeSymmetricKeyImportOptions(\n input: SymmetricKeyImportOptionsInput,\n) : SymmetricKeyImportOptions {\n if (input.name === SymmetricAlgorithm.HMAC) {\n return {\n hash: 'SHA-256',\n ...input,\n };\n }\n\n return input;\n}\n","/*\n * Copyright (c) 2025.\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 { base64ToArrayBuffer } from '@authup/kit';\nimport { JWTAlgorithm } from '@authup/specs';\nimport { subtle } from 'uncrypto';\nimport { BaseKey } from '../base';\nimport { SymmetricAlgorithm } from './constants';\nimport { getKeyUsagesForSymmetricAlgorithm } from './key-usages';\nimport { normalizeSymmetricKeyImportOptions } from './normalize';\nimport type { SymmetricKeyImportContext, SymmetricKeyImportOptions } from './types';\n\nexport class SymmetricKey extends BaseKey {\n static async fromBase64(\n ctx: SymmetricKeyImportContext<string>,\n ) : Promise<SymmetricKey> {\n const arrayBuffer = base64ToArrayBuffer(ctx.key);\n\n return SymmetricKey.fromArrayBuffer({\n ...ctx,\n key: arrayBuffer,\n });\n }\n\n static async fromArrayBuffer(\n ctx: SymmetricKeyImportContext<ArrayBuffer>,\n ) : Promise<SymmetricKey> {\n const normalizedOptions : SymmetricKeyImportOptions = normalizeSymmetricKeyImportOptions(ctx.options);\n\n const cryptoKey = await subtle.importKey(\n ctx.format,\n ctx.key,\n normalizedOptions,\n true,\n getKeyUsagesForSymmetricAlgorithm(normalizedOptions.name),\n );\n\n return new SymmetricKey(cryptoKey);\n }\n\n static buildImportOptionsForJWTAlgorithm(alg: `${JWTAlgorithm}`) {\n if (alg === JWTAlgorithm.HS256) {\n return {\n name: SymmetricAlgorithm.HMAC,\n hash: 'SHA-256',\n };\n }\n\n if (alg === JWTAlgorithm.HS384) {\n return {\n name: SymmetricAlgorithm.HMAC,\n hash: 'SHA-384',\n };\n }\n\n if (alg === JWTAlgorithm.HS512) {\n return {\n name: SymmetricAlgorithm.HMAC,\n hash: 'SHA-512',\n };\n }\n\n throw new Error(`Signature algorithm ${alg} is not supported.`);\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 { subtle } from 'uncrypto';\nimport { getKeyUsagesForSymmetricAlgorithm } from './key-usages';\nimport { normalizeSymmetricKeyCreateOptions } from './normalize';\nimport type { SymmetricKeyCreateOptionsInput } from './types';\n\nexport async function createSymmetricKey(input: SymmetricKeyCreateOptionsInput) : Promise<CryptoKey> {\n const optionsNormalized = normalizeSymmetricKeyCreateOptions(input);\n\n return subtle.generateKey(\n optionsNormalized,\n true,\n getKeyUsagesForSymmetricAlgorithm(optionsNormalized.name),\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 type { JWTClaims, JWTHeader } from '@authup/specs';\nimport { JWTError } from '@authup/specs';\n\n/**\n * Decode a JWT token with no verification.\n *\n * @param token\n *\n * @throws JWTError\n */\nexport function extractTokenHeader(\n token: string,\n) : JWTHeader {\n const parts = token.split('.');\n if (parts.length !== 3) {\n throw JWTError.invalid();\n }\n\n const [headerBase64] = parts;\n\n try {\n const payload = atob(headerBase64);\n\n return JSON.parse(payload);\n\n /*\n return {\n typ: 'JWT',\n alg: transformInternalToJWTAlgorithm(header.algorithm),\n cty: header.contentType,\n jku: header.jsonKeyUrl,\n kid: header.keyId,\n x5u: header.x5Url,\n x5c: header.x5CertChain,\n x5t: header.x5CertThumbprint,\n 'x5t#S256': header.x5TS256CertThumbprint,\n };\n */\n } catch {\n throw JWTError.headerInvalid('The token header could not be extracted.');\n }\n}\n\n/**\n * @param token\n *\n * @throws JWTError\n */\nexport function extractTokenPayload(\n token: string,\n) : JWTClaims {\n const parts = token.split('.');\n if (parts.length !== 3) {\n throw JWTError.invalid();\n }\n\n const [, payloadBase64] = parts;\n\n try {\n const payload = atob(payloadBase64);\n\n return JSON.parse(payload);\n } catch {\n throw JWTError.payloadInvalid('The token payload could not be extracted.');\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 { JWTAlgorithm, JWTError } from '@authup/specs';\nimport { Algorithm } from '@node-rs/jsonwebtoken';\nimport { isObject } from 'smob';\n\nexport function createErrorForJWTError(e: unknown) : JWTError {\n if (isObject(e)) {\n if (typeof e.name === 'string') {\n switch (e.name) {\n case 'TokenExpiredError': {\n return JWTError.expired();\n }\n case 'NotBeforeError': {\n if (typeof e.date === 'string' || e.date instanceof Date) {\n return JWTError.notActiveBefore(e.date);\n }\n break;\n }\n case 'JsonWebTokenError': {\n if (typeof e.message === 'string') {\n return JWTError.payloadInvalid(e.message);\n }\n\n break;\n }\n }\n }\n\n // @see https://github.com/Keats/jsonwebtoken/blob/master/src/errors.rs\n switch (e.message) {\n case 'ExpiredSignature': {\n return JWTError.expired();\n }\n case 'ImmatureSignature': {\n return JWTError.notActiveBefore();\n }\n case 'InvalidToken':\n case 'InvalidSignature': {\n return JWTError.payloadInvalid();\n }\n }\n }\n\n return new JWTError({\n cause: e as Error,\n message: 'The JWT error could not be determined.',\n });\n}\n\nexport function transformJWTAlgorithmToInternal(algorithm: `${JWTAlgorithm}`) : Algorithm {\n switch (algorithm) {\n case JWTAlgorithm.HS256: {\n return Algorithm.HS256;\n }\n case JWTAlgorithm.HS384: {\n return Algorithm.HS384;\n }\n case JWTAlgorithm.HS512: {\n return Algorithm.HS512;\n }\n case JWTAlgorithm.RS256: {\n return Algorithm.RS256;\n }\n case JWTAlgorithm.RS384: {\n return Algorithm.RS384;\n }\n case JWTAlgorithm.RS512: {\n return Algorithm.RS512;\n }\n case JWTAlgorithm.ES256: {\n return Algorithm.ES256;\n }\n case JWTAlgorithm.ES384: {\n return Algorithm.ES384;\n }\n case JWTAlgorithm.PS256: {\n return Algorithm.PS256;\n }\n case JWTAlgorithm.PS384: {\n return Algorithm.PS384;\n }\n case JWTAlgorithm.PS512: {\n return Algorithm.PS512;\n }\n }\n\n throw new Error(`The algorithm ${algorithm} is not supported.`);\n}\n\nexport function transformInternalToJWTAlgorithm(input: Algorithm) : JWTAlgorithm {\n switch (input) {\n case Algorithm.HS256:\n return JWTAlgorithm.HS256;\n case Algorithm.HS384:\n return JWTAlgorithm.HS384;\n case Algorithm.HS512:\n return JWTAlgorithm.HS512;\n case Algorithm.RS256:\n return JWTAlgorithm.RS256;\n case Algorithm.RS384:\n return JWTAlgorithm.RS384;\n case Algorithm.RS512:\n return JWTAlgorithm.RS512;\n case Algorithm.ES256:\n return JWTAlgorithm.ES256;\n case Algorithm.ES384:\n return JWTAlgorithm.ES384;\n case Algorithm.PS256:\n return JWTAlgorithm.PS256;\n case Algorithm.PS384:\n return JWTAlgorithm.PS384;\n case Algorithm.PS512:\n return JWTAlgorithm.PS512;\n }\n\n throw new SyntaxError(`The algorithm ${input} is not supported.`);\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 { JWKType, JWTError } from '@authup/specs';\nimport type { JWTClaims } from '@authup/specs';\nimport { Algorithm, sign } from '@node-rs/jsonwebtoken';\nimport { AsymmetricKey, SymmetricKey, encodePKCS8ToPEM } from '../../key';\nimport { transformJWTAlgorithmToInternal } from '../utils';\nimport type { TokenSignOptions } from './types';\n\nconst getUtcTimestamp = () => Math.floor(new Date().getTime() / 1000);\n\nexport async function signToken(claims: JWTClaims, context: TokenSignOptions): Promise<string> {\n if (typeof claims.exp !== 'number') {\n claims.exp = getUtcTimestamp() + 3600;\n }\n if (typeof claims.iat !== 'number') {\n claims.iat = getUtcTimestamp();\n }\n\n switch (context.type) {\n case JWKType.RSA:\n case JWKType.EC: {\n let algorithm : Algorithm;\n\n let key : string;\n if (typeof context.key === 'string') {\n key = encodePKCS8ToPEM(context.key);\n } else {\n const keyContainer = new AsymmetricKey(context.key);\n key = await keyContainer.toPem();\n }\n\n if (context.type === JWKType.RSA) {\n algorithm = context.algorithm ?\n transformJWTAlgorithmToInternal(context.algorithm) :\n Algorithm.RS256;\n } else {\n algorithm = context.algorithm ?\n transformJWTAlgorithmToInternal(context.algorithm) :\n Algorithm.ES256;\n }\n\n return sign(claims, key, {\n algorithm,\n keyId: context.keyId,\n });\n }\n case JWKType.OCT: {\n const algorithm : Algorithm = context.algorithm ?\n transformJWTAlgorithmToInternal(context.algorithm) :\n Algorithm.HS256;\n\n let key : string | Uint8Array;\n if (typeof context.key === 'string') {\n key = context.key;\n } else {\n const keyContainer = new SymmetricKey(context.key);\n key = await keyContainer.toUint8Array();\n }\n\n return sign(claims, key, {\n algorithm,\n keyId: context.keyId,\n });\n }\n }\n\n throw new JWTError();\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 { JWKType, JWTError } from '@authup/specs';\nimport type { JWTClaims, OAuth2TokenPayload } from '@authup/specs';\nimport { Algorithm, verify } from '@node-rs/jsonwebtoken';\nimport { AsymmetricKey, SymmetricKey, encodeSPKIToPem } from '../../key';\nimport { createErrorForJWTError, transformJWTAlgorithmToInternal } from '../utils';\nimport type { TokenVerifyOptions } from './types';\n\n/**\n * Verify JWT.\n *\n * @param token\n * @param context\n *\n * @throws OAuth2Error\n */\nexport async function verifyToken(\n token: string,\n context: TokenVerifyOptions,\n) : Promise<OAuth2TokenPayload> {\n let promise : Promise<JWTClaims> | undefined;\n\n let output : JWTClaims | undefined;\n\n try {\n switch (context.type) {\n case JWKType.RSA:\n case JWKType.EC: {\n let algorithms : Algorithm[];\n\n if (context.type === JWKType.RSA) {\n algorithms = context.algorithms ?\n context.algorithms.map((algorithm) => transformJWTAlgorithmToInternal(algorithm)) :\n [\n Algorithm.RS256,\n Algorithm.RS384,\n Algorithm.RS512,\n Algorithm.PS256,\n Algorithm.PS384,\n Algorithm.PS512,\n ];\n } else {\n algorithms = context.algorithms ?\n context.algorithms.map((algorithm) => transformJWTAlgorithmToInternal(algorithm)) :\n [\n Algorithm.ES256,\n Algorithm.ES384,\n ];\n }\n\n let key : string;\n if (typeof context.key === 'string') {\n key = encodeSPKIToPem(context.key);\n } else {\n const keyContainer = new AsymmetricKey(context.key);\n key = await keyContainer.toPem();\n }\n\n promise = verify(token, key, {\n algorithms,\n validateNbf: true,\n });\n break;\n }\n case JWKType.OCT: {\n const algorithms : Algorithm[] = context.algorithms ?\n context.algorithms.map((algorithm) => transformJWTAlgorithmToInternal(algorithm)) :\n [\n Algorithm.HS256,\n Algorithm.HS384,\n Algorithm.HS512,\n ];\n\n let key : string | Uint8Array;\n if (typeof context.key === 'string') {\n key = context.key;\n } else {\n const keyContainer = new SymmetricKey(context.key);\n key = await keyContainer.toUint8Array();\n }\n\n promise = verify(token, key, {\n algorithms,\n validateNbf: true,\n });\n }\n }\n\n if (promise) {\n output = await promise;\n }\n } catch (e) {\n throw createErrorForJWTError(e);\n }\n\n if (!output) {\n throw new JWTError();\n }\n\n return output as OAuth2TokenPayload;\n}\n","/*\n * Copyright (c) 2024-2026.\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 { EventPayload } from '@authup/core-realtime-kit';\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 mount(publisher: IDomainEventPublisher): void {\n this.publishers.add(publisher);\n }\n\n async publish<T extends EventPayload>(\n ctx: DomainEventPublishContext<T>,\n ) : Promise<void> {\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) 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 { TTLCacheOptions } from '@isaacs/ttlcache';\nimport { TTLCache } from '@isaacs/ttlcache';\nimport type { CacheClearOptions, CacheSetOptions, ICache } from '../types';\n\nexport class MemoryCache implements ICache {\n protected instance : TTLCache<string, unknown>;\n\n constructor(options: TTLCacheOptions<string, unknown> = {}) {\n this.instance = new TTLCache<string, unknown>({\n checkAgeOnGet: true,\n ttl: Infinity,\n ...(options || {}),\n });\n }\n\n async pop<T = unknown>(key: string): Promise<T | null> {\n if (this.instance.has(key)) {\n const output = this.instance.get(key);\n this.instance.delete(key);\n return output as T;\n }\n\n return null;\n }\n\n async has(key: string) : Promise<boolean> {\n return this.instance.has(key);\n }\n\n async get<T =unknown>(key: string): Promise<T | null> {\n const output = await this.instance.get(key);\n if (output) {\n return output as T;\n }\n\n return null;\n }\n\n async set(key: string, value: unknown, options: CacheSetOptions): Promise<void> {\n this.instance.set(key, value, { ttl: options.ttl });\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 (const key of keys) {\n this.instance.delete(key);\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 (typeof iterator.value !== 'string') {\n continue;\n }\n\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) 2025.\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 'smob';\nimport type { RedisClient } from './module';\n\nexport function isRedisClient(data: unknown) : data is RedisClient {\n return isObject(data) &&\n typeof data.connect === 'function' &&\n typeof data.disconnect === 'function';\n}\n","/*\n * Copyright (c) 2025.\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 { createClient } from 'redis-extension';\nimport { isRedisClient } from './check';\nimport type { RedisClient, RedisClientOptions } from './module';\n\nexport type RedisClientCreateInput = string | boolean | RedisClient | RedisClientOptions;\n\nexport function createRedisClient(input: RedisClientCreateInput) {\n if (typeof input === 'boolean') {\n return createClient({ connectionString: 'redis://127.0.0.1' });\n }\n\n if (typeof input === 'string') {\n return createClient({ connectionString: input });\n }\n\n if (!isRedisClient(input)) {\n return createClient({ options: input });\n }\n\n return input;\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 type { RedisClient, RedisClientOptions } from '../../redis';\nimport { createRedisClient } from '../../redis';\nimport type { CacheClearOptions, CacheSetOptions, ICache } from '../types';\n\nexport class RedisCache implements ICache {\n protected client : Client;\n\n protected jsonAdapter : JsonAdapter;\n\n constructor(input: string | boolean | RedisClient | RedisClientOptions) {\n this.client = createRedisClient(input);\n this.jsonAdapter = new JsonAdapter(this.client);\n }\n\n async get(key: string): Promise<any> {\n const output = await this.jsonAdapter.get(key);\n if (output) {\n return output;\n }\n\n return null;\n }\n\n async pop<T = unknown>(key: string): Promise<T | null> {\n const raw = await this.client.getdel(key);\n if (!raw) {\n return null;\n }\n\n try {\n return JSON.parse(raw) as T;\n } catch {\n return null;\n }\n }\n\n async has(key: string) : Promise<boolean> {\n const output = await this.get(key);\n\n return !!output;\n }\n\n async set(key: string, value: any, options: CacheSetOptions): Promise<void> {\n await this.jsonAdapter.set(key, value, { milliseconds: options.ttl });\n }\n\n async drop(key: string): Promise<void> {\n await this.jsonAdapter.drop(key);\n }\n\n async dropMany(keys: string[]) : Promise<void> {\n const pipeline = this.client.pipeline();\n\n for (const key of keys) {\n pipeline.del(key);\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 (const key of keys) {\n pipeline.del(key);\n }\n\n await pipeline.exec();\n\n return;\n }\n await this.client.flushdb();\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 { buildRedisKeyPath } from '../redis';\nimport type { CacheKeyBuildOptions } from './types';\n\nexport function buildCacheKey(options: CacheKeyBuildOptions) {\n return buildRedisKeyPath(options);\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 path from 'node:path';\nimport process from 'node:process';\nimport type { LoggerOptions } from 'winston';\nimport { createLogger as create, format, transports } from 'winston';\nimport type { Logger, LoggerCreateContext } from './types';\n\nexport function createNoopLogger() : Logger {\n return create({ silent: true });\n}\n\nexport function createLogger(context: LoggerCreateContext) : Logger {\n let items : LoggerOptions['transports'];\n\n const cwd = context.directory || process.cwd();\n\n if (context.env === 'production') {\n items = [\n new transports.Console({ level: 'info' }),\n new transports.File({\n filename: path.join(cwd, 'http.log'),\n level: 'http',\n maxsize: 10 * 1024 * 1024, // 10MB\n maxFiles: 5,\n }),\n new transports.File({\n filename: path.join(cwd, 'error.log'),\n level: 'warn',\n maxsize: 10 * 1024 * 1024, // 10MB\n maxFiles: 5,\n }),\n ];\n } else {\n items = [\n new transports.Console({ level: 'debug' }),\n ];\n }\n\n // @see https://github.com/winstonjs/triple-beam/blob/master/config/npm.js\n return create({\n format: format.combine(\n format.errors({ stack: true }),\n format.timestamp(),\n format.colorize(),\n format.simple(),\n ),\n transports: items,\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 Factory, singa } from 'singa';\nimport type { Logger } from 'winston';\n\nconst instance = singa<Logger>({ name: 'logger' });\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 { Factory } from 'singa';\nimport { singa } from 'singa';\nimport type { VaultClient } from '@hapic/vault';\n\nconst instance = singa<VaultClient>({ name: 'vault' });\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) 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 { ObjectLiteral } from '@authup/kit';\nimport { isObject } from '@authup/kit';\nimport type { DomainEventChannelName } from './type';\n\nexport function transformDomainEventData<T extends ObjectLiteral>(input: T) : T {\n const keys = Object.keys(input);\n for (const key_ of keys) {\n const key = key_ as keyof T;\n\n const value = input[key] as T[keyof T];\n if (!isObject(value)) {\n continue;\n }\n\n if ((value as Record<string, any>) instanceof Date) {\n input[key] = value.toISOString() as T[keyof T];\n }\n }\n\n return input;\n}\n\nexport function buildDomainEventChannelName(\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 { RedisClientCreateInput } from '../../services';\nimport { createRedisClient } from '../../services';\nimport type { DomainEventPublishContext, IDomainEventPublisher } from '../type';\nimport { buildDomainEventChannelName, transformDomainEventData } from '../utils';\n\nexport class DomainEventRedisPublisher implements IDomainEventPublisher {\n protected driver : Client;\n\n constructor(input: RedisClientCreateInput) {\n this.driver = createRedisClient(input);\n }\n\n async publish(ctx: DomainEventPublishContext) : Promise<void> {\n const data = JSON.stringify(transformDomainEventData(ctx.content));\n\n const pipeline = this.driver.pipeline();\n for (let i = 0; i < ctx.destinations.length; i++) {\n const { namespace } = ctx.destinations[i];\n const keyPrefix = (namespace ? `${namespace}:` : '');\n\n let key = keyPrefix + buildDomainEventChannelName(ctx.destinations[i].channel);\n pipeline.publish(key, data);\n\n if (typeof ctx.destinations[i].channel === 'function') {\n key = keyPrefix + buildDomainEventChannelName(ctx.destinations[i].channel, ctx.content.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 { buildEventFullName } from '@authup/core-realtime-kit';\nimport { Emitter } from '@socket.io/redis-emitter';\nimport type { RedisClientCreateInput } from '../../services';\nimport { createRedisClient } from '../../services';\nimport type { DomainEventPublishContext, IDomainEventPublisher } from '../type';\nimport { buildDomainEventChannelName, transformDomainEventData } from '../utils';\n\nexport class DomainEventSocketPublisher implements IDomainEventPublisher {\n protected driver : Emitter;\n\n constructor(input: RedisClientCreateInput) {\n const client = createRedisClient(input);\n this.driver = new Emitter(client);\n }\n\n async publish(ctx: DomainEventPublishContext) : Promise<void> {\n ctx.content = transformDomainEventData(ctx.content);\n\n for (let i = 0; i < ctx.destinations.length; i++) {\n const destination = ctx.destinations[i];\n\n let emitter : Emitter;\n\n if (destination.namespace) {\n emitter = this.driver.of(destination.namespace);\n } else {\n emitter = this.driver;\n }\n\n let roomName = buildDomainEventChannelName(destination.channel);\n\n const fullEventName = buildEventFullName(ctx.content.type, ctx.content.event);\n\n emitter\n .in(roomName)\n .emit(fullEventName, {\n ...ctx.content,\n meta: { roomName },\n });\n\n if (typeof destination.channel === 'function') {\n roomName = buildDomainEventChannelName(destination.channel, ctx.content.data.id);\n\n emitter\n .in(roomName)\n .emit(fullEventName, {\n ...ctx.content,\n meta: {\n roomName,\n roomId: ctx.content.data.id,\n },\n });\n }\n }\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\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"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/services/cache/adapters/index.ts"],"names":[],"mappings":"AAOA,cAAc,UAAU,CAAC;AACzB,cAAc,SAAS,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { TTLCacheOptions } from '@isaacs/ttlcache';
|
|
2
|
+
import { TTLCache } from '@isaacs/ttlcache';
|
|
3
|
+
import type { CacheClearOptions, CacheSetOptions, ICache } from '../types';
|
|
4
|
+
export declare class MemoryCache implements ICache {
|
|
5
|
+
protected instance: TTLCache<string, unknown>;
|
|
6
|
+
constructor(options?: TTLCacheOptions<string, unknown>);
|
|
7
|
+
pop<T = unknown>(key: string): Promise<T | null>;
|
|
8
|
+
has(key: string): Promise<boolean>;
|
|
9
|
+
get<T = unknown>(key: string): Promise<T | null>;
|
|
10
|
+
set(key: string, value: unknown, options: CacheSetOptions): Promise<void>;
|
|
11
|
+
drop(key: string): Promise<void>;
|
|
12
|
+
dropMany(keys: string[]): Promise<void>;
|
|
13
|
+
clear(options?: CacheClearOptions): Promise<void>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=memory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"memory.d.ts","sourceRoot":"","sources":["../../../../src/services/cache/adapters/memory.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AACxD,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,KAAK,EAAE,iBAAiB,EAAE,eAAe,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAE3E,qBAAa,WAAY,YAAW,MAAM;IACtC,SAAS,CAAC,QAAQ,EAAG,QAAQ,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;gBAEnC,OAAO,GAAE,eAAe,CAAC,MAAM,EAAE,OAAO,CAAM;IAQpD,GAAG,CAAC,CAAC,GAAG,OAAO,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAUhD,GAAG,CAAC,GAAG,EAAE,MAAM,GAAI,OAAO,CAAC,OAAO,CAAC;IAInC,GAAG,CAAC,CAAC,GAAE,OAAO,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAS/C,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;IAIzE,IAAI,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIhC,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,GAAI,OAAO,CAAC,IAAI,CAAC;IAMxC,KAAK,CAAC,OAAO,GAAE,iBAAsB,GAAI,OAAO,CAAC,IAAI,CAAC;CAqB/D"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { Client } from 'redis-extension';
|
|
2
|
+
import { JsonAdapter } from 'redis-extension';
|
|
3
|
+
import type { RedisClient, RedisClientOptions } from '../../redis';
|
|
4
|
+
import type { CacheClearOptions, CacheSetOptions, ICache } from '../types';
|
|
5
|
+
export declare class RedisCache implements ICache {
|
|
6
|
+
protected client: Client;
|
|
7
|
+
protected jsonAdapter: JsonAdapter;
|
|
8
|
+
constructor(input: string | boolean | RedisClient | RedisClientOptions);
|
|
9
|
+
get(key: string): Promise<any>;
|
|
10
|
+
pop<T = unknown>(key: string): Promise<T | null>;
|
|
11
|
+
has(key: string): Promise<boolean>;
|
|
12
|
+
set(key: string, value: any, options: CacheSetOptions): Promise<void>;
|
|
13
|
+
drop(key: string): Promise<void>;
|
|
14
|
+
dropMany(keys: string[]): Promise<void>;
|
|
15
|
+
clear(options?: CacheClearOptions): Promise<void>;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=redis.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redis.d.ts","sourceRoot":"","sources":["../../../../src/services/cache/adapters/redis.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,KAAK,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAEnE,OAAO,KAAK,EAAE,iBAAiB,EAAE,eAAe,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAE3E,qBAAa,UAAW,YAAW,MAAM;IACrC,SAAS,CAAC,MAAM,EAAG,MAAM,CAAC;IAE1B,SAAS,CAAC,WAAW,EAAG,WAAW,CAAC;gBAExB,KAAK,EAAE,MAAM,GAAG,OAAO,GAAG,WAAW,GAAG,kBAAkB;IAKhE,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IAS9B,GAAG,CAAC,CAAC,GAAG,OAAO,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAahD,GAAG,CAAC,GAAG,EAAE,MAAM,GAAI,OAAO,CAAC,OAAO,CAAC;IAMnC,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;IAIrE,IAAI,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIhC,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,GAAI,OAAO,CAAC,IAAI,CAAC;IAUxC,KAAK,CAAC,OAAO,GAAE,iBAAsB,GAAI,OAAO,CAAC,IAAI,CAAC;CAe/D"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helper.d.ts","sourceRoot":"","sources":["../../../src/services/cache/helper.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAC;AAEpD,wBAAgB,aAAa,CAAC,OAAO,EAAE,oBAAoB,UAE1D"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/cache/index.ts"],"names":[],"mappings":"AAOA,cAAc,YAAY,CAAC;AAC3B,cAAc,UAAU,CAAC;AACzB,cAAc,SAAS,CAAC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export type CacheKeyBuildOptions = {
|
|
2
|
+
key: string;
|
|
3
|
+
prefix?: string;
|
|
4
|
+
suffix?: string;
|
|
5
|
+
};
|
|
6
|
+
export type CacheSetOptions = {
|
|
7
|
+
/**
|
|
8
|
+
* Time to live in milliseconds (ms).
|
|
9
|
+
*/
|
|
10
|
+
ttl?: number;
|
|
11
|
+
};
|
|
12
|
+
export type CacheClearOptions = {
|
|
13
|
+
prefix?: string;
|
|
14
|
+
suffix?: string;
|
|
15
|
+
};
|
|
16
|
+
export interface ICache {
|
|
17
|
+
set(key: string, value: any, options?: CacheSetOptions): Promise<void>;
|
|
18
|
+
has(key: string): Promise<boolean>;
|
|
19
|
+
get<T = unknown>(key: string): Promise<T | null>;
|
|
20
|
+
pop<T = unknown>(key: string): Promise<T | null>;
|
|
21
|
+
drop(key: string): Promise<void>;
|
|
22
|
+
dropMany(keys: string[]): Promise<void>;
|
|
23
|
+
clear(options?: CacheClearOptions): Promise<void>;
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/services/cache/types.ts"],"names":[],"mappings":"AAOA,MAAM,MAAM,oBAAoB,GAAG;IAC/B,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAA;CAClB,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAC1B;;OAEG;IACH,GAAG,CAAC,EAAE,MAAM,CAAA;CACf,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC5B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAA;CAClB,CAAC;AAEF,MAAM,WAAW,MAAM;IACnB,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,OAAO,CAAC,EAAE,eAAe,GAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAExE,GAAG,CAAC,GAAG,EAAE,MAAM,GAAI,OAAO,CAAC,OAAO,CAAC,CAAC;IAEpC,GAAG,CAAC,CAAC,GAAG,OAAO,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;IAEjD,GAAG,CAAC,CAAC,GAAG,OAAO,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;IAEjD,IAAI,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEjC,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAExC,KAAK,CAAC,OAAO,CAAC,EAAE,iBAAiB,GAAI,OAAO,CAAC,IAAI,CAAC,CAAC;CACtD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/services/index.ts"],"names":[],"mappings":"AAOA,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC;AACzB,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/logger/index.ts"],"names":[],"mappings":"AAOA,cAAc,UAAU,CAAC;AACzB,cAAc,aAAa,CAAC;AAC5B,cAAc,SAAS,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"module.d.ts","sourceRoot":"","sources":["../../../src/services/logger/module.ts"],"names":[],"mappings":"AAWA,OAAO,KAAK,EAAE,MAAM,EAAE,mBAAmB,EAAE,MAAM,SAAS,CAAC;AAE3D,wBAAgB,gBAAgB,IAAK,MAAM,CAE1C;AAED,wBAAgB,YAAY,CAAC,OAAO,EAAE,mBAAmB,GAAI,MAAM,CAqClE"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { type Factory } from 'singa';
|
|
2
|
+
import type { Logger } from 'winston';
|
|
3
|
+
export declare function setLoggerFactory(factory: Factory<Logger>): void;
|
|
4
|
+
export declare function isLoggerUsable(): boolean;
|
|
5
|
+
export declare function setLogger(input: Logger): void;
|
|
6
|
+
export declare function useLogger(): Logger;
|
|
7
|
+
//# sourceMappingURL=singleton.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"singleton.d.ts","sourceRoot":"","sources":["../../../src/services/logger/singleton.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,KAAK,OAAO,EAAS,MAAM,OAAO,CAAC;AAC5C,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAItC,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,OAAO,CAAC,MAAM,CAAC,QAExD;AAED,wBAAgB,cAAc,YAE7B;AAED,wBAAgB,SAAS,CAAC,KAAK,EAAE,MAAM,QAEtC;AAED,wBAAgB,SAAS,WAExB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/services/logger/types.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAEjC,OAAO,EAAE,MAAM,EAAE,CAAC;AAElB,MAAM,MAAM,mBAAmB,GAAG;IAC9B,GAAG,EAAE,MAAM,CAAA;IACX,SAAS,CAAC,EAAE,MAAM,CAAA;CACrB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"check.d.ts","sourceRoot":"","sources":["../../../src/services/redis/check.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAE5C,wBAAgB,aAAa,CAAC,IAAI,EAAE,OAAO,GAAI,IAAI,IAAI,WAAW,CAIjE"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { RedisClient, RedisClientOptions } from './module';
|
|
2
|
+
export type RedisClientCreateInput = string | boolean | RedisClient | RedisClientOptions;
|
|
3
|
+
export declare function createRedisClient(input: RedisClientCreateInput): RedisClient;
|
|
4
|
+
//# sourceMappingURL=factory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../../src/services/redis/factory.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAEhE,MAAM,MAAM,sBAAsB,GAAG,MAAM,GAAG,OAAO,GAAG,WAAW,GAAG,kBAAkB,CAAC;AAEzF,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,sBAAsB,eAc9D"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/redis/index.ts"],"names":[],"mappings":"AAOA,cAAc,UAAU,CAAC;AACzB,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { Client as RedisClient, JsonAdapter as RedisJsonAdapter, Watcher as RedisWatcher, buildKeyPath as buildRedisKeyPath, escapeKey as escapeRedisKey, parseKeyPath as parseRedisKeyPath } from 'redis-extension';
|
|
2
|
+
import type { ClientOptions as RedisClientOptions } from 'redis-extension';
|
|
3
|
+
export type { RedisClientOptions };
|
|
4
|
+
export { RedisClient, RedisJsonAdapter, RedisWatcher, escapeRedisKey, buildRedisKeyPath, parseRedisKeyPath, };
|
|
5
|
+
//# sourceMappingURL=module.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"module.d.ts","sourceRoot":"","sources":["../../../src/services/redis/module.ts"],"names":[],"mappings":"AAOA,OAAO,EACH,MAAM,IAAI,WAAW,EACrB,WAAW,IAAI,gBAAgB,EAC/B,OAAO,IAAI,YAAY,EACvB,YAAY,IAAI,iBAAiB,EAEjC,SAAS,IAAI,cAAc,EAC3B,YAAY,IAAI,iBAAiB,EACpC,MAAM,iBAAiB,CAAC;AAEzB,OAAO,KAAK,EAAE,aAAa,IAAI,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAE3E,YAAY,EAAE,kBAAkB,EAAE,CAAC;AAEnC,OAAO,EACH,WAAW,EACX,gBAAgB,EAChB,YAAY,EAEZ,cAAc,EACd,iBAAiB,EACjB,iBAAiB,GACpB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/vault/index.ts"],"names":[],"mappings":"AAOA,cAAc,UAAU,CAAC;AACzB,cAAc,aAAa,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"module.d.ts","sourceRoot":"","sources":["../../../src/services/vault/module.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,WAAW,EAAE,YAAY,IAAI,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAE9E,OAAO,EACH,WAAW,EACX,iBAAiB,GACpB,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { Factory } from 'singa';
|
|
2
|
+
import type { VaultClient } from '@hapic/vault';
|
|
3
|
+
export declare function setVaultFactory(factory: Factory<VaultClient>): void;
|
|
4
|
+
export declare function isVaultClientUsable(): boolean;
|
|
5
|
+
export declare function useVaultClient(): VaultClient;
|
|
6
|
+
//# sourceMappingURL=singleton.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"singleton.d.ts","sourceRoot":"","sources":["../../../src/services/vault/singleton.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAErC,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAIhD,wBAAgB,eAAe,CAAC,OAAO,EAAE,OAAO,CAAC,WAAW,CAAC,QAE5D;AAED,wBAAgB,mBAAmB,YAElC;AAED,wBAAgB,cAAc,gBAE7B"}
|