📦 EqualifyEverything / equalify-api

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

export const runEveryFiveMinutes = async () => {
    await db.connect();
    const pendingScans = (await db.query({
        text: `SELECT DISTINCT s.user_id, s.property_id, CONCAT(u.first_name,' ',u.last_name) AS user_name, u.email AS user_email, p.name AS property_name, COUNT(s.id) AS "pending_scans" FROM scans AS s 
            INNER JOIN users AS u ON u.id=s.user_id 
            INNER JOIN properties AS p ON p.id=s.property_id 
            WHERE s.processing = true 
            GROUP BY s.user_id, s.property_id, user_name, user_email, property_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.property_name}*: ${obj.pending_scans} scans left`).join('\n')
        })
    });

    for (const { user_id, property_id } of pendingScans) {
        lambda.send(new InvokeCommand({
            FunctionName: `equalify-api${isStaging ? '-staging' : ''}`,
            InvocationType: "Event",
            Payload: Buffer.from(JSON.stringify({
                path: '/internal/processScans',
                userId: user_id,
                propertyId: property_id,
                discovery: 'sitemap',
            })),
        }));
    }
    return;
}