Add specificity to entry queries
This commit is contained in:
parent
bba9a216ee
commit
83ddd9f15d
@ -46,12 +46,12 @@ app.post("/", async (req: Request, res: Response) => {
|
|||||||
const voteIndex = parseInt((req.body.voteIndex as string | undefined) ?? "");
|
const voteIndex = parseInt((req.body.voteIndex as string | undefined) ?? "");
|
||||||
|
|
||||||
if (!voteId) {
|
if (!voteId) {
|
||||||
res.status(400).send("Missing voteId");
|
res.status(400).json({error: "Missing voteId"});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!voter) {
|
if (!voter) {
|
||||||
res.status(400).send("Missing voter");
|
res.status(400).json({error: "Missing voter"});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -84,7 +84,7 @@ app.post("/", async (req: Request, res: Response) => {
|
|||||||
app.get("/", async (req: Request, res: Response) => {
|
app.get("/", async (req: Request, res: Response) => {
|
||||||
const voteId = req.query.voteId as string | undefined;
|
const voteId = req.query.voteId as string | undefined;
|
||||||
if (!voteId) {
|
if (!voteId) {
|
||||||
res.status(400).send("Missing voteId");
|
res.status(400).json({error: "Missing voteId"});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -99,8 +99,15 @@ app.get("/", async (req: Request, res: Response) => {
|
|||||||
|
|
||||||
app.get("/entries", async (req: Request, res: Response) => {
|
app.get("/entries", async (req: Request, res: Response) => {
|
||||||
const voteId = req.query.voteId as string | undefined;
|
const voteId = req.query.voteId as string | undefined;
|
||||||
|
const voteIndexStr = req.query.voteIndex as string | undefined;
|
||||||
|
const voteIndex = parseInt(voteIndexStr ?? "");
|
||||||
if (!voteId) {
|
if (!voteId) {
|
||||||
res.status(400).send("Missing voteId");
|
res.status(400).json({error: "Missing voteId"});
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Number.isNaN(voteIndex) && voteIndexStr) {
|
||||||
|
res.status(400).json({error: "Invalid voteIndex"});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -110,7 +117,17 @@ app.get("/entries", async (req: Request, res: Response) => {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const entries = await vote.ref.collection("entries").get();
|
if (!Number.isNaN(voteIndex) && (voteIndex < 0 || voteIndex >= (vote.data()?.options ?? []).length)) {
|
||||||
|
res.status(400).json({error: "Invalid vote index"});
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const entryCollection = vote.ref.collection("entries");
|
||||||
|
const entries = await (
|
||||||
|
Number.isNaN(voteIndex) ?
|
||||||
|
entryCollection :
|
||||||
|
entryCollection.where("voteIndex", "==", voteIndex)
|
||||||
|
).get();
|
||||||
res.json(entries.docs.map((d) => d.data()));
|
res.json(entries.docs.map((d) => d.data()));
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -118,7 +135,7 @@ app.get("/count", async (req: Request, res: Response) => {
|
|||||||
const voteId = req.query.voteId as string | undefined;
|
const voteId = req.query.voteId as string | undefined;
|
||||||
|
|
||||||
if (!voteId) {
|
if (!voteId) {
|
||||||
res.status(400).send("Missing voteId");
|
res.status(400).json({error: "Missing voteId"});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user