mirror of
https://github.com/okiba-org/backend.git
synced 2025-07-02 04:48:22 +00:00
feat: get paste route
This commit is contained in:
@ -1,16 +1,29 @@
|
||||
import { Pool, QueryResult } from "pg";
|
||||
import { Word } from "../utils/types";
|
||||
import { Query } from "./queries";
|
||||
|
||||
// query wrappers
|
||||
export const getAvailableWord = async (db: Pool): Promise<Word | undefined> => {
|
||||
let query =
|
||||
"SELECT * FROM words WHERE taken = 'f' ORDER BY random() LIMIT 1;";
|
||||
const data: void | QueryResult<Word> = await db
|
||||
.query(Query.getAvailableWord)
|
||||
.query(query)
|
||||
.catch((err) => err);
|
||||
|
||||
return data?.rows[0];
|
||||
};
|
||||
|
||||
export const setWordTaken = async (db: Pool, id: number) => {
|
||||
await db.query(Query.setWordTaken(id)).catch((err) => err);
|
||||
let query = `UPDATE words SET taken = 't' WHERE id = ${id}`;
|
||||
await db.query(query).catch((err) => err);
|
||||
};
|
||||
|
||||
export const getWordFromVal = async (
|
||||
db: Pool,
|
||||
id: string
|
||||
): Promise<Word | undefined> => {
|
||||
let query = `SELECT * FROM words WHERE val = '${id}';`;
|
||||
let results: QueryResult<Word> | void = await db
|
||||
.query(query)
|
||||
.catch((err) => err);
|
||||
return results?.rows[0];
|
||||
};
|
||||
|
@ -1,9 +0,0 @@
|
||||
// query strings
|
||||
export const Query = {
|
||||
getAvailableWord:
|
||||
"SELECT * FROM words WHERE taken = 'f' ORDER BY random() LIMIT 1;",
|
||||
|
||||
setWordTaken(id: number) {
|
||||
return `UPDATE words SET taken = 't' WHERE id = ${id}`;
|
||||
},
|
||||
};
|
Reference in New Issue
Block a user