mirror of
https://github.com/oceanprotocol/webtasks
synced 2025-01-08 21:04:03 +01:00
116 lines
3.1 KiB
JavaScript
116 lines
3.1 KiB
JavaScript
const express = require('express')
|
|
const Webtask = require('webtask-tools')
|
|
const cors = require('cors')
|
|
const crypto = require('crypto')
|
|
const bodyParser = require('body-parser')
|
|
const request = require('request')
|
|
|
|
const server = express()
|
|
|
|
server.listen(4430)
|
|
server.use(bodyParser.json())
|
|
|
|
//
|
|
// Allow requests from these domains only
|
|
//
|
|
const corsOptions = {
|
|
origin: ['https://oceanprotocol.com', /\.oceanprotocol\.com$/],
|
|
optionsSuccessStatus: 200 // some legacy browsers (IE11, various SmartTVs) choke on 204
|
|
}
|
|
|
|
server.use(cors(corsOptions))
|
|
|
|
const baseUrl = 'https://us16.api.mailchimp.com/3.0'
|
|
const listId = '3c6eed8b71'
|
|
|
|
const md5 = data =>
|
|
crypto
|
|
.createHash('md5')
|
|
.update(data)
|
|
.digest('hex')
|
|
|
|
server.post('/newsletter/:email', (req, res) => {
|
|
const { email } = req.params
|
|
const { MAILCHIMP_API_KEY } = req.webtaskContext.secrets
|
|
const emailDecoded = decodeURIComponent(email)
|
|
const subscriberHash = md5(emailDecoded)
|
|
|
|
const baseOptions = {
|
|
url: `${baseUrl}/lists/${listId}/members/${subscriberHash}`,
|
|
auth: {
|
|
user: 'oceanprotocol',
|
|
pass: MAILCHIMP_API_KEY
|
|
}
|
|
}
|
|
|
|
const optionsCreate = {
|
|
...baseOptions,
|
|
json: {
|
|
email_address: emailDecoded,
|
|
status: 'pending', // double opt-in
|
|
merge_fields: {
|
|
// our GDPR fallback
|
|
GDPR: 'yes'
|
|
}
|
|
}
|
|
}
|
|
|
|
const optionsMarketing = marketingPermissionId => ({
|
|
...baseOptions,
|
|
json: {
|
|
marketing_permissions: [
|
|
{
|
|
marketing_permission_id: marketingPermissionId,
|
|
text: 'Email',
|
|
enabled: true
|
|
}
|
|
]
|
|
}
|
|
})
|
|
|
|
const addMarketingPermissions = (data, cb) => {
|
|
const marketingPermissionId =
|
|
data.marketing_permissions[0].marketing_permission_id
|
|
|
|
request.patch(
|
|
optionsMarketing(marketingPermissionId),
|
|
(error, response, body) => {
|
|
if (error) res.send(error)
|
|
|
|
return cb(body)
|
|
}
|
|
)
|
|
}
|
|
|
|
// Check if user exists first
|
|
request.get(baseOptions, (error, response, body) => {
|
|
if (error) res.send(error)
|
|
|
|
const data = JSON.parse(body)
|
|
|
|
// Member exists and is subscribed
|
|
if (data.status === 'subscribed') {
|
|
// Patch in native GDPR permissions
|
|
addMarketingPermissions(data, () => {
|
|
res.send('{ "status": "exists" }')
|
|
})
|
|
} else {
|
|
// Create user
|
|
request.put(optionsCreate, (error2, response, body2) => {
|
|
if (error2) res.send(error2)
|
|
|
|
if (Number.isInteger(body2.status)) {
|
|
res.send(body2)
|
|
}
|
|
|
|
// Patch in native GDPR permissions
|
|
addMarketingPermissions(body2, () => {
|
|
res.send('{ "status": "created" }')
|
|
})
|
|
})
|
|
}
|
|
})
|
|
})
|
|
|
|
module.exports = Webtask.fromExpress(server)
|