40 lines
1.1 KiB
JavaScript
40 lines
1.1 KiB
JavaScript
const express = require('express');
|
|
const r = express.Router();
|
|
const ur = express.Router();
|
|
|
|
const pool = require('../db');
|
|
|
|
//insert a new latest rank for a user
|
|
ur.post('/', async (req, res) => {
|
|
try {
|
|
const change = req.body?.change;
|
|
console.log(change);
|
|
|
|
const sql = `INSERT INTO members_ranks (member_id, rank_id, event_date) VALUES (?, ?, ?);`;
|
|
|
|
const params = [change.member_id, change.rank_id, change.event_date]
|
|
|
|
await pool.query(sql, params);
|
|
|
|
res.sendStatus(201);
|
|
} catch (err) {
|
|
console.error('Insert failed:', err);
|
|
res.status(500).json({ error: 'Failed to update ranks' });
|
|
}
|
|
});
|
|
|
|
//get all ranks
|
|
r.get('/', async (req, res) => {
|
|
try {
|
|
const result = await pool.query('SELECT id, name, short_name, sort_id FROM ranks;');
|
|
res.json(result);
|
|
} catch (err) {
|
|
console.error(err);
|
|
res.status(500).json({ error: 'Internal server error' });
|
|
}
|
|
});
|
|
|
|
module.exports.ranks = r;
|
|
module.exports.memberRanks = ur;
|
|
|
|
// TODO, implement get all ranks route with SQL stirng SELECT id, name, short_name, category, sort_id FROM ranks;
|