apeframework 0.0.0-dev.20 → 0.0.0-dev.22
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/{cipher → dist/cipher}/Algorithm.js +2 -4
- package/dist/cipher/Cipher.js +32 -0
- package/dist/cipher/errors/DecryptError.js +7 -0
- package/dist/cipher/errors/SecretLengthError.js +7 -0
- package/dist/cipher/validateSecretLength.js +13 -0
- package/dist/cli/Args.js +1 -0
- package/dist/cli/Command.js +1 -0
- package/dist/cli/getArgs.js +5 -0
- package/{cli → dist/cli}/parseArgs.js +3 -9
- package/dist/cli/utils/exit.js +4 -0
- package/dist/cli/utils/formatList.js +7 -0
- package/{cli → dist/cli}/utils/formatTable.js +3 -6
- package/dist/cli/utils/formatText.js +5 -0
- package/dist/cli/utils/print.js +4 -0
- package/dist/cli/utils/printLn.js +5 -0
- package/dist/config/Config.js +1 -0
- package/dist/config/Properties.js +1 -0
- package/dist/config/errors/FileReadError.js +7 -0
- package/dist/config/errors/PropertyNameError.js +7 -0
- package/dist/config/errors/PropertyParseError.js +7 -0
- package/dist/config/getConfig.js +18 -0
- package/{config → dist/config}/getPropertyEnvVar.js +1 -4
- package/{config → dist/config}/parseProperty.js +3 -6
- package/dist/config/readFile.js +25 -0
- package/dist/config/validatePropertyName.js +8 -0
- package/dist/env/Env.js +1 -0
- package/dist/env/errors/FileReadError.js +7 -0
- package/dist/env/getEnv.js +12 -0
- package/dist/env/readFile.js +18 -0
- package/{error → dist/error}/BaseError.js +1 -4
- package/dist/jwt/Algorithm.js +7 -0
- package/{jwt → dist/jwt}/Jwt.js +6 -9
- package/dist/jwt/Payload.js +1 -0
- package/dist/jwt/errors/SecretLengthError.js +7 -0
- package/dist/jwt/validateSecretLength.js +13 -0
- package/{logger → dist/logger}/Level.js +2 -4
- package/dist/logger/Logger.js +3 -0
- package/{logger → dist/logger}/Severity.js +2 -4
- package/{logger → dist/logger}/adapters/file/FileLogger.js +11 -17
- package/dist/logger/adapters/file/errors/FileInitError.js +7 -0
- package/dist/logger/adapters/file/initFile.js +14 -0
- package/dist/logger/adapters/noop/NoopLogger.js +11 -0
- package/{logger → dist/logger}/adapters/stdio/StdioLogger.js +11 -17
- package/dist/mailer/Address.js +1 -0
- package/dist/mailer/Attachment.js +1 -0
- package/dist/mailer/Event.js +1 -0
- package/dist/mailer/List.js +1 -0
- package/dist/mailer/Location.js +1 -0
- package/dist/mailer/Mail.js +1 -0
- package/dist/mailer/Mailer.js +47 -0
- package/dist/mailer/Method.js +6 -0
- package/dist/mailer/adapters/noop/NoopMailer.js +9 -0
- package/dist/mailer/adapters/smtp/SmtpMailer.js +54 -0
- package/{mailer → dist/mailer}/adapters/smtp/getAddress.js +1 -4
- package/dist/mailer/adapters/smtp/getAddresses.js +11 -0
- package/{mailer → dist/mailer}/adapters/smtp/getAttachments.js +1 -4
- package/dist/mailer/errors/AddressEmailError.js +7 -0
- package/dist/mailer/errors/EventAttachmentUrlError.js +7 -0
- package/dist/mailer/errors/EventGeolocationError.js +7 -0
- package/dist/mailer/errors/EventUrlError.js +7 -0
- package/dist/mailer/errors/ListUrlError.js +7 -0
- package/{mailer → dist/mailer}/getIcalendar.js +3 -6
- package/dist/mailer/validateAddressEmail.js +8 -0
- package/dist/mailer/validateEventAttachmentUrl.js +8 -0
- package/dist/mailer/validateEventGeolocation.js +8 -0
- package/dist/mailer/validateEventUrl.js +8 -0
- package/dist/mailer/validateListUrl.js +8 -0
- package/dist/parser/Parser.js +1 -0
- package/dist/parser/errors/ParseError.js +7 -0
- package/dist/parser/factories/enum/createEnumParser.js +10 -0
- package/dist/parser/factories/unit/Unit.js +1 -0
- package/{parser → dist/parser}/factories/unit/createUnitParser.js +8 -11
- package/{parser → dist/parser}/parseBoolean.js +3 -6
- package/{parser → dist/parser}/parseBytes.js +3 -6
- package/dist/parser/parseInteger.js +16 -0
- package/{parser → dist/parser}/parseMilliseconds.js +3 -6
- package/dist/parser/parseNumber.js +15 -0
- package/dist/parser/parseString.js +11 -0
- package/dist/pwd/Pwd.js +16 -0
- package/dist/pwd/errors/HashRoundsError.js +7 -0
- package/dist/pwd/validateHashRounds.js +7 -0
- package/dist/server/ErrorHandler.js +1 -0
- package/dist/server/Format.js +1 -0
- package/dist/server/Handler.js +1 -0
- package/{server → dist/server}/Method.js +2 -4
- package/dist/server/OpenApiFormat.js +6 -0
- package/dist/server/Route.js +1 -0
- package/dist/server/Schema.js +1 -0
- package/{server → dist/server}/Server.js +15 -21
- package/dist/server/getAjv.js +19 -0
- package/dist/tls/Tls.js +1 -0
- package/dist/tls/errors/FileReadError.js +7 -0
- package/dist/tls/getTls.js +14 -0
- package/dist/tls/readFile.js +14 -0
- package/dist/utils/getRandomHexString.js +5 -0
- package/dist/utils/getTimestamp.js +4 -0
- package/dist/utils/isValidEmail.js +5 -0
- package/{utils → dist/utils}/isValidGeolocation.js +1 -4
- package/dist/utils/isValidHexString.js +5 -0
- package/dist/utils/isValidIsoDate.js +5 -0
- package/dist/utils/isValidJwtToken.js +5 -0
- package/{utils → dist/utils}/isValidUrl.js +1 -4
- package/{utils → dist/utils}/isValidUuid.js +1 -4
- package/{utils → dist/utils}/wait.js +1 -4
- package/package.json +631 -7
- package/cipher/Algorithm.ts +0 -9
- package/cipher/Cipher.js +0 -38
- package/cipher/Cipher.ts +0 -46
- package/cipher/errors/DecryptError.js +0 -10
- package/cipher/errors/DecryptError.ts +0 -11
- package/cipher/errors/SecretLengthError.js +0 -10
- package/cipher/errors/SecretLengthError.ts +0 -11
- package/cipher/validateSecretLength.js +0 -16
- package/cipher/validateSecretLength.ts +0 -18
- package/cli/Args.js +0 -2
- package/cli/Args.ts +0 -8
- package/cli/Command.js +0 -2
- package/cli/Command.ts +0 -7
- package/cli/getArgs.js +0 -8
- package/cli/getArgs.ts +0 -10
- package/cli/parseArgs.ts +0 -34
- package/cli/utils/exit.js +0 -7
- package/cli/utils/exit.ts +0 -7
- package/cli/utils/formatList.js +0 -10
- package/cli/utils/formatList.ts +0 -11
- package/cli/utils/formatTable.ts +0 -25
- package/cli/utils/formatText.js +0 -8
- package/cli/utils/formatText.ts +0 -9
- package/cli/utils/print.js +0 -7
- package/cli/utils/print.ts +0 -7
- package/cli/utils/printLn.js +0 -8
- package/cli/utils/printLn.ts +0 -9
- package/config/Config.js +0 -2
- package/config/Config.ts +0 -5
- package/config/Properties.js +0 -2
- package/config/Properties.ts +0 -12
- package/config/errors/FileReadError.js +0 -10
- package/config/errors/FileReadError.ts +0 -11
- package/config/errors/PropertyNameError.js +0 -10
- package/config/errors/PropertyNameError.ts +0 -11
- package/config/errors/PropertyParseError.js +0 -10
- package/config/errors/PropertyParseError.ts +0 -11
- package/config/getConfig.js +0 -21
- package/config/getConfig.ts +0 -47
- package/config/getPropertyEnvVar.ts +0 -15
- package/config/parseProperty.ts +0 -47
- package/config/readFile.js +0 -31
- package/config/readFile.ts +0 -34
- package/config/validatePropertyName.js +0 -11
- package/config/validatePropertyName.ts +0 -13
- package/env/Env.js +0 -2
- package/env/Env.ts +0 -5
- package/env/errors/FileReadError.js +0 -10
- package/env/errors/FileReadError.ts +0 -11
- package/env/getEnv.js +0 -15
- package/env/getEnv.ts +0 -24
- package/env/readFile.js +0 -24
- package/env/readFile.ts +0 -24
- package/error/BaseError.ts +0 -12
- package/jwt/Algorithm.js +0 -9
- package/jwt/Algorithm.ts +0 -9
- package/jwt/Jwt.ts +0 -49
- package/jwt/Payload.js +0 -2
- package/jwt/Payload.ts +0 -14
- package/jwt/errors/SecretLengthError.js +0 -10
- package/jwt/errors/SecretLengthError.ts +0 -11
- package/jwt/validateSecretLength.js +0 -16
- package/jwt/validateSecretLength.ts +0 -18
- package/logger/Level.ts +0 -13
- package/logger/Logger.js +0 -6
- package/logger/Logger.ts +0 -19
- package/logger/Severity.ts +0 -12
- package/logger/adapters/file/FileLogger.ts +0 -87
- package/logger/adapters/file/errors/FileInitError.js +0 -10
- package/logger/adapters/file/errors/FileInitError.ts +0 -11
- package/logger/adapters/file/initFile.js +0 -20
- package/logger/adapters/file/initFile.ts +0 -18
- package/logger/adapters/noop/NoopLogger.js +0 -14
- package/logger/adapters/noop/NoopLogger.ts +0 -21
- package/logger/adapters/stdio/StdioLogger.ts +0 -89
- package/mailer/Address.js +0 -2
- package/mailer/Address.ts +0 -8
- package/mailer/Attachment.js +0 -2
- package/mailer/Attachment.ts +0 -11
- package/mailer/Event.js +0 -2
- package/mailer/Event.ts +0 -20
- package/mailer/List.js +0 -2
- package/mailer/List.ts +0 -10
- package/mailer/Location.js +0 -2
- package/mailer/Location.ts +0 -12
- package/mailer/Mail.js +0 -2
- package/mailer/Mail.ts +0 -23
- package/mailer/Mailer.js +0 -50
- package/mailer/Mailer.ts +0 -69
- package/mailer/Method.js +0 -8
- package/mailer/Method.ts +0 -8
- package/mailer/adapters/noop/NoopMailer.js +0 -12
- package/mailer/adapters/noop/NoopMailer.ts +0 -15
- package/mailer/adapters/smtp/SmtpMailer.js +0 -60
- package/mailer/adapters/smtp/SmtpMailer.ts +0 -74
- package/mailer/adapters/smtp/getAddress.ts +0 -15
- package/mailer/adapters/smtp/getAddresses.js +0 -14
- package/mailer/adapters/smtp/getAddresses.ts +0 -17
- package/mailer/adapters/smtp/getAttachments.ts +0 -20
- package/mailer/errors/AddressEmailError.js +0 -10
- package/mailer/errors/AddressEmailError.ts +0 -11
- package/mailer/errors/EventAttachmentUrlError.js +0 -10
- package/mailer/errors/EventAttachmentUrlError.ts +0 -11
- package/mailer/errors/EventGeolocationError.js +0 -10
- package/mailer/errors/EventGeolocationError.ts +0 -11
- package/mailer/errors/EventUrlError.js +0 -10
- package/mailer/errors/EventUrlError.ts +0 -11
- package/mailer/errors/ListUrlError.js +0 -10
- package/mailer/errors/ListUrlError.ts +0 -11
- package/mailer/getIcalendar.ts +0 -39
- package/mailer/validateAddressEmail.js +0 -11
- package/mailer/validateAddressEmail.ts +0 -12
- package/mailer/validateEventAttachmentUrl.js +0 -11
- package/mailer/validateEventAttachmentUrl.ts +0 -12
- package/mailer/validateEventGeolocation.js +0 -11
- package/mailer/validateEventGeolocation.ts +0 -15
- package/mailer/validateEventUrl.js +0 -11
- package/mailer/validateEventUrl.ts +0 -12
- package/mailer/validateListUrl.js +0 -11
- package/mailer/validateListUrl.ts +0 -12
- package/parser/Parser.js +0 -2
- package/parser/Parser.ts +0 -5
- package/parser/errors/ParseError.js +0 -10
- package/parser/errors/ParseError.ts +0 -11
- package/parser/factories/enum/createEnumParser.js +0 -13
- package/parser/factories/enum/createEnumParser.ts +0 -21
- package/parser/factories/unit/Unit.js +0 -2
- package/parser/factories/unit/Unit.ts +0 -8
- package/parser/factories/unit/createUnitParser.ts +0 -50
- package/parser/parseBoolean.ts +0 -33
- package/parser/parseBytes.ts +0 -55
- package/parser/parseInteger.js +0 -19
- package/parser/parseInteger.ts +0 -23
- package/parser/parseMilliseconds.ts +0 -31
- package/parser/parseNumber.js +0 -18
- package/parser/parseNumber.ts +0 -22
- package/parser/parseString.js +0 -14
- package/parser/parseString.ts +0 -16
- package/pwd/Pwd.js +0 -22
- package/pwd/Pwd.ts +0 -31
- package/pwd/errors/HashRoundsError.js +0 -10
- package/pwd/errors/HashRoundsError.ts +0 -11
- package/pwd/validateHashRounds.js +0 -10
- package/pwd/validateHashRounds.ts +0 -11
- package/server/ErrorHandler.js +0 -2
- package/server/ErrorHandler.ts +0 -11
- package/server/Format.js +0 -2
- package/server/Format.ts +0 -15
- package/server/Handler.js +0 -2
- package/server/Handler.ts +0 -10
- package/server/Method.ts +0 -11
- package/server/OpenApiFormat.js +0 -8
- package/server/OpenApiFormat.ts +0 -8
- package/server/Route.js +0 -2
- package/server/Route.ts +0 -16
- package/server/Schema.js +0 -2
- package/server/Schema.ts +0 -13
- package/server/Server.ts +0 -134
- package/server/getAjv.js +0 -25
- package/server/getAjv.ts +0 -26
- package/tls/Tls.js +0 -2
- package/tls/Tls.ts +0 -10
- package/tls/errors/FileReadError.js +0 -10
- package/tls/errors/FileReadError.ts +0 -11
- package/tls/getTls.js +0 -17
- package/tls/getTls.ts +0 -24
- package/tls/readFile.js +0 -20
- package/tls/readFile.ts +0 -18
- package/utils/getRandomHexString.js +0 -8
- package/utils/getRandomHexString.ts +0 -9
- package/utils/getTimestamp.js +0 -7
- package/utils/getTimestamp.ts +0 -7
- package/utils/isValidEmail.js +0 -8
- package/utils/isValidEmail.ts +0 -9
- package/utils/isValidGeolocation.ts +0 -10
- package/utils/isValidHexString.js +0 -8
- package/utils/isValidHexString.ts +0 -9
- package/utils/isValidIsoDate.js +0 -8
- package/utils/isValidIsoDate.ts +0 -9
- package/utils/isValidJwtToken.js +0 -8
- package/utils/isValidJwtToken.ts +0 -9
- package/utils/isValidUrl.ts +0 -21
- package/utils/isValidUuid.ts +0 -10
- package/utils/wait.ts +0 -9
- /package/{cipher → dist/cipher}/Algorithm.d.ts +0 -0
- /package/{cipher → dist/cipher}/Cipher.d.ts +0 -0
- /package/{cipher → dist/cipher}/errors/DecryptError.d.ts +0 -0
- /package/{cipher → dist/cipher}/errors/SecretLengthError.d.ts +0 -0
- /package/{cipher → dist/cipher}/validateSecretLength.d.ts +0 -0
- /package/{cli → dist/cli}/Args.d.ts +0 -0
- /package/{cli → dist/cli}/Command.d.ts +0 -0
- /package/{cli → dist/cli}/getArgs.d.ts +0 -0
- /package/{cli → dist/cli}/parseArgs.d.ts +0 -0
- /package/{cli → dist/cli}/utils/exit.d.ts +0 -0
- /package/{cli → dist/cli}/utils/formatList.d.ts +0 -0
- /package/{cli → dist/cli}/utils/formatTable.d.ts +0 -0
- /package/{cli → dist/cli}/utils/formatText.d.ts +0 -0
- /package/{cli → dist/cli}/utils/print.d.ts +0 -0
- /package/{cli → dist/cli}/utils/printLn.d.ts +0 -0
- /package/{config → dist/config}/Config.d.ts +0 -0
- /package/{config → dist/config}/Properties.d.ts +0 -0
- /package/{config → dist/config}/errors/FileReadError.d.ts +0 -0
- /package/{config → dist/config}/errors/PropertyNameError.d.ts +0 -0
- /package/{config → dist/config}/errors/PropertyParseError.d.ts +0 -0
- /package/{config → dist/config}/getConfig.d.ts +0 -0
- /package/{config → dist/config}/getPropertyEnvVar.d.ts +0 -0
- /package/{config → dist/config}/parseProperty.d.ts +0 -0
- /package/{config → dist/config}/readFile.d.ts +0 -0
- /package/{config → dist/config}/validatePropertyName.d.ts +0 -0
- /package/{env → dist/env}/Env.d.ts +0 -0
- /package/{env → dist/env}/errors/FileReadError.d.ts +0 -0
- /package/{env → dist/env}/getEnv.d.ts +0 -0
- /package/{env → dist/env}/readFile.d.ts +0 -0
- /package/{error → dist/error}/BaseError.d.ts +0 -0
- /package/{jwt → dist/jwt}/Algorithm.d.ts +0 -0
- /package/{jwt → dist/jwt}/Jwt.d.ts +0 -0
- /package/{jwt → dist/jwt}/Payload.d.ts +0 -0
- /package/{jwt → dist/jwt}/errors/SecretLengthError.d.ts +0 -0
- /package/{jwt → dist/jwt}/validateSecretLength.d.ts +0 -0
- /package/{logger → dist/logger}/Level.d.ts +0 -0
- /package/{logger → dist/logger}/Logger.d.ts +0 -0
- /package/{logger → dist/logger}/Severity.d.ts +0 -0
- /package/{logger → dist/logger}/adapters/file/FileLogger.d.ts +0 -0
- /package/{logger → dist/logger}/adapters/file/errors/FileInitError.d.ts +0 -0
- /package/{logger → dist/logger}/adapters/file/initFile.d.ts +0 -0
- /package/{logger → dist/logger}/adapters/noop/NoopLogger.d.ts +0 -0
- /package/{logger → dist/logger}/adapters/stdio/StdioLogger.d.ts +0 -0
- /package/{mailer → dist/mailer}/Address.d.ts +0 -0
- /package/{mailer → dist/mailer}/Attachment.d.ts +0 -0
- /package/{mailer → dist/mailer}/Event.d.ts +0 -0
- /package/{mailer → dist/mailer}/List.d.ts +0 -0
- /package/{mailer → dist/mailer}/Location.d.ts +0 -0
- /package/{mailer → dist/mailer}/Mail.d.ts +0 -0
- /package/{mailer → dist/mailer}/Mailer.d.ts +0 -0
- /package/{mailer → dist/mailer}/Method.d.ts +0 -0
- /package/{mailer → dist/mailer}/adapters/noop/NoopMailer.d.ts +0 -0
- /package/{mailer → dist/mailer}/adapters/smtp/SmtpMailer.d.ts +0 -0
- /package/{mailer → dist/mailer}/adapters/smtp/getAddress.d.ts +0 -0
- /package/{mailer → dist/mailer}/adapters/smtp/getAddresses.d.ts +0 -0
- /package/{mailer → dist/mailer}/adapters/smtp/getAttachments.d.ts +0 -0
- /package/{mailer → dist/mailer}/errors/AddressEmailError.d.ts +0 -0
- /package/{mailer → dist/mailer}/errors/EventAttachmentUrlError.d.ts +0 -0
- /package/{mailer → dist/mailer}/errors/EventGeolocationError.d.ts +0 -0
- /package/{mailer → dist/mailer}/errors/EventUrlError.d.ts +0 -0
- /package/{mailer → dist/mailer}/errors/ListUrlError.d.ts +0 -0
- /package/{mailer → dist/mailer}/getIcalendar.d.ts +0 -0
- /package/{mailer → dist/mailer}/validateAddressEmail.d.ts +0 -0
- /package/{mailer → dist/mailer}/validateEventAttachmentUrl.d.ts +0 -0
- /package/{mailer → dist/mailer}/validateEventGeolocation.d.ts +0 -0
- /package/{mailer → dist/mailer}/validateEventUrl.d.ts +0 -0
- /package/{mailer → dist/mailer}/validateListUrl.d.ts +0 -0
- /package/{parser → dist/parser}/Parser.d.ts +0 -0
- /package/{parser → dist/parser}/errors/ParseError.d.ts +0 -0
- /package/{parser → dist/parser}/factories/enum/createEnumParser.d.ts +0 -0
- /package/{parser → dist/parser}/factories/unit/Unit.d.ts +0 -0
- /package/{parser → dist/parser}/factories/unit/createUnitParser.d.ts +0 -0
- /package/{parser → dist/parser}/parseBoolean.d.ts +0 -0
- /package/{parser → dist/parser}/parseBytes.d.ts +0 -0
- /package/{parser → dist/parser}/parseInteger.d.ts +0 -0
- /package/{parser → dist/parser}/parseMilliseconds.d.ts +0 -0
- /package/{parser → dist/parser}/parseNumber.d.ts +0 -0
- /package/{parser → dist/parser}/parseString.d.ts +0 -0
- /package/{pwd → dist/pwd}/Pwd.d.ts +0 -0
- /package/{pwd → dist/pwd}/errors/HashRoundsError.d.ts +0 -0
- /package/{pwd → dist/pwd}/validateHashRounds.d.ts +0 -0
- /package/{server → dist/server}/ErrorHandler.d.ts +0 -0
- /package/{server → dist/server}/Format.d.ts +0 -0
- /package/{server → dist/server}/Handler.d.ts +0 -0
- /package/{server → dist/server}/Method.d.ts +0 -0
- /package/{server → dist/server}/OpenApiFormat.d.ts +0 -0
- /package/{server → dist/server}/Route.d.ts +0 -0
- /package/{server → dist/server}/Schema.d.ts +0 -0
- /package/{server → dist/server}/Server.d.ts +0 -0
- /package/{server → dist/server}/getAjv.d.ts +0 -0
- /package/{tls → dist/tls}/Tls.d.ts +0 -0
- /package/{tls → dist/tls}/errors/FileReadError.d.ts +0 -0
- /package/{tls → dist/tls}/getTls.d.ts +0 -0
- /package/{tls → dist/tls}/readFile.d.ts +0 -0
- /package/{utils → dist/utils}/getRandomHexString.d.ts +0 -0
- /package/{utils → dist/utils}/getTimestamp.d.ts +0 -0
- /package/{utils → dist/utils}/isValidEmail.d.ts +0 -0
- /package/{utils → dist/utils}/isValidGeolocation.d.ts +0 -0
- /package/{utils → dist/utils}/isValidHexString.d.ts +0 -0
- /package/{utils → dist/utils}/isValidIsoDate.d.ts +0 -0
- /package/{utils → dist/utils}/isValidJwtToken.d.ts +0 -0
- /package/{utils → dist/utils}/isValidUrl.d.ts +0 -0
- /package/{utils → dist/utils}/isValidUuid.d.ts +0 -0
- /package/{utils → dist/utils}/wait.d.ts +0 -0
package/config/readFile.ts
DELETED
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import fs from 'fs-extra'
|
|
2
|
-
import { FileReadError } from './errors/FileReadError'
|
|
3
|
-
|
|
4
|
-
const readFile = (path: string, required = false): Record<string, any> => {
|
|
5
|
-
let json: any = {}
|
|
6
|
-
let fileExists: boolean
|
|
7
|
-
|
|
8
|
-
try {
|
|
9
|
-
fileExists = fs.existsSync(path)
|
|
10
|
-
if (fileExists) {
|
|
11
|
-
json = fs.readJsonSync(path)
|
|
12
|
-
}
|
|
13
|
-
} catch (error) {
|
|
14
|
-
throw new FileReadError(path, (error as Error).message)
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
if (required && !fileExists) {
|
|
18
|
-
throw new FileReadError(path, 'missing file')
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
if (
|
|
22
|
-
typeof json !== 'object'
|
|
23
|
-
|| Array.isArray(json)
|
|
24
|
-
|| json === null
|
|
25
|
-
) {
|
|
26
|
-
throw new FileReadError(path, 'invalid content')
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
return json as Record<string, any>
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
export {
|
|
33
|
-
readFile,
|
|
34
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.validatePropertyName = void 0;
|
|
4
|
-
const PropertyNameError_1 = require("./errors/PropertyNameError");
|
|
5
|
-
const propertyNameRegex = /^[a-z](?:[0-9A-Za-z])*$/u;
|
|
6
|
-
const validatePropertyName = (name) => {
|
|
7
|
-
if (!propertyNameRegex.test(name)) {
|
|
8
|
-
throw new PropertyNameError_1.PropertyNameError(name);
|
|
9
|
-
}
|
|
10
|
-
};
|
|
11
|
-
exports.validatePropertyName = validatePropertyName;
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { PropertyNameError } from './errors/PropertyNameError'
|
|
2
|
-
|
|
3
|
-
const propertyNameRegex = /^[a-z](?:[0-9A-Za-z])*$/u
|
|
4
|
-
|
|
5
|
-
const validatePropertyName = (name: string): void => {
|
|
6
|
-
if (!propertyNameRegex.test(name)) {
|
|
7
|
-
throw new PropertyNameError(name)
|
|
8
|
-
}
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
export {
|
|
12
|
-
validatePropertyName,
|
|
13
|
-
}
|
package/env/Env.js
DELETED
package/env/Env.ts
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.FileReadError = void 0;
|
|
4
|
-
const BaseError_1 = require("../../error/BaseError");
|
|
5
|
-
class FileReadError extends BaseError_1.BaseError {
|
|
6
|
-
constructor(path, message) {
|
|
7
|
-
super(`failed reading file "${path}": ${message}`);
|
|
8
|
-
}
|
|
9
|
-
}
|
|
10
|
-
exports.FileReadError = FileReadError;
|
package/env/getEnv.js
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getEnv = void 0;
|
|
4
|
-
const readFile_1 = require("./readFile");
|
|
5
|
-
const getEnv = (params) => {
|
|
6
|
-
let file = {};
|
|
7
|
-
if (params?.file) {
|
|
8
|
-
file = (0, readFile_1.readFile)(params.file.path, params.file.required);
|
|
9
|
-
}
|
|
10
|
-
return {
|
|
11
|
-
...file,
|
|
12
|
-
...process.env,
|
|
13
|
-
};
|
|
14
|
-
};
|
|
15
|
-
exports.getEnv = getEnv;
|
package/env/getEnv.ts
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { readFile } from './readFile'
|
|
2
|
-
import type { Env } from './Env'
|
|
3
|
-
|
|
4
|
-
const getEnv = (params?: {
|
|
5
|
-
file?: {
|
|
6
|
-
path: string,
|
|
7
|
-
required?: boolean,
|
|
8
|
-
},
|
|
9
|
-
}): Env => {
|
|
10
|
-
let file: Env = {}
|
|
11
|
-
|
|
12
|
-
if (params?.file) {
|
|
13
|
-
file = readFile(params.file.path, params.file.required)
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
return {
|
|
17
|
-
...file,
|
|
18
|
-
...process.env as Env,
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export {
|
|
23
|
-
getEnv,
|
|
24
|
-
}
|
package/env/readFile.js
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.readFile = void 0;
|
|
7
|
-
const dotenv_1 = __importDefault(require("dotenv"));
|
|
8
|
-
const fs_extra_1 = __importDefault(require("fs-extra"));
|
|
9
|
-
const FileReadError_1 = require("./errors/FileReadError");
|
|
10
|
-
const readFile = (path, required = false) => {
|
|
11
|
-
try {
|
|
12
|
-
if (fs_extra_1.default.existsSync(path)) {
|
|
13
|
-
return dotenv_1.default.parse(fs_extra_1.default.readFileSync(path));
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
catch (error) {
|
|
17
|
-
throw new FileReadError_1.FileReadError(path, error.message);
|
|
18
|
-
}
|
|
19
|
-
if (required) {
|
|
20
|
-
throw new FileReadError_1.FileReadError(path, 'missing file');
|
|
21
|
-
}
|
|
22
|
-
return {};
|
|
23
|
-
};
|
|
24
|
-
exports.readFile = readFile;
|
package/env/readFile.ts
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import dotenv from 'dotenv'
|
|
2
|
-
import fs from 'fs-extra'
|
|
3
|
-
import { FileReadError } from './errors/FileReadError'
|
|
4
|
-
import type { Env } from './Env'
|
|
5
|
-
|
|
6
|
-
const readFile = (path: string, required = false): Env => {
|
|
7
|
-
try {
|
|
8
|
-
if (fs.existsSync(path)) {
|
|
9
|
-
return dotenv.parse(fs.readFileSync(path))
|
|
10
|
-
}
|
|
11
|
-
} catch (error) {
|
|
12
|
-
throw new FileReadError(path, (error as Error).message)
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
if (required) {
|
|
16
|
-
throw new FileReadError(path, 'missing file')
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
return {}
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export {
|
|
23
|
-
readFile,
|
|
24
|
-
}
|
package/error/BaseError.ts
DELETED
package/jwt/Algorithm.js
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Algorithm = void 0;
|
|
4
|
-
var Algorithm;
|
|
5
|
-
(function (Algorithm) {
|
|
6
|
-
Algorithm["HS256"] = "HS256";
|
|
7
|
-
Algorithm["HS384"] = "HS384";
|
|
8
|
-
Algorithm["HS512"] = "HS512";
|
|
9
|
-
})(Algorithm || (exports.Algorithm = Algorithm = {}));
|
package/jwt/Algorithm.ts
DELETED
package/jwt/Jwt.ts
DELETED
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import { SignJWT, jwtVerify } from 'jose'
|
|
2
|
-
import { validateSecretLength } from './validateSecretLength'
|
|
3
|
-
import type { Algorithm } from './Algorithm'
|
|
4
|
-
import type { Payload } from './Payload'
|
|
5
|
-
|
|
6
|
-
class Jwt {
|
|
7
|
-
private readonly algorithm: Algorithm
|
|
8
|
-
|
|
9
|
-
private readonly secret: Uint8Array
|
|
10
|
-
|
|
11
|
-
public constructor(params: {
|
|
12
|
-
algorithm: Algorithm,
|
|
13
|
-
secret: string,
|
|
14
|
-
}) {
|
|
15
|
-
validateSecretLength(params.algorithm, params.secret)
|
|
16
|
-
|
|
17
|
-
this.algorithm = params.algorithm
|
|
18
|
-
this.secret = new TextEncoder().encode(params.secret)
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
public async createToken(payload: Payload): Promise<string> {
|
|
22
|
-
return new SignJWT(payload)
|
|
23
|
-
.setProtectedHeader({
|
|
24
|
-
typ: 'JWT',
|
|
25
|
-
alg: this.algorithm,
|
|
26
|
-
})
|
|
27
|
-
.sign(this.secret)
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
public async verifyToken<Type extends Payload>(
|
|
31
|
-
token: string,
|
|
32
|
-
timestamp: number,
|
|
33
|
-
): Promise<Type | undefined> {
|
|
34
|
-
try {
|
|
35
|
-
const { payload } = await jwtVerify(token, this.secret, {
|
|
36
|
-
typ: 'JWT',
|
|
37
|
-
currentDate: new Date(timestamp * 1000),
|
|
38
|
-
})
|
|
39
|
-
|
|
40
|
-
return payload as Type
|
|
41
|
-
} catch (error) {
|
|
42
|
-
return undefined
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
export {
|
|
48
|
-
Jwt,
|
|
49
|
-
}
|
package/jwt/Payload.js
DELETED
package/jwt/Payload.ts
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.SecretLengthError = void 0;
|
|
4
|
-
const BaseError_1 = require("../../error/BaseError");
|
|
5
|
-
class SecretLengthError extends BaseError_1.BaseError {
|
|
6
|
-
constructor() {
|
|
7
|
-
super('invalid secret length');
|
|
8
|
-
}
|
|
9
|
-
}
|
|
10
|
-
exports.SecretLengthError = SecretLengthError;
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.validateSecretLength = void 0;
|
|
4
|
-
const Algorithm_1 = require("./Algorithm");
|
|
5
|
-
const SecretLengthError_1 = require("./errors/SecretLengthError");
|
|
6
|
-
const minSecretLength = {
|
|
7
|
-
[Algorithm_1.Algorithm.HS256]: 32,
|
|
8
|
-
[Algorithm_1.Algorithm.HS384]: 48,
|
|
9
|
-
[Algorithm_1.Algorithm.HS512]: 64,
|
|
10
|
-
};
|
|
11
|
-
const validateSecretLength = (algorithm, secret) => {
|
|
12
|
-
if (Buffer.from(secret).length < minSecretLength[algorithm]) {
|
|
13
|
-
throw new SecretLengthError_1.SecretLengthError();
|
|
14
|
-
}
|
|
15
|
-
};
|
|
16
|
-
exports.validateSecretLength = validateSecretLength;
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { Algorithm } from './Algorithm'
|
|
2
|
-
import { SecretLengthError } from './errors/SecretLengthError'
|
|
3
|
-
|
|
4
|
-
const minSecretLength = {
|
|
5
|
-
[Algorithm.HS256]: 32,
|
|
6
|
-
[Algorithm.HS384]: 48,
|
|
7
|
-
[Algorithm.HS512]: 64,
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
const validateSecretLength = (algorithm: Algorithm, secret: string): void => {
|
|
11
|
-
if (Buffer.from(secret).length < minSecretLength[algorithm]) {
|
|
12
|
-
throw new SecretLengthError()
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
export {
|
|
17
|
-
validateSecretLength,
|
|
18
|
-
}
|
package/logger/Level.ts
DELETED
package/logger/Logger.js
DELETED
package/logger/Logger.ts
DELETED
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
abstract class Logger {
|
|
2
|
-
public abstract trace(message: string, data?: unknown): void
|
|
3
|
-
|
|
4
|
-
public abstract debug(message: string, data?: unknown): void
|
|
5
|
-
|
|
6
|
-
public abstract info(message: string, data?: unknown): void
|
|
7
|
-
|
|
8
|
-
public abstract warn(message: string, data?: unknown): void
|
|
9
|
-
|
|
10
|
-
public abstract error(message: string, data?: unknown): void
|
|
11
|
-
|
|
12
|
-
public abstract fatal(message: string, data?: unknown): void
|
|
13
|
-
|
|
14
|
-
public abstract close(): Promise<void>
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
export {
|
|
18
|
-
Logger,
|
|
19
|
-
}
|
package/logger/Severity.ts
DELETED
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
import pino from 'pino'
|
|
2
|
-
import { Level } from '../../Level'
|
|
3
|
-
import { Logger } from '../../Logger'
|
|
4
|
-
import { initFile } from './initFile'
|
|
5
|
-
import type { Logger as PinoLogger } from 'pino'
|
|
6
|
-
|
|
7
|
-
class FileLogger extends Logger {
|
|
8
|
-
private readonly logger: PinoLogger
|
|
9
|
-
|
|
10
|
-
private readonly context: object | undefined
|
|
11
|
-
|
|
12
|
-
public constructor(params: {
|
|
13
|
-
path: string,
|
|
14
|
-
level?: Level,
|
|
15
|
-
context?: object,
|
|
16
|
-
}) {
|
|
17
|
-
super()
|
|
18
|
-
|
|
19
|
-
initFile(params.path)
|
|
20
|
-
|
|
21
|
-
const stream = pino.destination(params.path)
|
|
22
|
-
|
|
23
|
-
this.logger = pino({
|
|
24
|
-
enabled: params.level !== Level.OFF,
|
|
25
|
-
level: params.level ?? Level.INFO,
|
|
26
|
-
messageKey: 'message',
|
|
27
|
-
formatters: {
|
|
28
|
-
level(label, number) {
|
|
29
|
-
return {
|
|
30
|
-
level: label,
|
|
31
|
-
severity: number,
|
|
32
|
-
}
|
|
33
|
-
},
|
|
34
|
-
bindings: () => { return {} },
|
|
35
|
-
},
|
|
36
|
-
}, stream)
|
|
37
|
-
|
|
38
|
-
this.context = params.context
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
public trace(message: string, data?: unknown): void {
|
|
42
|
-
this.logger.trace(this.getPayload(message, data))
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
public debug(message: string, data?: unknown): void {
|
|
46
|
-
this.logger.debug(this.getPayload(message, data))
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
public info(message: string, data?: unknown): void {
|
|
50
|
-
this.logger.info(this.getPayload(message, data))
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
public warn(message: string, data?: unknown): void {
|
|
54
|
-
this.logger.warn(this.getPayload(message, data))
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
public error(message: string, data?: unknown): void {
|
|
58
|
-
this.logger.error(this.getPayload(message, data))
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
public fatal(message: string, data?: unknown): void {
|
|
62
|
-
this.logger.fatal(this.getPayload(message, data))
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
public async close(): Promise<void> {
|
|
66
|
-
return new Promise((resolve, reject) => {
|
|
67
|
-
this.logger.flush((error) => {
|
|
68
|
-
if (error) {
|
|
69
|
-
reject(error)
|
|
70
|
-
}
|
|
71
|
-
resolve()
|
|
72
|
-
})
|
|
73
|
-
})
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
private getPayload(message: string, data?: unknown): object {
|
|
77
|
-
return {
|
|
78
|
-
...this.context,
|
|
79
|
-
message,
|
|
80
|
-
data,
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
export {
|
|
86
|
-
FileLogger,
|
|
87
|
-
}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.FileInitError = void 0;
|
|
4
|
-
const BaseError_1 = require("../../../../error/BaseError");
|
|
5
|
-
class FileInitError extends BaseError_1.BaseError {
|
|
6
|
-
constructor(path, message) {
|
|
7
|
-
super(`failed initializing file "${path}": ${message}`);
|
|
8
|
-
}
|
|
9
|
-
}
|
|
10
|
-
exports.FileInitError = FileInitError;
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.initFile = void 0;
|
|
7
|
-
const fs_extra_1 = __importDefault(require("fs-extra"));
|
|
8
|
-
const FileInitError_1 = require("./errors/FileInitError");
|
|
9
|
-
const initFile = (path) => {
|
|
10
|
-
if (path === '') {
|
|
11
|
-
throw new FileInitError_1.FileInitError('', 'empty path');
|
|
12
|
-
}
|
|
13
|
-
try {
|
|
14
|
-
fs_extra_1.default.ensureFileSync(path);
|
|
15
|
-
}
|
|
16
|
-
catch (error) {
|
|
17
|
-
throw new FileInitError_1.FileInitError(path, error.message);
|
|
18
|
-
}
|
|
19
|
-
};
|
|
20
|
-
exports.initFile = initFile;
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import fs from 'fs-extra'
|
|
2
|
-
import { FileInitError } from './errors/FileInitError'
|
|
3
|
-
|
|
4
|
-
const initFile = (path: string): void => {
|
|
5
|
-
if (path === '') {
|
|
6
|
-
throw new FileInitError('', 'empty path')
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
try {
|
|
10
|
-
fs.ensureFileSync(path)
|
|
11
|
-
} catch (error) {
|
|
12
|
-
throw new FileInitError(path, (error as Error).message)
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
export {
|
|
17
|
-
initFile,
|
|
18
|
-
}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.NoopLogger = void 0;
|
|
4
|
-
const Logger_1 = require("../../Logger");
|
|
5
|
-
class NoopLogger extends Logger_1.Logger {
|
|
6
|
-
trace() { }
|
|
7
|
-
debug() { }
|
|
8
|
-
info() { }
|
|
9
|
-
warn() { }
|
|
10
|
-
error() { }
|
|
11
|
-
fatal() { }
|
|
12
|
-
async close() { }
|
|
13
|
-
}
|
|
14
|
-
exports.NoopLogger = NoopLogger;
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { Logger } from '../../Logger'
|
|
2
|
-
|
|
3
|
-
class NoopLogger extends Logger {
|
|
4
|
-
public trace(): void { }
|
|
5
|
-
|
|
6
|
-
public debug(): void { }
|
|
7
|
-
|
|
8
|
-
public info(): void { }
|
|
9
|
-
|
|
10
|
-
public warn(): void { }
|
|
11
|
-
|
|
12
|
-
public error(): void { }
|
|
13
|
-
|
|
14
|
-
public fatal(): void { }
|
|
15
|
-
|
|
16
|
-
public async close(): Promise<void> { }
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
export {
|
|
20
|
-
NoopLogger,
|
|
21
|
-
}
|