summary refs log tree commit diff
path: root/src/api/routes/adminRoutes.js
blob: 4baa5e4156981bc69d091d7e1e4137bbeef0a229 (plain) (blame)
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
import {
    requireMonitor,
    requireUser,
    requireRole,
    requireAdmin
} from '#api/middlewares/index.js';
import { DbUser, UserType } from '#db/schemas/index.js';
import { RouteMethod } from '#api/RouteDescription.js';
import { getUserById } from '#db/dbAccess/index.js';
import { AlarmDto } from '#dto/AlarmDto.js';

/**
 * @type {RouteDescription}
 */
export const adminGetUserIdsRoute = {
    path: '/admin/allUserIds',
    methods: {
        get: new RouteMethod({
            exampleHeaders: {
                Authorization: 'Bearer {{accessToken}}'
            },
            middlewares: [requireAdmin],
            description: 'Get all user IDs',
            async method(req, res) {
                // streaming json array
                res.status(200);
                res.write('[\n');

                let first = true;
                const users = DbUser.find().lean().cursor();
                for await (const user of users) {
                    res.write(
                        (first ? '' : ',') + JSON.stringify(user._id) + '\n'
                    );
                    first = false;
                }

                res.write(']');
                res.end();
            }
        })
    }
};
export const adminMonitorAllRoute = {
    path: '/admin/monitorAllUsers',
    methods: {
        post: new RouteMethod({
            exampleHeaders: {
                Authorization: 'Bearer {{accessToken}}'
            },
            middlewares: [requireAdmin],
            description: 'Monitor all users',
            async method(req, res) {
                const users = await DbUser.find({ type: UserType.USER }).lean();
                const monitoredUsers = users.map(user => user._id);

                // Update the admin's monitoredUsers
                req.user.monitoredUsers = monitoredUsers;
                await req.user.save();

                res.status(204).send();
            }
        })
    }
};