Add resource Custom Verification Email to AWS SES (#1405)

*  Add resource Custom Verification Email to AWS SES

*  Minor improvements to AWS SES Node

Co-authored-by: Jan Oberhauser <jan.oberhauser@gmail.com>
This commit is contained in:
Ricardo Espinoza 2021-02-07 18:02:10 -05:00 committed by GitHub
parent ba7c35dbf5
commit 894a4b950a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 478 additions and 5 deletions

View file

@ -18,7 +18,7 @@ import {
function setParameter(params: string[], base: string, values: string[]) {
for (let i = 0; i < values.length; i++) {
params.push(`${base}.${i+1}=${values[i]}`);
params.push(`${base}.${i + 1}=${values[i]}`);
}
}
@ -26,7 +26,7 @@ export class AwsSes implements INodeType {
description: INodeTypeDescription = {
displayName: 'AWS SES',
name: 'awsSes',
icon: 'file:ses.png',
icon: 'file:ses.svg',
group: ['output'],
version: 1,
subtitle: '={{$parameter["operation"] + ": " + $parameter["resource"]}}',
@ -49,6 +49,10 @@ export class AwsSes implements INodeType {
name: 'resource',
type: 'options',
options: [
{
name: 'Custom Verification Email',
value: 'customVerificationEmail',
},
{
name: 'Email',
value: 'email',
@ -61,6 +65,338 @@ export class AwsSes implements INodeType {
default: 'email',
description: 'The operation to perform.',
},
{
displayName: 'Operation',
name: 'operation',
type: 'options',
displayOptions: {
show: {
resource: [
'customVerificationEmail',
],
},
},
options: [
{
name: 'Create',
value: 'create',
description: 'Create a new custom verification email template',
},
{
name: 'Delete',
value: 'delete',
description: 'Delete an existing custom verification email template',
},
{
name: 'Get',
value: 'get',
description: 'Get the custom email verification template',
},
{
name: 'Get All',
value: 'getAll',
description: 'Get all the existing custom verification email templates for your account',
},
{
name: 'Send',
value: 'send',
description: 'Add an email address to the list of identities',
},
{
name: 'Update',
value: 'update',
description: 'Update an existing custom verification email template.',
},
],
default: 'create',
description: 'The operation to perform.',
},
{
displayName: 'From Email',
name: 'fromEmailAddress',
type: 'string',
displayOptions: {
show: {
resource: [
'customVerificationEmail',
],
operation: [
'create',
],
},
},
required: true,
description: 'The email address that the custom verification email is sent from.',
default: '',
},
{
displayName: 'Template Name',
name: 'templateName',
type: 'string',
displayOptions: {
show: {
resource: [
'customVerificationEmail',
],
operation: [
'create',
],
},
},
default: '',
description: 'The name of the custom verification email template.',
},
{
displayName: 'Template Content',
name: 'templateContent',
type: 'string',
typeOptions: {
alwaysOpenEditWindow: true,
},
displayOptions: {
show: {
resource: [
'customVerificationEmail',
],
operation: [
'create',
],
},
},
description: `The content of the custom verification email. The total size of the email must be less than 10 MB. The message body may contain HTML`,
default: '',
},
{
displayName: 'Template Subject',
name: 'templateSubject',
type: 'string',
displayOptions: {
show: {
resource: [
'customVerificationEmail',
],
operation: [
'create',
],
},
},
default: '',
required: true,
description: 'The subject line of the custom verification email.',
},
{
displayName: 'Success Redirection URL',
name: 'successRedirectionURL',
type: 'string',
displayOptions: {
show: {
resource: [
'customVerificationEmail',
],
operation: [
'create',
],
},
},
required: true,
description: 'The URL that the recipient of the verification email is sent to if his or her address is successfully verified.',
default: '',
},
{
displayName: 'Failure Redirection URL',
name: 'failureRedirectionURL',
type: 'string',
displayOptions: {
show: {
resource: [
'customVerificationEmail',
],
operation: [
'create',
],
},
},
required: true,
description: 'The URL that the recipient of the verification email is sent to if his or her address is not successfully verified.',
default: '',
},
{
displayName: 'Email',
name: 'email',
type: 'string',
displayOptions: {
show: {
resource: [
'customVerificationEmail',
],
operation: [
'send',
],
},
},
default: '',
required: true,
description: 'The email address to verify.',
},
{
displayName: 'Template Name',
name: 'templateName',
type: 'string',
displayOptions: {
show: {
resource: [
'customVerificationEmail',
],
operation: [
'send',
],
},
},
default: '',
required: true,
description: 'The name of the custom verification email template to use when sending the verification email.',
},
{
displayName: 'Additional Fields',
name: 'additionalFields',
type: 'collection',
placeholder: 'Add Field',
default: {},
displayOptions: {
show: {
resource: [
'customVerificationEmail',
],
operation: [
'send',
],
},
},
options: [
{
displayName: 'Configuration Set Name',
name: 'configurationSetName',
type: 'string',
description: 'Name of a configuration set to use when sending the verification email.',
default: '',
},
],
},
{
displayName: 'Template Name',
name: 'templateName',
type: 'string',
displayOptions: {
show: {
resource: [
'customVerificationEmail',
],
operation: [
'update',
'delete',
'get',
],
},
},
default: '',
description: 'The name of the custom verification email template.',
},
{
displayName: 'Update Fields',
name: 'updateFields',
type: 'collection',
placeholder: 'Add Field',
default: {},
displayOptions: {
show: {
resource: [
'customVerificationEmail',
],
operation: [
'update',
],
},
},
options: [
{
displayName: 'Failure Redirection URL',
name: 'failureRedirectionURL',
type: 'string',
description: 'The URL that the recipient of the verification email is sent to if his or her address is not successfully verified.',
default: '',
},
{
displayName: 'From Email',
name: 'fromEmailAddress',
type: 'string',
description: 'The email address that the custom verification email is sent from.',
default: '',
},
{
displayName: 'Success Redirection URL',
name: 'successRedirectionURL',
type: 'string',
description: 'The URL that the recipient of the verification email is sent to if his or her address is successfully verified.',
default: '',
},
{
displayName: 'Template Content',
name: 'templateContent',
type: 'string',
typeOptions: {
alwaysOpenEditWindow: true,
},
description: `The content of the custom verification email. The total size of the email must be less than 10 MB. The message body may contain HTML`,
default: '',
},
{
displayName: 'Template Subject',
name: 'templateSubject',
type: 'string',
default: '',
description: 'The subject line of the custom verification email.',
},
],
},
{
displayName: 'Return All',
name: 'returnAll',
type: 'boolean',
displayOptions: {
show: {
resource: [
'customVerificationEmail',
],
operation: [
'getAll',
],
},
},
default: false,
description: 'If all results should be returned or only up to a given limit.',
},
{
displayName: 'Limit',
name: 'limit',
type: 'number',
default: 20,
displayOptions: {
show: {
resource: [
'customVerificationEmail',
],
operation: [
'getAll',
],
returnAll: [
false,
],
},
},
},
{
displayName: 'Operation',
name: 'operation',
@ -598,6 +934,140 @@ export class AwsSes implements INodeType {
for (let i = 0; i < items.length; i++) {
if (resource === 'customVerificationEmail') {
if (operation === 'create') {
const failureRedirectionURL = this.getNodeParameter('failureRedirectionURL', i) as string;
const email = this.getNodeParameter('fromEmailAddress', i) as string;
const successRedirectionURL = this.getNodeParameter('successRedirectionURL', i) as string;
const templateContent = this.getNodeParameter('templateContent', i) as string;
const templateName = this.getNodeParameter('templateName', i) as string;
const templateSubject = this.getNodeParameter('templateSubject', i) as string;
const params = [
`Action=CreateCustomVerificationEmailTemplate`,
`FailureRedirectionURL=${failureRedirectionURL}`,
`FromEmailAddress=${email}`,
`SuccessRedirectionURL=${successRedirectionURL}`,
`TemplateContent=${templateContent}`,
`TemplateName=${templateName}`,
`TemplateSubject=${templateSubject}`,
];
responseData = await awsApiRequestSOAP.call(this, 'email', 'POST', '', params.join('&'));
responseData = responseData.CreateCustomVerificationEmailTemplateResponse;
}
if (operation === 'delete') {
const templateName = this.getNodeParameter('templateName', i) as string;
const params = [
`Action=DeleteCustomVerificationEmailTemplate`,
`TemplateName=${templateName}`,
];
responseData = await awsApiRequestSOAP.call(this, 'email', 'POST', '', params.join('&'));
responseData = responseData.DeleteCustomVerificationEmailTemplateResponse;
}
if (operation === 'get') {
const templateName = this.getNodeParameter('templateName', i) as string;
const params = [
`TemplateName=${templateName}`,
];
responseData = await awsApiRequestSOAP.call(this, 'email', 'POST', '/?Action=GetCustomVerificationEmailTemplate&' + params.join('&'));
responseData = responseData.GetCustomVerificationEmailTemplateResponse;
}
if (operation === 'getAll') {
const returnAll = this.getNodeParameter('returnAll', i) as boolean;
if (returnAll === true) {
responseData = await awsApiRequestSOAPAllItems.call(this, 'ListCustomVerificationEmailTemplatesResponse.ListCustomVerificationEmailTemplatesResult.CustomVerificationEmailTemplates.member', 'email', 'POST', '/?Action=ListCustomVerificationEmailTemplates');
} else {
const limit = this.getNodeParameter('limit', i) as number;
responseData = await awsApiRequestSOAP.call(this, 'email', 'GET', `/?Action=ListCustomVerificationEmailTemplates&MaxResults=${limit}`);
responseData = responseData.ListCustomVerificationEmailTemplatesResponse.ListCustomVerificationEmailTemplatesResult.CustomVerificationEmailTemplates.member;
}
}
if (operation === 'send') {
const email = this.getNodeParameter('email', i) as string[];
const templateName = this.getNodeParameter('templateName', i) as string;
const additionalFields = this.getNodeParameter('additionalFields', i) as IDataObject;
const params = [
`Action=SendCustomVerificationEmail`,
`TemplateName=${templateName}`,
`EmailAddress=${email}`,
];
if (additionalFields.configurationSetName) {
params.push(`ConfigurationSetName=${additionalFields.configurationSetName}`);
}
responseData = await awsApiRequestSOAP.call(this, 'email', 'POST', '', params.join('&'));
responseData = responseData.SendCustomVerificationEmailResponse;
}
if (operation === 'update') {
const templateName = this.getNodeParameter('templateName', i) as string;
const updateFields = this.getNodeParameter('updateFields', i) as IDataObject;
const params = [
`Action=UpdateCustomVerificationEmailTemplate`,
`TemplateName=${templateName}`,
];
if (updateFields.FailureRedirectionURL) {
params.push(`FailureRedirectionURL=${updateFields.FailureRedirectionURL}`);
}
if (updateFields.email) {
params.push(`FromEmailAddress=${updateFields.email}`);
}
if (updateFields.successRedirectionURL) {
params.push(`SuccessRedirectionURL=${updateFields.successRedirectionURL}`);
}
if (updateFields.templateContent) {
params.push(`TemplateContent=${updateFields.templateContent}`);
}
if (updateFields.templateSubject) {
params.push(`TemplateSubject=${updateFields.templateSubject}`);
}
responseData = await awsApiRequestSOAP.call(this, 'email', 'POST', '', params.join('&'));
responseData = responseData.UpdateCustomVerificationEmailTemplateResponse;
}
}
if (resource === 'email') {
if (operation === 'send') {
@ -837,13 +1307,15 @@ export class AwsSes implements INodeType {
responseData = responseData.UpdateTemplateResponse;
}
}
if (Array.isArray(responseData)) {
returnData.push.apply(returnData, responseData as IDataObject[]);
} else {
if (responseData !== undefined) {
returnData.push(responseData as IDataObject);
}
}
}
return [this.helpers.returnJsonArray(returnData)];
}

View file

@ -46,7 +46,7 @@ export async function awsApiRequest(this: IHookFunctions | IExecuteFunctions | I
headers: signOpts.headers,
method,
uri: endpoint.href,
body: signOpts.body,
body: signOpts.body as string,
};
try {

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1,022 B

View file

@ -0,0 +1 @@
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 74.375 85" fill="#fff" fill-rule="evenodd" stroke="#000" stroke-linecap="round" stroke-linejoin="round"><use xlink:href="#A" x="2.188" y="2.5"/><symbol id="A" overflow="visible"><g stroke="none"><path d="M16.558 12.75L0 38.591l16.558 25.841 13.227-3.324.654-44.869-13.881-3.489z" fill="#876929"/><path d="M35.049 59.786l-18.491 4.645V12.75l18.491 4.645v42.391z" fill="#d9a741"/><g fill="#876929"><path d="M32.849 21.614L35.05 80 70 62.867l-.01-43.615-8.914 1.448-28.228.913z"/><path d="M46.184 33.149l10.906-.632 10.778-19.164L40.612 0 30.439 4.364l15.745 28.785z"/></g><path d="M40.612 0l27.256 13.353-10.778 19.164L40.612 0z" fill="#d9a741"/><path d="M35.049 5.539L57.09 44.742l3.788 22.595L35.049 80l-10.46-5.131V9.64l10.46-4.101z" fill="#876929"/><path d="M69.991 19.251L70 62.867 35.05 80V5.539l22.041 39.203 12.899-25.491z" fill="#d9a741"/></g></symbol></svg>

After

Width:  |  Height:  |  Size: 961 B