Product CRUD
This commit is contained in:
		| @@ -1,22 +1,77 @@ | |||||||
| import {Request, Response} from 'express'; | import {Request, Response} from 'express'; | ||||||
|  | import {db} from '../../db/index'; | ||||||
|  | import {eq} from 'drizzle-orm'; | ||||||
|  | import { productsTable } from '../../db/productsSchema'; | ||||||
|  |  | ||||||
| export function listProducts(req: Request, res: Response) { | export async function listProducts(req: Request, res: Response) { | ||||||
|     res.send ('listProducts'); |     try{ | ||||||
|  |         const products = await db.select().from(productsTable); | ||||||
|  |         res.json(products); | ||||||
|  |     } catch (e) { | ||||||
|  |         res.status(500).send(e); | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| export function getProductById(req: Request, res: Response) { | export async function getProductById(req: Request, res: Response) { | ||||||
|     res.send ('getProductById'); |     try{ | ||||||
|  |         const {id} = req.params; | ||||||
|  |         const product = await db | ||||||
|  |             .select() | ||||||
|  |             .from(productsTable) | ||||||
|  |             .where(eq(productsTable.id, Number(id))); | ||||||
|  |         if (product.length == 0) { | ||||||
|  |             res.status(404).send({message: "Product not found"}); | ||||||
|  |         } else { | ||||||
|  |             res.json(product); | ||||||
|  |         } | ||||||
|  |         //console.log(product.length); | ||||||
|  |  | ||||||
|  |     } catch (e) { | ||||||
|  |         res.status(500).send(e); | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| export function createProduct(req: Request, res: Response) { | export async function createProduct(req: Request, res: Response) { | ||||||
|     console.log (req.body); |     try{ | ||||||
|     res.send ('createProduct'); |         const productId = await db | ||||||
|  |         .insert(productsTable) | ||||||
|  |         .values(req.body) | ||||||
|  |         .$returningId() | ||||||
|  |         //const [product] = await db.insert(productsTable).values(req.body).Returning() | ||||||
|  |         //Postgresql can return series of products so we can capture the first one from array[] | ||||||
|  |         res.status(201).json(productId); | ||||||
|  |     } catch (e) { | ||||||
|  |         res.status(500).send(e); | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| export function updateProduct(req: Request, res: Response) { | export async function updateProduct(req: Request, res: Response) { | ||||||
|     res.send ('updateProduct'); |     try{ | ||||||
|  |         const id = Number(req.params.id); | ||||||
|  |         const updatedFields = req.body; | ||||||
|  |  | ||||||
|  |         const result = await db | ||||||
|  |             .update(productsTable) | ||||||
|  |             .set(updatedFields) | ||||||
|  |             .where(eq(productsTable.id, id)) | ||||||
|  |  | ||||||
|  |         console.log(result); | ||||||
|  |  | ||||||
|  |     } catch (e) { | ||||||
|  |         res.status(500).send(e); | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| export function deleteProduct(req: Request, res: Response) { | export async function deleteProduct(req: Request, res: Response) { | ||||||
|     res.send ('deleteProduct'); |     try{ | ||||||
|  |         const id = Number(req.params.id); | ||||||
|  |  | ||||||
|  |         const [deletedProduct] = await db | ||||||
|  |         .delete(productsTable) | ||||||
|  |         .where(eq(productsTable.id , id)); | ||||||
|  |  | ||||||
|  |         console.log(deleteProduct); | ||||||
|  |     } catch (e) { | ||||||
|  |         res.status(500).send(e); | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user