apeframework 0.0.0-dev.9 → 0.1.0
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 +47 -1
- package/{cipher → dist/cipher}/Algorithm.js +2 -4
- package/{cipher → dist/cipher}/Cipher.d.ts +1 -1
- package/dist/cipher/Cipher.js +32 -0
- package/{cipher → dist/cipher}/errors/DecryptError.d.ts +1 -1
- package/dist/cipher/errors/DecryptError.js +7 -0
- package/{cipher → dist/cipher}/errors/SecretLengthError.d.ts +1 -1
- package/dist/cipher/errors/SecretLengthError.js +7 -0
- package/{cipher → dist/cipher}/validateSecretLength.d.ts +1 -1
- package/dist/cipher/validateSecretLength.js +13 -0
- package/{cli → dist/cli}/Args.d.ts +1 -1
- package/dist/cli/Args.js +1 -0
- package/{cli → dist/cli}/Command.d.ts +1 -1
- package/dist/cli/Command.js +1 -0
- package/{cli → dist/cli}/getArgs.d.ts +1 -1
- package/dist/cli/getArgs.js +5 -0
- package/{cli → dist/cli}/parseArgs.d.ts +1 -1
- 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.d.ts +2 -0
- package/dist/config/Config.js +1 -0
- package/{config → dist/config}/Properties.d.ts +1 -1
- package/dist/config/Properties.js +1 -0
- package/{config → dist/config}/errors/FileReadError.d.ts +1 -1
- package/dist/config/errors/FileReadError.js +7 -0
- package/{config → dist/config}/errors/PropertyNameError.d.ts +1 -1
- package/dist/config/errors/PropertyNameError.js +7 -0
- package/{config → dist/config}/errors/PropertyParseError.d.ts +1 -1
- package/dist/config/errors/PropertyParseError.js +7 -0
- package/{config → dist/config}/getConfig.d.ts +4 -4
- package/dist/config/getConfig.js +18 -0
- package/{config → dist/config}/getPropertyEnvVar.js +1 -4
- package/{config → dist/config}/parseProperty.d.ts +1 -1
- 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/{env → dist/env}/errors/FileReadError.d.ts +1 -1
- package/dist/env/errors/FileReadError.js +7 -0
- package/{env → dist/env}/getEnv.d.ts +1 -1
- package/dist/env/getEnv.js +12 -0
- package/{env → dist/env}/readFile.d.ts +1 -1
- 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.d.ts +2 -2
- package/{jwt → dist/jwt}/Jwt.js +6 -9
- package/dist/jwt/Payload.js +1 -0
- package/{jwt → dist/jwt}/errors/SecretLengthError.d.ts +1 -1
- package/dist/jwt/errors/SecretLengthError.js +7 -0
- package/{jwt → dist/jwt}/validateSecretLength.d.ts +1 -1
- 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.d.ts +2 -2
- package/{logger → dist/logger}/adapters/file/FileLogger.js +11 -17
- package/{logger → dist/logger}/adapters/file/errors/FileInitError.d.ts +1 -1
- package/dist/logger/adapters/file/errors/FileInitError.js +7 -0
- package/dist/logger/adapters/file/initFile.js +14 -0
- package/{logger → dist/logger}/adapters/noop/NoopLogger.d.ts +1 -1
- package/dist/logger/adapters/noop/NoopLogger.js +11 -0
- package/{logger → dist/logger}/adapters/stdio/StdioLogger.d.ts +2 -2
- package/{logger → dist/logger}/adapters/stdio/StdioLogger.js +11 -17
- package/dist/mailer/Address.js +1 -0
- package/{mailer → dist/mailer}/Attachment.d.ts +1 -1
- package/dist/mailer/Attachment.js +1 -0
- package/{mailer → dist/mailer}/Event.d.ts +2 -2
- package/dist/mailer/Event.js +1 -0
- package/dist/mailer/List.js +1 -0
- package/dist/mailer/Location.js +1 -0
- package/{mailer → dist/mailer}/Mail.d.ts +4 -4
- package/dist/mailer/Mail.js +1 -0
- package/{mailer → dist/mailer}/Mailer.d.ts +1 -1
- package/dist/mailer/Mailer.js +47 -0
- package/dist/mailer/Method.js +6 -0
- package/{mailer → dist/mailer}/adapters/noop/NoopMailer.d.ts +2 -2
- package/dist/mailer/adapters/noop/NoopMailer.js +9 -0
- package/{mailer → dist/mailer}/adapters/smtp/SmtpMailer.d.ts +3 -3
- package/dist/mailer/adapters/smtp/SmtpMailer.js +54 -0
- package/dist/mailer/adapters/smtp/getAddress.d.ts +7 -0
- package/{mailer → dist/mailer}/adapters/smtp/getAddress.js +1 -4
- package/dist/mailer/adapters/smtp/getAddresses.d.ts +7 -0
- package/dist/mailer/adapters/smtp/getAddresses.js +11 -0
- package/dist/mailer/adapters/smtp/getAttachments.d.ts +10 -0
- package/{mailer → dist/mailer}/adapters/smtp/getAttachments.js +1 -4
- package/{mailer → dist/mailer}/errors/AddressEmailError.d.ts +1 -1
- package/dist/mailer/errors/AddressEmailError.js +7 -0
- package/{mailer → dist/mailer}/errors/EventAttachmentUrlError.d.ts +1 -1
- package/dist/mailer/errors/EventAttachmentUrlError.js +7 -0
- package/{mailer → dist/mailer}/errors/EventGeolocationError.d.ts +1 -1
- package/dist/mailer/errors/EventGeolocationError.js +7 -0
- package/{mailer → dist/mailer}/errors/EventUrlError.d.ts +1 -1
- package/dist/mailer/errors/EventUrlError.js +7 -0
- package/{mailer → dist/mailer}/errors/ListUrlError.d.ts +1 -1
- package/dist/mailer/errors/ListUrlError.js +7 -0
- package/{mailer → dist/mailer}/getIcalendar.d.ts +1 -1
- 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/{parser → dist/parser}/errors/ParseError.d.ts +1 -1
- package/dist/parser/errors/ParseError.js +7 -0
- package/dist/parser/factories/enum/createEnumParser.d.ts +6 -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.d.ts +2 -2
- package/{parser → dist/parser}/factories/unit/createUnitParser.js +8 -11
- package/{parser → dist/parser}/parseBoolean.d.ts +1 -1
- package/dist/parser/parseBoolean.js +28 -0
- package/dist/parser/parseBytes.d.ts +2 -0
- package/{parser → dist/parser}/parseBytes.js +3 -6
- package/{parser → dist/parser}/parseInteger.d.ts +1 -1
- package/dist/parser/parseInteger.js +16 -0
- package/dist/parser/parseMilliseconds.d.ts +2 -0
- package/{parser → dist/parser}/parseMilliseconds.js +3 -6
- package/{parser → dist/parser}/parseNumber.d.ts +1 -1
- package/dist/parser/parseNumber.js +15 -0
- package/{parser → dist/parser}/parseString.d.ts +1 -1
- package/dist/parser/parseString.js +11 -0
- package/dist/pwd/Algorithm.d.ts +6 -0
- package/dist/pwd/Algorithm.js +7 -0
- package/dist/pwd/Pwd.d.ts +18 -0
- package/dist/pwd/Pwd.js +36 -0
- package/dist/pwd/errors/HashLengthError.d.ts +5 -0
- package/dist/pwd/errors/HashLengthError.js +7 -0
- package/dist/pwd/errors/MemoryCostError.d.ts +5 -0
- package/dist/pwd/errors/MemoryCostError.js +7 -0
- package/dist/pwd/errors/ParallelismError.d.ts +5 -0
- package/dist/pwd/errors/ParallelismError.js +7 -0
- package/dist/pwd/errors/TimeCostError.d.ts +5 -0
- package/dist/pwd/errors/TimeCostError.js +7 -0
- package/dist/pwd/validateHashLength.d.ts +2 -0
- package/dist/pwd/validateHashLength.js +7 -0
- package/dist/pwd/validateMemoryCost.d.ts +2 -0
- package/dist/pwd/validateMemoryCost.js +7 -0
- package/dist/pwd/validateParallelism.d.ts +2 -0
- package/dist/pwd/validateParallelism.js +7 -0
- package/dist/pwd/validateTimeCost.d.ts +2 -0
- package/dist/pwd/validateTimeCost.js +7 -0
- package/dist/server/ErrorHandler.d.ts +5 -0
- package/dist/server/ErrorHandler.js +1 -0
- package/dist/server/Format.d.ts +9 -0
- package/dist/server/Format.js +1 -0
- package/dist/server/Handler.d.ts +4 -0
- package/dist/server/Handler.js +1 -0
- package/{api → dist/server}/Method.js +2 -4
- package/dist/server/OpenApiFormat.d.ts +5 -0
- package/dist/server/OpenApiFormat.js +6 -0
- package/dist/server/Request.d.ts +5 -0
- package/dist/server/Request.js +1 -0
- package/dist/server/Response.d.ts +8 -0
- package/dist/server/Response.js +1 -0
- package/dist/server/Route.d.ts +12 -0
- package/dist/server/Route.js +1 -0
- package/dist/server/Schema.js +1 -0
- package/dist/server/Server.d.ts +47 -0
- package/dist/server/Server.js +98 -0
- package/dist/server/getAjv.d.ts +4 -0
- package/dist/server/getAjv.js +19 -0
- package/dist/tls/Tls.js +1 -0
- package/{tls → dist/tls}/errors/FileReadError.d.ts +1 -1
- package/dist/tls/errors/FileReadError.js +7 -0
- package/{tls → dist/tls}/getTls.d.ts +1 -1
- package/dist/tls/getTls.js +14 -0
- package/dist/tls/readFile.js +14 -0
- package/dist/utils/getRandomHexString.js +5 -0
- package/dist/utils/getRandomIntString.d.ts +2 -0
- package/dist/utils/getRandomIntString.js +9 -0
- package/dist/utils/getTimestamp.d.ts +2 -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/isValidIntString.d.ts +2 -0
- package/dist/utils/isValidIntString.js +5 -0
- package/dist/utils/isValidIsoDate.d.ts +2 -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 +722 -25
- package/api/Api.d.ts +0 -30
- package/api/Api.js +0 -78
- package/api/Api.ts +0 -112
- package/api/Endpoint.d.ts +0 -12
- package/api/Endpoint.js +0 -2
- package/api/Endpoint.ts +0 -16
- package/api/ErrorHandler.d.ts +0 -3
- package/api/ErrorHandler.js +0 -2
- package/api/ErrorHandler.ts +0 -11
- package/api/Handler.d.ts +0 -3
- package/api/Handler.js +0 -2
- package/api/Handler.ts +0 -10
- package/api/Method.ts +0 -11
- package/api/Schema.js +0 -2
- package/api/Schema.ts +0 -13
- 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.d.ts +0 -2
- 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.d.ts +0 -4
- package/mailer/adapters/smtp/getAddress.ts +0 -15
- package/mailer/adapters/smtp/getAddresses.d.ts +0 -4
- package/mailer/adapters/smtp/getAddresses.js +0 -14
- package/mailer/adapters/smtp/getAddresses.ts +0 -17
- package/mailer/adapters/smtp/getAttachments.d.ts +0 -4
- 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/unit/Unit.js +0 -2
- package/parser/factories/unit/Unit.ts +0 -8
- package/parser/factories/unit/createUnitParser.ts +0 -50
- package/parser/parseBoolean.js +0 -14
- package/parser/parseBoolean.ts +0 -16
- package/parser/parseBytes.d.ts +0 -2
- package/parser/parseBytes.ts +0 -55
- package/parser/parseInteger.js +0 -19
- package/parser/parseInteger.ts +0 -23
- package/parser/parseMilliseconds.d.ts +0 -2
- package/parser/parseMilliseconds.ts +0 -31
- package/parser/parseNumber.js +0 -18
- package/parser/parseNumber.ts +0 -22
- package/parser/parseString.js +0 -20
- package/parser/parseString.ts +0 -20
- package/pwd/Pwd.d.ts +0 -9
- package/pwd/Pwd.js +0 -22
- package/pwd/Pwd.ts +0 -31
- package/pwd/errors/HashRoundsError.d.ts +0 -5
- package/pwd/errors/HashRoundsError.js +0 -10
- package/pwd/errors/HashRoundsError.ts +0 -11
- package/pwd/validateHashRounds.d.ts +0 -2
- package/pwd/validateHashRounds.js +0 -10
- package/pwd/validateHashRounds.ts +0 -11
- 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.d.ts +0 -2
- 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/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/{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}/getPropertyEnvVar.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/{error → dist/error}/BaseError.d.ts +0 -0
- /package/{jwt → dist/jwt}/Algorithm.d.ts +0 -0
- /package/{jwt → dist/jwt}/Payload.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/initFile.d.ts +0 -0
- /package/{mailer → dist/mailer}/Address.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}/Method.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}/factories/unit/Unit.d.ts +0 -0
- /package/{api → dist/server}/Method.d.ts +0 -0
- /package/{api → dist/server}/Schema.d.ts +0 -0
- /package/{tls → dist/tls}/Tls.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}/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}/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
|
@@ -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
|
-
}
|
|
@@ -1,89 +0,0 @@
|
|
|
1
|
-
import pino from 'pino'
|
|
2
|
-
import pretty from 'pino-pretty'
|
|
3
|
-
import { Level } from '../../Level'
|
|
4
|
-
import { Logger } from '../../Logger'
|
|
5
|
-
import type { Logger as PinoLogger } from 'pino'
|
|
6
|
-
|
|
7
|
-
class StdioLogger extends Logger {
|
|
8
|
-
private readonly logger: PinoLogger
|
|
9
|
-
|
|
10
|
-
private readonly context: object | undefined
|
|
11
|
-
|
|
12
|
-
public constructor(params?: {
|
|
13
|
-
pretty?: boolean,
|
|
14
|
-
level?: Level,
|
|
15
|
-
context?: object,
|
|
16
|
-
}) {
|
|
17
|
-
super()
|
|
18
|
-
|
|
19
|
-
const stream = params?.pretty
|
|
20
|
-
? pretty()
|
|
21
|
-
: pino.destination(process.stdout.fd)
|
|
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
|
-
...params?.pretty
|
|
32
|
-
? {}
|
|
33
|
-
: { severity: number },
|
|
34
|
-
}
|
|
35
|
-
},
|
|
36
|
-
bindings: () => { return {} },
|
|
37
|
-
},
|
|
38
|
-
}, stream)
|
|
39
|
-
|
|
40
|
-
this.context = params?.context
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
public trace(message: string, data?: unknown): void {
|
|
44
|
-
this.logger.trace(this.getPayload(message, data))
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
public debug(message: string, data?: unknown): void {
|
|
48
|
-
this.logger.debug(this.getPayload(message, data))
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
public info(message: string, data?: unknown): void {
|
|
52
|
-
this.logger.info(this.getPayload(message, data))
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
public warn(message: string, data?: unknown): void {
|
|
56
|
-
this.logger.warn(this.getPayload(message, data))
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
public error(message: string, data?: unknown): void {
|
|
60
|
-
this.logger.error(this.getPayload(message, data))
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
public fatal(message: string, data?: unknown): void {
|
|
64
|
-
this.logger.fatal(this.getPayload(message, data))
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
public async close(): Promise<void> {
|
|
68
|
-
return new Promise((resolve, reject) => {
|
|
69
|
-
this.logger.flush((error) => {
|
|
70
|
-
if (error) {
|
|
71
|
-
reject(error)
|
|
72
|
-
}
|
|
73
|
-
resolve()
|
|
74
|
-
})
|
|
75
|
-
})
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
private getPayload(message: string, data?: unknown): object {
|
|
79
|
-
return {
|
|
80
|
-
...this.context,
|
|
81
|
-
message,
|
|
82
|
-
data,
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
export {
|
|
88
|
-
StdioLogger,
|
|
89
|
-
}
|
package/mailer/Address.js
DELETED
package/mailer/Address.ts
DELETED
package/mailer/Attachment.js
DELETED
package/mailer/Attachment.ts
DELETED
package/mailer/Event.js
DELETED
package/mailer/Event.ts
DELETED
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import type { Location } from './Location'
|
|
2
|
-
import type { Method } from './Method'
|
|
3
|
-
|
|
4
|
-
interface Event {
|
|
5
|
-
fileName?: string,
|
|
6
|
-
method: Method,
|
|
7
|
-
id?: string,
|
|
8
|
-
start: Date,
|
|
9
|
-
end: Date,
|
|
10
|
-
allDay?: boolean,
|
|
11
|
-
name: string,
|
|
12
|
-
description?: string,
|
|
13
|
-
url?: string,
|
|
14
|
-
location?: Location,
|
|
15
|
-
attachments?: string[],
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
export {
|
|
19
|
-
type Event,
|
|
20
|
-
}
|
package/mailer/List.js
DELETED
package/mailer/List.ts
DELETED
package/mailer/Location.js
DELETED
package/mailer/Location.ts
DELETED
package/mailer/Mail.js
DELETED
package/mailer/Mail.ts
DELETED
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import type { Address } from './Address'
|
|
2
|
-
import type { Attachment } from './Attachment'
|
|
3
|
-
import type { Event } from './Event'
|
|
4
|
-
import type { List } from './List'
|
|
5
|
-
|
|
6
|
-
interface Mail {
|
|
7
|
-
from: Address,
|
|
8
|
-
sender?: Address,
|
|
9
|
-
replyTo?: Address,
|
|
10
|
-
to: Address[],
|
|
11
|
-
cc?: Address[],
|
|
12
|
-
bcc?: Address[],
|
|
13
|
-
subject: string,
|
|
14
|
-
text: string,
|
|
15
|
-
html?: string,
|
|
16
|
-
attachments?: Attachment[],
|
|
17
|
-
event?: Event,
|
|
18
|
-
list?: List,
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
export {
|
|
22
|
-
type Mail,
|
|
23
|
-
}
|
package/mailer/Mailer.js
DELETED
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Mailer = void 0;
|
|
4
|
-
const validateAddressEmail_1 = require("./validateAddressEmail");
|
|
5
|
-
const validateEventAttachmentUrl_1 = require("./validateEventAttachmentUrl");
|
|
6
|
-
const validateEventGeolocation_1 = require("./validateEventGeolocation");
|
|
7
|
-
const validateEventUrl_1 = require("./validateEventUrl");
|
|
8
|
-
const validateListUrl_1 = require("./validateListUrl");
|
|
9
|
-
class Mailer {
|
|
10
|
-
async send(mail) {
|
|
11
|
-
(0, validateAddressEmail_1.validateAddressEmail)(mail.from.email);
|
|
12
|
-
if (mail.sender) {
|
|
13
|
-
(0, validateAddressEmail_1.validateAddressEmail)(mail.sender.email);
|
|
14
|
-
}
|
|
15
|
-
if (mail.replyTo) {
|
|
16
|
-
(0, validateAddressEmail_1.validateAddressEmail)(mail.replyTo.email);
|
|
17
|
-
}
|
|
18
|
-
mail.to.forEach((address) => {
|
|
19
|
-
(0, validateAddressEmail_1.validateAddressEmail)(address.email);
|
|
20
|
-
});
|
|
21
|
-
if (mail.cc) {
|
|
22
|
-
mail.cc.forEach((address) => {
|
|
23
|
-
(0, validateAddressEmail_1.validateAddressEmail)(address.email);
|
|
24
|
-
});
|
|
25
|
-
}
|
|
26
|
-
if (mail.bcc) {
|
|
27
|
-
mail.bcc.forEach((address) => {
|
|
28
|
-
(0, validateAddressEmail_1.validateAddressEmail)(address.email);
|
|
29
|
-
});
|
|
30
|
-
}
|
|
31
|
-
if (mail.event?.url) {
|
|
32
|
-
(0, validateEventUrl_1.validateEventUrl)(mail.event.url);
|
|
33
|
-
}
|
|
34
|
-
if (mail.event?.location?.geo) {
|
|
35
|
-
(0, validateEventGeolocation_1.validateEventGeolocation)(mail.event.location.geo.latitude, mail.event.location.geo.longitude);
|
|
36
|
-
}
|
|
37
|
-
if (mail.event?.attachments) {
|
|
38
|
-
mail.event.attachments.forEach((attachment) => {
|
|
39
|
-
(0, validateEventAttachmentUrl_1.validateEventAttachmentUrl)(attachment);
|
|
40
|
-
});
|
|
41
|
-
}
|
|
42
|
-
if (mail.list) {
|
|
43
|
-
Object.entries(mail.list).forEach(([property, url]) => {
|
|
44
|
-
(0, validateListUrl_1.validateListUrl)(property, url);
|
|
45
|
-
});
|
|
46
|
-
}
|
|
47
|
-
return this.sendMail(mail);
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
exports.Mailer = Mailer;
|
package/mailer/Mailer.ts
DELETED
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
import { validateAddressEmail } from './validateAddressEmail'
|
|
2
|
-
import { validateEventAttachmentUrl } from './validateEventAttachmentUrl'
|
|
3
|
-
import { validateEventGeolocation } from './validateEventGeolocation'
|
|
4
|
-
import { validateEventUrl } from './validateEventUrl'
|
|
5
|
-
import { validateListUrl } from './validateListUrl'
|
|
6
|
-
import type { Mail } from './Mail'
|
|
7
|
-
|
|
8
|
-
abstract class Mailer {
|
|
9
|
-
public async send(mail: Mail): Promise<string> {
|
|
10
|
-
validateAddressEmail(mail.from.email)
|
|
11
|
-
|
|
12
|
-
if (mail.sender) {
|
|
13
|
-
validateAddressEmail(mail.sender.email)
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
if (mail.replyTo) {
|
|
17
|
-
validateAddressEmail(mail.replyTo.email)
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
mail.to.forEach((address) => {
|
|
21
|
-
validateAddressEmail(address.email)
|
|
22
|
-
})
|
|
23
|
-
|
|
24
|
-
if (mail.cc) {
|
|
25
|
-
mail.cc.forEach((address) => {
|
|
26
|
-
validateAddressEmail(address.email)
|
|
27
|
-
})
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
if (mail.bcc) {
|
|
31
|
-
mail.bcc.forEach((address) => {
|
|
32
|
-
validateAddressEmail(address.email)
|
|
33
|
-
})
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
if (mail.event?.url) {
|
|
37
|
-
validateEventUrl(mail.event.url)
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
if (mail.event?.location?.geo) {
|
|
41
|
-
validateEventGeolocation(
|
|
42
|
-
mail.event.location.geo.latitude,
|
|
43
|
-
mail.event.location.geo.longitude,
|
|
44
|
-
)
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
if (mail.event?.attachments) {
|
|
48
|
-
mail.event.attachments.forEach((attachment) => {
|
|
49
|
-
validateEventAttachmentUrl(attachment)
|
|
50
|
-
})
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
if (mail.list) {
|
|
54
|
-
Object.entries(mail.list).forEach(([property, url]: [string, string]) => {
|
|
55
|
-
validateListUrl(property, url)
|
|
56
|
-
})
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
return this.sendMail(mail)
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
public abstract sendMail(mail: Mail): Promise<string>
|
|
63
|
-
|
|
64
|
-
public abstract close(): Promise<void>
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
export {
|
|
68
|
-
Mailer,
|
|
69
|
-
}
|
package/mailer/Method.js
DELETED
package/mailer/Method.ts
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.NoopMailer = void 0;
|
|
4
|
-
const crypto_1 = require("crypto");
|
|
5
|
-
const Mailer_1 = require("../../Mailer");
|
|
6
|
-
class NoopMailer extends Mailer_1.Mailer {
|
|
7
|
-
async sendMail(mail) {
|
|
8
|
-
return `${(0, crypto_1.randomUUID)()}@${mail.from.email.split('@')[1]}`;
|
|
9
|
-
}
|
|
10
|
-
async close() { }
|
|
11
|
-
}
|
|
12
|
-
exports.NoopMailer = NoopMailer;
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { randomUUID } from 'crypto'
|
|
2
|
-
import { Mailer } from '../../Mailer'
|
|
3
|
-
import type { Mail } from '../../Mail'
|
|
4
|
-
|
|
5
|
-
class NoopMailer extends Mailer {
|
|
6
|
-
public async sendMail(mail: Mail): Promise<string> {
|
|
7
|
-
return `${randomUUID()}@${mail.from.email.split('@')[1]}`
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
public async close(): Promise<void> { }
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
export {
|
|
14
|
-
NoopMailer,
|
|
15
|
-
}
|