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/LICENSE
CHANGED
|
@@ -1,9 +1,7 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Algorithm = void 0;
|
|
4
1
|
var Algorithm;
|
|
5
2
|
(function (Algorithm) {
|
|
6
3
|
Algorithm["AES128"] = "aes-128-cbc";
|
|
7
4
|
Algorithm["AES192"] = "aes-192-cbc";
|
|
8
5
|
Algorithm["AES256"] = "aes-256-cbc";
|
|
9
|
-
})(Algorithm || (
|
|
6
|
+
})(Algorithm || (Algorithm = {}));
|
|
7
|
+
export { Algorithm, };
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import crypto from 'crypto';
|
|
2
|
+
import { DecryptError } from './errors/DecryptError';
|
|
3
|
+
import { validateSecretLength } from './validateSecretLength';
|
|
4
|
+
class Cipher {
|
|
5
|
+
algorithm;
|
|
6
|
+
secret;
|
|
7
|
+
constructor(params) {
|
|
8
|
+
validateSecretLength(params.algorithm, params.secret);
|
|
9
|
+
this.algorithm = params.algorithm;
|
|
10
|
+
this.secret = Buffer.from(params.secret, 'utf8');
|
|
11
|
+
}
|
|
12
|
+
encrypt(string) {
|
|
13
|
+
const iv = crypto.randomBytes(16);
|
|
14
|
+
const cipher = crypto.createCipheriv(this.algorithm, this.secret, iv);
|
|
15
|
+
return iv.toString('hex')
|
|
16
|
+
+ cipher.update(string, 'utf8', 'hex')
|
|
17
|
+
+ cipher.final('hex');
|
|
18
|
+
}
|
|
19
|
+
decrypt(string) {
|
|
20
|
+
const buffer = Buffer.from(string, 'hex');
|
|
21
|
+
const iv = buffer.subarray(0, 16);
|
|
22
|
+
const decipher = crypto.createDecipheriv(this.algorithm, this.secret, iv);
|
|
23
|
+
try {
|
|
24
|
+
return decipher.update(buffer.subarray(16), undefined, 'utf8')
|
|
25
|
+
+ decipher.final('utf8');
|
|
26
|
+
}
|
|
27
|
+
catch (error) {
|
|
28
|
+
throw new DecryptError(error.message);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
export { Cipher, };
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Algorithm } from './Algorithm';
|
|
2
|
+
import { SecretLengthError } from './errors/SecretLengthError';
|
|
3
|
+
const secretLength = {
|
|
4
|
+
[Algorithm.AES128]: 16,
|
|
5
|
+
[Algorithm.AES192]: 24,
|
|
6
|
+
[Algorithm.AES256]: 32,
|
|
7
|
+
};
|
|
8
|
+
const validateSecretLength = (algorithm, secret) => {
|
|
9
|
+
if (Buffer.from(secret).length !== secretLength[algorithm]) {
|
|
10
|
+
throw new SecretLengthError();
|
|
11
|
+
}
|
|
12
|
+
};
|
|
13
|
+
export { validateSecretLength, };
|
package/dist/cli/Args.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -1,12 +1,6 @@
|
|
|
1
|
-
|
|
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.parseArgs = void 0;
|
|
7
|
-
const yargs_parser_1 = __importDefault(require("yargs-parser"));
|
|
1
|
+
import yargsParser from 'yargs-parser';
|
|
8
2
|
const parseArgs = (args) => {
|
|
9
|
-
const parsed = (
|
|
3
|
+
const parsed = yargsParser(args, {
|
|
10
4
|
configuration: {
|
|
11
5
|
'boolean-negation': false,
|
|
12
6
|
'camel-case-expansion': true,
|
|
@@ -28,4 +22,4 @@ const parseArgs = (args) => {
|
|
|
28
22
|
optional,
|
|
29
23
|
};
|
|
30
24
|
};
|
|
31
|
-
|
|
25
|
+
export { parseArgs, };
|
|
@@ -1,7 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.formatTable = void 0;
|
|
4
|
-
const os_1 = require("os");
|
|
1
|
+
import { EOL } from 'os';
|
|
5
2
|
const formatTable = (table) => {
|
|
6
3
|
const colLength = [];
|
|
7
4
|
table.forEach((row) => {
|
|
@@ -17,6 +14,6 @@ const formatTable = (table) => {
|
|
|
17
14
|
.map((col, i) => { return col.padEnd(colLength[i], ' '); })
|
|
18
15
|
.join(' ');
|
|
19
16
|
})
|
|
20
|
-
.join(
|
|
17
|
+
.join(EOL);
|
|
21
18
|
};
|
|
22
|
-
|
|
19
|
+
export { formatTable, };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { getPropertyEnvVar } from './getPropertyEnvVar';
|
|
2
|
+
import { parseProperty } from './parseProperty';
|
|
3
|
+
import { readFile } from './readFile';
|
|
4
|
+
import { validatePropertyName } from './validatePropertyName';
|
|
5
|
+
const getConfig = (params) => {
|
|
6
|
+
const file = params.file
|
|
7
|
+
? readFile(params.file.path, params.file.required)
|
|
8
|
+
: {};
|
|
9
|
+
const env = params.env ?? {};
|
|
10
|
+
const args = params.args ?? { positional: [], optional: {} };
|
|
11
|
+
const config = {};
|
|
12
|
+
for (const name in params.properties) {
|
|
13
|
+
validatePropertyName(name);
|
|
14
|
+
config[name] = parseProperty(name, params.properties[name].parser, params.properties[name].default, file[name], env[getPropertyEnvVar(name)], args.optional[name]);
|
|
15
|
+
}
|
|
16
|
+
return config;
|
|
17
|
+
};
|
|
18
|
+
export { getConfig, };
|
|
@@ -1,6 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getPropertyEnvVar = void 0;
|
|
4
1
|
const capitalLetterRegex = /[A-Z]/gu;
|
|
5
2
|
const capitalLetterReplacer = (letter) => {
|
|
6
3
|
return `_${letter}`;
|
|
@@ -10,4 +7,4 @@ const getPropertyEnvVar = (name) => {
|
|
|
10
7
|
.replace(capitalLetterRegex, capitalLetterReplacer)
|
|
11
8
|
.toUpperCase();
|
|
12
9
|
};
|
|
13
|
-
|
|
10
|
+
export { getPropertyEnvVar, };
|
|
@@ -1,7 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.parseProperty = void 0;
|
|
4
|
-
const PropertyParseError_1 = require("./errors/PropertyParseError");
|
|
1
|
+
import { PropertyParseError } from './errors/PropertyParseError';
|
|
5
2
|
const parseProperty = (name, parser, defaultValue, fileValue, envValue, argsValue) => {
|
|
6
3
|
const sources = [
|
|
7
4
|
{
|
|
@@ -31,7 +28,7 @@ const parseProperty = (name, parser, defaultValue, fileValue, envValue, argsValu
|
|
|
31
28
|
return parser(source.value);
|
|
32
29
|
}
|
|
33
30
|
catch (error) {
|
|
34
|
-
throw new
|
|
31
|
+
throw new PropertyParseError(name, source.name, error.message);
|
|
35
32
|
}
|
|
36
33
|
};
|
|
37
|
-
|
|
34
|
+
export { parseProperty, };
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import fs from 'fs-extra';
|
|
2
|
+
import { FileReadError } from './errors/FileReadError';
|
|
3
|
+
const readFile = (path, required = false) => {
|
|
4
|
+
let json = {};
|
|
5
|
+
let fileExists;
|
|
6
|
+
try {
|
|
7
|
+
fileExists = fs.existsSync(path);
|
|
8
|
+
if (fileExists) {
|
|
9
|
+
json = fs.readJsonSync(path);
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
catch (error) {
|
|
13
|
+
throw new FileReadError(path, error.message);
|
|
14
|
+
}
|
|
15
|
+
if (required && !fileExists) {
|
|
16
|
+
throw new FileReadError(path, 'missing file');
|
|
17
|
+
}
|
|
18
|
+
if (typeof json !== 'object'
|
|
19
|
+
|| Array.isArray(json)
|
|
20
|
+
|| json === null) {
|
|
21
|
+
throw new FileReadError(path, 'invalid content');
|
|
22
|
+
}
|
|
23
|
+
return json;
|
|
24
|
+
};
|
|
25
|
+
export { readFile, };
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { PropertyNameError } from './errors/PropertyNameError';
|
|
2
|
+
const propertyNameRegex = /^[a-z](?:[0-9A-Za-z])*$/u;
|
|
3
|
+
const validatePropertyName = (name) => {
|
|
4
|
+
if (!propertyNameRegex.test(name)) {
|
|
5
|
+
throw new PropertyNameError(name);
|
|
6
|
+
}
|
|
7
|
+
};
|
|
8
|
+
export { validatePropertyName, };
|
package/dist/env/Env.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import dotenv from 'dotenv';
|
|
2
|
+
import fs from 'fs-extra';
|
|
3
|
+
import { FileReadError } from './errors/FileReadError';
|
|
4
|
+
const readFile = (path, required = false) => {
|
|
5
|
+
try {
|
|
6
|
+
if (fs.existsSync(path)) {
|
|
7
|
+
return dotenv.parse(fs.readFileSync(path));
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
catch (error) {
|
|
11
|
+
throw new FileReadError(path, error.message);
|
|
12
|
+
}
|
|
13
|
+
if (required) {
|
|
14
|
+
throw new FileReadError(path, 'missing file');
|
|
15
|
+
}
|
|
16
|
+
return {};
|
|
17
|
+
};
|
|
18
|
+
export { readFile, };
|
|
@@ -1,6 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.BaseError = void 0;
|
|
4
1
|
class BaseError extends Error {
|
|
5
2
|
constructor(message) {
|
|
6
3
|
super(message);
|
|
@@ -9,4 +6,4 @@ class BaseError extends Error {
|
|
|
9
6
|
Object.setPrototypeOf(this, new.target.prototype);
|
|
10
7
|
}
|
|
11
8
|
}
|
|
12
|
-
|
|
9
|
+
export { BaseError, };
|
package/{jwt → dist/jwt}/Jwt.js
RENAMED
|
@@ -1,18 +1,15 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
exports.Jwt = void 0;
|
|
4
|
-
const jose_1 = require("jose");
|
|
5
|
-
const validateSecretLength_1 = require("./validateSecretLength");
|
|
1
|
+
import { SignJWT, jwtVerify } from 'jose';
|
|
2
|
+
import { validateSecretLength } from './validateSecretLength';
|
|
6
3
|
class Jwt {
|
|
7
4
|
algorithm;
|
|
8
5
|
secret;
|
|
9
6
|
constructor(params) {
|
|
10
|
-
|
|
7
|
+
validateSecretLength(params.algorithm, params.secret);
|
|
11
8
|
this.algorithm = params.algorithm;
|
|
12
9
|
this.secret = new TextEncoder().encode(params.secret);
|
|
13
10
|
}
|
|
14
11
|
async createToken(payload) {
|
|
15
|
-
return new
|
|
12
|
+
return new SignJWT(payload)
|
|
16
13
|
.setProtectedHeader({
|
|
17
14
|
typ: 'JWT',
|
|
18
15
|
alg: this.algorithm,
|
|
@@ -21,7 +18,7 @@ class Jwt {
|
|
|
21
18
|
}
|
|
22
19
|
async verifyToken(token, timestamp) {
|
|
23
20
|
try {
|
|
24
|
-
const { payload } = await
|
|
21
|
+
const { payload } = await jwtVerify(token, this.secret, {
|
|
25
22
|
typ: 'JWT',
|
|
26
23
|
currentDate: new Date(timestamp * 1000),
|
|
27
24
|
});
|
|
@@ -32,4 +29,4 @@ class Jwt {
|
|
|
32
29
|
}
|
|
33
30
|
}
|
|
34
31
|
}
|
|
35
|
-
|
|
32
|
+
export { Jwt, };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Algorithm } from './Algorithm';
|
|
2
|
+
import { SecretLengthError } from './errors/SecretLengthError';
|
|
3
|
+
const minSecretLength = {
|
|
4
|
+
[Algorithm.HS256]: 32,
|
|
5
|
+
[Algorithm.HS384]: 48,
|
|
6
|
+
[Algorithm.HS512]: 64,
|
|
7
|
+
};
|
|
8
|
+
const validateSecretLength = (algorithm, secret) => {
|
|
9
|
+
if (Buffer.from(secret).length < minSecretLength[algorithm]) {
|
|
10
|
+
throw new SecretLengthError();
|
|
11
|
+
}
|
|
12
|
+
};
|
|
13
|
+
export { validateSecretLength, };
|
|
@@ -1,6 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Level = void 0;
|
|
4
1
|
var Level;
|
|
5
2
|
(function (Level) {
|
|
6
3
|
Level["TRACE"] = "trace";
|
|
@@ -10,4 +7,5 @@ var Level;
|
|
|
10
7
|
Level["ERROR"] = "error";
|
|
11
8
|
Level["FATAL"] = "fatal";
|
|
12
9
|
Level["OFF"] = "off";
|
|
13
|
-
})(Level || (
|
|
10
|
+
})(Level || (Level = {}));
|
|
11
|
+
export { Level, };
|
|
@@ -1,6 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Severity = void 0;
|
|
4
1
|
var Severity;
|
|
5
2
|
(function (Severity) {
|
|
6
3
|
Severity[Severity["TRACE"] = 10] = "TRACE";
|
|
@@ -9,4 +6,5 @@ var Severity;
|
|
|
9
6
|
Severity[Severity["WARN"] = 40] = "WARN";
|
|
10
7
|
Severity[Severity["ERROR"] = 50] = "ERROR";
|
|
11
8
|
Severity[Severity["FATAL"] = 60] = "FATAL";
|
|
12
|
-
})(Severity || (
|
|
9
|
+
})(Severity || (Severity = {}));
|
|
10
|
+
export { Severity, };
|
|
@@ -1,23 +1,17 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
5
|
-
|
|
6
|
-
exports.FileLogger = void 0;
|
|
7
|
-
const pino_1 = __importDefault(require("pino"));
|
|
8
|
-
const Level_1 = require("../../Level");
|
|
9
|
-
const Logger_1 = require("../../Logger");
|
|
10
|
-
const initFile_1 = require("./initFile");
|
|
11
|
-
class FileLogger extends Logger_1.Logger {
|
|
1
|
+
import pino from 'pino';
|
|
2
|
+
import { Level } from '../../Level';
|
|
3
|
+
import { Logger } from '../../Logger';
|
|
4
|
+
import { initFile } from './initFile';
|
|
5
|
+
class FileLogger extends Logger {
|
|
12
6
|
logger;
|
|
13
7
|
context;
|
|
14
8
|
constructor(params) {
|
|
15
9
|
super();
|
|
16
|
-
|
|
17
|
-
const stream =
|
|
18
|
-
this.logger = (
|
|
19
|
-
enabled: params.level !==
|
|
20
|
-
level: params.level ??
|
|
10
|
+
initFile(params.path);
|
|
11
|
+
const stream = pino.destination(params.path);
|
|
12
|
+
this.logger = pino({
|
|
13
|
+
enabled: params.level !== Level.OFF,
|
|
14
|
+
level: params.level ?? Level.INFO,
|
|
21
15
|
messageKey: 'message',
|
|
22
16
|
formatters: {
|
|
23
17
|
level(label, number) {
|
|
@@ -67,4 +61,4 @@ class FileLogger extends Logger_1.Logger {
|
|
|
67
61
|
};
|
|
68
62
|
}
|
|
69
63
|
}
|
|
70
|
-
|
|
64
|
+
export { FileLogger, };
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import fs from 'fs-extra';
|
|
2
|
+
import { FileInitError } from './errors/FileInitError';
|
|
3
|
+
const initFile = (path) => {
|
|
4
|
+
if (path === '') {
|
|
5
|
+
throw new FileInitError('', 'empty path');
|
|
6
|
+
}
|
|
7
|
+
try {
|
|
8
|
+
fs.ensureFileSync(path);
|
|
9
|
+
}
|
|
10
|
+
catch (error) {
|
|
11
|
+
throw new FileInitError(path, error.message);
|
|
12
|
+
}
|
|
13
|
+
};
|
|
14
|
+
export { initFile, };
|
|
@@ -1,24 +1,18 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
5
|
-
|
|
6
|
-
exports.StdioLogger = void 0;
|
|
7
|
-
const pino_1 = __importDefault(require("pino"));
|
|
8
|
-
const pino_pretty_1 = __importDefault(require("pino-pretty"));
|
|
9
|
-
const Level_1 = require("../../Level");
|
|
10
|
-
const Logger_1 = require("../../Logger");
|
|
11
|
-
class StdioLogger extends Logger_1.Logger {
|
|
1
|
+
import pino from 'pino';
|
|
2
|
+
import pretty from 'pino-pretty';
|
|
3
|
+
import { Level } from '../../Level';
|
|
4
|
+
import { Logger } from '../../Logger';
|
|
5
|
+
class StdioLogger extends Logger {
|
|
12
6
|
logger;
|
|
13
7
|
context;
|
|
14
8
|
constructor(params) {
|
|
15
9
|
super();
|
|
16
10
|
const stream = params?.pretty
|
|
17
|
-
? (
|
|
18
|
-
:
|
|
19
|
-
this.logger = (
|
|
20
|
-
enabled: params?.level !==
|
|
21
|
-
level: params?.level ??
|
|
11
|
+
? pretty()
|
|
12
|
+
: pino.destination(process.stdout.fd);
|
|
13
|
+
this.logger = pino({
|
|
14
|
+
enabled: params?.level !== Level.OFF,
|
|
15
|
+
level: params?.level ?? Level.INFO,
|
|
22
16
|
messageKey: 'message',
|
|
23
17
|
formatters: {
|
|
24
18
|
level(label, number) {
|
|
@@ -70,4 +64,4 @@ class StdioLogger extends Logger_1.Logger {
|
|
|
70
64
|
};
|
|
71
65
|
}
|
|
72
66
|
}
|
|
73
|
-
|
|
67
|
+
export { StdioLogger, };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|