@strapi/email 0.0.0 → 5.0.0-beta.10

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 (145) hide show
  1. package/README.md +3 -1
  2. package/dist/_chunks/Settings-DPpUcr9n.js +300 -0
  3. package/dist/_chunks/Settings-DPpUcr9n.js.map +1 -0
  4. package/dist/_chunks/Settings-DwGRZXNs.mjs +281 -0
  5. package/dist/_chunks/Settings-DwGRZXNs.mjs.map +1 -0
  6. package/dist/_chunks/ar-Bf9XlLLo.mjs +5 -0
  7. package/dist/_chunks/ar-Bf9XlLLo.mjs.map +1 -0
  8. package/dist/_chunks/ar-C_tQu1XS.js +5 -0
  9. package/dist/_chunks/ar-C_tQu1XS.js.map +1 -0
  10. package/dist/_chunks/cs-B0QZJTah.mjs +5 -0
  11. package/dist/_chunks/cs-B0QZJTah.mjs.map +1 -0
  12. package/dist/_chunks/cs-CPKIUWLp.js +5 -0
  13. package/dist/_chunks/cs-CPKIUWLp.js.map +1 -0
  14. package/dist/_chunks/de-B9kiAC-s.mjs +5 -0
  15. package/dist/_chunks/de-B9kiAC-s.mjs.map +1 -0
  16. package/dist/_chunks/de-K6IYQk2d.js +5 -0
  17. package/dist/_chunks/de-K6IYQk2d.js.map +1 -0
  18. package/dist/_chunks/dk-31mOPYpI.js +26 -0
  19. package/dist/_chunks/dk-31mOPYpI.js.map +1 -0
  20. package/dist/_chunks/dk-DqrbgSkv.mjs +26 -0
  21. package/dist/_chunks/dk-DqrbgSkv.mjs.map +1 -0
  22. package/dist/_chunks/en-BCu4d6-o.js +29 -0
  23. package/dist/_chunks/en-BCu4d6-o.js.map +1 -0
  24. package/dist/_chunks/en-DF4KtAAC.mjs +29 -0
  25. package/dist/_chunks/en-DF4KtAAC.mjs.map +1 -0
  26. package/dist/_chunks/es-BNo7eLLJ.mjs +26 -0
  27. package/dist/_chunks/es-BNo7eLLJ.mjs.map +1 -0
  28. package/dist/_chunks/es-Dl2HVmwz.js +26 -0
  29. package/dist/_chunks/es-Dl2HVmwz.js.map +1 -0
  30. package/dist/_chunks/fr-C8Qw4iPZ.js +5 -0
  31. package/dist/_chunks/fr-C8Qw4iPZ.js.map +1 -0
  32. package/dist/_chunks/fr-hkSxFuzl.mjs +5 -0
  33. package/dist/_chunks/fr-hkSxFuzl.mjs.map +1 -0
  34. package/dist/_chunks/id-CHtAzAUz.mjs +5 -0
  35. package/dist/_chunks/id-CHtAzAUz.mjs.map +1 -0
  36. package/dist/_chunks/id-CvE5f0zz.js +5 -0
  37. package/dist/_chunks/id-CvE5f0zz.js.map +1 -0
  38. package/dist/_chunks/index-BL_YuIzh.mjs +81 -0
  39. package/dist/_chunks/index-BL_YuIzh.mjs.map +1 -0
  40. package/dist/_chunks/index-D6q3fYgO.js +80 -0
  41. package/dist/_chunks/index-D6q3fYgO.js.map +1 -0
  42. package/dist/_chunks/it-C7z82V3g.mjs +5 -0
  43. package/dist/_chunks/it-C7z82V3g.mjs.map +1 -0
  44. package/dist/_chunks/it-DYpuAHa5.js +5 -0
  45. package/dist/_chunks/it-DYpuAHa5.js.map +1 -0
  46. package/dist/_chunks/ja-CiekkoEN.mjs +26 -0
  47. package/dist/_chunks/ja-CiekkoEN.mjs.map +1 -0
  48. package/dist/_chunks/ja-PL3WilO7.js +26 -0
  49. package/dist/_chunks/ja-PL3WilO7.js.map +1 -0
  50. package/dist/_chunks/ko-CJBkZ375.mjs +26 -0
  51. package/dist/_chunks/ko-CJBkZ375.mjs.map +1 -0
  52. package/dist/_chunks/ko-CL2BB_w_.js +26 -0
  53. package/dist/_chunks/ko-CL2BB_w_.js.map +1 -0
  54. package/dist/_chunks/ms-BGlHkuJz.js +5 -0
  55. package/dist/_chunks/ms-BGlHkuJz.js.map +1 -0
  56. package/dist/_chunks/ms-C1wNkEQw.mjs +5 -0
  57. package/dist/_chunks/ms-C1wNkEQw.mjs.map +1 -0
  58. package/dist/_chunks/nl-BuofSsmb.js +5 -0
  59. package/dist/_chunks/nl-BuofSsmb.js.map +1 -0
  60. package/dist/_chunks/nl-C79CwB4e.mjs +5 -0
  61. package/dist/_chunks/nl-C79CwB4e.mjs.map +1 -0
  62. package/dist/_chunks/pl-DXcJCevg.mjs +26 -0
  63. package/dist/_chunks/pl-DXcJCevg.mjs.map +1 -0
  64. package/dist/_chunks/pl-DdtXf3SH.js +26 -0
  65. package/dist/_chunks/pl-DdtXf3SH.js.map +1 -0
  66. package/dist/_chunks/pt-BR-B_ii8U63.js +5 -0
  67. package/dist/_chunks/pt-BR-B_ii8U63.js.map +1 -0
  68. package/dist/_chunks/pt-BR-DjINUWGk.mjs +5 -0
  69. package/dist/_chunks/pt-BR-DjINUWGk.mjs.map +1 -0
  70. package/dist/_chunks/pt-CzRDvk6c.js +29 -0
  71. package/dist/_chunks/pt-CzRDvk6c.js.map +1 -0
  72. package/dist/_chunks/pt-DEVCt2mt.mjs +29 -0
  73. package/dist/_chunks/pt-DEVCt2mt.mjs.map +1 -0
  74. package/dist/_chunks/ru-C_7wBr9e.mjs +5 -0
  75. package/dist/_chunks/ru-C_7wBr9e.mjs.map +1 -0
  76. package/dist/_chunks/ru-Dc-rSPqb.js +5 -0
  77. package/dist/_chunks/ru-Dc-rSPqb.js.map +1 -0
  78. package/dist/_chunks/sk-Cnpb4YOK.js +5 -0
  79. package/dist/_chunks/sk-Cnpb4YOK.js.map +1 -0
  80. package/dist/_chunks/sk-i1gQKUBN.mjs +5 -0
  81. package/dist/_chunks/sk-i1gQKUBN.mjs.map +1 -0
  82. package/dist/_chunks/th-BXTLF08M.js +5 -0
  83. package/dist/_chunks/th-BXTLF08M.js.map +1 -0
  84. package/dist/_chunks/th-D-MxpWKr.mjs +5 -0
  85. package/dist/_chunks/th-D-MxpWKr.mjs.map +1 -0
  86. package/dist/_chunks/tr-BXu41MLY.mjs +29 -0
  87. package/dist/_chunks/tr-BXu41MLY.mjs.map +1 -0
  88. package/dist/_chunks/tr-DwBySNgJ.js +29 -0
  89. package/dist/_chunks/tr-DwBySNgJ.js.map +1 -0
  90. package/dist/_chunks/uk-C_1qrLRM.mjs +5 -0
  91. package/dist/_chunks/uk-C_1qrLRM.mjs.map +1 -0
  92. package/dist/_chunks/uk-CxIePjBD.js +5 -0
  93. package/dist/_chunks/uk-CxIePjBD.js.map +1 -0
  94. package/dist/_chunks/vi-B4uqmjm6.js +5 -0
  95. package/dist/_chunks/vi-B4uqmjm6.js.map +1 -0
  96. package/dist/_chunks/vi-BfZkgFxI.mjs +5 -0
  97. package/dist/_chunks/vi-BfZkgFxI.mjs.map +1 -0
  98. package/dist/_chunks/zh-BS-XJCSt.mjs +29 -0
  99. package/dist/_chunks/zh-BS-XJCSt.mjs.map +1 -0
  100. package/dist/_chunks/zh-DsMIjTgu.js +29 -0
  101. package/dist/_chunks/zh-DsMIjTgu.js.map +1 -0
  102. package/dist/_chunks/zh-Hans-BLEEaLoN.mjs +21 -0
  103. package/dist/_chunks/zh-Hans-BLEEaLoN.mjs.map +1 -0
  104. package/dist/_chunks/zh-Hans-CmL3sY9o.js +21 -0
  105. package/dist/_chunks/zh-Hans-CmL3sY9o.js.map +1 -0
  106. package/dist/admin/index.js +4 -0
  107. package/dist/admin/index.js.map +1 -0
  108. package/dist/admin/index.mjs +5 -0
  109. package/dist/admin/index.mjs.map +1 -0
  110. package/dist/admin/src/constants.d.ts +6 -0
  111. package/dist/admin/src/index.d.ts +3 -0
  112. package/dist/admin/src/pages/Settings.d.ts +1 -0
  113. package/dist/admin/src/utils/getYupInnerErrors.d.ts +7 -0
  114. package/dist/admin/src/utils/prefixPluginTranslations.d.ts +3 -0
  115. package/dist/admin/src/utils/schema.d.ts +8 -0
  116. package/dist/server/index.js +209 -0
  117. package/dist/server/index.js.map +1 -0
  118. package/dist/server/index.mjs +191 -0
  119. package/dist/server/index.mjs.map +1 -0
  120. package/dist/server/src/bootstrap.d.ts +5 -0
  121. package/dist/server/src/bootstrap.d.ts.map +1 -0
  122. package/dist/server/src/config.d.ts +3 -0
  123. package/dist/server/src/config.d.ts.map +1 -0
  124. package/dist/server/src/controllers/email.d.ts +13 -0
  125. package/dist/server/src/controllers/email.d.ts.map +1 -0
  126. package/dist/server/src/controllers/index.d.ts +9 -0
  127. package/dist/server/src/controllers/index.d.ts.map +1 -0
  128. package/dist/server/src/index.d.ts +49 -0
  129. package/dist/server/src/index.d.ts.map +1 -0
  130. package/dist/server/src/routes/admin.d.ts +18 -0
  131. package/dist/server/src/routes/admin.d.ts.map +1 -0
  132. package/dist/server/src/routes/content-api.d.ts +10 -0
  133. package/dist/server/src/routes/content-api.d.ts.map +1 -0
  134. package/dist/server/src/routes/index.d.ts +27 -0
  135. package/dist/server/src/routes/index.d.ts.map +1 -0
  136. package/dist/server/src/services/email.d.ts +8 -0
  137. package/dist/server/src/services/email.d.ts.map +1 -0
  138. package/dist/server/src/services/index.d.ts +8 -0
  139. package/dist/server/src/services/index.d.ts.map +1 -0
  140. package/dist/server/src/types.d.ts +38 -0
  141. package/dist/server/src/types.d.ts.map +1 -0
  142. package/dist/shared/types.d.ts +11 -0
  143. package/dist/shared/types.d.ts.map +1 -0
  144. package/package.json +80 -3
  145. package/strapi-server.js +3 -0
@@ -0,0 +1,3 @@
1
+ import type { Plugin } from '@strapi/types';
2
+ declare const admin: Plugin.Config.AdminInput;
3
+ export default admin;
@@ -0,0 +1 @@
1
+ export declare const ProtectedSettingsPage: () => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,7 @@
1
+ import type { MessageDescriptor, PrimitiveType } from 'react-intl';
2
+ import type { ValidationError } from 'yup';
3
+ interface TranslationMessage extends MessageDescriptor {
4
+ values?: Record<string, PrimitiveType>;
5
+ }
6
+ declare const getYupInnerErrors: (error: ValidationError) => Record<string, TranslationMessage>;
7
+ export { getYupInnerErrors };
@@ -0,0 +1,3 @@
1
+ type TradOptions = Record<string, string>;
2
+ declare const prefixPluginTranslations: (trad: TradOptions, pluginId: string) => TradOptions;
3
+ export { prefixPluginTranslations };
@@ -0,0 +1,8 @@
1
+ import * as yup from 'yup';
2
+ export declare const schema: yup.default<import("yup/lib/object").Assign<import("yup/lib/object").ObjectShape, {
3
+ email: import("yup/lib/string").RequiredStringSchema<string | undefined, Record<string, any>>;
4
+ }>, Record<string, any>, import("yup/lib/object").TypeOfShape<import("yup/lib/object").Assign<import("yup/lib/object").ObjectShape, {
5
+ email: import("yup/lib/string").RequiredStringSchema<string | undefined, Record<string, any>>;
6
+ }>>, import("yup/lib/object").AssertsShape<import("yup/lib/object").Assign<import("yup/lib/object").ObjectShape, {
7
+ email: import("yup/lib/string").RequiredStringSchema<string | undefined, Record<string, any>>;
8
+ }>>>;
@@ -0,0 +1,209 @@
1
+ "use strict";
2
+ const _ = require("lodash");
3
+ const utils = require("@strapi/utils");
4
+ const fp = require("lodash/fp");
5
+ function _interopNamespace(e) {
6
+ if (e && e.__esModule)
7
+ return e;
8
+ const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
9
+ if (e) {
10
+ for (const k in e) {
11
+ if (k !== "default") {
12
+ const d = Object.getOwnPropertyDescriptor(e, k);
13
+ Object.defineProperty(n, k, d.get ? d : {
14
+ enumerable: true,
15
+ get: () => e[k]
16
+ });
17
+ }
18
+ }
19
+ }
20
+ n.default = e;
21
+ return Object.freeze(n);
22
+ }
23
+ const ___namespace = /* @__PURE__ */ _interopNamespace(_);
24
+ const createProvider = (emailConfig) => {
25
+ const providerName = emailConfig.provider.toLowerCase();
26
+ let provider;
27
+ let modulePath;
28
+ try {
29
+ modulePath = require.resolve(`@strapi/provider-email-${providerName}`);
30
+ } catch (error) {
31
+ if (error instanceof Error && "code" in error && error.code === "MODULE_NOT_FOUND") {
32
+ modulePath = providerName;
33
+ } else {
34
+ throw error;
35
+ }
36
+ }
37
+ try {
38
+ provider = require(modulePath);
39
+ } catch (err) {
40
+ throw new Error(`Could not load email provider "${providerName}".`);
41
+ }
42
+ return provider.init(emailConfig.providerOptions, emailConfig.settings);
43
+ };
44
+ const bootstrap = async ({ strapi: strapi2 }) => {
45
+ const emailConfig = strapi2.config.get("plugin::email");
46
+ strapi2.plugin("email").provider = createProvider(emailConfig);
47
+ const actions = [
48
+ {
49
+ section: "settings",
50
+ category: "email",
51
+ displayName: "Access the Email Settings page",
52
+ uid: "settings.read",
53
+ pluginName: "email"
54
+ }
55
+ ];
56
+ await strapi2.service("admin::permission").actionProvider.registerMany(actions);
57
+ };
58
+ const { createStrictInterpolationRegExp } = utils.template;
59
+ const getProviderSettings = () => strapi.config.get("plugin::email");
60
+ const send = async (options) => strapi.plugin("email").provider.send(options);
61
+ const sendTemplatedEmail = (emailOptions, emailTemplate, data) => {
62
+ const attributes = ["subject", "text", "html"];
63
+ const missingAttributes = ___namespace.difference(attributes, Object.keys(emailTemplate));
64
+ if (missingAttributes.length > 0) {
65
+ throw new Error(
66
+ `Following attributes are missing from your email template : ${missingAttributes.join(", ")}`
67
+ );
68
+ }
69
+ const allowedInterpolationVariables = utils.objects.keysDeep(data);
70
+ const interpolate = createStrictInterpolationRegExp(allowedInterpolationVariables, "g");
71
+ const templatedAttributes = attributes.reduce(
72
+ (compiled, attribute) => emailTemplate[attribute] ? Object.assign(compiled, {
73
+ [attribute]: ___namespace.template(emailTemplate[attribute], {
74
+ interpolate
75
+ })(data)
76
+ }) : compiled,
77
+ {}
78
+ );
79
+ return strapi.plugin("email").provider.send({ ...emailOptions, ...templatedAttributes });
80
+ };
81
+ const emailService = () => ({
82
+ getProviderSettings,
83
+ send,
84
+ sendTemplatedEmail
85
+ });
86
+ const services = { email: emailService };
87
+ const admin = {
88
+ type: "admin",
89
+ routes: [
90
+ {
91
+ method: "POST",
92
+ path: "/",
93
+ handler: "email.send",
94
+ config: {
95
+ policies: ["admin::isAuthenticatedAdmin"]
96
+ }
97
+ },
98
+ {
99
+ method: "POST",
100
+ path: "/test",
101
+ handler: "email.test",
102
+ config: {
103
+ policies: [
104
+ "admin::isAuthenticatedAdmin",
105
+ { name: "admin::hasPermissions", config: { actions: ["plugin::email.settings.read"] } }
106
+ ]
107
+ }
108
+ },
109
+ {
110
+ method: "GET",
111
+ path: "/settings",
112
+ handler: "email.getSettings",
113
+ config: {
114
+ policies: [
115
+ "admin::isAuthenticatedAdmin",
116
+ { name: "admin::hasPermissions", config: { actions: ["plugin::email.settings.read"] } }
117
+ ]
118
+ }
119
+ }
120
+ ]
121
+ };
122
+ const contentApi = {
123
+ type: "content-api",
124
+ routes: [
125
+ {
126
+ method: "POST",
127
+ path: "/",
128
+ handler: "email.send"
129
+ }
130
+ ]
131
+ };
132
+ const routes = {
133
+ admin,
134
+ "content-api": contentApi
135
+ };
136
+ const { ApplicationError } = utils.errors;
137
+ const emailController = {
138
+ async send(ctx) {
139
+ const options = ctx.request.body;
140
+ try {
141
+ await strapi.plugin("email").service("email").send(options);
142
+ } catch (error) {
143
+ if (error instanceof Error) {
144
+ if ("statusCode" in error && error.statusCode === 400) {
145
+ throw new ApplicationError(error.message);
146
+ } else {
147
+ throw new Error(`Couldn't send email: ${error.message}.`);
148
+ }
149
+ }
150
+ }
151
+ ctx.send({});
152
+ },
153
+ async test(ctx) {
154
+ const { to } = ctx.request.body;
155
+ if (!to) {
156
+ throw new ApplicationError("No recipient(s) are given");
157
+ }
158
+ const email = {
159
+ to,
160
+ subject: `Strapi test mail to: ${to}`,
161
+ text: `Great! You have correctly configured the Strapi email plugin with the ${strapi.config.get(
162
+ "plugin::email.provider"
163
+ )} provider. \r
164
+ For documentation on how to use the email plugin checkout: https://docs.strapi.io/developer-docs/latest/plugins/email.html`
165
+ };
166
+ try {
167
+ await strapi.plugin("email").service("email").send(email);
168
+ } catch (error) {
169
+ if (error instanceof Error) {
170
+ if ("statusCode" in error && error.statusCode === 400) {
171
+ throw new ApplicationError(error.message);
172
+ } else {
173
+ throw new Error(`Couldn't send test email: ${error.message}.`);
174
+ }
175
+ }
176
+ }
177
+ ctx.send({});
178
+ },
179
+ async getSettings(ctx) {
180
+ const config2 = strapi.plugin("email").service("email").getProviderSettings();
181
+ ctx.send({
182
+ config: fp.pick(
183
+ ["provider", "settings.defaultFrom", "settings.defaultReplyTo", "settings.testAddress"],
184
+ config2
185
+ )
186
+ });
187
+ }
188
+ };
189
+ const controllers = { email: emailController };
190
+ const config = {
191
+ default: {
192
+ provider: "sendmail",
193
+ providerOptions: {},
194
+ settings: {
195
+ defaultFrom: "Strapi <no-reply@strapi.io>"
196
+ }
197
+ },
198
+ validator() {
199
+ }
200
+ };
201
+ const index = {
202
+ bootstrap,
203
+ services,
204
+ routes,
205
+ controllers,
206
+ config
207
+ };
208
+ module.exports = index;
209
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../server/src/bootstrap.ts","../../server/src/services/email.ts","../../server/src/services/index.ts","../../server/src/routes/admin.ts","../../server/src/routes/content-api.ts","../../server/src/routes/index.ts","../../server/src/controllers/email.ts","../../server/src/controllers/index.ts","../../server/src/config.ts","../../server/src/index.ts"],"sourcesContent":["import type { Core } from '@strapi/types';\nimport type { EmailConfig, SendOptions } from './types';\n\ninterface EmailProvider {\n send: (options: SendOptions) => Promise<any>;\n}\n\ninterface EmailProviderModule {\n init: (\n options: EmailConfig['providerOptions'],\n settings: EmailConfig['settings']\n ) => EmailProvider;\n name?: string;\n provider?: string;\n}\n\nconst createProvider = (emailConfig: EmailConfig) => {\n const providerName = emailConfig.provider.toLowerCase();\n let provider: EmailProviderModule;\n\n let modulePath: string;\n try {\n modulePath = require.resolve(`@strapi/provider-email-${providerName}`);\n } catch (error) {\n if (error instanceof Error && 'code' in error && error.code === 'MODULE_NOT_FOUND') {\n modulePath = providerName;\n } else {\n throw error;\n }\n }\n\n try {\n provider = require(modulePath);\n } catch (err) {\n throw new Error(`Could not load email provider \"${providerName}\".`);\n }\n\n return provider.init(emailConfig.providerOptions, emailConfig.settings);\n};\n\nexport const bootstrap = async ({ strapi }: { strapi: Core.Strapi }) => {\n const emailConfig: EmailConfig = strapi.config.get('plugin::email');\n strapi.plugin('email').provider = createProvider(emailConfig);\n\n // Add permissions\n const actions = [\n {\n section: 'settings',\n category: 'email',\n displayName: 'Access the Email Settings page',\n uid: 'settings.read',\n pluginName: 'email',\n },\n ];\n\n await strapi.service('admin::permission').actionProvider.registerMany(actions);\n};\n","import * as _ from 'lodash';\nimport { objects, template } from '@strapi/utils';\n\nimport type {\n EmailConfig,\n EmailOptions,\n EmailTemplate,\n EmailTemplateData,\n SendOptions,\n} from '../types';\n\nconst { createStrictInterpolationRegExp } = template;\n\nconst getProviderSettings = (): EmailConfig => strapi.config.get('plugin::email');\n\nconst send = async (options: SendOptions) => strapi.plugin('email').provider.send(options);\n\n/**\n * fill subject, text and html using lodash template\n * @param {object} emailOptions - to, from and replyto...\n * @param {object} emailTemplate - object containing attributes to fill\n * @param {object} data - data used to fill the template\n * @returns {{ subject, text, subject }}\n */\nconst sendTemplatedEmail = (\n emailOptions: EmailOptions,\n emailTemplate: EmailTemplate,\n data: EmailTemplateData\n) => {\n const attributes = ['subject', 'text', 'html'];\n const missingAttributes = _.difference(attributes, Object.keys(emailTemplate));\n\n if (missingAttributes.length > 0) {\n throw new Error(\n `Following attributes are missing from your email template : ${missingAttributes.join(', ')}`\n );\n }\n\n const allowedInterpolationVariables = objects.keysDeep(data);\n const interpolate = createStrictInterpolationRegExp(allowedInterpolationVariables, 'g');\n\n const templatedAttributes = attributes.reduce(\n (compiled, attribute) =>\n emailTemplate[attribute]\n ? Object.assign(compiled, {\n [attribute]: _.template(emailTemplate[attribute], {\n interpolate,\n })(data),\n })\n : compiled,\n {}\n );\n\n return strapi.plugin('email').provider.send({ ...emailOptions, ...templatedAttributes });\n};\n\nconst emailService = () => ({\n getProviderSettings,\n send,\n sendTemplatedEmail,\n});\n\nexport default emailService;\n","import email from './email';\n\nexport const services = { email };\n","export default {\n type: 'admin',\n routes: [\n {\n method: 'POST',\n path: '/',\n handler: 'email.send',\n config: {\n policies: ['admin::isAuthenticatedAdmin'],\n },\n },\n {\n method: 'POST',\n path: '/test',\n handler: 'email.test',\n config: {\n policies: [\n 'admin::isAuthenticatedAdmin',\n { name: 'admin::hasPermissions', config: { actions: ['plugin::email.settings.read'] } },\n ],\n },\n },\n {\n method: 'GET',\n path: '/settings',\n handler: 'email.getSettings',\n config: {\n policies: [\n 'admin::isAuthenticatedAdmin',\n { name: 'admin::hasPermissions', config: { actions: ['plugin::email.settings.read'] } },\n ],\n },\n },\n ],\n};\n","export default {\n type: 'content-api',\n routes: [\n {\n method: 'POST',\n path: '/',\n handler: 'email.send',\n },\n ],\n};\n","import admin from './admin';\nimport contentApi from './content-api';\n\nexport const routes = {\n admin,\n 'content-api': contentApi,\n};\n","import { pick } from 'lodash/fp';\nimport { errors } from '@strapi/utils';\n\nimport type Koa from 'koa';\nimport type {} from 'koa-body';\nimport type { EmailConfig, SendOptions } from '../types';\n\nconst { ApplicationError } = errors;\n\n/**\n * Email.js controller\n *\n * @description: A set of functions called \"actions\" of the `email` plugin.\n */\nconst emailController = {\n async send(ctx: Koa.Context) {\n const options = ctx.request.body as SendOptions;\n\n try {\n await strapi.plugin('email').service('email').send(options);\n } catch (error) {\n if (error instanceof Error) {\n if ('statusCode' in error && error.statusCode === 400) {\n throw new ApplicationError(error.message);\n } else {\n throw new Error(`Couldn't send email: ${error.message}.`);\n }\n }\n }\n\n // Send 200 `ok`\n ctx.send({});\n },\n\n async test(ctx: Koa.Context) {\n const { to } = ctx.request.body as Pick<SendOptions, 'to'>;\n\n if (!to) {\n throw new ApplicationError('No recipient(s) are given');\n }\n\n const email: SendOptions = {\n to,\n subject: `Strapi test mail to: ${to}`,\n text: `Great! You have correctly configured the Strapi email plugin with the ${strapi.config.get(\n 'plugin::email.provider'\n )} provider. \\r\\nFor documentation on how to use the email plugin checkout: https://docs.strapi.io/developer-docs/latest/plugins/email.html`,\n };\n\n try {\n await strapi.plugin('email').service('email').send(email);\n } catch (error) {\n if (error instanceof Error) {\n if ('statusCode' in error && error.statusCode === 400) {\n throw new ApplicationError(error.message);\n } else {\n throw new Error(`Couldn't send test email: ${error.message}.`);\n }\n }\n }\n\n // Send 200 `ok`\n ctx.send({});\n },\n\n async getSettings(ctx: Koa.Context) {\n const config: EmailConfig = strapi.plugin('email').service('email').getProviderSettings();\n\n ctx.send({\n config: pick(\n ['provider', 'settings.defaultFrom', 'settings.defaultReplyTo', 'settings.testAddress'],\n config\n ),\n });\n },\n};\n\nexport default emailController;\n","import email from './email';\n\nexport const controllers = { email };\n","import type { StrapiConfig } from './types';\n\nexport const config: StrapiConfig = {\n default: {\n provider: 'sendmail',\n providerOptions: {},\n settings: {\n defaultFrom: 'Strapi <no-reply@strapi.io>',\n },\n },\n validator() {},\n};\n","import { bootstrap } from './bootstrap';\nimport { services } from './services';\nimport { routes } from './routes';\nimport { controllers } from './controllers';\nimport { config } from './config';\n\nexport default {\n bootstrap,\n services,\n routes,\n controllers,\n config,\n};\n"],"names":["strapi","template","_","objects","email","errors","config","pick"],"mappings":"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"}
@@ -0,0 +1,191 @@
1
+ import * as _ from "lodash";
2
+ import { objects, template, errors } from "@strapi/utils";
3
+ import { pick } from "lodash/fp";
4
+ const createProvider = (emailConfig) => {
5
+ const providerName = emailConfig.provider.toLowerCase();
6
+ let provider;
7
+ let modulePath;
8
+ try {
9
+ modulePath = require.resolve(`@strapi/provider-email-${providerName}`);
10
+ } catch (error) {
11
+ if (error instanceof Error && "code" in error && error.code === "MODULE_NOT_FOUND") {
12
+ modulePath = providerName;
13
+ } else {
14
+ throw error;
15
+ }
16
+ }
17
+ try {
18
+ provider = require(modulePath);
19
+ } catch (err) {
20
+ throw new Error(`Could not load email provider "${providerName}".`);
21
+ }
22
+ return provider.init(emailConfig.providerOptions, emailConfig.settings);
23
+ };
24
+ const bootstrap = async ({ strapi: strapi2 }) => {
25
+ const emailConfig = strapi2.config.get("plugin::email");
26
+ strapi2.plugin("email").provider = createProvider(emailConfig);
27
+ const actions = [
28
+ {
29
+ section: "settings",
30
+ category: "email",
31
+ displayName: "Access the Email Settings page",
32
+ uid: "settings.read",
33
+ pluginName: "email"
34
+ }
35
+ ];
36
+ await strapi2.service("admin::permission").actionProvider.registerMany(actions);
37
+ };
38
+ const { createStrictInterpolationRegExp } = template;
39
+ const getProviderSettings = () => strapi.config.get("plugin::email");
40
+ const send = async (options) => strapi.plugin("email").provider.send(options);
41
+ const sendTemplatedEmail = (emailOptions, emailTemplate, data) => {
42
+ const attributes = ["subject", "text", "html"];
43
+ const missingAttributes = _.difference(attributes, Object.keys(emailTemplate));
44
+ if (missingAttributes.length > 0) {
45
+ throw new Error(
46
+ `Following attributes are missing from your email template : ${missingAttributes.join(", ")}`
47
+ );
48
+ }
49
+ const allowedInterpolationVariables = objects.keysDeep(data);
50
+ const interpolate = createStrictInterpolationRegExp(allowedInterpolationVariables, "g");
51
+ const templatedAttributes = attributes.reduce(
52
+ (compiled, attribute) => emailTemplate[attribute] ? Object.assign(compiled, {
53
+ [attribute]: _.template(emailTemplate[attribute], {
54
+ interpolate
55
+ })(data)
56
+ }) : compiled,
57
+ {}
58
+ );
59
+ return strapi.plugin("email").provider.send({ ...emailOptions, ...templatedAttributes });
60
+ };
61
+ const emailService = () => ({
62
+ getProviderSettings,
63
+ send,
64
+ sendTemplatedEmail
65
+ });
66
+ const services = { email: emailService };
67
+ const admin = {
68
+ type: "admin",
69
+ routes: [
70
+ {
71
+ method: "POST",
72
+ path: "/",
73
+ handler: "email.send",
74
+ config: {
75
+ policies: ["admin::isAuthenticatedAdmin"]
76
+ }
77
+ },
78
+ {
79
+ method: "POST",
80
+ path: "/test",
81
+ handler: "email.test",
82
+ config: {
83
+ policies: [
84
+ "admin::isAuthenticatedAdmin",
85
+ { name: "admin::hasPermissions", config: { actions: ["plugin::email.settings.read"] } }
86
+ ]
87
+ }
88
+ },
89
+ {
90
+ method: "GET",
91
+ path: "/settings",
92
+ handler: "email.getSettings",
93
+ config: {
94
+ policies: [
95
+ "admin::isAuthenticatedAdmin",
96
+ { name: "admin::hasPermissions", config: { actions: ["plugin::email.settings.read"] } }
97
+ ]
98
+ }
99
+ }
100
+ ]
101
+ };
102
+ const contentApi = {
103
+ type: "content-api",
104
+ routes: [
105
+ {
106
+ method: "POST",
107
+ path: "/",
108
+ handler: "email.send"
109
+ }
110
+ ]
111
+ };
112
+ const routes = {
113
+ admin,
114
+ "content-api": contentApi
115
+ };
116
+ const { ApplicationError } = errors;
117
+ const emailController = {
118
+ async send(ctx) {
119
+ const options = ctx.request.body;
120
+ try {
121
+ await strapi.plugin("email").service("email").send(options);
122
+ } catch (error) {
123
+ if (error instanceof Error) {
124
+ if ("statusCode" in error && error.statusCode === 400) {
125
+ throw new ApplicationError(error.message);
126
+ } else {
127
+ throw new Error(`Couldn't send email: ${error.message}.`);
128
+ }
129
+ }
130
+ }
131
+ ctx.send({});
132
+ },
133
+ async test(ctx) {
134
+ const { to } = ctx.request.body;
135
+ if (!to) {
136
+ throw new ApplicationError("No recipient(s) are given");
137
+ }
138
+ const email = {
139
+ to,
140
+ subject: `Strapi test mail to: ${to}`,
141
+ text: `Great! You have correctly configured the Strapi email plugin with the ${strapi.config.get(
142
+ "plugin::email.provider"
143
+ )} provider. \r
144
+ For documentation on how to use the email plugin checkout: https://docs.strapi.io/developer-docs/latest/plugins/email.html`
145
+ };
146
+ try {
147
+ await strapi.plugin("email").service("email").send(email);
148
+ } catch (error) {
149
+ if (error instanceof Error) {
150
+ if ("statusCode" in error && error.statusCode === 400) {
151
+ throw new ApplicationError(error.message);
152
+ } else {
153
+ throw new Error(`Couldn't send test email: ${error.message}.`);
154
+ }
155
+ }
156
+ }
157
+ ctx.send({});
158
+ },
159
+ async getSettings(ctx) {
160
+ const config2 = strapi.plugin("email").service("email").getProviderSettings();
161
+ ctx.send({
162
+ config: pick(
163
+ ["provider", "settings.defaultFrom", "settings.defaultReplyTo", "settings.testAddress"],
164
+ config2
165
+ )
166
+ });
167
+ }
168
+ };
169
+ const controllers = { email: emailController };
170
+ const config = {
171
+ default: {
172
+ provider: "sendmail",
173
+ providerOptions: {},
174
+ settings: {
175
+ defaultFrom: "Strapi <no-reply@strapi.io>"
176
+ }
177
+ },
178
+ validator() {
179
+ }
180
+ };
181
+ const index = {
182
+ bootstrap,
183
+ services,
184
+ routes,
185
+ controllers,
186
+ config
187
+ };
188
+ export {
189
+ index as default
190
+ };
191
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../server/src/bootstrap.ts","../../server/src/services/email.ts","../../server/src/services/index.ts","../../server/src/routes/admin.ts","../../server/src/routes/content-api.ts","../../server/src/routes/index.ts","../../server/src/controllers/email.ts","../../server/src/controllers/index.ts","../../server/src/config.ts","../../server/src/index.ts"],"sourcesContent":["import type { Core } from '@strapi/types';\nimport type { EmailConfig, SendOptions } from './types';\n\ninterface EmailProvider {\n send: (options: SendOptions) => Promise<any>;\n}\n\ninterface EmailProviderModule {\n init: (\n options: EmailConfig['providerOptions'],\n settings: EmailConfig['settings']\n ) => EmailProvider;\n name?: string;\n provider?: string;\n}\n\nconst createProvider = (emailConfig: EmailConfig) => {\n const providerName = emailConfig.provider.toLowerCase();\n let provider: EmailProviderModule;\n\n let modulePath: string;\n try {\n modulePath = require.resolve(`@strapi/provider-email-${providerName}`);\n } catch (error) {\n if (error instanceof Error && 'code' in error && error.code === 'MODULE_NOT_FOUND') {\n modulePath = providerName;\n } else {\n throw error;\n }\n }\n\n try {\n provider = require(modulePath);\n } catch (err) {\n throw new Error(`Could not load email provider \"${providerName}\".`);\n }\n\n return provider.init(emailConfig.providerOptions, emailConfig.settings);\n};\n\nexport const bootstrap = async ({ strapi }: { strapi: Core.Strapi }) => {\n const emailConfig: EmailConfig = strapi.config.get('plugin::email');\n strapi.plugin('email').provider = createProvider(emailConfig);\n\n // Add permissions\n const actions = [\n {\n section: 'settings',\n category: 'email',\n displayName: 'Access the Email Settings page',\n uid: 'settings.read',\n pluginName: 'email',\n },\n ];\n\n await strapi.service('admin::permission').actionProvider.registerMany(actions);\n};\n","import * as _ from 'lodash';\nimport { objects, template } from '@strapi/utils';\n\nimport type {\n EmailConfig,\n EmailOptions,\n EmailTemplate,\n EmailTemplateData,\n SendOptions,\n} from '../types';\n\nconst { createStrictInterpolationRegExp } = template;\n\nconst getProviderSettings = (): EmailConfig => strapi.config.get('plugin::email');\n\nconst send = async (options: SendOptions) => strapi.plugin('email').provider.send(options);\n\n/**\n * fill subject, text and html using lodash template\n * @param {object} emailOptions - to, from and replyto...\n * @param {object} emailTemplate - object containing attributes to fill\n * @param {object} data - data used to fill the template\n * @returns {{ subject, text, subject }}\n */\nconst sendTemplatedEmail = (\n emailOptions: EmailOptions,\n emailTemplate: EmailTemplate,\n data: EmailTemplateData\n) => {\n const attributes = ['subject', 'text', 'html'];\n const missingAttributes = _.difference(attributes, Object.keys(emailTemplate));\n\n if (missingAttributes.length > 0) {\n throw new Error(\n `Following attributes are missing from your email template : ${missingAttributes.join(', ')}`\n );\n }\n\n const allowedInterpolationVariables = objects.keysDeep(data);\n const interpolate = createStrictInterpolationRegExp(allowedInterpolationVariables, 'g');\n\n const templatedAttributes = attributes.reduce(\n (compiled, attribute) =>\n emailTemplate[attribute]\n ? Object.assign(compiled, {\n [attribute]: _.template(emailTemplate[attribute], {\n interpolate,\n })(data),\n })\n : compiled,\n {}\n );\n\n return strapi.plugin('email').provider.send({ ...emailOptions, ...templatedAttributes });\n};\n\nconst emailService = () => ({\n getProviderSettings,\n send,\n sendTemplatedEmail,\n});\n\nexport default emailService;\n","import email from './email';\n\nexport const services = { email };\n","export default {\n type: 'admin',\n routes: [\n {\n method: 'POST',\n path: '/',\n handler: 'email.send',\n config: {\n policies: ['admin::isAuthenticatedAdmin'],\n },\n },\n {\n method: 'POST',\n path: '/test',\n handler: 'email.test',\n config: {\n policies: [\n 'admin::isAuthenticatedAdmin',\n { name: 'admin::hasPermissions', config: { actions: ['plugin::email.settings.read'] } },\n ],\n },\n },\n {\n method: 'GET',\n path: '/settings',\n handler: 'email.getSettings',\n config: {\n policies: [\n 'admin::isAuthenticatedAdmin',\n { name: 'admin::hasPermissions', config: { actions: ['plugin::email.settings.read'] } },\n ],\n },\n },\n ],\n};\n","export default {\n type: 'content-api',\n routes: [\n {\n method: 'POST',\n path: '/',\n handler: 'email.send',\n },\n ],\n};\n","import admin from './admin';\nimport contentApi from './content-api';\n\nexport const routes = {\n admin,\n 'content-api': contentApi,\n};\n","import { pick } from 'lodash/fp';\nimport { errors } from '@strapi/utils';\n\nimport type Koa from 'koa';\nimport type {} from 'koa-body';\nimport type { EmailConfig, SendOptions } from '../types';\n\nconst { ApplicationError } = errors;\n\n/**\n * Email.js controller\n *\n * @description: A set of functions called \"actions\" of the `email` plugin.\n */\nconst emailController = {\n async send(ctx: Koa.Context) {\n const options = ctx.request.body as SendOptions;\n\n try {\n await strapi.plugin('email').service('email').send(options);\n } catch (error) {\n if (error instanceof Error) {\n if ('statusCode' in error && error.statusCode === 400) {\n throw new ApplicationError(error.message);\n } else {\n throw new Error(`Couldn't send email: ${error.message}.`);\n }\n }\n }\n\n // Send 200 `ok`\n ctx.send({});\n },\n\n async test(ctx: Koa.Context) {\n const { to } = ctx.request.body as Pick<SendOptions, 'to'>;\n\n if (!to) {\n throw new ApplicationError('No recipient(s) are given');\n }\n\n const email: SendOptions = {\n to,\n subject: `Strapi test mail to: ${to}`,\n text: `Great! You have correctly configured the Strapi email plugin with the ${strapi.config.get(\n 'plugin::email.provider'\n )} provider. \\r\\nFor documentation on how to use the email plugin checkout: https://docs.strapi.io/developer-docs/latest/plugins/email.html`,\n };\n\n try {\n await strapi.plugin('email').service('email').send(email);\n } catch (error) {\n if (error instanceof Error) {\n if ('statusCode' in error && error.statusCode === 400) {\n throw new ApplicationError(error.message);\n } else {\n throw new Error(`Couldn't send test email: ${error.message}.`);\n }\n }\n }\n\n // Send 200 `ok`\n ctx.send({});\n },\n\n async getSettings(ctx: Koa.Context) {\n const config: EmailConfig = strapi.plugin('email').service('email').getProviderSettings();\n\n ctx.send({\n config: pick(\n ['provider', 'settings.defaultFrom', 'settings.defaultReplyTo', 'settings.testAddress'],\n config\n ),\n });\n },\n};\n\nexport default emailController;\n","import email from './email';\n\nexport const controllers = { email };\n","import type { StrapiConfig } from './types';\n\nexport const config: StrapiConfig = {\n default: {\n provider: 'sendmail',\n providerOptions: {},\n settings: {\n defaultFrom: 'Strapi <no-reply@strapi.io>',\n },\n },\n validator() {},\n};\n","import { bootstrap } from './bootstrap';\nimport { services } from './services';\nimport { routes } from './routes';\nimport { controllers } from './controllers';\nimport { config } from './config';\n\nexport default {\n bootstrap,\n services,\n routes,\n controllers,\n config,\n};\n"],"names":["strapi","email","config"],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import type { Core } from '@strapi/types';
2
+ export declare const bootstrap: ({ strapi }: {
3
+ strapi: Core.Strapi;
4
+ }) => Promise<void>;
5
+ //# sourceMappingURL=bootstrap.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bootstrap.d.ts","sourceRoot":"","sources":["../../../server/src/bootstrap.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAwC1C,eAAO,MAAM,SAAS,eAAsB;IAAE,MAAM,EAAE,KAAK,MAAM,CAAA;CAAE,kBAgBlE,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { StrapiConfig } from './types';
2
+ export declare const config: StrapiConfig;
3
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../../server/src/config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAE5C,eAAO,MAAM,MAAM,EAAE,YASpB,CAAC"}
@@ -0,0 +1,13 @@
1
+ import type Koa from 'koa';
2
+ /**
3
+ * Email.js controller
4
+ *
5
+ * @description: A set of functions called "actions" of the `email` plugin.
6
+ */
7
+ declare const emailController: {
8
+ send(ctx: Koa.Context): Promise<void>;
9
+ test(ctx: Koa.Context): Promise<void>;
10
+ getSettings(ctx: Koa.Context): Promise<void>;
11
+ };
12
+ export default emailController;
13
+ //# sourceMappingURL=email.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"email.d.ts","sourceRoot":"","sources":["../../../../server/src/controllers/email.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,GAAG,MAAM,KAAK,CAAC;AAM3B;;;;GAIG;AACH,QAAA,MAAM,eAAe;cACH,IAAI,OAAO;cAmBX,IAAI,OAAO;qBA+BJ,IAAI,OAAO;CAUnC,CAAC;AAEF,eAAe,eAAe,CAAC"}
@@ -0,0 +1,9 @@
1
+ /// <reference types="koa" />
2
+ export declare const controllers: {
3
+ email: {
4
+ send(ctx: import("koa").Context): Promise<void>;
5
+ test(ctx: import("koa").Context): Promise<void>;
6
+ getSettings(ctx: import("koa").Context): Promise<void>;
7
+ };
8
+ };
9
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../server/src/controllers/index.ts"],"names":[],"mappings":";AAEA,eAAO,MAAM,WAAW;;;;;;CAAY,CAAC"}
@@ -0,0 +1,49 @@
1
+ /// <reference types="koa" />
2
+ declare const _default: {
3
+ bootstrap: ({ strapi }: {
4
+ strapi: import("@strapi/types/dist/core").Strapi;
5
+ }) => Promise<void>;
6
+ services: {
7
+ email: () => {
8
+ getProviderSettings: () => import("./types").EmailConfig;
9
+ send: (options: import("./types").SendOptions) => Promise<any>;
10
+ sendTemplatedEmail: (emailOptions: import("./types").EmailOptions, emailTemplate: import("./types").EmailTemplate, data: import("./types").EmailTemplateData) => any;
11
+ };
12
+ };
13
+ routes: {
14
+ admin: {
15
+ type: string;
16
+ routes: {
17
+ method: string;
18
+ path: string;
19
+ handler: string;
20
+ config: {
21
+ policies: (string | {
22
+ name: string;
23
+ config: {
24
+ actions: string[];
25
+ };
26
+ })[];
27
+ };
28
+ }[];
29
+ };
30
+ 'content-api': {
31
+ type: string;
32
+ routes: {
33
+ method: string;
34
+ path: string;
35
+ handler: string;
36
+ }[];
37
+ };
38
+ };
39
+ controllers: {
40
+ email: {
41
+ send(ctx: import("koa").Context): Promise<void>;
42
+ test(ctx: import("koa").Context): Promise<void>;
43
+ getSettings(ctx: import("koa").Context): Promise<void>;
44
+ };
45
+ };
46
+ config: import("./types").StrapiConfig;
47
+ };
48
+ export default _default;
49
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../server/src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAMA,wBAME"}
@@ -0,0 +1,18 @@
1
+ declare const _default: {
2
+ type: string;
3
+ routes: {
4
+ method: string;
5
+ path: string;
6
+ handler: string;
7
+ config: {
8
+ policies: (string | {
9
+ name: string;
10
+ config: {
11
+ actions: string[];
12
+ };
13
+ })[];
14
+ };
15
+ }[];
16
+ };
17
+ export default _default;
18
+ //# sourceMappingURL=admin.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"admin.d.ts","sourceRoot":"","sources":["../../../../server/src/routes/admin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wBAkCE"}
@@ -0,0 +1,10 @@
1
+ declare const _default: {
2
+ type: string;
3
+ routes: {
4
+ method: string;
5
+ path: string;
6
+ handler: string;
7
+ }[];
8
+ };
9
+ export default _default;
10
+ //# sourceMappingURL=content-api.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"content-api.d.ts","sourceRoot":"","sources":["../../../../server/src/routes/content-api.ts"],"names":[],"mappings":";;;;;;;;AAAA,wBASE"}
@@ -0,0 +1,27 @@
1
+ export declare const routes: {
2
+ admin: {
3
+ type: string;
4
+ routes: {
5
+ method: string;
6
+ path: string;
7
+ handler: string;
8
+ config: {
9
+ policies: (string | {
10
+ name: string;
11
+ config: {
12
+ actions: string[];
13
+ };
14
+ })[];
15
+ };
16
+ }[];
17
+ };
18
+ 'content-api': {
19
+ type: string;
20
+ routes: {
21
+ method: string;
22
+ path: string;
23
+ handler: string;
24
+ }[];
25
+ };
26
+ };
27
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../server/src/routes/index.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;CAGlB,CAAC"}