Compare commits
3 Commits
7b9fe95cd4
...
6b665bb41d
Author | SHA1 | Date | |
---|---|---|---|
6b665bb41d | |||
5720b45c6b | |||
de5a4b9f19 |
12
README.MD
12
README.MD
@ -1,9 +1,13 @@
|
||||
# HydrationHUB
|
||||
HydrationHUB - TODO: Luistiger slogan?
|
||||
|
||||
## Serving static files from node_modules
|
||||
## Security Disclaimer
|
||||
This application is not designed for security and therefore has exploitable vulnerabilities.
|
||||
This is due to the simplicity of the application and is sufficient for the intended purpose.
|
||||
If you plan to use this application for a different purpose where security vulnerabilities are a concern, we would greatly appreciate your contributions.
|
||||
|
||||
## Static handling
|
||||
### Serving static files from node_modules
|
||||
Files from explicit dirs inside `node_modules` will be served below `/libs`.
|
||||
|
||||
## Serving static files from /static
|
||||
### Serving static files from /static
|
||||
Files from the `/static` folder will be served below `/static`.
|
||||
|
||||
|
@ -8,6 +8,9 @@ import versionRoute from './version.js';
|
||||
import user_route from './user.js';
|
||||
import user_schema from './user_schema.js';
|
||||
|
||||
import user_codecheck_route from './user_codecheck.js';
|
||||
import user_codecheck_schema from './user_codecheck_schema.js';
|
||||
|
||||
import products_route from './products.js';
|
||||
import products_schema from './products_schema.js';
|
||||
|
||||
@ -28,6 +31,9 @@ Router.use('*', function (req, res, next) {
|
||||
Router.route('/user').get(user_route.get).post(user_route.post).patch(user_route.patch).delete(user_route.del);
|
||||
Router.route('/user/describe').get(user_schema);
|
||||
|
||||
Router.route('/user/codecheck').get(user_codecheck_route.get);
|
||||
Router.route('/user/codecheck/describe').get(user_codecheck_schema);
|
||||
|
||||
Router.route('/products').get(products_route.get).post(products_route.post).patch(products_route.patch).delete(products_route.del);
|
||||
Router.route('/products/describe').get(products_schema);
|
||||
|
||||
|
@ -95,7 +95,7 @@ async function post(req: Request, res: Response) {
|
||||
.create({
|
||||
data: {
|
||||
name: value.name,
|
||||
code: (value.code === '0000') ? null : value.code
|
||||
code: value.code === '0000' ? null : value.code
|
||||
},
|
||||
select: {
|
||||
id: true
|
||||
@ -125,7 +125,7 @@ async function patch(req: Request, res: Response) {
|
||||
},
|
||||
data: {
|
||||
name: value.name,
|
||||
code: (value.code === '0000') ? null : value.code
|
||||
code: value.code === '0000' ? null : value.code
|
||||
},
|
||||
select: {
|
||||
id: true
|
||||
@ -156,7 +156,8 @@ async function del(req: Request, res: Response) {
|
||||
})
|
||||
.then((result) => {
|
||||
res.status(200).json({ status: 'DELETED', message: 'Successfully deleted user', id: result.id });
|
||||
}).catch((err) => {
|
||||
})
|
||||
.catch((err) => {
|
||||
handlePrismaError(err, res, 'DEL user');
|
||||
});
|
||||
}
|
||||
|
34
src/routes/api/v1/user_codecheck.ts
Normal file
34
src/routes/api/v1/user_codecheck.ts
Normal file
@ -0,0 +1,34 @@
|
||||
import { Request, Response } from 'express';
|
||||
import db, { handlePrismaError } from '../../../handlers/db.js'; // Database
|
||||
import log from '../../../handlers/log.js';
|
||||
import { schema_get } from './user_codecheck_schema.js';
|
||||
|
||||
// MARK: GET check user code
|
||||
async function get(req: Request, res: Response) {
|
||||
const { error, value } = schema_get.validate(req.query);
|
||||
if (error) {
|
||||
log.api?.debug('GET check user code Error:', req.query, value, error.details[0].message);
|
||||
res.status(400).json({ status: 'ERROR', errorcode: 'VALIDATION_ERROR', message: error.details[0].message });
|
||||
} else {
|
||||
log.api?.debug('GET check user code Success:', req.query, value);
|
||||
|
||||
await db.user
|
||||
.findUnique({
|
||||
where: {
|
||||
id: value.id
|
||||
}
|
||||
})
|
||||
.catch((err) => {
|
||||
handlePrismaError(err, res, 'GET check user code');
|
||||
})
|
||||
.then((result) => {
|
||||
// user has no code OR code must match
|
||||
res.status(200).json(result?.code === '' || value.code === result?.code);
|
||||
// log.api?.debug('result', result);
|
||||
});
|
||||
// res.status(200).json({ count, result });
|
||||
// res.status(404).json({ status: 'ERROR', errorcode: 'NOT_FOUND', message: 'Could not find specified object' });
|
||||
}
|
||||
}
|
||||
|
||||
export default { get };
|
32
src/routes/api/v1/user_codecheck_schema.ts
Normal file
32
src/routes/api/v1/user_codecheck_schema.ts
Normal file
@ -0,0 +1,32 @@
|
||||
import { Request, Response } from 'express';
|
||||
import validator from 'joi'; // DOCS: https://joi.dev/api
|
||||
|
||||
// MARK: GET check user code
|
||||
const schema_get = validator.object({
|
||||
id: validator.number().positive().precision(0).required(),
|
||||
code: validator
|
||||
.string()
|
||||
.min(4)
|
||||
.max(4)
|
||||
.trim()
|
||||
.regex(new RegExp(/^[0-9]+$/))
|
||||
.required()
|
||||
});
|
||||
|
||||
// Describe all schemas
|
||||
const schema_get_desc = schema_get.describe();
|
||||
// const schema_post_desc = schema_post.describe();
|
||||
// const schema_patch_desc = schema_patch.describe();
|
||||
// const schema_del_desc = schema_del.describe();
|
||||
|
||||
// GET route
|
||||
export default async function get(req: Request, res: Response) {
|
||||
res.status(200).json({
|
||||
GET: schema_get_desc
|
||||
// POST: schema_post_desc,
|
||||
// PATCH: schema_patch_desc,
|
||||
// DELETE: schema_del_desc
|
||||
});
|
||||
}
|
||||
|
||||
export { schema_get }; //, schema_post, schema_patch, schema_del };
|
@ -1,8 +1,7 @@
|
||||
import express from 'express';
|
||||
import path from 'node:path';
|
||||
import __path from "../handlers/path.js";
|
||||
import log from "../handlers/log.js";
|
||||
|
||||
import __path from '../handlers/path.js';
|
||||
import log from '../handlers/log.js';
|
||||
|
||||
// Route imports
|
||||
import frontend_routes from './frontend/index.js';
|
||||
@ -12,7 +11,7 @@ const Router = express.Router({ strict: false });
|
||||
|
||||
// static / libs routes
|
||||
Router.use('/static', express.static(__path + '/static'));
|
||||
Router.use('/libs/bulma', express.static(path.join(__path, 'node_modules', 'bulma', 'css'))); // http://192.168.221.10:3000/libs/bulma/bulma.css
|
||||
Router.use('/libs/bulma', express.static(path.join(__path, 'node_modules', 'bulma', 'css'))); // /libs/bulma/bulma.css
|
||||
Router.use('/libs/jquery', express.static(path.join(__path, 'node_modules', 'jquery', 'dist')));
|
||||
Router.use('/libs/bootstrap-icons', express.static(path.join(__path, 'node_modules', 'bootstrap-icons')));
|
||||
|
||||
@ -20,7 +19,6 @@ Router.use('/libs/bootstrap-icons', express.static(path.join(__path, 'node_modul
|
||||
Router.use('/api', api_routes);
|
||||
Router.use('/', frontend_routes);
|
||||
|
||||
|
||||
// Default route.
|
||||
Router.all('*', function (req, res) {
|
||||
// TODO: Respond based on content-type (with req.is('application/json'))
|
||||
|
Loading…
x
Reference in New Issue
Block a user