feat(routes): thread userId through routes + visibility/fork/curated endpoints
This commit is contained in:
@@ -4,20 +4,22 @@ import { getCardStats, getHeatmap, getLessonStats, getOverview } from '../servic
|
||||
|
||||
export function statsRouter(db: Db): Router {
|
||||
const r = Router();
|
||||
r.get('/overview', async (_req, res, next) => {
|
||||
try { res.json(await getOverview(db)); } catch (e) { next(e); }
|
||||
|
||||
r.get('/overview', async (req, res, next) => {
|
||||
try { res.json(await getOverview(db, req.user!.id)); } catch (e) { next(e); }
|
||||
});
|
||||
r.get('/lessons/:id', async (req, res, next) => {
|
||||
try { res.json(await getLessonStats(db, Number(req.params.id))); } catch (e) { next(e); }
|
||||
try { res.json(await getLessonStats(db, req.user!.id, Number(req.params.id))); } catch (e) { next(e); }
|
||||
});
|
||||
r.get('/cards/:id', async (req, res, next) => {
|
||||
try { res.json(await getCardStats(db, Number(req.params.id))); } catch (e) { next(e); }
|
||||
try { res.json(await getCardStats(db, req.user!.id, Number(req.params.id))); } catch (e) { next(e); }
|
||||
});
|
||||
r.get('/heatmap', async (req, res, next) => {
|
||||
try {
|
||||
const weeks = Math.min(52, Math.max(1, Number(req.query.weeks ?? 12)));
|
||||
res.json(await getHeatmap(db, weeks));
|
||||
res.json(await getHeatmap(db, req.user!.id, weeks));
|
||||
} catch (e) { next(e); }
|
||||
});
|
||||
|
||||
return r;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user