📦 EqualifyEverything / equalify-v2-api

📄 runEveryFifteenMinutes.ts · 39 lines
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
39import { db, isStaging } from '#src/utils';
import { LambdaClient, InvokeCommand } from '@aws-sdk/client-lambda';
const lambda = new LambdaClient();

export const runEveryFifteenMinutes = async () => {
    await db.connect();
    const pendingScans = (await db.query({
        text: `SELECT DISTINCT s.organization_id, s.audit_id, o.name AS organization_name, a.name AS audit_name, COUNT(s.id) AS "pending_scans" FROM scans AS s 
            INNER JOIN organizations AS o ON o.id=s.organization_id 
            INNER JOIN audits AS a ON a.id=s.audit_id 
            WHERE s.status = 'processing' 
            GROUP BY s.organization_id, s.audit_id, organization_name, audit_name
            ORDER BY pending_scans DESC`,
    })).rows;
    await db.clean();

    console.log(JSON.stringify({ pendingScans }));
    // await fetch(process.env.SLACK_WEBHOOK, {
    //     method: 'POST',
    //     body: JSON.stringify({
    //         text: pendingScans.map(obj => `*${obj.user_name}* (${obj.user_email}) scan for *${obj.audit_name}*: ${obj.pending_scans} scans left`).join('\n')
    //     })
    // });

    for (const { organization_id, audit_id } of pendingScans) {
        const response = await lambda.send(new InvokeCommand({
            FunctionName: `equalifyv2-api${isStaging ? '-staging' : ''}`,
            InvocationType: "Event",
            Payload: Buffer.from(JSON.stringify({
                path: '/internal/processScans',
                organization_id: organization_id,
                audit_id: audit_id,
                is_sitemap: true,
            })),
        }));
        console.log(JSON.stringify({ response }))
    }
    return;
}