@webiny/api-mailer 5.33.5 → 5.34.0-beta.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 (68) hide show
  1. package/context.d.ts +2 -2
  2. package/context.js +9 -3
  3. package/context.js.map +1 -1
  4. package/crud/group.d.ts +2 -0
  5. package/crud/group.js +21 -0
  6. package/crud/group.js.map +1 -0
  7. package/crud/settings/hooks.d.ts +5 -0
  8. package/crud/settings/hooks.js +55 -0
  9. package/crud/settings/hooks.js.map +1 -0
  10. package/crud/settings/model.d.ts +3 -0
  11. package/crud/settings/model.js +90 -0
  12. package/crud/settings/model.js.map +1 -0
  13. package/crud/settings/password.d.ts +7 -0
  14. package/crud/settings/password.js +71 -0
  15. package/crud/settings/password.js.map +1 -0
  16. package/crud/settings/secret.d.ts +1 -0
  17. package/crud/settings/secret.js +23 -0
  18. package/crud/settings/secret.js.map +1 -0
  19. package/crud/settings/transform.d.ts +13 -0
  20. package/crud/settings/transform.js +56 -0
  21. package/crud/settings/transform.js.map +1 -0
  22. package/crud/settings/validation.d.ts +4 -0
  23. package/crud/settings/validation.js +38 -0
  24. package/crud/settings/validation.js.map +1 -0
  25. package/crud/settings.crud.d.ts +5 -0
  26. package/crud/settings.crud.js +331 -0
  27. package/crud/settings.crud.js.map +1 -0
  28. package/crud/transport/onTransportBeforeSend.d.ts +7 -0
  29. package/crud/transport/onTransportBeforeSend.js +69 -0
  30. package/crud/transport/onTransportBeforeSend.js.map +1 -0
  31. package/crud/transporter.crud.d.ts +2 -0
  32. package/crud/transporter.crud.js +193 -0
  33. package/crud/transporter.crud.js.map +1 -0
  34. package/graphql/index.d.ts +1 -0
  35. package/graphql/index.js +14 -0
  36. package/graphql/index.js.map +1 -0
  37. package/graphql/settings.d.ts +3 -0
  38. package/graphql/settings.js +109 -0
  39. package/graphql/settings.js.map +1 -0
  40. package/index.d.ts +7 -6
  41. package/index.js +69 -10
  42. package/index.js.map +1 -1
  43. package/package.json +33 -15
  44. package/plugins/CreateTransportPlugin.d.ts +17 -0
  45. package/plugins/CreateTransportPlugin.js +34 -0
  46. package/plugins/CreateTransportPlugin.js.map +1 -0
  47. package/plugins/index.d.ts +1 -0
  48. package/plugins/index.js +18 -0
  49. package/plugins/index.js.map +1 -0
  50. package/transports/createDummyTransport.d.ts +5 -0
  51. package/{mailers/createDummyMailer.js → transports/createDummyTransport.js} +4 -3
  52. package/transports/createDummyTransport.js.map +1 -0
  53. package/transports/createSmtpTransport.d.ts +12 -0
  54. package/transports/createSmtpTransport.js +101 -0
  55. package/transports/createSmtpTransport.js.map +1 -0
  56. package/types.d.ts +124 -34
  57. package/types.js.map +1 -1
  58. package/crud/mailer/onBeforeSend.d.ts +0 -7
  59. package/crud/mailer/onBeforeSend.js +0 -69
  60. package/crud/mailer/onBeforeSend.js.map +0 -1
  61. package/crud/mailer.crud.d.ts +0 -2
  62. package/crud/mailer.crud.js +0 -123
  63. package/crud/mailer.crud.js.map +0 -1
  64. package/mailers/createDummyMailer.d.ts +0 -5
  65. package/mailers/createDummyMailer.js.map +0 -1
  66. package/mailers/createSmtpMailer.d.ts +0 -13
  67. package/mailers/createSmtpMailer.js +0 -106
  68. package/mailers/createSmtpMailer.js.map +0 -1
package/context.d.ts CHANGED
@@ -1,3 +1,3 @@
1
1
  import { ContextPlugin } from "@webiny/api";
2
- import { MailerConfig, MailerContext } from "./types";
3
- export declare const createMailerContext: (config?: MailerConfig) => ContextPlugin<MailerContext>;
2
+ import { MailerContext } from "./types";
3
+ export declare const createMailerContext: () => ContextPlugin<MailerContext>;
package/context.js CHANGED
@@ -1,17 +1,23 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+
3
5
  Object.defineProperty(exports, "__esModule", {
4
6
  value: true
5
7
  });
6
8
  exports.createMailerContext = void 0;
7
9
 
10
+ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
11
+
8
12
  var _api = require("@webiny/api");
9
13
 
10
- var _mailer = require("./crud/mailer.crud");
14
+ var _transporter = require("./crud/transporter.crud");
15
+
16
+ var _settings = require("./crud/settings.crud");
11
17
 
12
- const createMailerContext = config => {
18
+ const createMailerContext = () => {
13
19
  return new _api.ContextPlugin(async context => {
14
- context.mailer = (0, _mailer.createMailerCrud)(config);
20
+ context.mailer = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, await (0, _transporter.createTransporterCrud)(context)), await (0, _settings.createSettingsCrud)(context));
15
21
  });
16
22
  };
17
23
 
package/context.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"names":["createMailerContext","config","ContextPlugin","context","mailer","createMailerCrud"],"sources":["context.ts"],"sourcesContent":["import { ContextPlugin } from \"@webiny/api\";\nimport { MailerConfig, MailerContext } from \"./types\";\nimport { createMailerCrud } from \"~/crud/mailer.crud\";\n\nexport const createMailerContext = (config?: MailerConfig) => {\n return new ContextPlugin<MailerContext>(async context => {\n context.mailer = createMailerCrud(config);\n });\n};\n"],"mappings":";;;;;;;AAAA;;AAEA;;AAEO,MAAMA,mBAAmB,GAAIC,MAAD,IAA2B;EAC1D,OAAO,IAAIC,kBAAJ,CAAiC,MAAMC,OAAN,IAAiB;IACrDA,OAAO,CAACC,MAAR,GAAiB,IAAAC,wBAAA,EAAiBJ,MAAjB,CAAjB;EACH,CAFM,CAAP;AAGH,CAJM"}
1
+ {"version":3,"names":["createMailerContext","ContextPlugin","context","mailer","createTransporterCrud","createSettingsCrud"],"sources":["context.ts"],"sourcesContent":["import { ContextPlugin } from \"@webiny/api\";\nimport { MailerContext } from \"./types\";\nimport { createTransporterCrud } from \"~/crud/transporter.crud\";\nimport { createSettingsCrud } from \"~/crud/settings.crud\";\n\nexport const createMailerContext = () => {\n return new ContextPlugin<MailerContext>(async context => {\n context.mailer = {\n ...(await createTransporterCrud(context)),\n ...(await createSettingsCrud(context))\n };\n });\n};\n"],"mappings":";;;;;;;;;;;AAAA;;AAEA;;AACA;;AAEO,MAAMA,mBAAmB,GAAG,MAAM;EACrC,OAAO,IAAIC,kBAAJ,CAAiC,MAAMC,OAAN,IAAiB;IACrDA,OAAO,CAACC,MAAR,+DACQ,MAAM,IAAAC,kCAAA,EAAsBF,OAAtB,CADd,GAEQ,MAAM,IAAAG,4BAAA,EAAmBH,OAAnB,CAFd;EAIH,CALM,CAAP;AAMH,CAPM"}
@@ -0,0 +1,2 @@
1
+ import { CmsGroupPlugin } from "@webiny/api-headless-cms";
2
+ export declare const createGroup: () => CmsGroupPlugin;
package/crud/group.js ADDED
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.createGroup = void 0;
7
+
8
+ var _apiHeadlessCms = require("@webiny/api-headless-cms");
9
+
10
+ const createGroup = () => {
11
+ return (0, _apiHeadlessCms.createCmsGroup)({
12
+ name: "Mailer Group",
13
+ description: "Mailer Group for CMS",
14
+ id: "mailerGroup",
15
+ slug: "mailerGroup",
16
+ icon: "none",
17
+ isPrivate: true
18
+ });
19
+ };
20
+
21
+ exports.createGroup = createGroup;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["createGroup","createCmsGroup","name","description","id","slug","icon","isPrivate"],"sources":["group.ts"],"sourcesContent":["import { CmsGroupPlugin, createCmsGroup } from \"@webiny/api-headless-cms\";\n\nexport const createGroup = (): CmsGroupPlugin => {\n return createCmsGroup({\n name: \"Mailer Group\",\n description: \"Mailer Group for CMS\",\n id: \"mailerGroup\",\n slug: \"mailerGroup\",\n icon: \"none\",\n isPrivate: true\n });\n};\n"],"mappings":";;;;;;;AAAA;;AAEO,MAAMA,WAAW,GAAG,MAAsB;EAC7C,OAAO,IAAAC,8BAAA,EAAe;IAClBC,IAAI,EAAE,cADY;IAElBC,WAAW,EAAE,sBAFK;IAGlBC,EAAE,EAAE,aAHc;IAIlBC,IAAI,EAAE,aAJY;IAKlBC,IAAI,EAAE,MALY;IAMlBC,SAAS,EAAE;EANO,CAAf,CAAP;AAQH,CATM"}
@@ -0,0 +1,5 @@
1
+ import { MailerContext } from "../../types";
2
+ /**
3
+ * We need to remove password from all error reporting and all returns.
4
+ */
5
+ export declare const attachPasswordObfuscatingHooks: (context: MailerContext) => void;
@@ -0,0 +1,55 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.attachPasswordObfuscatingHooks = void 0;
9
+
10
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
11
+
12
+ var _model = require("./model");
13
+
14
+ const _excluded = ["password"];
15
+
16
+ const obfuscatePassword = values => {
17
+ // eslint-disable-next-line
18
+ const {
19
+ password
20
+ } = values,
21
+ rest = (0, _objectWithoutProperties2.default)(values, _excluded);
22
+ return {
23
+ rest
24
+ };
25
+ };
26
+
27
+ const hook = async params => {
28
+ if (params.model.modelId !== _model.SETTINGS_MODEL_ID) {
29
+ return;
30
+ }
31
+
32
+ delete params.input["password"];
33
+ params.entry.values = obfuscatePassword(params.entry.values);
34
+
35
+ if (typeof params.original !== "undefined") {
36
+ params.original.values = obfuscatePassword(params.original.values);
37
+ }
38
+
39
+ if (params.storageEntry) {
40
+ params.storageEntry.values = obfuscatePassword(params.storageEntry.values);
41
+ }
42
+ };
43
+ /**
44
+ * We need to remove password from all error reporting and all returns.
45
+ */
46
+
47
+
48
+ const attachPasswordObfuscatingHooks = context => {
49
+ context.cms.onEntryAfterCreate.subscribe(hook);
50
+ context.cms.onEntryCreateError.subscribe(hook);
51
+ context.cms.onEntryAfterUpdate.subscribe(hook);
52
+ context.cms.onEntryUpdateError.subscribe(hook);
53
+ };
54
+
55
+ exports.attachPasswordObfuscatingHooks = attachPasswordObfuscatingHooks;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["obfuscatePassword","values","password","rest","hook","params","model","modelId","SETTINGS_MODEL_ID","input","entry","original","storageEntry","attachPasswordObfuscatingHooks","context","cms","onEntryAfterCreate","subscribe","onEntryCreateError","onEntryAfterUpdate","onEntryUpdateError"],"sources":["hooks.ts"],"sourcesContent":["import { MailerContext } from \"~/types\";\nimport {\n OnEntryAfterCreateTopicParams,\n OnEntryAfterUpdateTopicParams,\n OnEntryCreateErrorTopicParams,\n OnEntryUpdateErrorTopicParams\n} from \"@webiny/api-headless-cms/types\";\nimport { SETTINGS_MODEL_ID } from \"~/crud/settings/model\";\n\nconst obfuscatePassword = (values: Record<string, any>) => {\n // eslint-disable-next-line\n const { password, ...rest } = values;\n\n return { rest };\n};\n\ntype Params = (\n | OnEntryAfterCreateTopicParams\n | OnEntryCreateErrorTopicParams\n | OnEntryAfterUpdateTopicParams\n | OnEntryUpdateErrorTopicParams\n) & {\n storageEntry?: any;\n original?: any;\n};\n\nconst hook = async (params: Params) => {\n if (params.model.modelId !== SETTINGS_MODEL_ID) {\n return;\n }\n delete params.input[\"password\"];\n params.entry.values = obfuscatePassword(params.entry.values);\n if (typeof params.original !== \"undefined\") {\n params.original.values = obfuscatePassword(params.original.values);\n }\n if (params.storageEntry) {\n params.storageEntry.values = obfuscatePassword(params.storageEntry.values);\n }\n};\n/**\n * We need to remove password from all error reporting and all returns.\n */\nexport const attachPasswordObfuscatingHooks = (context: MailerContext) => {\n context.cms.onEntryAfterCreate.subscribe(hook);\n context.cms.onEntryCreateError.subscribe(hook);\n context.cms.onEntryAfterUpdate.subscribe(hook);\n context.cms.onEntryUpdateError.subscribe(hook);\n};\n"],"mappings":";;;;;;;;;;;AAOA;;;;AAEA,MAAMA,iBAAiB,GAAIC,MAAD,IAAiC;EACvD;EACA,MAAM;IAAEC;EAAF,IAAwBD,MAA9B;EAAA,MAAqBE,IAArB,0CAA8BF,MAA9B;EAEA,OAAO;IAAEE;EAAF,CAAP;AACH,CALD;;AAiBA,MAAMC,IAAI,GAAG,MAAOC,MAAP,IAA0B;EACnC,IAAIA,MAAM,CAACC,KAAP,CAAaC,OAAb,KAAyBC,wBAA7B,EAAgD;IAC5C;EACH;;EACD,OAAOH,MAAM,CAACI,KAAP,CAAa,UAAb,CAAP;EACAJ,MAAM,CAACK,KAAP,CAAaT,MAAb,GAAsBD,iBAAiB,CAACK,MAAM,CAACK,KAAP,CAAaT,MAAd,CAAvC;;EACA,IAAI,OAAOI,MAAM,CAACM,QAAd,KAA2B,WAA/B,EAA4C;IACxCN,MAAM,CAACM,QAAP,CAAgBV,MAAhB,GAAyBD,iBAAiB,CAACK,MAAM,CAACM,QAAP,CAAgBV,MAAjB,CAA1C;EACH;;EACD,IAAII,MAAM,CAACO,YAAX,EAAyB;IACrBP,MAAM,CAACO,YAAP,CAAoBX,MAApB,GAA6BD,iBAAiB,CAACK,MAAM,CAACO,YAAP,CAAoBX,MAArB,CAA9C;EACH;AACJ,CAZD;AAaA;AACA;AACA;;;AACO,MAAMY,8BAA8B,GAAIC,OAAD,IAA4B;EACtEA,OAAO,CAACC,GAAR,CAAYC,kBAAZ,CAA+BC,SAA/B,CAAyCb,IAAzC;EACAU,OAAO,CAACC,GAAR,CAAYG,kBAAZ,CAA+BD,SAA/B,CAAyCb,IAAzC;EACAU,OAAO,CAACC,GAAR,CAAYI,kBAAZ,CAA+BF,SAA/B,CAAyCb,IAAzC;EACAU,OAAO,CAACC,GAAR,CAAYK,kBAAZ,CAA+BH,SAA/B,CAAyCb,IAAzC;AACH,CALM"}
@@ -0,0 +1,3 @@
1
+ import { CmsGroupPlugin } from "@webiny/api-headless-cms";
2
+ export declare const SETTINGS_MODEL_ID = "mailerSettings";
3
+ export declare const createSettingsModel: (group: CmsGroupPlugin) => import("@webiny/api-headless-cms").CmsModelPlugin;
@@ -0,0 +1,90 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.createSettingsModel = exports.SETTINGS_MODEL_ID = void 0;
9
+
10
+ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
11
+
12
+ var _apiHeadlessCms = require("@webiny/api-headless-cms");
13
+
14
+ var _camelCase = _interopRequireDefault(require("lodash/camelCase"));
15
+
16
+ const SETTINGS_MODEL_ID = "mailerSettings";
17
+ exports.SETTINGS_MODEL_ID = SETTINGS_MODEL_ID;
18
+
19
+ const createField = params => {
20
+ const {
21
+ label,
22
+ required,
23
+ type
24
+ } = params;
25
+ const id = (0, _camelCase.default)(label);
26
+ const validation = [];
27
+
28
+ if (required) {
29
+ validation.push({
30
+ message: `Field "${label}" is required!`,
31
+ name: "required",
32
+ settings: {}
33
+ });
34
+ }
35
+
36
+ return {
37
+ label,
38
+ id,
39
+ fieldId: id,
40
+ storageId: id,
41
+ type,
42
+ validation
43
+ };
44
+ };
45
+
46
+ const createTextField = params => {
47
+ return createField((0, _objectSpread2.default)((0, _objectSpread2.default)({}, params), {}, {
48
+ type: "text"
49
+ }));
50
+ };
51
+
52
+ const createNumberField = params => {
53
+ return createField((0, _objectSpread2.default)((0, _objectSpread2.default)({}, params), {}, {
54
+ type: "number"
55
+ }));
56
+ };
57
+
58
+ const createSettingsModel = group => {
59
+ return (0, _apiHeadlessCms.createCmsModel)({
60
+ modelId: SETTINGS_MODEL_ID,
61
+ name: "Mailer Settings",
62
+ group: {
63
+ id: group.contentModelGroup.id,
64
+ name: group.contentModelGroup.name
65
+ },
66
+ fields: [createTextField({
67
+ label: "Host",
68
+ required: true
69
+ }), createNumberField({
70
+ label: "Port"
71
+ }), createTextField({
72
+ label: "User",
73
+ required: true
74
+ }), createTextField({
75
+ label: "Password",
76
+ required: true
77
+ }), createTextField({
78
+ label: "From",
79
+ required: true
80
+ }), createTextField({
81
+ label: "Reply-To"
82
+ })],
83
+ layout: [["host", "port", "user", "password", "from", "replyTo"]],
84
+ description: "Mailer Settings",
85
+ titleFieldId: "",
86
+ isPrivate: true
87
+ });
88
+ };
89
+
90
+ exports.createSettingsModel = createSettingsModel;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["SETTINGS_MODEL_ID","createField","params","label","required","type","id","lodashCamelCase","validation","push","message","name","settings","fieldId","storageId","createTextField","createNumberField","createSettingsModel","group","createCmsModel","modelId","contentModelGroup","fields","layout","description","titleFieldId","isPrivate"],"sources":["model.ts"],"sourcesContent":["import { createCmsModel, CmsGroupPlugin } from \"@webiny/api-headless-cms\";\nimport { CmsModelField, CmsModelFieldValidation } from \"@webiny/api-headless-cms/types\";\nimport lodashCamelCase from \"lodash/camelCase\";\n\nexport const SETTINGS_MODEL_ID = \"mailerSettings\";\n\ninterface CreateFieldParams {\n type: string;\n label: string;\n required?: boolean;\n}\nconst createField = (params: CreateFieldParams): CmsModelField => {\n const { label, required, type } = params;\n const id = lodashCamelCase(label);\n\n const validation: CmsModelFieldValidation[] = [];\n if (required) {\n validation.push({\n message: `Field \"${label}\" is required!`,\n name: \"required\",\n settings: {}\n });\n }\n return {\n label,\n id,\n fieldId: id,\n storageId: id,\n type,\n validation\n };\n};\n\nconst createTextField = (params: Omit<CreateFieldParams, \"type\">) => {\n return createField({\n ...params,\n type: \"text\"\n });\n};\nconst createNumberField = (params: Omit<CreateFieldParams, \"type\">) => {\n return createField({\n ...params,\n type: \"number\"\n });\n};\n\nexport const createSettingsModel = (group: CmsGroupPlugin) => {\n return createCmsModel({\n modelId: SETTINGS_MODEL_ID,\n name: \"Mailer Settings\",\n group: {\n id: group.contentModelGroup.id,\n name: group.contentModelGroup.name\n },\n fields: [\n createTextField({\n label: \"Host\",\n required: true\n }),\n createNumberField({\n label: \"Port\"\n }),\n createTextField({\n label: \"User\",\n required: true\n }),\n createTextField({\n label: \"Password\",\n required: true\n }),\n createTextField({\n label: \"From\",\n required: true\n }),\n createTextField({\n label: \"Reply-To\"\n })\n ],\n layout: [[\"host\", \"port\", \"user\", \"password\", \"from\", \"replyTo\"]],\n description: \"Mailer Settings\",\n titleFieldId: \"\",\n isPrivate: true\n });\n};\n"],"mappings":";;;;;;;;;;;AAAA;;AAEA;;AAEO,MAAMA,iBAAiB,GAAG,gBAA1B;;;AAOP,MAAMC,WAAW,GAAIC,MAAD,IAA8C;EAC9D,MAAM;IAAEC,KAAF;IAASC,QAAT;IAAmBC;EAAnB,IAA4BH,MAAlC;EACA,MAAMI,EAAE,GAAG,IAAAC,kBAAA,EAAgBJ,KAAhB,CAAX;EAEA,MAAMK,UAAqC,GAAG,EAA9C;;EACA,IAAIJ,QAAJ,EAAc;IACVI,UAAU,CAACC,IAAX,CAAgB;MACZC,OAAO,EAAG,UAASP,KAAM,gBADb;MAEZQ,IAAI,EAAE,UAFM;MAGZC,QAAQ,EAAE;IAHE,CAAhB;EAKH;;EACD,OAAO;IACHT,KADG;IAEHG,EAFG;IAGHO,OAAO,EAAEP,EAHN;IAIHQ,SAAS,EAAER,EAJR;IAKHD,IALG;IAMHG;EANG,CAAP;AAQH,CApBD;;AAsBA,MAAMO,eAAe,GAAIb,MAAD,IAA6C;EACjE,OAAOD,WAAW,6DACXC,MADW;IAEdG,IAAI,EAAE;EAFQ,GAAlB;AAIH,CALD;;AAMA,MAAMW,iBAAiB,GAAId,MAAD,IAA6C;EACnE,OAAOD,WAAW,6DACXC,MADW;IAEdG,IAAI,EAAE;EAFQ,GAAlB;AAIH,CALD;;AAOO,MAAMY,mBAAmB,GAAIC,KAAD,IAA2B;EAC1D,OAAO,IAAAC,8BAAA,EAAe;IAClBC,OAAO,EAAEpB,iBADS;IAElBW,IAAI,EAAE,iBAFY;IAGlBO,KAAK,EAAE;MACHZ,EAAE,EAAEY,KAAK,CAACG,iBAAN,CAAwBf,EADzB;MAEHK,IAAI,EAAEO,KAAK,CAACG,iBAAN,CAAwBV;IAF3B,CAHW;IAOlBW,MAAM,EAAE,CACJP,eAAe,CAAC;MACZZ,KAAK,EAAE,MADK;MAEZC,QAAQ,EAAE;IAFE,CAAD,CADX,EAKJY,iBAAiB,CAAC;MACdb,KAAK,EAAE;IADO,CAAD,CALb,EAQJY,eAAe,CAAC;MACZZ,KAAK,EAAE,MADK;MAEZC,QAAQ,EAAE;IAFE,CAAD,CARX,EAYJW,eAAe,CAAC;MACZZ,KAAK,EAAE,UADK;MAEZC,QAAQ,EAAE;IAFE,CAAD,CAZX,EAgBJW,eAAe,CAAC;MACZZ,KAAK,EAAE,MADK;MAEZC,QAAQ,EAAE;IAFE,CAAD,CAhBX,EAoBJW,eAAe,CAAC;MACZZ,KAAK,EAAE;IADK,CAAD,CApBX,CAPU;IA+BlBoB,MAAM,EAAE,CAAC,CAAC,MAAD,EAAS,MAAT,EAAiB,MAAjB,EAAyB,UAAzB,EAAqC,MAArC,EAA6C,SAA7C,CAAD,CA/BU;IAgClBC,WAAW,EAAE,iBAhCK;IAiClBC,YAAY,EAAE,EAjCI;IAkClBC,SAAS,EAAE;EAlCO,CAAf,CAAP;AAoCH,CArCM"}
@@ -0,0 +1,7 @@
1
+ interface Params {
2
+ value?: string | null;
3
+ secret?: string | null;
4
+ }
5
+ export declare const decrypt: (params: Params) => string;
6
+ export declare const encrypt: (params: Params) => string;
7
+ export {};
@@ -0,0 +1,71 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.encrypt = exports.decrypt = void 0;
9
+
10
+ var _cryptoJs = _interopRequireDefault(require("crypto-js"));
11
+
12
+ var _error = _interopRequireDefault(require("@webiny/error"));
13
+
14
+ const decrypt = params => {
15
+ const {
16
+ value,
17
+ secret
18
+ } = params;
19
+
20
+ if (!secret) {
21
+ throw new _error.default(`Cannot call decrypt without passing the secret.`);
22
+ }
23
+
24
+ if (!value) {
25
+ return "";
26
+ }
27
+
28
+ try {
29
+ const bytes = _cryptoJs.default.AES.decrypt(value, secret);
30
+
31
+ const result = bytes.toString(_cryptoJs.default.enc.Utf8);
32
+
33
+ if (!result) {
34
+ console.log(`Error while converting decrypted password bytes into string. `);
35
+ return "";
36
+ }
37
+
38
+ return result;
39
+ } catch (ex) {
40
+ console.log(`Could not decrypt given encrypted password.`);
41
+ }
42
+
43
+ return "";
44
+ };
45
+
46
+ exports.decrypt = decrypt;
47
+
48
+ const encrypt = params => {
49
+ const {
50
+ value,
51
+ secret
52
+ } = params;
53
+
54
+ if (!secret) {
55
+ throw new _error.default(`Cannot call decrypt without passing the secret.`);
56
+ }
57
+
58
+ if (!value) {
59
+ return "";
60
+ }
61
+
62
+ try {
63
+ return _cryptoJs.default.AES.encrypt(value, secret).toString();
64
+ } catch (ex) {
65
+ console.log(`Could not encrypt given password.`);
66
+ }
67
+
68
+ return "";
69
+ };
70
+
71
+ exports.encrypt = encrypt;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["decrypt","params","value","secret","WebinyError","bytes","CryptoJS","AES","result","toString","enc","Utf8","console","log","ex","encrypt"],"sources":["password.ts"],"sourcesContent":["import CryptoJS from \"crypto-js\";\nimport WebinyError from \"@webiny/error\";\n\ninterface Params {\n value?: string | null;\n secret?: string | null;\n}\n\nexport const decrypt = (params: Params): string => {\n const { value, secret } = params;\n if (!secret) {\n throw new WebinyError(`Cannot call decrypt without passing the secret.`);\n }\n if (!value) {\n return \"\";\n }\n try {\n const bytes = CryptoJS.AES.decrypt(value, secret);\n const result = bytes.toString(CryptoJS.enc.Utf8);\n if (!result) {\n console.log(`Error while converting decrypted password bytes into string. `);\n return \"\";\n }\n return result;\n } catch (ex) {\n console.log(`Could not decrypt given encrypted password.`);\n }\n return \"\";\n};\n\nexport const encrypt = (params: Params): string => {\n const { value, secret } = params;\n if (!secret) {\n throw new WebinyError(`Cannot call decrypt without passing the secret.`);\n }\n if (!value) {\n return \"\";\n }\n try {\n return CryptoJS.AES.encrypt(value, secret).toString();\n } catch (ex) {\n console.log(`Could not encrypt given password.`);\n }\n return \"\";\n};\n"],"mappings":";;;;;;;;;AAAA;;AACA;;AAOO,MAAMA,OAAO,GAAIC,MAAD,IAA4B;EAC/C,MAAM;IAAEC,KAAF;IAASC;EAAT,IAAoBF,MAA1B;;EACA,IAAI,CAACE,MAAL,EAAa;IACT,MAAM,IAAIC,cAAJ,CAAiB,iDAAjB,CAAN;EACH;;EACD,IAAI,CAACF,KAAL,EAAY;IACR,OAAO,EAAP;EACH;;EACD,IAAI;IACA,MAAMG,KAAK,GAAGC,iBAAA,CAASC,GAAT,CAAaP,OAAb,CAAqBE,KAArB,EAA4BC,MAA5B,CAAd;;IACA,MAAMK,MAAM,GAAGH,KAAK,CAACI,QAAN,CAAeH,iBAAA,CAASI,GAAT,CAAaC,IAA5B,CAAf;;IACA,IAAI,CAACH,MAAL,EAAa;MACTI,OAAO,CAACC,GAAR,CAAa,+DAAb;MACA,OAAO,EAAP;IACH;;IACD,OAAOL,MAAP;EACH,CARD,CAQE,OAAOM,EAAP,EAAW;IACTF,OAAO,CAACC,GAAR,CAAa,6CAAb;EACH;;EACD,OAAO,EAAP;AACH,CApBM;;;;AAsBA,MAAME,OAAO,GAAId,MAAD,IAA4B;EAC/C,MAAM;IAAEC,KAAF;IAASC;EAAT,IAAoBF,MAA1B;;EACA,IAAI,CAACE,MAAL,EAAa;IACT,MAAM,IAAIC,cAAJ,CAAiB,iDAAjB,CAAN;EACH;;EACD,IAAI,CAACF,KAAL,EAAY;IACR,OAAO,EAAP;EACH;;EACD,IAAI;IACA,OAAOI,iBAAA,CAASC,GAAT,CAAaQ,OAAb,CAAqBb,KAArB,EAA4BC,MAA5B,EAAoCM,QAApC,EAAP;EACH,CAFD,CAEE,OAAOK,EAAP,EAAW;IACTF,OAAO,CAACC,GAAR,CAAa,mCAAb;EACH;;EACD,OAAO,EAAP;AACH,CAdM"}
@@ -0,0 +1 @@
1
+ export declare const getSecret: () => string;
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.getSecret = void 0;
9
+
10
+ var _error = _interopRequireDefault(require("@webiny/error"));
11
+
12
+ const getSecret = () => {
13
+ const envValue = process.env.WEBINY_MAILER_PASSWORD_SECRET;
14
+ const value = String(envValue).trim();
15
+
16
+ if (!envValue || !value) {
17
+ throw new _error.default(`There must be a password secret defined!`, "PASSWORD_SECRET_ERROR");
18
+ }
19
+
20
+ return value;
21
+ };
22
+
23
+ exports.getSecret = getSecret;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["getSecret","envValue","process","env","WEBINY_MAILER_PASSWORD_SECRET","value","String","trim","WebinyError"],"sources":["secret.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\n\nexport const getSecret = (): string => {\n const envValue = process.env.WEBINY_MAILER_PASSWORD_SECRET;\n\n const value = String(envValue).trim();\n if (!envValue || !value) {\n throw new WebinyError(`There must be a password secret defined!`, \"PASSWORD_SECRET_ERROR\");\n }\n return value;\n};\n"],"mappings":";;;;;;;;;AAAA;;AAEO,MAAMA,SAAS,GAAG,MAAc;EACnC,MAAMC,QAAQ,GAAGC,OAAO,CAACC,GAAR,CAAYC,6BAA7B;EAEA,MAAMC,KAAK,GAAGC,MAAM,CAACL,QAAD,CAAN,CAAiBM,IAAjB,EAAd;;EACA,IAAI,CAACN,QAAD,IAAa,CAACI,KAAlB,EAAyB;IACrB,MAAM,IAAIG,cAAJ,CAAiB,0CAAjB,EAA4D,uBAA5D,CAAN;EACH;;EACD,OAAOH,KAAP;AACH,CARM"}
@@ -0,0 +1,13 @@
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 {};
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.transformValuesFromEntry = exports.transformInputToEntryValues = void 0;
9
+
10
+ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
11
+
12
+ var _error = _interopRequireDefault(require("@webiny/error"));
13
+
14
+ var _password = require("./password");
15
+
16
+ const transformValuesFromEntry = params => {
17
+ const {
18
+ entry,
19
+ secret
20
+ } = params;
21
+
22
+ if (!secret) {
23
+ throw new _error.default(`There is no secret defined. Without it we cannot decrypt the password.`);
24
+ }
25
+
26
+ return (0, _objectSpread2.default)((0, _objectSpread2.default)({
27
+ id: entry.id
28
+ }, entry.values), {}, {
29
+ password: (0, _password.decrypt)({
30
+ value: entry.values.password,
31
+ secret
32
+ })
33
+ });
34
+ };
35
+
36
+ exports.transformValuesFromEntry = transformValuesFromEntry;
37
+
38
+ const transformInputToEntryValues = params => {
39
+ const {
40
+ values,
41
+ secret
42
+ } = params;
43
+
44
+ if (!secret) {
45
+ throw new _error.default(`There is no secret defined. Without it we cannot decrypt the password.`);
46
+ }
47
+
48
+ return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, values), {}, {
49
+ password: (0, _password.encrypt)({
50
+ value: values.password,
51
+ secret
52
+ })
53
+ });
54
+ };
55
+
56
+ exports.transformInputToEntryValues = transformInputToEntryValues;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["transformValuesFromEntry","params","entry","secret","WebinyError","id","values","password","decrypt","value","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;;AAEA;;AAOO,MAAMA,wBAAwB,GACjCC,MADoC,IAER;EAC5B,MAAM;IAAEC,KAAF;IAASC;EAAT,IAAoBF,MAA1B;;EACA,IAAI,CAACE,MAAL,EAAa;IACT,MAAM,IAAIC,cAAJ,CACD,wEADC,CAAN;EAGH;;EACD;IACIC,EAAE,EAAEH,KAAK,CAACG;EADd,GAEOH,KAAK,CAACI,MAFb;IAGIC,QAAQ,EAAE,IAAAC,iBAAA,EAAQ;MACdC,KAAK,EAAEP,KAAK,CAACI,MAAN,CAAaC,QADN;MAEdJ;IAFc,CAAR;EAHd;AAQH,CAjBM;;;;AAuBA,MAAMO,2BAA2B,GACpCT,MADuC,IAEnB;EACpB,MAAM;IAAEK,MAAF;IAAUH;EAAV,IAAqBF,MAA3B;;EAEA,IAAI,CAACE,MAAL,EAAa;IACT,MAAM,IAAIC,cAAJ,CACD,wEADC,CAAN;EAGH;;EAED,mEACOE,MADP;IAEIC,QAAQ,EAAE,IAAAI,iBAAA,EAAQ;MACdF,KAAK,EAAEH,MAAM,CAACC,QADA;MAEdJ;IAFc,CAAR;EAFd;AAOH,CAlBM"}
@@ -0,0 +1,4 @@
1
+ import joi from "joi";
2
+ import { TransportSettings } from "../../types";
3
+ export declare const createValidation: joi.ObjectSchema<TransportSettings>;
4
+ export declare const updateValidation: joi.ObjectSchema<TransportSettings>;
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.updateValidation = exports.createValidation = void 0;
9
+
10
+ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
11
+
12
+ var _joi = _interopRequireDefault(require("joi"));
13
+
14
+ const options = {
15
+ tlds: false
16
+ };
17
+
18
+ const password = _joi.default.string().label("Password");
19
+
20
+ const common = {
21
+ from: _joi.default.string().email(options).required().label("Mail from"),
22
+ port: _joi.default.number().label("Port").default(25),
23
+ replyTo: _joi.default.string().email(options).optional().label("Mail reply-to"),
24
+ host: _joi.default.string().required().label("Hostname"),
25
+ user: _joi.default.string().required().label("User")
26
+ };
27
+
28
+ const createValidation = _joi.default.object((0, _objectSpread2.default)((0, _objectSpread2.default)({}, common), {}, {
29
+ password: password.required()
30
+ })).required();
31
+
32
+ exports.createValidation = createValidation;
33
+
34
+ const updateValidation = _joi.default.object((0, _objectSpread2.default)((0, _objectSpread2.default)({}, common), {}, {
35
+ password
36
+ })).required();
37
+
38
+ exports.updateValidation = updateValidation;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["options","tlds","password","joi","string","label","common","from","email","required","port","number","default","replyTo","optional","host","user","createValidation","object","updateValidation"],"sources":["validation.ts"],"sourcesContent":["import joi, { EmailOptions } from \"joi\";\nimport { TransportSettings } from \"~/types\";\n\nconst options: EmailOptions = {\n tlds: false\n};\n\nconst password = joi.string().label(\"Password\");\nconst common = {\n from: joi.string().email(options).required().label(\"Mail from\"),\n port: joi.number().label(\"Port\").default(25),\n replyTo: joi.string().email(options).optional().label(\"Mail reply-to\"),\n host: joi.string().required().label(\"Hostname\"),\n user: joi.string().required().label(\"User\")\n};\n\nexport const createValidation = joi\n .object<TransportSettings>({\n ...common,\n password: password.required()\n })\n .required();\n\nexport const updateValidation = joi\n .object<TransportSettings>({\n ...common,\n password\n })\n .required();\n"],"mappings":";;;;;;;;;;;AAAA;;AAGA,MAAMA,OAAqB,GAAG;EAC1BC,IAAI,EAAE;AADoB,CAA9B;;AAIA,MAAMC,QAAQ,GAAGC,YAAA,CAAIC,MAAJ,GAAaC,KAAb,CAAmB,UAAnB,CAAjB;;AACA,MAAMC,MAAM,GAAG;EACXC,IAAI,EAAEJ,YAAA,CAAIC,MAAJ,GAAaI,KAAb,CAAmBR,OAAnB,EAA4BS,QAA5B,GAAuCJ,KAAvC,CAA6C,WAA7C,CADK;EAEXK,IAAI,EAAEP,YAAA,CAAIQ,MAAJ,GAAaN,KAAb,CAAmB,MAAnB,EAA2BO,OAA3B,CAAmC,EAAnC,CAFK;EAGXC,OAAO,EAAEV,YAAA,CAAIC,MAAJ,GAAaI,KAAb,CAAmBR,OAAnB,EAA4Bc,QAA5B,GAAuCT,KAAvC,CAA6C,eAA7C,CAHE;EAIXU,IAAI,EAAEZ,YAAA,CAAIC,MAAJ,GAAaK,QAAb,GAAwBJ,KAAxB,CAA8B,UAA9B,CAJK;EAKXW,IAAI,EAAEb,YAAA,CAAIC,MAAJ,GAAaK,QAAb,GAAwBJ,KAAxB,CAA8B,MAA9B;AALK,CAAf;;AAQO,MAAMY,gBAAgB,GAAGd,YAAA,CAC3Be,MAD2B,6DAErBZ,MAFqB;EAGxBJ,QAAQ,EAAEA,QAAQ,CAACO,QAAT;AAHc,IAK3BA,QAL2B,EAAzB;;;;AAOA,MAAMU,gBAAgB,GAAGhB,YAAA,CAC3Be,MAD2B,6DAErBZ,MAFqB;EAGxBJ;AAHwB,IAK3BO,QAL2B,EAAzB"}
@@ -0,0 +1,5 @@
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>;