mirror of
https://github.com/fleetdm/fleet
synced 2026-05-05 06:18:25 +00:00
This pull request relies on the `mdm-gen-cert` command from https://github.com/fleetdm/fleet/pull/8884. Closes: https://github.com/fleetdm/fleet/issues/8223 Changes: - Updated the deploy Fleet website workflow to: - Add Go as a dependency - Build the mdm-gen-cert binary in `/website/.tools/` - add the `/.tools/` folder to the Heroku app - Added `deliver-apple-csr.js` - an API that: - can be called by making a `POST` request to `/api/v1/deliver-apple-csr` - accepts `csr` as an input - runs the `mdm-gen-cert` command with the `csr` set as an environment variable - returns an `invalidEmailDomain` response if the user's email domain is in the array of banned email domains. - saves the users organization and email address to the website's database - Sends an email to the requesting user's email address with the signed CSR attached as a text file named `apple-apns-request.txt` - Posts a message to a channel in the Fleet Slack. - Added a new model: `CertificateSigningRequests` that contains two required attributes: `emailAddress` and `organization` - Added a new email template `email-signed-csr-for-apns` - Updated routes, policies, eslintrc, and rebuilt cloud-sdk Before this can be merged, we will need to: - [x] Add new config variables in Heroku - [x] `sails.config.custom.mdmVendorCertPem` - [x] `sails.config.custom.mdmVendorKeyPem` - [x] `sails.config.custom.mdmVendorKeyPassphrase` - [x] `sails.config.custom.slackWebhookUrlForMDMSignups` - [x] Add the `CertificateSigningRequests` model to the website's database
156 lines
4.4 KiB
JavaScript
Vendored
156 lines
4.4 KiB
JavaScript
Vendored
module.exports = {
|
|
|
|
|
|
friendlyName: 'View email template preview',
|
|
|
|
|
|
description: 'Display "email template preview" page.',
|
|
|
|
|
|
urlWildcardSuffix: 'template',
|
|
|
|
|
|
inputs: {
|
|
|
|
template: {
|
|
description: 'The path to an email template, specified in precisely the same way as the equivalent input of the sendTemplateEmail() helper.',
|
|
example: 'email-reset-password',
|
|
type: 'string',
|
|
required: true
|
|
},
|
|
|
|
raw: {
|
|
description: 'Whether to return the raw HTML for the email with no JS/CSS (rather than a personalized previewer web page.)',
|
|
extendedDescription: 'This can be used from an iframe to allow for accurately previewing email templates without worrying about style interference from the rest of the Sails app.',
|
|
type: 'boolean',
|
|
}
|
|
|
|
},
|
|
|
|
exits: {
|
|
|
|
success: {
|
|
viewTemplatePath: 'pages/admin/email-preview'
|
|
},
|
|
|
|
sendRawHtmlInstead: {
|
|
statusCode: 200,
|
|
outputType: 'string',
|
|
outputDescription: 'The raw HTML for the email as a string.',
|
|
},
|
|
|
|
},
|
|
|
|
|
|
fn: async function ({template, raw}) {
|
|
|
|
var path = require('path');
|
|
var moment = require('moment');
|
|
var url = require('url');
|
|
var util = require('util');
|
|
// Determine appropriate email layout and fake data to use.
|
|
let layout;
|
|
let fakeData;
|
|
switch (template) {
|
|
case 'internal/email-contact-form':
|
|
layout = false;
|
|
fakeData = {
|
|
contactName: 'Sage',
|
|
contactEmail: '[email protected]',
|
|
topic: 'Pricing question',
|
|
message: 'What is the difference between the "Free" plan and the "Premium" plan?',
|
|
};
|
|
break;
|
|
case 'email-reset-password':
|
|
layout = 'layout-email';
|
|
fakeData = {
|
|
token: '4-32fad81jdaf$329',
|
|
};
|
|
break;
|
|
case 'email-verify-account':
|
|
layout = 'layout-email';
|
|
fakeData = {
|
|
firstName: 'Fleet user',
|
|
token: '4-32fad81jdaf$329',
|
|
};
|
|
break;
|
|
case 'email-verify-new-email':
|
|
layout = 'layout-email';
|
|
fakeData = {
|
|
fullName: 'Fleet user',
|
|
token: '4-32fad81jdaf$329',
|
|
};
|
|
break;
|
|
case 'email-order-confirmation':
|
|
layout = 'layout-email';
|
|
fakeData = {
|
|
firstName: 'Fleet',
|
|
lastName: 'user',
|
|
};
|
|
break;
|
|
case 'email-subscription-renewal-confirmation':
|
|
layout = 'layout-email';
|
|
fakeData = {
|
|
firstName: 'Fleet',
|
|
lastName: 'user',
|
|
};
|
|
break;
|
|
case 'email-upcoming-subscription-renewal':
|
|
layout = 'layout-email';
|
|
fakeData = {
|
|
firstName: 'Fleet',
|
|
lastName: 'user',
|
|
subscriptionPriceInWholeDollars: 60,
|
|
numberOfHosts: 10,
|
|
subscriptionCostPerHost: 6,
|
|
nextBillingAt: Date.now() + (1000 * 60 * 60 * 24 * 7),
|
|
};
|
|
break;
|
|
case 'email-signed-csr-for-apns':
|
|
layout = 'layout-email';
|
|
fakeData = {};
|
|
break;
|
|
default:
|
|
layout = 'layout-email-newsletter';
|
|
fakeData = {
|
|
emailAddress: '[email protected]',
|
|
};
|
|
}
|
|
|
|
// Compile HTML template using the appropriate layout.
|
|
// > Note that we set the layout, provide access to core `url` package (for
|
|
// > building links and image srcs, etc.), and also provide access to core
|
|
// > `util` package (for dumping debug data in internal emails).
|
|
let emailTemplatePath = path.join('emails/', template);
|
|
if (layout) {
|
|
layout = path.relative(path.dirname(emailTemplatePath), path.resolve('layouts/', layout));
|
|
} else {
|
|
layout = false;
|
|
}
|
|
|
|
let sampleHtml = await sails.renderView(
|
|
emailTemplatePath,
|
|
Object.assign({layout, url, util, _, moment }, fakeData)
|
|
)
|
|
.intercept((err)=>{
|
|
err.message = 'Whoops, that email template failed to render. Could there be some fake data missing for this particular template in the `switch` statement api/controllers/admin/view-email-template-preview.js? Any chance you need to re-lift the app after making backend changes?\nMore details: '+err.message;
|
|
return err;
|
|
});
|
|
|
|
if (raw) {
|
|
// Respond with raw, rendered HTML for this email:
|
|
throw {sendRawHtmlInstead: sampleHtml};
|
|
} else {
|
|
// Respond with the previewer page for this email:
|
|
return {
|
|
sampleHtml,
|
|
template,
|
|
fakeData,
|
|
};
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
};
|