@webiny/api-mailer 6.0.0-beta.0 → 6.0.0-rc.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.
Files changed (165) hide show
  1. package/README.md +10 -13
  2. package/constants.d.ts +1 -0
  3. package/constants.js +3 -0
  4. package/constants.js.map +1 -0
  5. package/domain/Encryption/abstractions.d.ts +8 -0
  6. package/domain/Encryption/abstractions.js +4 -0
  7. package/domain/Encryption/abstractions.js.map +1 -0
  8. package/domain/MailTransport/abstractions.d.ts +18 -0
  9. package/domain/MailTransport/abstractions.js +5 -0
  10. package/domain/MailTransport/abstractions.js.map +1 -0
  11. package/domain/MailerService/abstractions.d.ts +19 -0
  12. package/domain/MailerService/abstractions.js +4 -0
  13. package/domain/MailerService/abstractions.js.map +1 -0
  14. package/domain/MailerService/errors.d.ts +16 -0
  15. package/domain/MailerService/errors.js +30 -0
  16. package/domain/MailerService/errors.js.map +1 -0
  17. package/domain/errors.d.ts +24 -0
  18. package/domain/errors.js +44 -0
  19. package/domain/errors.js.map +1 -0
  20. package/features/DummyTransport/DummyMailTransport.d.ts +9 -0
  21. package/features/DummyTransport/DummyMailTransport.js +12 -0
  22. package/features/DummyTransport/DummyMailTransport.js.map +1 -0
  23. package/features/DummyTransport/DummyMailTransportFactory.d.ts +8 -0
  24. package/features/DummyTransport/DummyMailTransportFactory.js +13 -0
  25. package/features/DummyTransport/DummyMailTransportFactory.js.map +1 -0
  26. package/features/DummyTransport/feature.d.ts +1 -0
  27. package/features/DummyTransport/feature.js +10 -0
  28. package/features/DummyTransport/feature.js.map +1 -0
  29. package/features/Encryption/PasswordEncryption.d.ts +9 -0
  30. package/features/Encryption/PasswordEncryption.js +23 -0
  31. package/features/Encryption/PasswordEncryption.js.map +1 -0
  32. package/features/Encryption/feature.d.ts +1 -0
  33. package/features/Encryption/feature.js +10 -0
  34. package/features/Encryption/feature.js.map +1 -0
  35. package/features/Encryption/utils/password.js +56 -0
  36. package/features/Encryption/utils/password.js.map +1 -0
  37. package/features/Encryption/utils/secret.js +11 -0
  38. package/features/Encryption/utils/secret.js.map +1 -0
  39. package/features/GetSettings/GetSettingsRepository.d.ts +15 -0
  40. package/features/GetSettings/GetSettingsRepository.js +39 -0
  41. package/features/GetSettings/GetSettingsRepository.js.map +1 -0
  42. package/features/GetSettings/GetSettingsUseCase.d.ts +12 -0
  43. package/features/GetSettings/GetSettingsUseCase.js +15 -0
  44. package/features/GetSettings/GetSettingsUseCase.js.map +1 -0
  45. package/features/GetSettings/abstractions.d.ts +16 -0
  46. package/features/GetSettings/abstractions.js +5 -0
  47. package/features/GetSettings/abstractions.js.map +1 -0
  48. package/features/GetSettings/feature.d.ts +1 -0
  49. package/features/GetSettings/feature.js +12 -0
  50. package/features/GetSettings/feature.js.map +1 -0
  51. package/features/GetSettings/index.d.ts +1 -0
  52. package/features/GetSettings/index.js +3 -0
  53. package/features/GetSettings/index.js.map +1 -0
  54. package/features/MailerService/MailerService.d.ts +15 -0
  55. package/features/MailerService/MailerService.js +52 -0
  56. package/features/MailerService/MailerService.js.map +1 -0
  57. package/features/MailerService/TransportFactory.d.ts +2 -0
  58. package/features/MailerService/TransportFactory.js +31 -0
  59. package/features/MailerService/TransportFactory.js.map +1 -0
  60. package/features/MailerService/feature.d.ts +1 -0
  61. package/features/MailerService/feature.js +10 -0
  62. package/features/MailerService/feature.js.map +1 -0
  63. package/features/SaveSettings/SaveSettingsRepository.d.ts +13 -0
  64. package/features/SaveSettings/SaveSettingsRepository.js +57 -0
  65. package/features/SaveSettings/SaveSettingsRepository.js.map +1 -0
  66. package/features/SaveSettings/SaveSettingsUseCase.d.ts +14 -0
  67. package/features/SaveSettings/SaveSettingsUseCase.js +51 -0
  68. package/features/SaveSettings/SaveSettingsUseCase.js.map +1 -0
  69. package/features/SaveSettings/abstractions.d.ts +53 -0
  70. package/features/SaveSettings/abstractions.js +11 -0
  71. package/features/SaveSettings/abstractions.js.map +1 -0
  72. package/features/SaveSettings/events.d.ts +10 -0
  73. package/features/SaveSettings/events.js +16 -0
  74. package/features/SaveSettings/events.js.map +1 -0
  75. package/features/SaveSettings/feature.d.ts +1 -0
  76. package/features/SaveSettings/feature.js +12 -0
  77. package/features/SaveSettings/feature.js.map +1 -0
  78. package/features/SaveSettings/index.d.ts +1 -0
  79. package/features/SaveSettings/index.js +3 -0
  80. package/features/SaveSettings/index.js.map +1 -0
  81. package/features/SaveSettings/validation.d.ts +23 -0
  82. package/features/SaveSettings/validation.js +19 -0
  83. package/features/SaveSettings/validation.js.map +1 -0
  84. package/features/SendMail/SendMailUseCase.d.ts +16 -0
  85. package/features/SendMail/SendMailUseCase.js +62 -0
  86. package/features/SendMail/SendMailUseCase.js.map +1 -0
  87. package/features/SendMail/abstractions.d.ts +45 -0
  88. package/features/SendMail/abstractions.js +11 -0
  89. package/features/SendMail/abstractions.js.map +1 -0
  90. package/features/SendMail/events.d.ts +14 -0
  91. package/features/SendMail/events.js +22 -0
  92. package/features/SendMail/events.js.map +1 -0
  93. package/features/SendMail/feature.d.ts +1 -0
  94. package/features/SendMail/feature.js +10 -0
  95. package/features/SendMail/feature.js.map +1 -0
  96. package/features/SmtpTransport/SmtpConfig.d.ts +6 -0
  97. package/features/SmtpTransport/SmtpConfig.js +29 -0
  98. package/features/SmtpTransport/SmtpConfig.js.map +1 -0
  99. package/features/SmtpTransport/SmtpMailTransport.d.ts +18 -0
  100. package/features/SmtpTransport/SmtpMailTransport.js +61 -0
  101. package/features/SmtpTransport/SmtpMailTransport.js.map +1 -0
  102. package/features/SmtpTransport/SmtpMailTransportFactory.d.ts +9 -0
  103. package/features/SmtpTransport/SmtpMailTransportFactory.js +14 -0
  104. package/features/SmtpTransport/SmtpMailTransportFactory.js.map +1 -0
  105. package/features/SmtpTransport/feature.d.ts +1 -0
  106. package/features/SmtpTransport/feature.js +10 -0
  107. package/features/SmtpTransport/feature.js.map +1 -0
  108. package/graphql/settings.d.ts +2 -2
  109. package/graphql/settings.js +46 -34
  110. package/graphql/settings.js.map +1 -1
  111. package/index.d.ts +4 -5
  112. package/index.js +22 -78
  113. package/index.js.map +1 -1
  114. package/package.json +31 -37
  115. package/types.d.ts +1 -108
  116. package/types.js +1 -5
  117. package/types.js.map +1 -1
  118. package/context.d.ts +0 -3
  119. package/context.js +0 -20
  120. package/context.js.map +0 -1
  121. package/crud/settings/hooks.d.ts +0 -5
  122. package/crud/settings/hooks.js +0 -42
  123. package/crud/settings/hooks.js.map +0 -1
  124. package/crud/settings/model.d.ts +0 -2
  125. package/crud/settings/model.js +0 -72
  126. package/crud/settings/model.js.map +0 -1
  127. package/crud/settings/password.js +0 -55
  128. package/crud/settings/password.js.map +0 -1
  129. package/crud/settings/secret.js +0 -19
  130. package/crud/settings/secret.js.map +0 -1
  131. package/crud/settings/transform.d.ts +0 -13
  132. package/crud/settings/transform.js +0 -46
  133. package/crud/settings/transform.js.map +0 -1
  134. package/crud/settings/validation.d.ts +0 -45
  135. package/crud/settings/validation.js +0 -28
  136. package/crud/settings/validation.js.map +0 -1
  137. package/crud/settings.crud.d.ts +0 -5
  138. package/crud/settings.crud.js +0 -269
  139. package/crud/settings.crud.js.map +0 -1
  140. package/crud/transport/onTransportBeforeSend.d.ts +0 -7
  141. package/crud/transport/onTransportBeforeSend.js +0 -62
  142. package/crud/transport/onTransportBeforeSend.js.map +0 -1
  143. package/crud/transporter.crud.d.ts +0 -2
  144. package/crud/transporter.crud.js +0 -158
  145. package/crud/transporter.crud.js.map +0 -1
  146. package/graphql/index.d.ts +0 -1
  147. package/graphql/index.js +0 -13
  148. package/graphql/index.js.map +0 -1
  149. package/plugins/CreateTransportPlugin.d.ts +0 -17
  150. package/plugins/CreateTransportPlugin.js +0 -24
  151. package/plugins/CreateTransportPlugin.js.map +0 -1
  152. package/plugins/index.d.ts +0 -1
  153. package/plugins/index.js +0 -18
  154. package/plugins/index.js.map +0 -1
  155. package/transports/createDummyTransport.d.ts +0 -5
  156. package/transports/createDummyTransport.js +0 -25
  157. package/transports/createDummyTransport.js.map +0 -1
  158. package/transports/createSmtpTransport.d.ts +0 -12
  159. package/transports/createSmtpTransport.js +0 -94
  160. package/transports/createSmtpTransport.js.map +0 -1
  161. package/transports/index.d.ts +0 -2
  162. package/transports/index.js +0 -29
  163. package/transports/index.js.map +0 -1
  164. /package/{crud/settings → features/Encryption/utils}/password.d.ts +0 -0
  165. /package/{crud/settings → features/Encryption/utils}/secret.d.ts +0 -0
@@ -1,13 +0,0 @@
1
- import { ExtendedTransportSettings, TransportSettings } from "../../types";
2
- import { CmsEntry } from "@webiny/api-headless-cms/types";
3
- interface TransformValuesFromEntryParams {
4
- entry: CmsEntry<TransportSettings>;
5
- secret: string | null;
6
- }
7
- export declare const transformValuesFromEntry: (params: TransformValuesFromEntryParams) => ExtendedTransportSettings;
8
- interface TransformValuesToEntryValuesParams {
9
- values: TransportSettings;
10
- secret: string | null;
11
- }
12
- export declare const transformInputToEntryValues: (params: TransformValuesToEntryValuesParams) => TransportSettings;
13
- export {};
@@ -1,46 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports.transformValuesFromEntry = exports.transformInputToEntryValues = void 0;
8
- var _error = _interopRequireDefault(require("@webiny/error"));
9
- var _password = require("./password");
10
- const transformValuesFromEntry = params => {
11
- const {
12
- entry,
13
- secret
14
- } = params;
15
- if (!secret) {
16
- throw new _error.default(`There is no secret defined. Without it we cannot decrypt the password.`);
17
- }
18
- return {
19
- id: entry.id,
20
- ...entry.values,
21
- password: (0, _password.decrypt)({
22
- value: entry.values.password,
23
- secret
24
- })
25
- };
26
- };
27
- exports.transformValuesFromEntry = transformValuesFromEntry;
28
- const transformInputToEntryValues = params => {
29
- const {
30
- values,
31
- secret
32
- } = params;
33
- if (!secret) {
34
- throw new _error.default(`There is no secret defined. Without it we cannot decrypt the password.`);
35
- }
36
- return {
37
- ...values,
38
- password: (0, _password.encrypt)({
39
- value: values.password,
40
- secret
41
- })
42
- };
43
- };
44
- exports.transformInputToEntryValues = transformInputToEntryValues;
45
-
46
- //# sourceMappingURL=transform.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["_error","_interopRequireDefault","require","_password","transformValuesFromEntry","params","entry","secret","WebinyError","id","values","password","decrypt","value","exports","transformInputToEntryValues","encrypt"],"sources":["transform.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { ExtendedTransportSettings, TransportSettings } from \"~/types\";\nimport { decrypt, encrypt } from \"./password\";\nimport { CmsEntry } from \"@webiny/api-headless-cms/types\";\n\ninterface TransformValuesFromEntryParams {\n entry: CmsEntry<TransportSettings>;\n secret: string | null;\n}\nexport const transformValuesFromEntry = (\n params: TransformValuesFromEntryParams\n): ExtendedTransportSettings => {\n const { entry, secret } = params;\n if (!secret) {\n throw new WebinyError(\n `There is no secret defined. Without it we cannot decrypt the password.`\n );\n }\n return {\n id: entry.id,\n ...entry.values,\n password: decrypt({\n value: entry.values.password,\n secret\n })\n };\n};\n\ninterface TransformValuesToEntryValuesParams {\n values: TransportSettings;\n secret: string | null;\n}\nexport const transformInputToEntryValues = (\n params: TransformValuesToEntryValuesParams\n): TransportSettings => {\n const { values, secret } = params;\n\n if (!secret) {\n throw new WebinyError(\n `There is no secret defined. Without it we cannot decrypt the password.`\n );\n }\n\n return {\n ...values,\n password: encrypt({\n value: values.password,\n secret\n })\n };\n};\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAEA,IAAAC,SAAA,GAAAD,OAAA;AAOO,MAAME,wBAAwB,GACjCC,MAAsC,IACV;EAC5B,MAAM;IAAEC,KAAK;IAAEC;EAAO,CAAC,GAAGF,MAAM;EAChC,IAAI,CAACE,MAAM,EAAE;IACT,MAAM,IAAIC,cAAW,CAChB,wEACL,CAAC;EACL;EACA,OAAO;IACHC,EAAE,EAAEH,KAAK,CAACG,EAAE;IACZ,GAAGH,KAAK,CAACI,MAAM;IACfC,QAAQ,EAAE,IAAAC,iBAAO,EAAC;MACdC,KAAK,EAAEP,KAAK,CAACI,MAAM,CAACC,QAAQ;MAC5BJ;IACJ,CAAC;EACL,CAAC;AACL,CAAC;AAACO,OAAA,CAAAV,wBAAA,GAAAA,wBAAA;AAMK,MAAMW,2BAA2B,GACpCV,MAA0C,IACtB;EACpB,MAAM;IAAEK,MAAM;IAAEH;EAAO,CAAC,GAAGF,MAAM;EAEjC,IAAI,CAACE,MAAM,EAAE;IACT,MAAM,IAAIC,cAAW,CAChB,wEACL,CAAC;EACL;EAEA,OAAO;IACH,GAAGE,MAAM;IACTC,QAAQ,EAAE,IAAAK,iBAAO,EAAC;MACdH,KAAK,EAAEH,MAAM,CAACC,QAAQ;MACtBJ;IACJ,CAAC;EACL,CAAC;AACL,CAAC;AAACO,OAAA,CAAAC,2BAAA,GAAAA,2BAAA","ignoreList":[]}
@@ -1,45 +0,0 @@
1
- import zod from "zod";
2
- export declare const createValidation: zod.ZodObject<{
3
- password: zod.ZodString;
4
- from: zod.ZodString;
5
- port: zod.ZodNullable<zod.ZodNumber>;
6
- replyTo: zod.ZodString;
7
- host: zod.ZodString;
8
- user: zod.ZodString;
9
- }, "strip", zod.ZodTypeAny, {
10
- from: string;
11
- replyTo: string;
12
- password: string;
13
- port: number | null;
14
- host: string;
15
- user: string;
16
- }, {
17
- from: string;
18
- replyTo: string;
19
- password: string;
20
- port: number | null;
21
- host: string;
22
- user: string;
23
- }>;
24
- export declare const updateValidation: zod.ZodObject<{
25
- password: zod.ZodEffects<zod.ZodOptional<zod.ZodOptional<zod.ZodNullable<zod.ZodString>>>, string | null, string | null | undefined>;
26
- from: zod.ZodString;
27
- port: zod.ZodNullable<zod.ZodNumber>;
28
- replyTo: zod.ZodString;
29
- host: zod.ZodString;
30
- user: zod.ZodString;
31
- }, "strip", zod.ZodTypeAny, {
32
- from: string;
33
- replyTo: string;
34
- password: string | null;
35
- port: number | null;
36
- host: string;
37
- user: string;
38
- }, {
39
- from: string;
40
- replyTo: string;
41
- port: number | null;
42
- host: string;
43
- user: string;
44
- password?: string | null | undefined;
45
- }>;
@@ -1,28 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports.updateValidation = exports.createValidation = void 0;
8
- var _zod = _interopRequireDefault(require("zod"));
9
- const password = _zod.default.string().describe("Password");
10
- const common = {
11
- from: _zod.default.string().email().describe("Mail from"),
12
- port: _zod.default.number().optional().nullish().describe("Port"),
13
- replyTo: _zod.default.string().email().optional().describe("Mail reply-to"),
14
- host: _zod.default.string().describe("Hostname"),
15
- user: _zod.default.string().describe("User")
16
- };
17
- const createValidation = exports.createValidation = _zod.default.object({
18
- ...common,
19
- password
20
- }).required();
21
- const updateValidation = exports.updateValidation = _zod.default.object({
22
- ...common,
23
- password: password.nullish().optional().transform(value => {
24
- return value === undefined ? null : value;
25
- })
26
- }).required();
27
-
28
- //# sourceMappingURL=validation.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["_zod","_interopRequireDefault","require","password","zod","string","describe","common","from","email","port","number","optional","nullish","replyTo","host","user","createValidation","exports","object","required","updateValidation","transform","value","undefined"],"sources":["validation.ts"],"sourcesContent":["import zod from \"zod\";\n\nconst password = zod.string().describe(\"Password\");\n\nconst common = {\n from: zod.string().email().describe(\"Mail from\"),\n port: zod.number().optional().nullish().describe(\"Port\"),\n replyTo: zod.string().email().optional().describe(\"Mail reply-to\"),\n host: zod.string().describe(\"Hostname\"),\n user: zod.string().describe(\"User\")\n};\n\nexport const createValidation = zod\n .object({\n ...common,\n password\n })\n .required();\n\nexport const updateValidation = zod\n .object({\n ...common,\n password: password\n .nullish()\n .optional()\n .transform(value => {\n return value === undefined ? null : value;\n })\n })\n .required();\n"],"mappings":";;;;;;;AAAA,IAAAA,IAAA,GAAAC,sBAAA,CAAAC,OAAA;AAEA,MAAMC,QAAQ,GAAGC,YAAG,CAACC,MAAM,CAAC,CAAC,CAACC,QAAQ,CAAC,UAAU,CAAC;AAElD,MAAMC,MAAM,GAAG;EACXC,IAAI,EAAEJ,YAAG,CAACC,MAAM,CAAC,CAAC,CAACI,KAAK,CAAC,CAAC,CAACH,QAAQ,CAAC,WAAW,CAAC;EAChDI,IAAI,EAAEN,YAAG,CAACO,MAAM,CAAC,CAAC,CAACC,QAAQ,CAAC,CAAC,CAACC,OAAO,CAAC,CAAC,CAACP,QAAQ,CAAC,MAAM,CAAC;EACxDQ,OAAO,EAAEV,YAAG,CAACC,MAAM,CAAC,CAAC,CAACI,KAAK,CAAC,CAAC,CAACG,QAAQ,CAAC,CAAC,CAACN,QAAQ,CAAC,eAAe,CAAC;EAClES,IAAI,EAAEX,YAAG,CAACC,MAAM,CAAC,CAAC,CAACC,QAAQ,CAAC,UAAU,CAAC;EACvCU,IAAI,EAAEZ,YAAG,CAACC,MAAM,CAAC,CAAC,CAACC,QAAQ,CAAC,MAAM;AACtC,CAAC;AAEM,MAAMW,gBAAgB,GAAAC,OAAA,CAAAD,gBAAA,GAAGb,YAAG,CAC9Be,MAAM,CAAC;EACJ,GAAGZ,MAAM;EACTJ;AACJ,CAAC,CAAC,CACDiB,QAAQ,CAAC,CAAC;AAER,MAAMC,gBAAgB,GAAAH,OAAA,CAAAG,gBAAA,GAAGjB,YAAG,CAC9Be,MAAM,CAAC;EACJ,GAAGZ,MAAM;EACTJ,QAAQ,EAAEA,QAAQ,CACbU,OAAO,CAAC,CAAC,CACTD,QAAQ,CAAC,CAAC,CACVU,SAAS,CAACC,KAAK,IAAI;IAChB,OAAOA,KAAK,KAAKC,SAAS,GAAG,IAAI,GAAGD,KAAK;EAC7C,CAAC;AACT,CAAC,CAAC,CACDH,QAAQ,CAAC,CAAC","ignoreList":[]}
@@ -1,5 +0,0 @@
1
- import { MailerContext, MailerSettingsContext } from "../types";
2
- /**
3
- * Note that settings cannot be used if there is no secret defined.
4
- */
5
- export declare const createSettingsCrud: (context: MailerContext) => Promise<MailerSettingsContext>;
@@ -1,269 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports.createSettingsCrud = void 0;
8
- var _error = _interopRequireDefault(require("@webiny/error"));
9
- var _pubsub = require("@webiny/pubsub");
10
- var _model = require("./settings/model");
11
- var _transform = require("./settings/transform");
12
- var _secret = require("./settings/secret");
13
- var _validation = require("./settings/validation");
14
- var _hooks = require("./settings/hooks");
15
- var _apiSecurity = require("@webiny/api-security");
16
- const defaultPort = 25;
17
- /**
18
- * Note that settings cannot be used if there is no secret defined.
19
- */
20
- const createSettingsCrud = async context => {
21
- /**
22
- * We need to remove password from all references on create and update in the CMS.
23
- */
24
- (0, _hooks.attachPasswordObfuscatingHooks)(context);
25
- const getTenant = () => {
26
- return context.tenancy.getCurrentTenant().id;
27
- };
28
- const validateAccess = async () => {
29
- const permission = await context.security.getPermission("mailer.settings");
30
- if (permission) {
31
- return;
32
- }
33
- throw new _apiSecurity.NotAuthorizedError({
34
- data: {
35
- reason: `Not allowed to update the mailer settings.`
36
- }
37
- });
38
- };
39
- let secret = null;
40
- try {
41
- secret = (0, _secret.getSecret)();
42
- } catch (ex) {}
43
- const getModel = async () => {
44
- return context.security.withoutAuthorization(async () => {
45
- try {
46
- const model = await context.cms.getModel(_model.SETTINGS_MODEL_ID);
47
- if (model) {
48
- return model;
49
- }
50
- } catch (ex) {
51
- throw new _error.default(ex.message, ex.code, ex.data);
52
- }
53
- throw new _error.default(`Missing CMS Model "${_model.SETTINGS_MODEL_ID}".`, "CMS_MODEL_MISSING", {
54
- modelId: _model.SETTINGS_MODEL_ID
55
- });
56
- });
57
- };
58
-
59
- // get
60
- const onSettingsBeforeGet = (0, _pubsub.createTopic)("mailer.onSettingsBeforeGet");
61
- const onSettingsAfterGet = (0, _pubsub.createTopic)("mailer.onSettingsAfterGet");
62
- const onSettingsGetError = (0, _pubsub.createTopic)("mailer.onSettingsCreateError");
63
- // create
64
- const onSettingsBeforeCreate = (0, _pubsub.createTopic)("mailer.onSettingsBeforeCreate");
65
- const onSettingsAfterCreate = (0, _pubsub.createTopic)("mailer.onSettingsAfterCreate");
66
- const onSettingsCreateError = (0, _pubsub.createTopic)("mailer.onSettingsCreateError");
67
- // update
68
- const onSettingsBeforeUpdate = (0, _pubsub.createTopic)("mailer.onSettingsBeforeUpdate");
69
- const onSettingsAfterUpdate = (0, _pubsub.createTopic)("mailer.onSettingsAfterUpdate");
70
- const onSettingsUpdateError = (0, _pubsub.createTopic)("mailer.onSettingsUpdateError");
71
- const checkSecret = () => {
72
- if (secret) {
73
- return;
74
- }
75
- throw new _error.default("There must be a password secret defined!", "PASSWORD_SECRET_ERROR", {
76
- description: "To store the Mailer settings, you must have a password secret environment variable defined."
77
- });
78
- };
79
- return {
80
- onSettingsAfterGet,
81
- onSettingsBeforeGet,
82
- onSettingsGetError,
83
- onSettingsBeforeCreate,
84
- onSettingsAfterCreate,
85
- onSettingsCreateError,
86
- onSettingsBeforeUpdate,
87
- onSettingsAfterUpdate,
88
- onSettingsUpdateError,
89
- getSettings: async () => {
90
- checkSecret();
91
- const model = await getModel();
92
- const tenant = getTenant();
93
- return await context.security.withoutAuthorization(async () => {
94
- try {
95
- await onSettingsBeforeGet.publish({
96
- tenant
97
- });
98
- /**
99
- * We always list because we have no id or something like that to query by.
100
- * This should return one setting anyway.
101
- */
102
- const [entries] = await context.cms.listLatestEntries(model, {
103
- limit: 1,
104
- sort: ["createdOn_DESC"]
105
- });
106
- const [entry] = entries;
107
- if (!entry) {
108
- return null;
109
- }
110
- const settings = (0, _transform.transformValuesFromEntry)({
111
- entry: entry,
112
- secret
113
- });
114
- const passwordlessSettings = {
115
- ...settings,
116
- password: ""
117
- };
118
- await onSettingsAfterGet.publish({
119
- tenant,
120
- settings: passwordlessSettings
121
- });
122
- return settings;
123
- } catch (ex) {
124
- await onSettingsGetError.publish({
125
- tenant,
126
- error: ex
127
- });
128
- }
129
- return null;
130
- });
131
- },
132
- /**
133
- * Method should not be used outside of mailer
134
- * @internal
135
- */
136
- async createSettings(params) {
137
- checkSecret();
138
- await validateAccess();
139
- const {
140
- input
141
- } = params;
142
- const model = await getModel();
143
- const result = _validation.createValidation.safeParse(input);
144
- if (!result.success) {
145
- throw new _error.default("Validation failed!", "VALIDATION_ERROR", {
146
- errors: result.error.errors
147
- });
148
- }
149
- const {
150
- password,
151
- ...settings
152
- } = result.data;
153
- const passwordlessSettings = {
154
- ...settings,
155
- port: settings.port || defaultPort,
156
- password: ""
157
- };
158
- return await context.security.withoutAuthorization(async () => {
159
- try {
160
- await onSettingsBeforeCreate.publish({
161
- settings: passwordlessSettings
162
- });
163
- await context.cms.createEntry(model, (0, _transform.transformInputToEntryValues)({
164
- values: {
165
- ...passwordlessSettings,
166
- password
167
- },
168
- secret
169
- }));
170
- await onSettingsAfterCreate.publish({
171
- settings: passwordlessSettings
172
- });
173
- return passwordlessSettings;
174
- } catch (ex) {
175
- await onSettingsCreateError.publish({
176
- settings: passwordlessSettings,
177
- error: ex
178
- });
179
- throw new _error.default(ex.message, ex.code, ex.data);
180
- }
181
- });
182
- },
183
- /**
184
- * Method should not be used outside of mailer
185
- * @internal
186
- */
187
- async updateSettings(params) {
188
- checkSecret();
189
- await validateAccess();
190
- const {
191
- input,
192
- original: initialOriginal
193
- } = params;
194
- const model = await getModel();
195
- const result = _validation.updateValidation.safeParse(input);
196
- if (!result.success) {
197
- throw new _error.default("Validation failed!", "VALIDATION_ERROR", {
198
- errors: result.error.errors
199
- });
200
- }
201
- let dbOriginal = null;
202
- if (!initialOriginal) {
203
- dbOriginal = await this.getSettings();
204
- }
205
- const original = initialOriginal || dbOriginal;
206
- if (!original) {
207
- throw new _error.default(`You are trying to update settings, but there is no existing record. Create it first!`, "NOT_FOUND");
208
- }
209
- const {
210
- password,
211
- ...settings
212
- } = result.data;
213
- const passwordlessSettings = {
214
- ...settings,
215
- port: settings.port || original.port || defaultPort,
216
- password: ""
217
- };
218
- return await context.security.withoutAuthorization(async () => {
219
- try {
220
- await onSettingsBeforeUpdate.publish({
221
- settings: passwordlessSettings,
222
- original: original
223
- });
224
- const transformedInput = (0, _transform.transformInputToEntryValues)({
225
- values: {
226
- ...passwordlessSettings,
227
- password: password || original.password
228
- },
229
- secret
230
- });
231
- /**
232
- * We want to make sure that old password gets stored again in case no password was sent in update input.
233
- */
234
- await context.cms.updateEntry(model, original.id, transformedInput);
235
- await onSettingsAfterUpdate.publish({
236
- settings: passwordlessSettings,
237
- original
238
- });
239
- return passwordlessSettings;
240
- } catch (ex) {
241
- await onSettingsUpdateError.publish({
242
- original,
243
- settings: passwordlessSettings,
244
- error: ex
245
- });
246
- throw new _error.default(ex.message, ex.code, ex.data);
247
- }
248
- });
249
- },
250
- async saveSettings(params) {
251
- const {
252
- input
253
- } = params;
254
- const original = await this.getSettings();
255
- if (!original) {
256
- return this.createSettings({
257
- input
258
- });
259
- }
260
- return this.updateSettings({
261
- input,
262
- original
263
- });
264
- }
265
- };
266
- };
267
- exports.createSettingsCrud = createSettingsCrud;
268
-
269
- //# sourceMappingURL=settings.crud.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["_error","_interopRequireDefault","require","_pubsub","_model","_transform","_secret","_validation","_hooks","_apiSecurity","defaultPort","createSettingsCrud","context","attachPasswordObfuscatingHooks","getTenant","tenancy","getCurrentTenant","id","validateAccess","permission","security","getPermission","NotAuthorizedError","data","reason","secret","getSecret","ex","getModel","withoutAuthorization","model","cms","SETTINGS_MODEL_ID","WebinyError","message","code","modelId","onSettingsBeforeGet","createTopic","onSettingsAfterGet","onSettingsGetError","onSettingsBeforeCreate","onSettingsAfterCreate","onSettingsCreateError","onSettingsBeforeUpdate","onSettingsAfterUpdate","onSettingsUpdateError","checkSecret","description","getSettings","tenant","publish","entries","listLatestEntries","limit","sort","entry","settings","transformValuesFromEntry","passwordlessSettings","password","error","createSettings","params","input","result","createValidation","safeParse","success","errors","port","createEntry","transformInputToEntryValues","values","updateSettings","original","initialOriginal","updateValidation","dbOriginal","transformedInput","updateEntry","saveSettings","exports"],"sources":["settings.crud.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport {\n ExtendedTransportSettings,\n MailerContext,\n MailerContextObject,\n MailerSettingsContext,\n OnSettingsAfterCreateTopicParams,\n OnSettingsAfterGetTopicParams,\n OnSettingsAfterUpdateTopicParams,\n OnSettingsBeforeCreateTopicParams,\n OnSettingsBeforeGetTopicParams,\n OnSettingsBeforeUpdateTopicParams,\n OnSettingsCreateErrorTopicParams,\n OnSettingsGetErrorTopicParams,\n OnSettingsUpdateErrorTopicParams,\n TransportSettings\n} from \"~/types\";\nimport { createTopic } from \"@webiny/pubsub\";\nimport { SETTINGS_MODEL_ID } from \"./settings/model\";\nimport { transformInputToEntryValues, transformValuesFromEntry } from \"~/crud/settings/transform\";\nimport { getSecret } from \"~/crud/settings/secret\";\nimport { createValidation, updateValidation } from \"~/crud/settings/validation\";\nimport { CmsEntry, CmsModel } from \"@webiny/api-headless-cms/types\";\nimport { attachPasswordObfuscatingHooks } from \"~/crud/settings/hooks\";\nimport { NotAuthorizedError } from \"@webiny/api-security\";\n\nconst defaultPort = 25;\n/**\n * Note that settings cannot be used if there is no secret defined.\n */\nexport const createSettingsCrud = async (\n context: MailerContext\n): Promise<MailerSettingsContext> => {\n /**\n * We need to remove password from all references on create and update in the CMS.\n */\n attachPasswordObfuscatingHooks(context);\n\n const getTenant = () => {\n return context.tenancy.getCurrentTenant().id;\n };\n\n const validateAccess = async () => {\n const permission = await context.security.getPermission(\"mailer.settings\");\n\n if (permission) {\n return;\n }\n throw new NotAuthorizedError({\n data: {\n reason: `Not allowed to update the mailer settings.`\n }\n });\n };\n\n let secret: string | null = null;\n try {\n secret = getSecret();\n } catch (ex) {}\n\n const getModel = async (): Promise<CmsModel> => {\n return context.security.withoutAuthorization(async () => {\n try {\n const model = await context.cms.getModel(SETTINGS_MODEL_ID);\n if (model) {\n return model;\n }\n } catch (ex) {\n throw new WebinyError(ex.message, ex.code, ex.data);\n }\n throw new WebinyError(\n `Missing CMS Model \"${SETTINGS_MODEL_ID}\".`,\n \"CMS_MODEL_MISSING\",\n {\n modelId: SETTINGS_MODEL_ID\n }\n );\n });\n };\n\n // get\n const onSettingsBeforeGet = createTopic<OnSettingsBeforeGetTopicParams>(\n \"mailer.onSettingsBeforeGet\"\n );\n const onSettingsAfterGet = createTopic<OnSettingsAfterGetTopicParams>(\n \"mailer.onSettingsAfterGet\"\n );\n const onSettingsGetError = createTopic<OnSettingsGetErrorTopicParams>(\n \"mailer.onSettingsCreateError\"\n );\n // create\n const onSettingsBeforeCreate = createTopic<OnSettingsBeforeCreateTopicParams>(\n \"mailer.onSettingsBeforeCreate\"\n );\n const onSettingsAfterCreate = createTopic<OnSettingsAfterCreateTopicParams>(\n \"mailer.onSettingsAfterCreate\"\n );\n const onSettingsCreateError = createTopic<OnSettingsCreateErrorTopicParams>(\n \"mailer.onSettingsCreateError\"\n );\n // update\n const onSettingsBeforeUpdate = createTopic<OnSettingsBeforeUpdateTopicParams>(\n \"mailer.onSettingsBeforeUpdate\"\n );\n const onSettingsAfterUpdate = createTopic<OnSettingsAfterUpdateTopicParams>(\n \"mailer.onSettingsAfterUpdate\"\n );\n const onSettingsUpdateError = createTopic<OnSettingsUpdateErrorTopicParams>(\n \"mailer.onSettingsUpdateError\"\n );\n\n const checkSecret = (): void => {\n if (secret) {\n return;\n }\n throw new WebinyError(\"There must be a password secret defined!\", \"PASSWORD_SECRET_ERROR\", {\n description:\n \"To store the Mailer settings, you must have a password secret environment variable defined.\"\n });\n };\n\n return {\n onSettingsAfterGet,\n onSettingsBeforeGet,\n onSettingsGetError,\n onSettingsBeforeCreate,\n onSettingsAfterCreate,\n onSettingsCreateError,\n onSettingsBeforeUpdate,\n onSettingsAfterUpdate,\n onSettingsUpdateError,\n getSettings: async () => {\n checkSecret();\n\n const model = await getModel();\n\n const tenant = getTenant();\n return await context.security.withoutAuthorization(async () => {\n try {\n await onSettingsBeforeGet.publish({\n tenant\n });\n /**\n * We always list because we have no id or something like that to query by.\n * This should return one setting anyway.\n */\n const [entries] = await context.cms.listLatestEntries(model, {\n limit: 1,\n sort: [\"createdOn_DESC\"]\n });\n const [entry] = entries;\n if (!entry) {\n return null;\n }\n const settings = transformValuesFromEntry({\n entry: entry as CmsEntry<TransportSettings>,\n secret\n });\n\n const passwordlessSettings: TransportSettings = {\n ...settings,\n password: \"\"\n };\n\n await onSettingsAfterGet.publish({\n tenant,\n settings: passwordlessSettings\n });\n\n return settings;\n } catch (ex) {\n await onSettingsGetError.publish({\n tenant,\n error: ex\n });\n }\n return null;\n });\n },\n /**\n * Method should not be used outside of mailer\n * @internal\n */\n async createSettings(this: MailerContextObject, params) {\n checkSecret();\n await validateAccess();\n\n const { input } = params;\n\n const model = await getModel();\n\n const result = createValidation.safeParse(input);\n\n if (!result.success) {\n throw new WebinyError(\"Validation failed!\", \"VALIDATION_ERROR\", {\n errors: result.error.errors\n });\n }\n\n const { password, ...settings } = result.data;\n\n const passwordlessSettings: TransportSettings = {\n ...settings,\n port: settings.port || defaultPort,\n password: \"\"\n };\n\n return await context.security.withoutAuthorization(async () => {\n try {\n await onSettingsBeforeCreate.publish({\n settings: passwordlessSettings\n });\n\n await context.cms.createEntry(\n model,\n transformInputToEntryValues({\n values: {\n ...passwordlessSettings,\n password\n },\n secret\n })\n );\n\n await onSettingsAfterCreate.publish({\n settings: passwordlessSettings\n });\n return passwordlessSettings;\n } catch (ex) {\n await onSettingsCreateError.publish({\n settings: passwordlessSettings,\n error: ex\n });\n throw new WebinyError(ex.message, ex.code, ex.data);\n }\n });\n },\n /**\n * Method should not be used outside of mailer\n * @internal\n */\n async updateSettings(this: MailerContextObject, params) {\n checkSecret();\n await validateAccess();\n\n const { input, original: initialOriginal } = params;\n\n const model = await getModel();\n\n const result = updateValidation.safeParse(input);\n\n if (!result.success) {\n throw new WebinyError(\"Validation failed!\", \"VALIDATION_ERROR\", {\n errors: result.error.errors\n });\n }\n\n let dbOriginal: ExtendedTransportSettings | null = null;\n if (!initialOriginal) {\n dbOriginal = await this.getSettings();\n }\n const original = initialOriginal || dbOriginal;\n if (!original) {\n throw new WebinyError(\n `You are trying to update settings, but there is no existing record. Create it first!`,\n \"NOT_FOUND\"\n );\n }\n\n const { password, ...settings } = result.data;\n\n const passwordlessSettings: TransportSettings = {\n ...settings,\n port: settings.port || original.port || defaultPort,\n password: \"\"\n };\n return await context.security.withoutAuthorization(async () => {\n try {\n await onSettingsBeforeUpdate.publish({\n settings: passwordlessSettings,\n original: original\n });\n\n const transformedInput = transformInputToEntryValues({\n values: {\n ...passwordlessSettings,\n password: password || original.password\n },\n secret\n });\n /**\n * We want to make sure that old password gets stored again in case no password was sent in update input.\n */\n await context.cms.updateEntry(model, original.id, transformedInput);\n\n await onSettingsAfterUpdate.publish({\n settings: passwordlessSettings,\n original\n });\n return passwordlessSettings;\n } catch (ex) {\n await onSettingsUpdateError.publish({\n original,\n settings: passwordlessSettings,\n error: ex\n });\n throw new WebinyError(ex.message, ex.code, ex.data);\n }\n });\n },\n async saveSettings(this: MailerContextObject, params) {\n const { input } = params;\n\n const original = await this.getSettings();\n if (!original) {\n return this.createSettings({\n input\n });\n }\n return this.updateSettings({\n input,\n original\n });\n }\n };\n};\n"],"mappings":"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","ignoreList":[]}
@@ -1,7 +0,0 @@
1
- import { Topic } from "@webiny/pubsub/types";
2
- import { OnTransportBeforeSendParams } from "../../types";
3
- interface Params {
4
- onTransportBeforeSend: Topic<OnTransportBeforeSendParams>;
5
- }
6
- export declare const attachOnTransportBeforeSend: (params: Params) => void;
7
- export {};
@@ -1,62 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports.attachOnTransportBeforeSend = void 0;
8
- var _error = _interopRequireDefault(require("@webiny/error"));
9
- var _zod = _interopRequireDefault(require("zod"));
10
- const requiredString = _zod.default.string();
11
- const requiredEmail = requiredString.email();
12
- const schema = _zod.default.object({
13
- to: _zod.default.array(requiredEmail).optional(),
14
- from: _zod.default.string().email().optional(),
15
- subject: requiredString.max(1024).min(2),
16
- cc: _zod.default.array(requiredEmail).optional(),
17
- bcc: _zod.default.array(requiredEmail).optional(),
18
- replyTo: _zod.default.string().email().optional(),
19
- text: _zod.default.string().optional(),
20
- html: _zod.default.string().optional()
21
- }).refine(data => {
22
- return !!data.text || !!data.html;
23
- }, "Either text or html is required.");
24
- const attachOnTransportBeforeSend = params => {
25
- const {
26
- onTransportBeforeSend
27
- } = params;
28
- onTransportBeforeSend.subscribe(async ({
29
- data: input
30
- }) => {
31
- let result;
32
- try {
33
- result = schema.safeParse(input);
34
- if (result.success) {
35
- return;
36
- }
37
- throw new _error.default({
38
- message: "Error while validating e-mail params.",
39
- code: "VALIDATION_ERROR",
40
- data: {
41
- error: result.error,
42
- input
43
- }
44
- });
45
- } catch (ex) {
46
- if (ex instanceof _error.default) {
47
- throw ex;
48
- }
49
- throw new _error.default({
50
- message: "Error while validating e-mail params.",
51
- code: "VALIDATION_ERROR",
52
- data: {
53
- input,
54
- error: ex
55
- }
56
- });
57
- }
58
- });
59
- };
60
- exports.attachOnTransportBeforeSend = attachOnTransportBeforeSend;
61
-
62
- //# sourceMappingURL=onTransportBeforeSend.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["_error","_interopRequireDefault","require","_zod","requiredString","zod","string","requiredEmail","email","schema","object","to","array","optional","from","subject","max","min","cc","bcc","replyTo","text","html","refine","data","attachOnTransportBeforeSend","params","onTransportBeforeSend","subscribe","input","result","safeParse","success","WebinyError","message","code","error","ex","exports"],"sources":["onTransportBeforeSend.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport zod from \"zod\";\nimport { Topic } from \"@webiny/pubsub/types\";\nimport { OnTransportBeforeSendParams } from \"~/types\";\nimport { SafeParseReturnType } from \"zod/lib/types\";\n\nconst requiredString = zod.string();\nconst requiredEmail = requiredString.email();\n\nconst schema = zod\n .object({\n to: zod.array(requiredEmail).optional(),\n from: zod.string().email().optional(),\n subject: requiredString.max(1024).min(2),\n cc: zod.array(requiredEmail).optional(),\n bcc: zod.array(requiredEmail).optional(),\n replyTo: zod.string().email().optional(),\n text: zod.string().optional(),\n html: zod.string().optional()\n })\n .refine(data => {\n return !!data.text || !!data.html;\n }, \"Either text or html is required.\");\n\ntype SchemaType = zod.infer<typeof schema>;\n\ninterface Params {\n onTransportBeforeSend: Topic<OnTransportBeforeSendParams>;\n}\nexport const attachOnTransportBeforeSend = (params: Params) => {\n const { onTransportBeforeSend } = params;\n\n onTransportBeforeSend.subscribe(async ({ data: input }) => {\n let result: SafeParseReturnType<SchemaType, SchemaType>;\n try {\n result = schema.safeParse(input);\n\n if (result.success) {\n return;\n }\n throw new WebinyError({\n message: \"Error while validating e-mail params.\",\n code: \"VALIDATION_ERROR\",\n data: {\n error: result.error,\n input\n }\n });\n } catch (ex) {\n if (ex instanceof WebinyError) {\n throw ex;\n }\n throw new WebinyError({\n message: \"Error while validating e-mail params.\",\n code: \"VALIDATION_ERROR\",\n data: {\n input,\n error: ex\n }\n });\n }\n });\n};\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,IAAA,GAAAF,sBAAA,CAAAC,OAAA;AAKA,MAAME,cAAc,GAAGC,YAAG,CAACC,MAAM,CAAC,CAAC;AACnC,MAAMC,aAAa,GAAGH,cAAc,CAACI,KAAK,CAAC,CAAC;AAE5C,MAAMC,MAAM,GAAGJ,YAAG,CACbK,MAAM,CAAC;EACJC,EAAE,EAAEN,YAAG,CAACO,KAAK,CAACL,aAAa,CAAC,CAACM,QAAQ,CAAC,CAAC;EACvCC,IAAI,EAAET,YAAG,CAACC,MAAM,CAAC,CAAC,CAACE,KAAK,CAAC,CAAC,CAACK,QAAQ,CAAC,CAAC;EACrCE,OAAO,EAAEX,cAAc,CAACY,GAAG,CAAC,IAAI,CAAC,CAACC,GAAG,CAAC,CAAC,CAAC;EACxCC,EAAE,EAAEb,YAAG,CAACO,KAAK,CAACL,aAAa,CAAC,CAACM,QAAQ,CAAC,CAAC;EACvCM,GAAG,EAAEd,YAAG,CAACO,KAAK,CAACL,aAAa,CAAC,CAACM,QAAQ,CAAC,CAAC;EACxCO,OAAO,EAAEf,YAAG,CAACC,MAAM,CAAC,CAAC,CAACE,KAAK,CAAC,CAAC,CAACK,QAAQ,CAAC,CAAC;EACxCQ,IAAI,EAAEhB,YAAG,CAACC,MAAM,CAAC,CAAC,CAACO,QAAQ,CAAC,CAAC;EAC7BS,IAAI,EAAEjB,YAAG,CAACC,MAAM,CAAC,CAAC,CAACO,QAAQ,CAAC;AAChC,CAAC,CAAC,CACDU,MAAM,CAACC,IAAI,IAAI;EACZ,OAAO,CAAC,CAACA,IAAI,CAACH,IAAI,IAAI,CAAC,CAACG,IAAI,CAACF,IAAI;AACrC,CAAC,EAAE,kCAAkC,CAAC;AAOnC,MAAMG,2BAA2B,GAAIC,MAAc,IAAK;EAC3D,MAAM;IAAEC;EAAsB,CAAC,GAAGD,MAAM;EAExCC,qBAAqB,CAACC,SAAS,CAAC,OAAO;IAAEJ,IAAI,EAAEK;EAAM,CAAC,KAAK;IACvD,IAAIC,MAAmD;IACvD,IAAI;MACAA,MAAM,GAAGrB,MAAM,CAACsB,SAAS,CAACF,KAAK,CAAC;MAEhC,IAAIC,MAAM,CAACE,OAAO,EAAE;QAChB;MACJ;MACA,MAAM,IAAIC,cAAW,CAAC;QAClBC,OAAO,EAAE,uCAAuC;QAChDC,IAAI,EAAE,kBAAkB;QACxBX,IAAI,EAAE;UACFY,KAAK,EAAEN,MAAM,CAACM,KAAK;UACnBP;QACJ;MACJ,CAAC,CAAC;IACN,CAAC,CAAC,OAAOQ,EAAE,EAAE;MACT,IAAIA,EAAE,YAAYJ,cAAW,EAAE;QAC3B,MAAMI,EAAE;MACZ;MACA,MAAM,IAAIJ,cAAW,CAAC;QAClBC,OAAO,EAAE,uCAAuC;QAChDC,IAAI,EAAE,kBAAkB;QACxBX,IAAI,EAAE;UACFK,KAAK;UACLO,KAAK,EAAEC;QACX;MACJ,CAAC,CAAC;IACN;EACJ,CAAC,CAAC;AACN,CAAC;AAACC,OAAA,CAAAb,2BAAA,GAAAA,2BAAA","ignoreList":[]}
@@ -1,2 +0,0 @@
1
- import { MailerContext, MailerTransporterContext } from "../types";
2
- export declare const createTransporterCrud: (context: MailerContext) => Promise<MailerTransporterContext>;