1 let crypto = require('crypto')
2 let XDate = require('xdate')
5 let nodemailer_contact = await env.site.get_nodemailer(
6 '/_config/nodemailer_contact.json'
8 let post_request = await _require('/_lib/post_request.jst')
9 let session_cookie = await _require('/_lib/session_cookie.jst')
10 let Problem = await _require('/_lib/Problem.jst')
17 // coerce and/or validate
19 given_names: details.given_names.slice(0, 256),
20 family_name: details.family_name.slice(0, 256),
21 company: details.company.slice(0, 256),
22 email: details.email.slice(0, 256).toLowerCase(),
23 message: details.message.slice(0, 65536),
26 details.given_names.length === 0 ||
27 details.email.length === 0 ||
28 details.message.length === 0
32 'Minimum length check failed',
36 let transaction = await env.site.database.Transaction()
37 let contact_from, contact_to
39 // initialize env.session_key, set cookie in env.response
40 session_cookie(env, transaction)
42 let globals = await (await transaction.get({})).get('globals')
43 contact_from = await globals.get_json('contact_from')
44 contact_to = await globals.get_json('contact_to')
46 await transaction.commit()
49 transaction.rollback()
54 details.family_name.length ?
55 `${details.given_names} ${details.family_name}` :
58 details.company.length ?
59 `Enquiry: ${details.company}` :
61 await nodemailer_contact.sendMail(
65 replyTo: `${name} <${details.email}>`,