This repository has been archived by the owner on Jan 24, 2025. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpoam.gs
77 lines (66 loc) · 2.6 KB
/
poam.gs
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
/*
PROJECT NAME: AWS Inspector Findings into Google Drive + POAM
GITHUB URL: https://github.com/CirrusMD/Automation-AWS-Inspector-Findings
- Fetching AWS Data: fetchAwsInspectorResults fetches the data from AWS Lambda via an API Gateway endpoint.
- Processing Data: processLambdaData processes the fetched data. Customize this function based on our data processing needs.
- CSV Conversion: convertToCsv converts the processed data into CSV format. It creates a string representing the CSV data.
- Google Drive Update: updateGoogleDrive checks if a file with a given name exists in a specific Google Drive folder. If it exists, the script updates the file with new data; otherwise, it creates a new file.
- Main Function: main orchestrates the entire process by calling the above functions in sequence.
- Scheduling: setupTrigger sets up an automated trigger to run the main function periodically.
*/
// Fetch results from AWS Inspector via AWS Lambda and API Gateway
// TO-DO: Replace 'YOUR_AWS_API_GATEWAY_ENDPOINT' with your actual AWS
function fetchAwsInspectorResults() {
var url = '[AWS_API_GATEWAY_ENDPOINT]';
var response = UrlFetchApp.fetch(url);
var data = JSON.parse(response.getContentText());
return data;
}
// TO-DO: Customize this function to process our data as required.
function processLambdaData(data) {
// TO-DO: Return data as is or apply transformations
return data;
}
// Convert the processed data to CSV format
function convertToCsv(data) {
var csvData = '';
var keys = Object.keys(data[0]);
// Add header row
csvData += keys.join(',') + '\n';
// Add data rows
data.forEach(function(row) {
keys.forEach(function(key, index) {
if (index > 0) csvData += ',';
csvData += JSON.stringify(row[key]);
});
csvData += '\n';
});
return csvData;
}
// TO-DO: Replace 'FolderName' with the actual name of the Google Drive folder.
function updateGoogleDrive(csvData) {
var fileName = 'AWS_Inspector_Results.csv';
var folder = DriveApp.getFoldersByName('FolderName').next();
var files = folder.getFilesByName(fileName);
var file;
if (files.hasNext()) {
file = files.next();
file.setContent(csvData);
} else {
file = folder.createFile(fileName, csvData, MimeType.PLAIN_TEXT);
}
}
// Main function to orchestrate the workflow
function main() {
var awsData = fetchAwsInspectorResults();
var processedData = processLambdaData(awsData);
var csvData = convertToCsv(processedData);
updateGoogleDrive(csvData);
}
// Time-driven trigger
function setupTrigger() {
ScriptApp.newTrigger('main')
.timeBased()
.everyDays(25) // Adjust if Needed
.create();
}