added support for account states to restrict resources for non-active members

This commit is contained in:
2025-10-19 21:52:32 -04:00
parent 659a8f5b98
commit 06764ebeb4
4 changed files with 19 additions and 17 deletions

View File

@@ -2,6 +2,7 @@ const express = require('express');
const router = express.Router();
import pool from '../db';
import { getUserData } from '../services/memberService';
import { getUserRoles } from '../services/rolesService';
router.use((req, res, next) => {
@@ -34,30 +35,25 @@ router.get('/', async (req, res) => {
});
router.get('/me', async (req, res) => {
console.log(req.user);
if (req.user === undefined)
return res.sendStatus(401)
try {
const { id, name, state } = await getUserData(req.user.id);
const LOAData = await pool.query(
`SELECT *
FROM leave_of_absences
WHERE member_id = ?
AND deleted = 0
AND UTC_TIMESTAMP() BETWEEN start_date AND end_date;`, req.user.id);
const roleData = await getUserRoles(req.user.id);
const userDataFull = {
...req.user,
loa: LOAData,
roles: roleData
};
console.log(userDataFull);
const roleData = await getUserRoles(req.user.id);
const userDataFull = { id, name, state, LOAData, roleData };
console.log(userDataFull)
res.status(200).json(userDataFull);
} catch (error) {
console.error('Error fetching LOA data:', error);
console.error('Error fetching user data:', error);
return res.status(500).json({ error: 'Failed to fetch user data' });
}
})

View File

@@ -7,7 +7,6 @@ const { getAllRanks, insertMemberRank } = require('../services/rankService')
ur.post('/', async (req, res) => {3
try {
const change = req.body?.change;
console.log(change);
await insertMemberRank(change);
res.sendStatus(201);
@@ -21,7 +20,6 @@ ur.post('/', async (req, res) => {3
r.get('/', async (req, res) => {
try {
const ranks = await getAllRanks();
console.log(ranks);
res.json(ranks);
} catch (err) {
console.error(err);

View File

@@ -0,0 +1,8 @@
import pool from "../db";
export async function getUserData(userID: number) {
const sql = `SELECT * FROM members WHERE id = ?`;
const res = await pool.query(sql, [userID]);
return res[0] ?? null;
}