44 lines
1.1 KiB
TypeScript
44 lines
1.1 KiB
TypeScript
/// <reference lib="deno.ns" />
|
|
|
|
/**
|
|
* @author Esad Mustafoski
|
|
* @file api/helpers.ts
|
|
* @description Helper functions for the API
|
|
*
|
|
*/
|
|
import { Context } from "https://deno.land/x/oak/mod.ts";
|
|
import { hash } from "node:crypto";
|
|
|
|
export type ApiResponse = {
|
|
status: number;
|
|
body: unknown;
|
|
};
|
|
|
|
// --- Helper Functions --- //
|
|
/**
|
|
* @description Sends a response to the client
|
|
* @usage sendResponse(ctx, { status: 200, body: { message: "Success" } })
|
|
* Status is the HTTP Status code
|
|
* Body is the response body/message/data.
|
|
*/
|
|
const sendResponse = (ctx: Context, {status, body}: ApiResponse): void => {
|
|
ctx.response.status = status;
|
|
ctx.response.body = body as any;
|
|
};
|
|
|
|
/**
|
|
* @usage errorResponse(ctx, 401, "Unauthorized")
|
|
* @see sendResponse
|
|
*/
|
|
const errorResponse = (ctx: Context, status: number, message: string): void => {
|
|
sendResponse(ctx, { status, body: { error: message } });
|
|
};
|
|
|
|
/**
|
|
* @description Hashing Function for Passwords/etc
|
|
* @param password The password to hash
|
|
* Works only up to 5 Megabytes
|
|
*/
|
|
const hashPassword = async (password: string): Promise<string> => {
|
|
return hash("sha256", password);
|
|
} |