feat: get paste route

This commit is contained in:
2022-07-10 01:33:56 +05:30
parent f520d16f19
commit 656c95519d
4 changed files with 50 additions and 15 deletions

View File

@ -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];
};

View File

@ -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}`;
},
};