This repository was archived by the owner on Sep 27, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathindex.js
110 lines (100 loc) · 2.96 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
'use strict';
const crypto = require('crypto');
const AWS = require('aws-sdk');
AWS.config.apiVersions = {
lambda: '2015-03-31',
sqs: '2012-11-05'
};
function respond(statusCode, message) {
return {
headers: {},
statusCode: statusCode,
body: JSON.stringify({
message
})
};
}
function validateSignature(event) {
return new Promise((resolve, reject) => {
const lambda = new AWS.Lambda({ region: process.env.AWS_DEFAULT_REGION });
const params = {
FunctionName: process.env.GITHUB_SIGNATURE_VERIFIER_FUNCTION,
InvocationType: 'RequestResponse',
Payload: JSON.stringify(event)
};
lambda.invoke(params, (err, data) => {
if (err) return reject(err);
if (data.StatusCode !== 200) {
return reject(new Error(`Received ${data.StatusCode} status when invoking ${params.FunctionName}`));
}
return resolve(JSON.parse(data.Payload));
});
});
}
function generateMessageDeduplicationID(content) {
const hash = crypto.createHash('sha256');
hash.update(JSON.stringify(content));
return hash.digest('hex');
}
function sendMessages(body) {
const release = `${body.repository.name}/${body.release.tag_name}`;
const promises = [];
body.release.assets.push({
name: 'source.zip',
content_override: 'application/json',
url: body.release.zipball_url
});
body.release.assets.forEach(asset => {
const p = new Promise((resolve, reject) => {
const sqs = new AWS.SQS({ region: process.env.AWS_SQS_REGION });
const params = {
QueueUrl: process.env.QUEUE_URL,
MessageAttributes: {
release: {
DataType: 'String',
StringValue: release
},
name: {
DataType: 'String',
StringValue: asset.name
},
contentType: {
DataType: 'String',
StringValue: asset.content_override || 'application/octet-stream'
},
url: {
DataType: 'String',
StringValue: asset.url
}
},
MessageBody: `Request to upload '${asset.name}' to S3 from '${release}'`,
MessageGroupId: 'git2s3'
};
params.MessageDeduplicationId = generateMessageDeduplicationID(params);
sqs.sendMessage(params, err => {
if (err) return reject(err);
return resolve();
});
});
promises.push(p);
});
return Promise.all(promises);
}
exports.handler = (event, context, callback) => {
// log the event and context for debugging
console.log(event);
console.log(context);
validateSignature(event)
.then(response => {
if (response.statusCode !== 200) {
return callback(null, respond(response.statusCode, JSON.parse(response.body).message));
}
return JSON.parse(event.body);
})
.then(sendMessages)
.then(() => callback(null, respond(200, 'OK')))
.catch(err => {
console.log(err);
return callback(null, respond(500, 'Server Error'));
});
};