@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.
- package/context.d.ts +2 -2
- package/context.js +9 -3
- package/context.js.map +1 -1
- package/crud/group.d.ts +2 -0
- package/crud/group.js +21 -0
- package/crud/group.js.map +1 -0
- package/crud/settings/hooks.d.ts +5 -0
- package/crud/settings/hooks.js +55 -0
- package/crud/settings/hooks.js.map +1 -0
- package/crud/settings/model.d.ts +3 -0
- package/crud/settings/model.js +90 -0
- package/crud/settings/model.js.map +1 -0
- package/crud/settings/password.d.ts +7 -0
- package/crud/settings/password.js +71 -0
- package/crud/settings/password.js.map +1 -0
- package/crud/settings/secret.d.ts +1 -0
- package/crud/settings/secret.js +23 -0
- package/crud/settings/secret.js.map +1 -0
- package/crud/settings/transform.d.ts +13 -0
- package/crud/settings/transform.js +56 -0
- package/crud/settings/transform.js.map +1 -0
- package/crud/settings/validation.d.ts +4 -0
- package/crud/settings/validation.js +38 -0
- package/crud/settings/validation.js.map +1 -0
- package/crud/settings.crud.d.ts +5 -0
- package/crud/settings.crud.js +331 -0
- package/crud/settings.crud.js.map +1 -0
- package/crud/transport/onTransportBeforeSend.d.ts +7 -0
- package/crud/transport/onTransportBeforeSend.js +69 -0
- package/crud/transport/onTransportBeforeSend.js.map +1 -0
- package/crud/transporter.crud.d.ts +2 -0
- package/crud/transporter.crud.js +193 -0
- package/crud/transporter.crud.js.map +1 -0
- package/graphql/index.d.ts +1 -0
- package/graphql/index.js +14 -0
- package/graphql/index.js.map +1 -0
- package/graphql/settings.d.ts +3 -0
- package/graphql/settings.js +109 -0
- package/graphql/settings.js.map +1 -0
- package/index.d.ts +7 -6
- package/index.js +69 -10
- package/index.js.map +1 -1
- package/package.json +33 -15
- package/plugins/CreateTransportPlugin.d.ts +17 -0
- package/plugins/CreateTransportPlugin.js +34 -0
- package/plugins/CreateTransportPlugin.js.map +1 -0
- package/plugins/index.d.ts +1 -0
- package/plugins/index.js +18 -0
- package/plugins/index.js.map +1 -0
- package/transports/createDummyTransport.d.ts +5 -0
- package/{mailers/createDummyMailer.js → transports/createDummyTransport.js} +4 -3
- package/transports/createDummyTransport.js.map +1 -0
- package/transports/createSmtpTransport.d.ts +12 -0
- package/transports/createSmtpTransport.js +101 -0
- package/transports/createSmtpTransport.js.map +1 -0
- package/types.d.ts +124 -34
- package/types.js.map +1 -1
- package/crud/mailer/onBeforeSend.d.ts +0 -7
- package/crud/mailer/onBeforeSend.js +0 -69
- package/crud/mailer/onBeforeSend.js.map +0 -1
- package/crud/mailer.crud.d.ts +0 -2
- package/crud/mailer.crud.js +0 -123
- package/crud/mailer.crud.js.map +0 -1
- package/mailers/createDummyMailer.d.ts +0 -5
- package/mailers/createDummyMailer.js.map +0 -1
- package/mailers/createSmtpMailer.d.ts +0 -13
- package/mailers/createSmtpMailer.js +0 -106
- 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 {
|
|
3
|
-
export declare const createMailerContext: (
|
|
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
|
|
14
|
+
var _transporter = require("./crud/transporter.crud");
|
|
15
|
+
|
|
16
|
+
var _settings = require("./crud/settings.crud");
|
|
11
17
|
|
|
12
|
-
const createMailerContext =
|
|
18
|
+
const createMailerContext = () => {
|
|
13
19
|
return new _api.ContextPlugin(async context => {
|
|
14
|
-
context.mailer = (0,
|
|
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","
|
|
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"}
|
package/crud/group.d.ts
ADDED
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,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,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,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,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"}
|