@webiny/api-mailer 5.34.8-beta.1 → 5.35.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.js +0 -7
- package/context.js.map +1 -1
- package/crud/group.js +0 -3
- package/crud/group.js.map +1 -1
- package/crud/settings/hooks.js +3 -15
- package/crud/settings/hooks.js.map +1 -1
- package/crud/settings/model.js +2 -13
- package/crud/settings/model.js.map +1 -1
- package/crud/settings/password.js +0 -18
- package/crud/settings/password.js.map +1 -1
- package/crud/settings/secret.js +0 -6
- package/crud/settings/secret.js.map +1 -1
- package/crud/settings/transform.js +0 -12
- package/crud/settings/transform.js.map +1 -1
- package/crud/settings/validation.d.ts +45 -4
- package/crud/settings/validation.js +11 -24
- package/crud/settings/validation.js.map +1 -1
- package/crud/settings.crud.js +132 -195
- package/crud/settings.crud.js.map +1 -1
- package/crud/transport/onTransportBeforeSend.js +28 -37
- package/crud/transport/onTransportBeforeSend.js.map +1 -1
- package/crud/transporter.crud.js +3 -40
- package/crud/transporter.crud.js.map +1 -1
- package/graphql/index.js +0 -3
- package/graphql/index.js.map +1 -1
- package/graphql/settings.js +0 -8
- package/graphql/settings.js.map +1 -1
- package/index.d.ts +2 -5
- package/index.js +29 -35
- package/index.js.map +1 -1
- package/package.json +24 -24
- package/plugins/CreateTransportPlugin.js +0 -9
- package/plugins/CreateTransportPlugin.js.map +1 -1
- package/plugins/index.js +0 -2
- package/plugins/index.js.map +1 -1
- package/transports/createDummyTransport.js +1 -3
- package/transports/createDummyTransport.js.map +1 -1
- package/transports/createSmtpTransport.js +1 -16
- package/transports/createSmtpTransport.js.map +1 -1
- package/transports/index.d.ts +2 -0
- package/transports/index.js +27 -0
- package/transports/index.js.map +1 -0
- package/types.d.ts +1 -1
- package/types.js.map +1 -1
package/context.js
CHANGED
|
@@ -1,24 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports.createMailerContext = void 0;
|
|
9
|
-
|
|
10
8
|
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
11
|
-
|
|
12
9
|
var _api = require("@webiny/api");
|
|
13
|
-
|
|
14
10
|
var _transporter = require("./crud/transporter.crud");
|
|
15
|
-
|
|
16
11
|
var _settings = require("./crud/settings.crud");
|
|
17
|
-
|
|
18
12
|
const createMailerContext = () => {
|
|
19
13
|
return new _api.ContextPlugin(async context => {
|
|
20
14
|
context.mailer = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, await (0, _transporter.createTransporterCrud)(context)), await (0, _settings.createSettingsCrud)(context));
|
|
21
15
|
});
|
|
22
16
|
};
|
|
23
|
-
|
|
24
17
|
exports.createMailerContext = createMailerContext;
|
package/context.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
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":"
|
|
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,kBAAa,CAAgB,MAAMC,OAAO,IAAI;IACrDA,OAAO,CAACC,MAAM,+DACN,MAAM,IAAAC,kCAAqB,EAACF,OAAO,CAAC,GACpC,MAAM,IAAAG,4BAAkB,EAACH,OAAO,CAAC,CACxC;EACL,CAAC,CAAC;AACN,CAAC;AAAC"}
|
package/crud/group.js
CHANGED
|
@@ -4,9 +4,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.createGroup = void 0;
|
|
7
|
-
|
|
8
7
|
var _apiHeadlessCms = require("@webiny/api-headless-cms");
|
|
9
|
-
|
|
10
8
|
const createGroup = () => {
|
|
11
9
|
return (0, _apiHeadlessCms.createCmsGroup)({
|
|
12
10
|
name: "Mailer Group",
|
|
@@ -17,5 +15,4 @@ const createGroup = () => {
|
|
|
17
15
|
isPrivate: true
|
|
18
16
|
});
|
|
19
17
|
};
|
|
20
|
-
|
|
21
18
|
exports.createGroup = createGroup;
|
package/crud/group.js.map
CHANGED
|
@@ -1 +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":"
|
|
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,8BAAc,EAAC;IAClBC,IAAI,EAAE,cAAc;IACpBC,WAAW,EAAE,sBAAsB;IACnCC,EAAE,EAAE,aAAa;IACjBC,IAAI,EAAE,aAAa;IACnBC,IAAI,EAAE,MAAM;IACZC,SAAS,EAAE;EACf,CAAC,CAAC;AACN,CAAC;AAAC"}
|
package/crud/settings/hooks.js
CHANGED
|
@@ -1,41 +1,32 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports.attachPasswordObfuscatingHooks = void 0;
|
|
9
|
-
|
|
10
8
|
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
|
11
|
-
|
|
12
9
|
var _model = require("./model");
|
|
13
|
-
|
|
14
10
|
const _excluded = ["password"];
|
|
15
|
-
|
|
16
11
|
const obfuscatePassword = values => {
|
|
17
12
|
// eslint-disable-next-line
|
|
18
13
|
const {
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
14
|
+
password
|
|
15
|
+
} = values,
|
|
16
|
+
rest = (0, _objectWithoutProperties2.default)(values, _excluded);
|
|
22
17
|
return {
|
|
23
18
|
rest
|
|
24
19
|
};
|
|
25
20
|
};
|
|
26
|
-
|
|
27
21
|
const hook = async params => {
|
|
28
22
|
if (params.model.modelId !== _model.SETTINGS_MODEL_ID) {
|
|
29
23
|
return;
|
|
30
24
|
}
|
|
31
|
-
|
|
32
25
|
delete params.input["password"];
|
|
33
26
|
params.entry.values = obfuscatePassword(params.entry.values);
|
|
34
|
-
|
|
35
27
|
if (typeof params.original !== "undefined") {
|
|
36
28
|
params.original.values = obfuscatePassword(params.original.values);
|
|
37
29
|
}
|
|
38
|
-
|
|
39
30
|
if (params.storageEntry) {
|
|
40
31
|
params.storageEntry.values = obfuscatePassword(params.storageEntry.values);
|
|
41
32
|
}
|
|
@@ -43,13 +34,10 @@ const hook = async params => {
|
|
|
43
34
|
/**
|
|
44
35
|
* We need to remove password from all error reporting and all returns.
|
|
45
36
|
*/
|
|
46
|
-
|
|
47
|
-
|
|
48
37
|
const attachPasswordObfuscatingHooks = context => {
|
|
49
38
|
context.cms.onEntryAfterCreate.subscribe(hook);
|
|
50
39
|
context.cms.onEntryCreateError.subscribe(hook);
|
|
51
40
|
context.cms.onEntryAfterUpdate.subscribe(hook);
|
|
52
41
|
context.cms.onEntryUpdateError.subscribe(hook);
|
|
53
42
|
};
|
|
54
|
-
|
|
55
43
|
exports.attachPasswordObfuscatingHooks = attachPasswordObfuscatingHooks;
|
|
@@ -1 +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":"
|
|
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;AAA0D;AAE1D,MAAMA,iBAAiB,GAAIC,MAA2B,IAAK;EACvD;EACA,MAAM;MAAEC;IAAkB,CAAC,GAAGD,MAAM;IAAfE,IAAI,0CAAKF,MAAM;EAEpC,OAAO;IAAEE;EAAK,CAAC;AACnB,CAAC;AAYD,MAAMC,IAAI,GAAG,MAAOC,MAAc,IAAK;EACnC,IAAIA,MAAM,CAACC,KAAK,CAACC,OAAO,KAAKC,wBAAiB,EAAE;IAC5C;EACJ;EACA,OAAOH,MAAM,CAACI,KAAK,CAAC,UAAU,CAAC;EAC/BJ,MAAM,CAACK,KAAK,CAACT,MAAM,GAAGD,iBAAiB,CAACK,MAAM,CAACK,KAAK,CAACT,MAAM,CAAC;EAC5D,IAAI,OAAOI,MAAM,CAACM,QAAQ,KAAK,WAAW,EAAE;IACxCN,MAAM,CAACM,QAAQ,CAACV,MAAM,GAAGD,iBAAiB,CAACK,MAAM,CAACM,QAAQ,CAACV,MAAM,CAAC;EACtE;EACA,IAAII,MAAM,CAACO,YAAY,EAAE;IACrBP,MAAM,CAACO,YAAY,CAACX,MAAM,GAAGD,iBAAiB,CAACK,MAAM,CAACO,YAAY,CAACX,MAAM,CAAC;EAC9E;AACJ,CAAC;AACD;AACA;AACA;AACO,MAAMY,8BAA8B,GAAIC,OAAsB,IAAK;EACtEA,OAAO,CAACC,GAAG,CAACC,kBAAkB,CAACC,SAAS,CAACb,IAAI,CAAC;EAC9CU,OAAO,CAACC,GAAG,CAACG,kBAAkB,CAACD,SAAS,CAACb,IAAI,CAAC;EAC9CU,OAAO,CAACC,GAAG,CAACI,kBAAkB,CAACF,SAAS,CAACb,IAAI,CAAC;EAC9CU,OAAO,CAACC,GAAG,CAACK,kBAAkB,CAACH,SAAS,CAACb,IAAI,CAAC;AAClD,CAAC;AAAC"}
|
package/crud/settings/model.js
CHANGED
|
@@ -1,21 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports.createSettingsModel = exports.SETTINGS_MODEL_ID = void 0;
|
|
9
|
-
|
|
10
8
|
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
11
|
-
|
|
12
9
|
var _apiHeadlessCms = require("@webiny/api-headless-cms");
|
|
13
|
-
|
|
14
10
|
var _camelCase = _interopRequireDefault(require("lodash/camelCase"));
|
|
15
|
-
|
|
16
11
|
const SETTINGS_MODEL_ID = "mailerSettings";
|
|
17
12
|
exports.SETTINGS_MODEL_ID = SETTINGS_MODEL_ID;
|
|
18
|
-
|
|
19
13
|
const createField = params => {
|
|
20
14
|
const {
|
|
21
15
|
label,
|
|
@@ -24,7 +18,6 @@ const createField = params => {
|
|
|
24
18
|
} = params;
|
|
25
19
|
const id = (0, _camelCase.default)(label);
|
|
26
20
|
const validation = [];
|
|
27
|
-
|
|
28
21
|
if (required) {
|
|
29
22
|
validation.push({
|
|
30
23
|
message: `Field "${label}" is required!`,
|
|
@@ -32,7 +25,6 @@ const createField = params => {
|
|
|
32
25
|
settings: {}
|
|
33
26
|
});
|
|
34
27
|
}
|
|
35
|
-
|
|
36
28
|
return {
|
|
37
29
|
label,
|
|
38
30
|
id,
|
|
@@ -42,19 +34,16 @@ const createField = params => {
|
|
|
42
34
|
validation
|
|
43
35
|
};
|
|
44
36
|
};
|
|
45
|
-
|
|
46
37
|
const createTextField = params => {
|
|
47
38
|
return createField((0, _objectSpread2.default)((0, _objectSpread2.default)({}, params), {}, {
|
|
48
39
|
type: "text"
|
|
49
40
|
}));
|
|
50
41
|
};
|
|
51
|
-
|
|
52
42
|
const createNumberField = params => {
|
|
53
43
|
return createField((0, _objectSpread2.default)((0, _objectSpread2.default)({}, params), {}, {
|
|
54
44
|
type: "number"
|
|
55
45
|
}));
|
|
56
46
|
};
|
|
57
|
-
|
|
58
47
|
const createSettingsModel = group => {
|
|
59
48
|
return (0, _apiHeadlessCms.createCmsModel)({
|
|
60
49
|
modelId: SETTINGS_MODEL_ID,
|
|
@@ -83,8 +72,8 @@ const createSettingsModel = group => {
|
|
|
83
72
|
layout: [["host", "port", "user", "password", "from", "replyTo"]],
|
|
84
73
|
description: "Mailer Settings",
|
|
85
74
|
titleFieldId: "",
|
|
86
|
-
isPrivate: true
|
|
75
|
+
isPrivate: true,
|
|
76
|
+
noValidate: true
|
|
87
77
|
});
|
|
88
78
|
};
|
|
89
|
-
|
|
90
79
|
exports.createSettingsModel = createSettingsModel;
|
|
@@ -1 +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":"
|
|
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","noValidate"],"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 noValidate: true\n });\n};\n"],"mappings":";;;;;;;;AAAA;AAEA;AAEO,MAAMA,iBAAiB,GAAG,gBAAgB;AAAC;AAOlD,MAAMC,WAAW,GAAIC,MAAyB,IAAoB;EAC9D,MAAM;IAAEC,KAAK;IAAEC,QAAQ;IAAEC;EAAK,CAAC,GAAGH,MAAM;EACxC,MAAMI,EAAE,GAAG,IAAAC,kBAAe,EAACJ,KAAK,CAAC;EAEjC,MAAMK,UAAqC,GAAG,EAAE;EAChD,IAAIJ,QAAQ,EAAE;IACVI,UAAU,CAACC,IAAI,CAAC;MACZC,OAAO,EAAG,UAASP,KAAM,gBAAe;MACxCQ,IAAI,EAAE,UAAU;MAChBC,QAAQ,EAAE,CAAC;IACf,CAAC,CAAC;EACN;EACA,OAAO;IACHT,KAAK;IACLG,EAAE;IACFO,OAAO,EAAEP,EAAE;IACXQ,SAAS,EAAER,EAAE;IACbD,IAAI;IACJG;EACJ,CAAC;AACL,CAAC;AAED,MAAMO,eAAe,GAAIb,MAAuC,IAAK;EACjE,OAAOD,WAAW,6DACXC,MAAM;IACTG,IAAI,EAAE;EAAM,GACd;AACN,CAAC;AACD,MAAMW,iBAAiB,GAAId,MAAuC,IAAK;EACnE,OAAOD,WAAW,6DACXC,MAAM;IACTG,IAAI,EAAE;EAAQ,GAChB;AACN,CAAC;AAEM,MAAMY,mBAAmB,GAAIC,KAAqB,IAAK;EAC1D,OAAO,IAAAC,8BAAc,EAAC;IAClBC,OAAO,EAAEpB,iBAAiB;IAC1BW,IAAI,EAAE,iBAAiB;IACvBO,KAAK,EAAE;MACHZ,EAAE,EAAEY,KAAK,CAACG,iBAAiB,CAACf,EAAE;MAC9BK,IAAI,EAAEO,KAAK,CAACG,iBAAiB,CAACV;IAClC,CAAC;IACDW,MAAM,EAAE,CACJP,eAAe,CAAC;MACZZ,KAAK,EAAE,MAAM;MACbC,QAAQ,EAAE;IACd,CAAC,CAAC,EACFY,iBAAiB,CAAC;MACdb,KAAK,EAAE;IACX,CAAC,CAAC,EACFY,eAAe,CAAC;MACZZ,KAAK,EAAE,MAAM;MACbC,QAAQ,EAAE;IACd,CAAC,CAAC,EACFW,eAAe,CAAC;MACZZ,KAAK,EAAE,UAAU;MACjBC,QAAQ,EAAE;IACd,CAAC,CAAC,EACFW,eAAe,CAAC;MACZZ,KAAK,EAAE,MAAM;MACbC,QAAQ,EAAE;IACd,CAAC,CAAC,EACFW,eAAe,CAAC;MACZZ,KAAK,EAAE;IACX,CAAC,CAAC,CACL;IACDoB,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC;IACjEC,WAAW,EAAE,iBAAiB;IAC9BC,YAAY,EAAE,EAAE;IAChBC,SAAS,EAAE,IAAI;IACfC,UAAU,EAAE;EAChB,CAAC,CAAC;AACN,CAAC;AAAC"}
|
|
@@ -1,71 +1,53 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports.encrypt = exports.decrypt = void 0;
|
|
9
|
-
|
|
10
8
|
var _cryptoJs = _interopRequireDefault(require("crypto-js"));
|
|
11
|
-
|
|
12
9
|
var _error = _interopRequireDefault(require("@webiny/error"));
|
|
13
|
-
|
|
14
10
|
const decrypt = params => {
|
|
15
11
|
const {
|
|
16
12
|
value,
|
|
17
13
|
secret
|
|
18
14
|
} = params;
|
|
19
|
-
|
|
20
15
|
if (!secret) {
|
|
21
16
|
throw new _error.default(`Cannot call decrypt without passing the secret.`);
|
|
22
17
|
}
|
|
23
|
-
|
|
24
18
|
if (!value) {
|
|
25
19
|
return "";
|
|
26
20
|
}
|
|
27
|
-
|
|
28
21
|
try {
|
|
29
22
|
const bytes = _cryptoJs.default.AES.decrypt(value, secret);
|
|
30
|
-
|
|
31
23
|
const result = bytes.toString(_cryptoJs.default.enc.Utf8);
|
|
32
|
-
|
|
33
24
|
if (!result) {
|
|
34
25
|
console.log(`Error while converting decrypted password bytes into string. `);
|
|
35
26
|
return "";
|
|
36
27
|
}
|
|
37
|
-
|
|
38
28
|
return result;
|
|
39
29
|
} catch (ex) {
|
|
40
30
|
console.log(`Could not decrypt given encrypted password.`);
|
|
41
31
|
}
|
|
42
|
-
|
|
43
32
|
return "";
|
|
44
33
|
};
|
|
45
|
-
|
|
46
34
|
exports.decrypt = decrypt;
|
|
47
|
-
|
|
48
35
|
const encrypt = params => {
|
|
49
36
|
const {
|
|
50
37
|
value,
|
|
51
38
|
secret
|
|
52
39
|
} = params;
|
|
53
|
-
|
|
54
40
|
if (!secret) {
|
|
55
41
|
throw new _error.default(`Cannot call decrypt without passing the secret.`);
|
|
56
42
|
}
|
|
57
|
-
|
|
58
43
|
if (!value) {
|
|
59
44
|
return "";
|
|
60
45
|
}
|
|
61
|
-
|
|
62
46
|
try {
|
|
63
47
|
return _cryptoJs.default.AES.encrypt(value, secret).toString();
|
|
64
48
|
} catch (ex) {
|
|
65
49
|
console.log(`Could not encrypt given password.`);
|
|
66
50
|
}
|
|
67
|
-
|
|
68
51
|
return "";
|
|
69
52
|
};
|
|
70
|
-
|
|
71
53
|
exports.encrypt = encrypt;
|
|
@@ -1 +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":"
|
|
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,MAAc,IAAa;EAC/C,MAAM;IAAEC,KAAK;IAAEC;EAAO,CAAC,GAAGF,MAAM;EAChC,IAAI,CAACE,MAAM,EAAE;IACT,MAAM,IAAIC,cAAW,CAAE,iDAAgD,CAAC;EAC5E;EACA,IAAI,CAACF,KAAK,EAAE;IACR,OAAO,EAAE;EACb;EACA,IAAI;IACA,MAAMG,KAAK,GAAGC,iBAAQ,CAACC,GAAG,CAACP,OAAO,CAACE,KAAK,EAAEC,MAAM,CAAC;IACjD,MAAMK,MAAM,GAAGH,KAAK,CAACI,QAAQ,CAACH,iBAAQ,CAACI,GAAG,CAACC,IAAI,CAAC;IAChD,IAAI,CAACH,MAAM,EAAE;MACTI,OAAO,CAACC,GAAG,CAAE,+DAA8D,CAAC;MAC5E,OAAO,EAAE;IACb;IACA,OAAOL,MAAM;EACjB,CAAC,CAAC,OAAOM,EAAE,EAAE;IACTF,OAAO,CAACC,GAAG,CAAE,6CAA4C,CAAC;EAC9D;EACA,OAAO,EAAE;AACb,CAAC;AAAC;AAEK,MAAME,OAAO,GAAId,MAAc,IAAa;EAC/C,MAAM;IAAEC,KAAK;IAAEC;EAAO,CAAC,GAAGF,MAAM;EAChC,IAAI,CAACE,MAAM,EAAE;IACT,MAAM,IAAIC,cAAW,CAAE,iDAAgD,CAAC;EAC5E;EACA,IAAI,CAACF,KAAK,EAAE;IACR,OAAO,EAAE;EACb;EACA,IAAI;IACA,OAAOI,iBAAQ,CAACC,GAAG,CAACQ,OAAO,CAACb,KAAK,EAAEC,MAAM,CAAC,CAACM,QAAQ,EAAE;EACzD,CAAC,CAAC,OAAOK,EAAE,EAAE;IACTF,OAAO,CAACC,GAAG,CAAE,mCAAkC,CAAC;EACpD;EACA,OAAO,EAAE;AACb,CAAC;AAAC"}
|
package/crud/settings/secret.js
CHANGED
|
@@ -1,23 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports.getSecret = void 0;
|
|
9
|
-
|
|
10
8
|
var _error = _interopRequireDefault(require("@webiny/error"));
|
|
11
|
-
|
|
12
9
|
const getSecret = () => {
|
|
13
10
|
const envValue = process.env.WEBINY_MAILER_PASSWORD_SECRET;
|
|
14
11
|
const value = String(envValue).trim();
|
|
15
|
-
|
|
16
12
|
if (!envValue || !value) {
|
|
17
13
|
throw new _error.default(`There must be a password secret defined!`, "PASSWORD_SECRET_ERROR");
|
|
18
14
|
}
|
|
19
|
-
|
|
20
15
|
return value;
|
|
21
16
|
};
|
|
22
|
-
|
|
23
17
|
exports.getSecret = getSecret;
|
|
@@ -1 +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":"
|
|
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,GAAG,CAACC,6BAA6B;EAE1D,MAAMC,KAAK,GAAGC,MAAM,CAACL,QAAQ,CAAC,CAACM,IAAI,EAAE;EACrC,IAAI,CAACN,QAAQ,IAAI,CAACI,KAAK,EAAE;IACrB,MAAM,IAAIG,cAAW,CAAE,0CAAyC,EAAE,uBAAuB,CAAC;EAC9F;EACA,OAAOH,KAAK;AAChB,CAAC;AAAC"}
|
|
@@ -1,28 +1,21 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports.transformValuesFromEntry = exports.transformInputToEntryValues = void 0;
|
|
9
|
-
|
|
10
8
|
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
11
|
-
|
|
12
9
|
var _error = _interopRequireDefault(require("@webiny/error"));
|
|
13
|
-
|
|
14
10
|
var _password = require("./password");
|
|
15
|
-
|
|
16
11
|
const transformValuesFromEntry = params => {
|
|
17
12
|
const {
|
|
18
13
|
entry,
|
|
19
14
|
secret
|
|
20
15
|
} = params;
|
|
21
|
-
|
|
22
16
|
if (!secret) {
|
|
23
17
|
throw new _error.default(`There is no secret defined. Without it we cannot decrypt the password.`);
|
|
24
18
|
}
|
|
25
|
-
|
|
26
19
|
return (0, _objectSpread2.default)((0, _objectSpread2.default)({
|
|
27
20
|
id: entry.id
|
|
28
21
|
}, entry.values), {}, {
|
|
@@ -32,19 +25,15 @@ const transformValuesFromEntry = params => {
|
|
|
32
25
|
})
|
|
33
26
|
});
|
|
34
27
|
};
|
|
35
|
-
|
|
36
28
|
exports.transformValuesFromEntry = transformValuesFromEntry;
|
|
37
|
-
|
|
38
29
|
const transformInputToEntryValues = params => {
|
|
39
30
|
const {
|
|
40
31
|
values,
|
|
41
32
|
secret
|
|
42
33
|
} = params;
|
|
43
|
-
|
|
44
34
|
if (!secret) {
|
|
45
35
|
throw new _error.default(`There is no secret defined. Without it we cannot decrypt the password.`);
|
|
46
36
|
}
|
|
47
|
-
|
|
48
37
|
return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, values), {}, {
|
|
49
38
|
password: (0, _password.encrypt)({
|
|
50
39
|
value: values.password,
|
|
@@ -52,5 +41,4 @@ const transformInputToEntryValues = params => {
|
|
|
52
41
|
})
|
|
53
42
|
});
|
|
54
43
|
};
|
|
55
|
-
|
|
56
44
|
exports.transformInputToEntryValues = transformInputToEntryValues;
|
|
@@ -1 +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":"
|
|
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,MAAsC,IACV;EAC5B,MAAM;IAAEC,KAAK;IAAEC;EAAO,CAAC,GAAGF,MAAM;EAChC,IAAI,CAACE,MAAM,EAAE;IACT,MAAM,IAAIC,cAAW,CAChB,wEAAuE,CAC3E;EACL;EACA;IACIC,EAAE,EAAEH,KAAK,CAACG;EAAE,GACTH,KAAK,CAACI,MAAM;IACfC,QAAQ,EAAE,IAAAC,iBAAO,EAAC;MACdC,KAAK,EAAEP,KAAK,CAACI,MAAM,CAACC,QAAQ;MAC5BJ;IACJ,CAAC;EAAC;AAEV,CAAC;AAAC;AAMK,MAAMO,2BAA2B,GACpCT,MAA0C,IACtB;EACpB,MAAM;IAAEK,MAAM;IAAEH;EAAO,CAAC,GAAGF,MAAM;EAEjC,IAAI,CAACE,MAAM,EAAE;IACT,MAAM,IAAIC,cAAW,CAChB,wEAAuE,CAC3E;EACL;EAEA,mEACOE,MAAM;IACTC,QAAQ,EAAE,IAAAI,iBAAO,EAAC;MACdF,KAAK,EAAEH,MAAM,CAACC,QAAQ;MACtBJ;IACJ,CAAC;EAAC;AAEV,CAAC;AAAC"}
|
|
@@ -1,4 +1,45 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
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.ZodNullable<zod.ZodString>;
|
|
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
|
+
password: string | null;
|
|
42
|
+
port: number | null;
|
|
43
|
+
host: string;
|
|
44
|
+
user: string;
|
|
45
|
+
}>;
|
|
@@ -1,38 +1,25 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports.updateValidation = exports.createValidation = void 0;
|
|
9
|
-
|
|
10
8
|
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
const options = {
|
|
15
|
-
tlds: false
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
const password = _joi.default.string().label("Password");
|
|
19
|
-
|
|
9
|
+
var _zod = _interopRequireDefault(require("zod"));
|
|
10
|
+
const password = _zod.default.string().describe("Password");
|
|
20
11
|
const common = {
|
|
21
|
-
from:
|
|
22
|
-
port:
|
|
23
|
-
replyTo:
|
|
24
|
-
host:
|
|
25
|
-
user:
|
|
12
|
+
from: _zod.default.string().email().describe("Mail from"),
|
|
13
|
+
port: _zod.default.number().optional().nullish().describe("Port"),
|
|
14
|
+
replyTo: _zod.default.string().email().optional().describe("Mail reply-to"),
|
|
15
|
+
host: _zod.default.string().describe("Hostname"),
|
|
16
|
+
user: _zod.default.string().describe("User")
|
|
26
17
|
};
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
password: password.required()
|
|
18
|
+
const createValidation = _zod.default.object((0, _objectSpread2.default)((0, _objectSpread2.default)({}, common), {}, {
|
|
19
|
+
password
|
|
30
20
|
})).required();
|
|
31
|
-
|
|
32
21
|
exports.createValidation = createValidation;
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
password
|
|
22
|
+
const updateValidation = _zod.default.object((0, _objectSpread2.default)((0, _objectSpread2.default)({}, common), {}, {
|
|
23
|
+
password: password.nullish().optional()
|
|
36
24
|
})).required();
|
|
37
|
-
|
|
38
25
|
exports.updateValidation = updateValidation;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["password","zod","string","describe","common","from","email","port","number","optional","nullish","replyTo","host","user","createValidation","object","required","updateValidation"],"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.nullish().optional()\n })\n .required();\n"],"mappings":";;;;;;;;AAAA;AAEA,MAAMA,QAAQ,GAAGC,YAAG,CAACC,MAAM,EAAE,CAACC,QAAQ,CAAC,UAAU,CAAC;AAElD,MAAMC,MAAM,GAAG;EACXC,IAAI,EAAEJ,YAAG,CAACC,MAAM,EAAE,CAACI,KAAK,EAAE,CAACH,QAAQ,CAAC,WAAW,CAAC;EAChDI,IAAI,EAAEN,YAAG,CAACO,MAAM,EAAE,CAACC,QAAQ,EAAE,CAACC,OAAO,EAAE,CAACP,QAAQ,CAAC,MAAM,CAAC;EACxDQ,OAAO,EAAEV,YAAG,CAACC,MAAM,EAAE,CAACI,KAAK,EAAE,CAACG,QAAQ,EAAE,CAACN,QAAQ,CAAC,eAAe,CAAC;EAClES,IAAI,EAAEX,YAAG,CAACC,MAAM,EAAE,CAACC,QAAQ,CAAC,UAAU,CAAC;EACvCU,IAAI,EAAEZ,YAAG,CAACC,MAAM,EAAE,CAACC,QAAQ,CAAC,MAAM;AACtC,CAAC;AAEM,MAAMW,gBAAgB,GAAGb,YAAG,CAC9Bc,MAAM,6DACAX,MAAM;EACTJ;AAAQ,GACV,CACDgB,QAAQ,EAAE;AAAC;AAET,MAAMC,gBAAgB,GAAGhB,YAAG,CAC9Bc,MAAM,6DACAX,MAAM;EACTJ,QAAQ,EAAEA,QAAQ,CAACU,OAAO,EAAE,CAACD,QAAQ;AAAE,GACzC,CACDO,QAAQ,EAAE;AAAC"}
|