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
|
@@ -0,0 +1,47 @@
|
|
|
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
|
+
class Mailer {
|
|
7
|
+
async send(mail) {
|
|
8
|
+
validateAddressEmail(mail.from.email);
|
|
9
|
+
if (mail.sender) {
|
|
10
|
+
validateAddressEmail(mail.sender.email);
|
|
11
|
+
}
|
|
12
|
+
if (mail.replyTo) {
|
|
13
|
+
validateAddressEmail(mail.replyTo.email);
|
|
14
|
+
}
|
|
15
|
+
mail.to.forEach((address) => {
|
|
16
|
+
validateAddressEmail(address.email);
|
|
17
|
+
});
|
|
18
|
+
if (mail.cc) {
|
|
19
|
+
mail.cc.forEach((address) => {
|
|
20
|
+
validateAddressEmail(address.email);
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
if (mail.bcc) {
|
|
24
|
+
mail.bcc.forEach((address) => {
|
|
25
|
+
validateAddressEmail(address.email);
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
if (mail.event?.url) {
|
|
29
|
+
validateEventUrl(mail.event.url);
|
|
30
|
+
}
|
|
31
|
+
if (mail.event?.location?.geo) {
|
|
32
|
+
validateEventGeolocation(mail.event.location.geo.latitude, mail.event.location.geo.longitude);
|
|
33
|
+
}
|
|
34
|
+
if (mail.event?.attachments) {
|
|
35
|
+
mail.event.attachments.forEach((attachment) => {
|
|
36
|
+
validateEventAttachmentUrl(attachment);
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
if (mail.list) {
|
|
40
|
+
Object.entries(mail.list).forEach(([property, url]) => {
|
|
41
|
+
validateListUrl(property, url);
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
return this.sendMail(mail);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
export { Mailer, };
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import nodemailer from 'nodemailer';
|
|
2
|
+
import { getTls } from '../../../tls/getTls';
|
|
3
|
+
import { Mailer } from '../../Mailer';
|
|
4
|
+
import { getIcalendar } from '../../getIcalendar';
|
|
5
|
+
import { getAddress } from './getAddress';
|
|
6
|
+
import { getAddresses } from './getAddresses';
|
|
7
|
+
import { getAttachments } from './getAttachments';
|
|
8
|
+
class SmtpMailer extends Mailer {
|
|
9
|
+
transporter;
|
|
10
|
+
constructor(params) {
|
|
11
|
+
super();
|
|
12
|
+
this.transporter = nodemailer.createTransport({
|
|
13
|
+
host: params.host,
|
|
14
|
+
port: params.port,
|
|
15
|
+
secure: params.secure ?? false,
|
|
16
|
+
tls: getTls(params.tls),
|
|
17
|
+
auth: params.user || params.password
|
|
18
|
+
? {
|
|
19
|
+
user: params.user,
|
|
20
|
+
pass: params.password,
|
|
21
|
+
}
|
|
22
|
+
: undefined,
|
|
23
|
+
pool: true,
|
|
24
|
+
maxConnections: params.maxConnections ?? 5,
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
async sendMail(mail) {
|
|
28
|
+
const result = await this.transporter.sendMail({
|
|
29
|
+
from: getAddress(mail.from),
|
|
30
|
+
sender: getAddress(mail.sender),
|
|
31
|
+
replyTo: getAddress(mail.replyTo),
|
|
32
|
+
to: getAddresses(mail.to),
|
|
33
|
+
cc: getAddresses(mail.cc),
|
|
34
|
+
bcc: getAddresses(mail.bcc),
|
|
35
|
+
subject: mail.subject,
|
|
36
|
+
text: mail.text,
|
|
37
|
+
html: mail.html,
|
|
38
|
+
attachments: getAttachments(mail.attachments),
|
|
39
|
+
icalEvent: mail.event
|
|
40
|
+
? {
|
|
41
|
+
filename: mail.event.fileName ?? 'event.ics',
|
|
42
|
+
method: mail.event.method,
|
|
43
|
+
content: getIcalendar(mail.event),
|
|
44
|
+
}
|
|
45
|
+
: undefined,
|
|
46
|
+
list: { ...mail.list },
|
|
47
|
+
});
|
|
48
|
+
return result.messageId.slice(1, -1);
|
|
49
|
+
}
|
|
50
|
+
async close() {
|
|
51
|
+
this.transporter.close();
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
export { SmtpMailer, };
|
|
@@ -1,6 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getAddress = void 0;
|
|
4
1
|
const getAddress = (address) => {
|
|
5
2
|
return address
|
|
6
3
|
? {
|
|
@@ -9,4 +6,4 @@ const getAddress = (address) => {
|
|
|
9
6
|
}
|
|
10
7
|
: undefined;
|
|
11
8
|
};
|
|
12
|
-
|
|
9
|
+
export { getAddress, };
|
|
@@ -1,6 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getAttachments = void 0;
|
|
4
1
|
const getAttachments = (attachments) => {
|
|
5
2
|
return attachments
|
|
6
3
|
? attachments
|
|
@@ -14,4 +11,4 @@ const getAttachments = (attachments) => {
|
|
|
14
11
|
})
|
|
15
12
|
: [];
|
|
16
13
|
};
|
|
17
|
-
|
|
14
|
+
export { getAttachments, };
|
|
@@ -1,9 +1,6 @@
|
|
|
1
|
-
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getIcalendar = void 0;
|
|
4
|
-
const ical_generator_1 = require("ical-generator");
|
|
1
|
+
import { ICalCalendar } from 'ical-generator';
|
|
5
2
|
const getIcalendar = (event) => {
|
|
6
|
-
const calendar = new
|
|
3
|
+
const calendar = new ICalCalendar({
|
|
7
4
|
method: event.method,
|
|
8
5
|
events: [
|
|
9
6
|
{
|
|
@@ -32,4 +29,4 @@ const getIcalendar = (event) => {
|
|
|
32
29
|
});
|
|
33
30
|
return calendar.toString();
|
|
34
31
|
};
|
|
35
|
-
|
|
32
|
+
export { getIcalendar, };
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { isValidEmail } from 'utils/isValidEmail';
|
|
2
|
+
import { AddressEmailError } from './errors/AddressEmailError';
|
|
3
|
+
const validateAddressEmail = (email) => {
|
|
4
|
+
if (!isValidEmail(email)) {
|
|
5
|
+
throw new AddressEmailError(email);
|
|
6
|
+
}
|
|
7
|
+
};
|
|
8
|
+
export { validateAddressEmail, };
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { isValidUrl } from 'utils/isValidUrl';
|
|
2
|
+
import { EventAttachmentUrlError } from './errors/EventAttachmentUrlError';
|
|
3
|
+
const validateEventAttachmentUrl = (url) => {
|
|
4
|
+
if (!isValidUrl(url)) {
|
|
5
|
+
throw new EventAttachmentUrlError(url);
|
|
6
|
+
}
|
|
7
|
+
};
|
|
8
|
+
export { validateEventAttachmentUrl, };
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { isValidGeolocation } from 'utils/isValidGeolocation';
|
|
2
|
+
import { EventGeolocationError } from './errors/EventGeolocationError';
|
|
3
|
+
const validateEventGeolocation = (latitude, longitude) => {
|
|
4
|
+
if (!isValidGeolocation(latitude, longitude)) {
|
|
5
|
+
throw new EventGeolocationError(latitude, longitude);
|
|
6
|
+
}
|
|
7
|
+
};
|
|
8
|
+
export { validateEventGeolocation, };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ParseError } from '../../errors/ParseError';
|
|
2
|
+
const createEnumParser = (params) => {
|
|
3
|
+
return (input) => {
|
|
4
|
+
if (!Object.values(params.enum).includes(input)) {
|
|
5
|
+
throw new ParseError(params.type);
|
|
6
|
+
}
|
|
7
|
+
return input;
|
|
8
|
+
};
|
|
9
|
+
};
|
|
10
|
+
export { createEnumParser, };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -1,17 +1,14 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const ParseError_1 = require("../../errors/ParseError");
|
|
5
|
-
const parseNumber_1 = require("../../parseNumber");
|
|
6
|
-
const parseString_1 = require("../../parseString");
|
|
1
|
+
import { ParseError } from '../../errors/ParseError';
|
|
2
|
+
import { parseNumber } from '../../parseNumber';
|
|
3
|
+
import { parseString } from '../../parseString';
|
|
7
4
|
const createUnitParser = (params) => {
|
|
8
5
|
return (input) => {
|
|
9
6
|
let string;
|
|
10
7
|
try {
|
|
11
|
-
string =
|
|
8
|
+
string = parseString(input);
|
|
12
9
|
}
|
|
13
10
|
catch (error) {
|
|
14
|
-
throw new
|
|
11
|
+
throw new ParseError(params.type);
|
|
15
12
|
}
|
|
16
13
|
const units = [];
|
|
17
14
|
params.units.forEach((u) => {
|
|
@@ -25,12 +22,12 @@ const createUnitParser = (params) => {
|
|
|
25
22
|
});
|
|
26
23
|
let number;
|
|
27
24
|
try {
|
|
28
|
-
number =
|
|
25
|
+
number = parseNumber(string.substring(0, string.length - (unit?.symbol.length ?? 0)));
|
|
29
26
|
}
|
|
30
27
|
catch (error) {
|
|
31
|
-
throw new
|
|
28
|
+
throw new ParseError(params.type);
|
|
32
29
|
}
|
|
33
30
|
return number * (unit?.value ?? 1);
|
|
34
31
|
};
|
|
35
32
|
};
|
|
36
|
-
|
|
33
|
+
export { createUnitParser, };
|
|
@@ -1,7 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.parseBoolean = void 0;
|
|
4
|
-
const ParseError_1 = require("./errors/ParseError");
|
|
1
|
+
import { ParseError } from './errors/ParseError';
|
|
5
2
|
const parseBoolean = (input) => {
|
|
6
3
|
if ([
|
|
7
4
|
true,
|
|
@@ -26,6 +23,6 @@ const parseBoolean = (input) => {
|
|
|
26
23
|
].includes(input)) {
|
|
27
24
|
return false;
|
|
28
25
|
}
|
|
29
|
-
throw new
|
|
26
|
+
throw new ParseError('boolean');
|
|
30
27
|
};
|
|
31
|
-
|
|
28
|
+
export { parseBoolean, };
|
|
@@ -1,8 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
exports.parseBytes = void 0;
|
|
4
|
-
const createUnitParser_1 = require("./factories/unit/createUnitParser");
|
|
5
|
-
const parseBytes = (0, createUnitParser_1.createUnitParser)({
|
|
1
|
+
import { createUnitParser } from './factories/unit/createUnitParser';
|
|
2
|
+
const parseBytes = createUnitParser({
|
|
6
3
|
type: 'bytes',
|
|
7
4
|
units: [
|
|
8
5
|
{
|
|
@@ -51,4 +48,4 @@ const parseBytes = (0, createUnitParser_1.createUnitParser)({
|
|
|
51
48
|
},
|
|
52
49
|
],
|
|
53
50
|
});
|
|
54
|
-
|
|
51
|
+
export { parseBytes, };
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ParseError } from './errors/ParseError';
|
|
2
|
+
import { parseNumber } from './parseNumber';
|
|
3
|
+
const parseInteger = (input) => {
|
|
4
|
+
let number;
|
|
5
|
+
try {
|
|
6
|
+
number = parseNumber(input);
|
|
7
|
+
}
|
|
8
|
+
catch (error) {
|
|
9
|
+
throw new ParseError('integer');
|
|
10
|
+
}
|
|
11
|
+
if (!Number.isSafeInteger(number)) {
|
|
12
|
+
throw new ParseError('integer');
|
|
13
|
+
}
|
|
14
|
+
return number;
|
|
15
|
+
};
|
|
16
|
+
export { parseInteger, };
|
|
@@ -1,8 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
exports.parseMilliseconds = void 0;
|
|
4
|
-
const createUnitParser_1 = require("./factories/unit/createUnitParser");
|
|
5
|
-
const parseMilliseconds = (0, createUnitParser_1.createUnitParser)({
|
|
1
|
+
import { createUnitParser } from './factories/unit/createUnitParser';
|
|
2
|
+
const parseMilliseconds = createUnitParser({
|
|
6
3
|
type: 'milliseconds',
|
|
7
4
|
units: [
|
|
8
5
|
{
|
|
@@ -27,4 +24,4 @@ const parseMilliseconds = (0, createUnitParser_1.createUnitParser)({
|
|
|
27
24
|
},
|
|
28
25
|
],
|
|
29
26
|
});
|
|
30
|
-
|
|
27
|
+
export { parseMilliseconds, };
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { ParseError } from './errors/ParseError';
|
|
2
|
+
const parseNumber = (input) => {
|
|
3
|
+
if ([undefined, null].includes(input)) {
|
|
4
|
+
return 0;
|
|
5
|
+
}
|
|
6
|
+
else if (['object', 'function', 'symbol'].includes(typeof input)) {
|
|
7
|
+
throw new ParseError('number');
|
|
8
|
+
}
|
|
9
|
+
const number = Number(input);
|
|
10
|
+
if (!Number.isFinite(number)) {
|
|
11
|
+
throw new ParseError('number');
|
|
12
|
+
}
|
|
13
|
+
return number;
|
|
14
|
+
};
|
|
15
|
+
export { parseNumber, };
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ParseError } from './errors/ParseError';
|
|
2
|
+
const parseString = (input) => {
|
|
3
|
+
if ([undefined, null].includes(input)) {
|
|
4
|
+
return '';
|
|
5
|
+
}
|
|
6
|
+
else if (['object', 'function', 'symbol'].includes(typeof input)) {
|
|
7
|
+
throw new ParseError('string');
|
|
8
|
+
}
|
|
9
|
+
return String(input);
|
|
10
|
+
};
|
|
11
|
+
export { parseString, };
|
package/dist/pwd/Pwd.js
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import bcrypt from 'bcryptjs';
|
|
2
|
+
import { validateHashRounds } from './validateHashRounds';
|
|
3
|
+
class Pwd {
|
|
4
|
+
hashRounds;
|
|
5
|
+
constructor(params) {
|
|
6
|
+
validateHashRounds(params.hashRounds);
|
|
7
|
+
this.hashRounds = params.hashRounds;
|
|
8
|
+
}
|
|
9
|
+
async hashPassword(password) {
|
|
10
|
+
return bcrypt.hashSync(password, this.hashRounds);
|
|
11
|
+
}
|
|
12
|
+
async verifyPassword(password, hash) {
|
|
13
|
+
return bcrypt.compareSync(password, hash);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
export { Pwd, };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -1,6 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Method = void 0;
|
|
4
1
|
var Method;
|
|
5
2
|
(function (Method) {
|
|
6
3
|
Method["DELETE"] = "DELETE";
|
|
@@ -8,4 +5,5 @@ var Method;
|
|
|
8
5
|
Method["PATCH"] = "PATCH";
|
|
9
6
|
Method["POST"] = "POST";
|
|
10
7
|
Method["PUT"] = "PUT";
|
|
11
|
-
})(Method || (
|
|
8
|
+
})(Method || (Method = {}));
|
|
9
|
+
export { Method, };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -1,16 +1,10 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
const cors_1 = __importDefault(require("@fastify/cors"));
|
|
9
|
-
const response_validation_1 = __importDefault(require("@fastify/response-validation"));
|
|
10
|
-
const swagger_1 = __importDefault(require("@fastify/swagger"));
|
|
11
|
-
const fastify_1 = __importDefault(require("fastify"));
|
|
12
|
-
const OpenApiFormat_1 = require("./OpenApiFormat");
|
|
13
|
-
const getAjv_1 = require("./getAjv");
|
|
1
|
+
import compress from '@fastify/compress';
|
|
2
|
+
import cors from '@fastify/cors';
|
|
3
|
+
import responseValidation from '@fastify/response-validation';
|
|
4
|
+
import swagger from '@fastify/swagger';
|
|
5
|
+
import fastify from 'fastify';
|
|
6
|
+
import { OpenApiFormat } from './OpenApiFormat';
|
|
7
|
+
import { getAjv } from './getAjv';
|
|
14
8
|
class Server {
|
|
15
9
|
server;
|
|
16
10
|
host;
|
|
@@ -18,11 +12,11 @@ class Server {
|
|
|
18
12
|
constructor(params) {
|
|
19
13
|
this.host = params.host;
|
|
20
14
|
this.port = params.port;
|
|
21
|
-
this.server = (
|
|
15
|
+
this.server = fastify();
|
|
22
16
|
this.server.setValidatorCompiler(({ schema }) => {
|
|
23
|
-
return
|
|
17
|
+
return getAjv(params.formats).compile(schema);
|
|
24
18
|
});
|
|
25
|
-
this.server.register(
|
|
19
|
+
this.server.register(swagger, {
|
|
26
20
|
openapi: {
|
|
27
21
|
openapi: '3.1.0',
|
|
28
22
|
info: {
|
|
@@ -32,16 +26,16 @@ class Server {
|
|
|
32
26
|
},
|
|
33
27
|
});
|
|
34
28
|
if (params.responseValidation) {
|
|
35
|
-
this.server.register(
|
|
29
|
+
this.server.register(responseValidation);
|
|
36
30
|
}
|
|
37
31
|
if (params.compression?.enabled) {
|
|
38
|
-
this.server.register(
|
|
32
|
+
this.server.register(compress, {
|
|
39
33
|
global: true,
|
|
40
34
|
threshold: params.compression.threshold ?? 1024,
|
|
41
35
|
});
|
|
42
36
|
}
|
|
43
37
|
if (params.cors?.enabled) {
|
|
44
|
-
this.server.register(
|
|
38
|
+
this.server.register(cors, {
|
|
45
39
|
origin: params.cors.origins,
|
|
46
40
|
});
|
|
47
41
|
}
|
|
@@ -85,8 +79,8 @@ class Server {
|
|
|
85
79
|
}
|
|
86
80
|
openapi(format) {
|
|
87
81
|
return this.server.swagger({
|
|
88
|
-
yaml: format ===
|
|
82
|
+
yaml: format === OpenApiFormat.YAML,
|
|
89
83
|
});
|
|
90
84
|
}
|
|
91
85
|
}
|
|
92
|
-
|
|
86
|
+
export { Server, };
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Ajv } from 'ajv';
|
|
2
|
+
import fastUri from 'fast-uri';
|
|
3
|
+
const getAjv = (formats) => {
|
|
4
|
+
const ajv = new Ajv({
|
|
5
|
+
addUsedSchema: false,
|
|
6
|
+
allErrors: false,
|
|
7
|
+
coerceTypes: 'array',
|
|
8
|
+
removeAdditional: true,
|
|
9
|
+
uriResolver: fastUri,
|
|
10
|
+
useDefaults: true,
|
|
11
|
+
});
|
|
12
|
+
if (formats) {
|
|
13
|
+
formats.forEach((format) => {
|
|
14
|
+
ajv.addFormat(format.name, format);
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
return ajv;
|
|
18
|
+
};
|
|
19
|
+
export { getAjv, };
|
package/dist/tls/Tls.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { readFile } from './readFile';
|
|
2
|
+
const getTls = (tls) => {
|
|
3
|
+
return tls
|
|
4
|
+
? {
|
|
5
|
+
...tls.key ? { key: readFile(tls.key) } : {},
|
|
6
|
+
...tls.cert ? { cert: readFile(tls.cert) } : {},
|
|
7
|
+
...tls.ca ? { ca: readFile(tls.ca) } : {},
|
|
8
|
+
...tls.verify === undefined
|
|
9
|
+
? {}
|
|
10
|
+
: { rejectUnauthorized: tls.verify },
|
|
11
|
+
}
|
|
12
|
+
: undefined;
|
|
13
|
+
};
|
|
14
|
+
export { getTls, };
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import fs from 'fs-extra';
|
|
2
|
+
import { FileReadError } from './errors/FileReadError';
|
|
3
|
+
const readFile = (path) => {
|
|
4
|
+
try {
|
|
5
|
+
if (fs.existsSync(path)) {
|
|
6
|
+
return fs.readFileSync(path).toString();
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
catch (error) {
|
|
10
|
+
throw new FileReadError(path, error.message);
|
|
11
|
+
}
|
|
12
|
+
throw new FileReadError(path, 'missing file');
|
|
13
|
+
};
|
|
14
|
+
export { readFile, };
|