- Finish cleanup

Signed-off-by: Dave Richer <dave@imexsystems.ca>
This commit is contained in:
Dave Richer
2024-01-22 23:00:31 -05:00
parent 82dc9e1c56
commit 2e7232bb65
27 changed files with 674 additions and 611 deletions

View File

@@ -51,6 +51,12 @@ app.use(bodyParser.json({limit: "50mb"}));
app.use(bodyParser.urlencoded({limit: "50mb", extended: true})); app.use(bodyParser.urlencoded({limit: "50mb", extended: true}));
app.use(cors({credentials: true, exposedHeaders: ["set-cookie"]})); app.use(cors({credentials: true, exposedHeaders: ["set-cookie"]}));
// Helper middleware
app.use((req, res, next) => {
req.logger = logger;
next();
});
// Route groupings // Route groupings
app.use('/', require("./server/routes/miscellaneousRoutes")); app.use('/', require("./server/routes/miscellaneousRoutes"));
app.use("/notifications", require("./server/routes/notificationsRoutes")); app.use("/notifications", require("./server/routes/notificationsRoutes"));

View File

@@ -211,7 +211,7 @@ async function logEmail(req, email) {
} }
} }
exports.emailBounce = async function (req, res, next) { exports.emailBounce = async function (req, res) {
try { try {
const body = JSON.parse(req.body); const body = JSON.parse(req.body);
if (body.Type === "SubscriptionConfirmation") { if (body.Type === "SubscriptionConfirmation") {

View File

@@ -1,7 +1,8 @@
var admin = require("firebase-admin"); const admin = require("firebase-admin");
const logger = require("../utils/logger"); const logger = require("../utils/logger");
const path = require("path"); const path = require("path");
const {auth} = require("firebase-admin"); const {auth} = require("firebase-admin");
require("dotenv").config({ require("dotenv").config({
path: path.resolve( path: path.resolve(
process.cwd(), process.cwd(),
@@ -9,7 +10,9 @@ require("dotenv").config({
), ),
}); });
const client = require("../graphql-client/graphql-client").client; const client = require("../graphql-client/graphql-client").client;
var serviceAccount = require(process.env.FIREBASE_ADMINSDK_JSON);
const serviceAccount = require(process.env.FIREBASE_ADMINSDK_JSON);
const adminEmail = require("../utils/adminEmail");
admin.initializeApp({ admin.initializeApp({
credential: admin.credential.cert(serviceAccount), credential: admin.credential.cert(serviceAccount),
@@ -18,14 +21,6 @@ admin.initializeApp({
exports.admin = admin; exports.admin = admin;
const adminEmail = [
"patrick@imex.dev",
//"patrick@imex.test",
"patrick@imex.prod",
"patrick@imexsystems.ca",
"patrick@thinkimex.com",
];
exports.createUser = async (req, res) => { exports.createUser = async (req, res) => {
logger.log("admin-create-user", "ADMIN", req.user.email, null, { logger.log("admin-create-user", "ADMIN", req.user.email, null, {
request: req.body, request: req.body,
@@ -215,73 +210,6 @@ exports.unsubscribe = async (req, res) => {
} }
}; };
exports.validateFirebaseIdToken = async (req, res, next) => {
if (
(!req.headers.authorization ||
!req.headers.authorization.startsWith("Bearer ")) &&
!(req.cookies && req.cookies.__session)
) {
console.error("Unauthorized attempt. No authorization provided.");
res.status(403).send("Unauthorized");
return;
}
let idToken;
if (
req.headers.authorization &&
req.headers.authorization.startsWith("Bearer ")
) {
// console.log('Found "Authorization" header');
// Read the ID Token from the Authorization header.
idToken = req.headers.authorization.split("Bearer ")[1];
} else if (req.cookies) {
//console.log('Found "__session" cookie');
// Read the ID Token from cookie.
idToken = req.cookies.__session;
} else {
// No cookie
console.error("Unauthorized attempt. No cookie provided.");
logger.log("api-unauthorized-call", "WARN", null, null, {
req,
type: "no-cookie",
});
res.status(403).send("Unauthorized");
return;
}
try {
const decodedIdToken = await admin.auth().verifyIdToken(idToken);
//console.log("ID Token correctly decoded", decodedIdToken);
req.user = decodedIdToken;
next();
return;
} catch (error) {
logger.log("api-unauthorized-call", "WARN", null, null, {
path: req.path,
body: req.body,
type: "unauthroized",
...error,
});
res.status(401).send("Unauthorized");
return;
}
};
exports.validateAdmin = async (req, res, next) => {
if (!adminEmail.includes(req.user.email) && !req.user.ioadmin) {
logger.log("admin-validation-failed", "ERROR", req.user.email, null, {
request: req.body,
user: req.user,
});
res.sendStatus(404);
return;
} else {
next();
return;
}
};
//Admin claims code. //Admin claims code.
// const uid = "JEqqYlsadwPEXIiyRBR55fflfko1"; // const uid = "JEqqYlsadwPEXIiyRBR55fflfko1";

View File

@@ -13,6 +13,7 @@ async function JobCosting(req, res) {
const { jobid } = req.body; const { jobid } = req.body;
const BearerToken = req.headers.authorization; const BearerToken = req.headers.authorization;
logger.log("job-costing-start", "DEBUG", req.user.email, jobid, null); logger.log("job-costing-start", "DEBUG", req.user.email, jobid, null);
const client = new GraphQLClient(process.env.GRAPHQL_ENDPOINT, { const client = new GraphQLClient(process.env.GRAPHQL_ENDPOINT, {
headers: { headers: {

View File

@@ -1,5 +1,17 @@
const _ = require("lodash");
const jobLifecycle = (req, res) => { const jobLifecycle = (req, res) => {
return res.status(200).send("jobLifecycle"); const {jobids} = req.body;
return _.isArray(jobids) ?
handleMultipleJobs(jobids, req, res) :
handleSingleJob(jobids, req, res);
}; };
const handleMultipleJobs = (jobIDs, req, res) => {
return res.status(200).send(jobIDs);
}
const handleSingleJob = (req, res) => {
return res.status(200).send(req.body);
}
module.exports = jobLifecycle; module.exports = jobLifecycle;

View File

@@ -9,20 +9,15 @@ const logger = require("../utils/logger");
Dinero.globalRoundingMode = "HALF_EVEN"; Dinero.globalRoundingMode = "HALF_EVEN";
const path = require("path"); const path = require("path");
const client = require("../graphql-client/graphql-client").client; const client = require("../graphql-client/graphql-client").client;
require("dotenv").config({ require("dotenv").config({
path: path.resolve( path: path.resolve(
process.cwd(), process.cwd(),
`.env.${process.env.NODE_ENV || "development"}` `.env.${process.env.NODE_ENV || "development"}`
), ),
}); });
async function StatusTransition(req, res) { async function StatusTransition(req, res) {
if (req.headers["event-secret"] !== process.env.EVENT_SECRET) {
res.status(401).send("Unauthorized");
return;
}
// return res.sendStatus(200);
const { const {
id: jobid, id: jobid,
status: value, status: value,

View File

@@ -0,0 +1,15 @@
/**
* Checks if the event secret is correct
* @param req
* @param res
* @param next
*/
function eventAuthorizationMiddleware(req, res, next) {
if (req.headers["event-secret"] !== process.env.EVENT_SECRET) {
return res.status(401).send("Unauthorized");
}
next();
}
module.exports = eventAuthorizationMiddleware;

View File

@@ -0,0 +1,15 @@
const logger = require("../utils/logger");
const adminEmail = require("../utils/adminEmail");
const validateAdminMiddleware = (req, res, next) => {
if (!adminEmail.includes(req.user.email) && !req.user.ioadmin) {
logger.log("admin-validation-failed", "ERROR", req.user.email, null, {
request: req.body,
user: req.user,
});
return res.sendStatus(404);
}
next();
};
module.exports = validateAdminMiddleware;

View File

@@ -0,0 +1,59 @@
const logger = require("../utils/logger");
const admin = require("firebase-admin");
const validateFirebaseIdTokenMiddleware = async (req, res, next) => {
if (
(!req.headers.authorization ||
!req.headers.authorization.startsWith("Bearer ")) &&
!(req.cookies && req.cookies.__session)
) {
console.error("Unauthorized attempt. No authorization provided.");
res.status(403).send("Unauthorized");
return;
}
let idToken;
if (
req.headers.authorization &&
req.headers.authorization.startsWith("Bearer ")
) {
// console.log('Found "Authorization" header');
// Read the ID Token from the Authorization header.
idToken = req.headers.authorization.split("Bearer ")[1];
} else if (req.cookies) {
//console.log('Found "__session" cookie');
// Read the ID Token from cookie.
idToken = req.cookies.__session;
} else {
// No cookie
console.error("Unauthorized attempt. No cookie provided.");
logger.log("api-unauthorized-call", "WARN", null, null, {
req,
type: "no-cookie",
});
res.status(403).send("Unauthorized");
return;
}
try {
const decodedIdToken = await admin.auth().verifyIdToken(idToken);
//console.log("ID Token correctly decoded", decodedIdToken);
req.user = decodedIdToken;
next();
} catch (error) {
logger.log("api-unauthorized-call", "WARN", null, null, {
path: req.path,
body: req.body,
type: "unauthroized",
...error,
});
res.status(401).send("Unauthorized");
}
};
module.exports = validateFirebaseIdTokenMiddleware;

View File

@@ -15,10 +15,6 @@ const {getClient} = require('../../libs/awsUtils');
async function OpenSearchUpdateHandler(req, res) { async function OpenSearchUpdateHandler(req, res) {
if (req.headers["event-secret"] !== process.env.EVENT_SECRET) {
res.status(401).send("Unauthorized");
return;
}
try { try {
const osClient = await getClient(); const osClient = await getClient();

View File

@@ -1,10 +1,12 @@
const express = require('express'); const express = require('express');
const router = express.Router(); const router = express.Router();
const fb = require('../firebase/firebase-handler'); const validateFirebaseIdTokenMiddleware = require("../middleware/validateFirebaseIdTokenMiddleware");
const accountQbxml = require('../accounting/qbxml/qbxml'); const {payments, payables, receivables} = require("../accounting/qbxml/qbxml");
router.post('/qbxml/receivables', fb.validateFirebaseIdToken, accountQbxml.receivables); router.use(validateFirebaseIdTokenMiddleware);
router.post('/qbxml/payables', fb.validateFirebaseIdToken, accountQbxml.payables);
router.post('/qbxml/payments', fb.validateFirebaseIdToken, accountQbxml.payments); router.post('/qbxml/receivables', receivables);
router.post('/qbxml/payables', payables);
router.post('/qbxml/payments', payments);
module.exports = router; module.exports = router;

View File

@@ -1,15 +1,18 @@
const express = require('express'); const express = require('express');
const router = express.Router(); const router = express.Router();
const fb = require('../firebase/firebase-handler'); const fb = require('../firebase/firebase-handler');
const adm = require('../admin/adminops'); const validateFirebaseIdTokenMiddleware = require("../middleware/validateFirebaseIdTokenMiddleware");
const {createAssociation, createShop, updateShop, updateCounter} = require("../admin/adminops");
const validateAdminMiddleware = require("../middleware/validateAdminMiddleware");
router.use(validateFirebaseIdTokenMiddleware);
router.post('/createassociation', fb.validateFirebaseIdToken, fb.validateAdmin, adm.createAssociation); router.post('/createassociation', validateAdminMiddleware, createAssociation);
router.post('/createshop', fb.validateFirebaseIdToken, fb.validateAdmin, adm.createShop); router.post('/createshop', validateAdminMiddleware, createShop);
router.post('/updateshop', fb.validateFirebaseIdToken, fb.validateAdmin, adm.updateShop); router.post('/updateshop', validateAdminMiddleware, updateShop);
router.post('/updatecounter', fb.validateFirebaseIdToken, fb.validateAdmin, adm.updateCounter); router.post('/updatecounter', validateAdminMiddleware, updateCounter);
router.post('/updateuser', fb.validateFirebaseIdToken, fb.updateUser); router.post('/updateuser', fb.updateUser);
router.post('/getuser', fb.validateFirebaseIdToken, fb.getUser); router.post('/getuser', fb.getUser);
router.post('/createuser', fb.validateFirebaseIdToken, fb.createUser); router.post('/createuser', fb.createUser);
module.exports = router; module.exports = router;

View File

@@ -1,8 +1,10 @@
const express = require('express'); const express = require('express');
const router = express.Router(); const router = express.Router();
const fb = require('../firebase/firebase-handler');
const cdkGetMake = require('../cdk/cdk-get-makes'); const cdkGetMake = require('../cdk/cdk-get-makes');
const validateFirebaseIdTokenMiddleware = require("../middleware/validateFirebaseIdTokenMiddleware");
router.post('/getvehicles', fb.validateFirebaseIdToken, cdkGetMake.default); router.use(validateFirebaseIdTokenMiddleware);
router.post('/getvehicles', cdkGetMake.default);
module.exports = router; module.exports = router;

View File

@@ -1,9 +1,9 @@
const express = require('express'); const express = require('express');
const router = express.Router(); const router = express.Router();
const data = require('../data/data'); const {autohouse, claimscorp, kaizen} = require('../data/data');
router.post('/ah', data.autohouse); router.post('/ah', autohouse);
router.post('/cc', data.claimscorp); router.post('/cc', claimscorp);
router.post('/kaizen', data.kaizen); router.post('/kaizen', kaizen);
module.exports = router; module.exports = router;

View File

@@ -1,11 +1,11 @@
const express = require('express'); const express = require('express');
const router = express.Router(); const router = express.Router();
const fb = require('../firebase/firebase-handler'); const validateFirebaseIdTokenMiddleware = require("../middleware/validateFirebaseIdTokenMiddleware");
const intellipay = require('../intellipay/intellipay'); const {lightbox_credentials, payment_refund, generate_payment_url, postback} = require("../intellipay/intellipay");
router.post('/lightbox_credentials', fb.validateFirebaseIdToken, intellipay.lightbox_credentials); router.post('/lightbox_credentials', validateFirebaseIdTokenMiddleware, lightbox_credentials);
router.post('/payment_refund', fb.validateFirebaseIdToken, intellipay.payment_refund); router.post('/payment_refund', validateFirebaseIdTokenMiddleware, payment_refund);
router.post('/generate_payment_url', fb.validateFirebaseIdToken, intellipay.generate_payment_url); router.post('/generate_payment_url', validateFirebaseIdTokenMiddleware, generate_payment_url);
router.post('/postback', intellipay.postback); router.post('/postback', postback);
module.exports = router; module.exports = router;

View File

@@ -1,15 +1,19 @@
const express = require('express'); const express = require('express');
const router = express.Router(); const router = express.Router();
const fb = require('../firebase/firebase-handler');
const job = require('../job/job'); const job = require('../job/job');
const partsScan = require('../parts-scan/parts-scan'); const {partsScan} = require('../parts-scan/parts-scan');
const eventAuthorizationMiddleware = require('../middleware/eventAuthorizationMIddleware');
const validateFirebaseIdTokenMiddleware = require("../middleware/validateFirebaseIdTokenMiddleware");
const {totals, statustransition, totalsSsu, costing, lifecycle, costingmulti} = require("../job/job");
router.post('/totals', fb.validateFirebaseIdToken, job.totals); router.use(validateFirebaseIdTokenMiddleware);
router.post('/statustransition', fb.validateFirebaseIdToken, job.statustransition);
router.post('/totalsssu', fb.validateFirebaseIdToken, job.totalsSsu); router.post('/totals', totals);
router.post('/costing', fb.validateFirebaseIdToken, job.costing); router.post('/statustransition', eventAuthorizationMiddleware, statustransition);
router.get('/lifecycle', fb.validateFirebaseIdToken, job.lifecycle); router.post('/totalsssu', totalsSsu);
router.post('/costingmulti', fb.validateFirebaseIdToken, job.costingmulti); router.post('/costing', costing);
router.post('/partsscan', fb.validateFirebaseIdToken, partsScan.partsScan); router.get('/lifecycle', lifecycle);
router.post('/costingmulti', costingmulti);
router.post('/partsscan', partsScan);
module.exports = router; module.exports = router;

View File

@@ -1,11 +1,13 @@
const express = require('express'); const express = require('express');
const router = express.Router(); const router = express.Router();
const fb = require('../firebase/firebase-handler'); const {createSignedUploadURL, downloadFiles, renameKeys, deleteFiles} = require('../media/media');
const media = require('../media/media'); const validateFirebaseIdTokenMiddleware = require("../middleware/validateFirebaseIdTokenMiddleware");
router.post('/sign', fb.validateFirebaseIdToken, media.createSignedUploadURL); router.use(validateFirebaseIdTokenMiddleware);
router.post('/download', fb.validateFirebaseIdToken, media.downloadFiles);
router.post('/rename', fb.validateFirebaseIdToken, media.renameKeys); router.post('/sign', createSignedUploadURL);
router.post('/delete', fb.validateFirebaseIdToken, media.deleteFiles); router.post('/download', downloadFiles);
router.post('/rename', renameKeys);
router.post('/delete', deleteFiles);
module.exports = router; module.exports = router;

View File

@@ -3,11 +3,12 @@ const router = express.Router();
const logger = require("../../server/utils/logger"); const logger = require("../../server/utils/logger");
const sendEmail = require("../email/sendemail"); const sendEmail = require("../email/sendemail");
const data = require("../data/data"); const data = require("../data/data");
const fb = require("../firebase/firebase-handler");
const bodyParser = require("body-parser"); const bodyParser = require("body-parser");
const ioevent = require("../ioevent/ioevent"); const ioevent = require("../ioevent/ioevent");
const taskHandler = require("../tasks/tasks"); const taskHandler = require("../tasks/tasks");
const os = require("../opensearch/os-handler"); const os = require("../opensearch/os-handler");
const eventAuthorizationMiddleware = require("../middleware/eventAuthorizationMIddleware");
const validateFirebaseIdTokenMiddleware = require("../middleware/validateFirebaseIdTokenMiddleware");
//Test route to ensure Express is responding. //Test route to ensure Express is responding.
router.get("/test", async function (req, res) { router.get("/test", async function (req, res) {
@@ -29,15 +30,21 @@ router.get("/test", async function (req, res) {
res.status(200).send(`OK - ${commit}`); res.status(200).send(`OK - ${commit}`);
}); });
router.post("/search", fb.validateFirebaseIdToken, os.search); // Search
router.post("/opensearch", os.handler); router.post("/search", validateFirebaseIdTokenMiddleware, os.search);
router.post("/opensearch", eventAuthorizationMiddleware, os.handler);
// IO Events
router.post('/ioevent', ioevent.default); router.post('/ioevent', ioevent.default);
router.post('/sendemail', fb.validateFirebaseIdToken, sendEmail.sendEmail);
// Email
router.post('/sendemail', validateFirebaseIdTokenMiddleware, sendEmail.sendEmail);
router.post('/emailbounce', bodyParser.text(), sendEmail.emailBounce); router.post('/emailbounce', bodyParser.text(), sendEmail.emailBounce);
// Handlers
router.post('/record-handler/arms', data.arms); router.post('/record-handler/arms', data.arms);
router.post("/taskHandler", fb.validateFirebaseIdToken, taskHandler.taskHandler); router.post("/taskHandler", validateFirebaseIdTokenMiddleware, taskHandler.taskHandler);
module.exports = router; module.exports = router;

View File

@@ -2,9 +2,9 @@ const express = require('express');
const router = express.Router(); const router = express.Router();
const multer = require('multer'); const multer = require('multer');
const upload = multer(); const upload = multer();
const fb = require('../firebase/firebase-handler'); const {mixdataUpload} = require('../mixdata/mixdata');
const mixdataUpload = require('../mixdata/mixdata'); const validateFirebaseIdTokenMiddleware = require("../middleware/validateFirebaseIdTokenMiddleware");
router.post('/upload', fb.validateFirebaseIdToken, upload.any(), mixdataUpload.mixdataUpload); router.post('/upload', validateFirebaseIdTokenMiddleware, upload.any(), mixdataUpload);
module.exports = router; module.exports = router;

View File

@@ -1,8 +1,11 @@
const express = require('express'); const express = require('express');
const validateFirebaseIdTokenMiddleware = require("../middleware/validateFirebaseIdTokenMiddleware");
const {subscribe, unsubscribe} = require("../firebase/firebase-handler");
const router = express.Router(); const router = express.Router();
const fb = require('../firebase/firebase-handler');
router.post('/subscribe', fb.validateFirebaseIdToken, fb.subscribe); router.use(validateFirebaseIdTokenMiddleware);
router.post('/unsubscribe', fb.validateFirebaseIdToken, fb.unsubscribe);
router.post('/subscribe', subscribe);
router.post('/unsubscribe', unsubscribe);
module.exports = router; module.exports = router;

View File

@@ -1,13 +1,13 @@
const express = require('express'); const express = require('express');
const router = express.Router(); const router = express.Router();
const fb = require('../firebase/firebase-handler'); const {authorize, callback, receivables, payables, payments} = require('../accounting/qbo/qbo');
const qbo = require('../accounting/qbo/qbo'); // Assuming you have a qbo module for handling QuickBooks Online related functionalities const validateFirebaseIdTokenMiddleware = require("../middleware/validateFirebaseIdTokenMiddleware"); // Assuming you have a qbo module for handling QuickBooks Online related functionalities
// Define the routes for QuickBooks Online // Define the routes for QuickBooks Online
router.post('/authorize', fb.validateFirebaseIdToken, qbo.authorize); router.post('/authorize', validateFirebaseIdTokenMiddleware, authorize);
router.get('/callback', qbo.callback); router.get('/callback', callback);
router.post('/receivables', fb.validateFirebaseIdToken, qbo.receivables); router.post('/receivables', validateFirebaseIdTokenMiddleware, receivables);
router.post('/payables', fb.validateFirebaseIdToken, qbo.payables); router.post('/payables', validateFirebaseIdTokenMiddleware, payables);
router.post('/payments', fb.validateFirebaseIdToken, qbo.payments); router.post('/payments', validateFirebaseIdTokenMiddleware, payments);
module.exports = router; module.exports = router;

View File

@@ -1,9 +1,9 @@
const express = require('express'); const express = require('express');
const router = express.Router(); const router = express.Router();
const fb = require('../firebase/firebase-handler'); const {inlinecss} = require('../render/inlinecss');
const inlineCss = require('../render/inlinecss'); const validateFirebaseIdTokenMiddleware = require("../middleware/validateFirebaseIdTokenMiddleware");
// Define the route for inline CSS rendering // Define the route for inline CSS rendering
router.post('/inlinecss', fb.validateFirebaseIdToken, inlineCss.inlinecss); router.post('/inlinecss', validateFirebaseIdTokenMiddleware, inlinecss);
module.exports = router; module.exports = router;

View File

@@ -1,8 +1,8 @@
const express = require('express'); const express = require('express');
const router = express.Router(); const router = express.Router();
const fb = require('../firebase/firebase-handler'); const {job} = require('../scheduling/scheduling-job');
const scheduling = require('../scheduling/scheduling-job'); const validateFirebaseIdTokenMiddleware = require("../middleware/validateFirebaseIdTokenMiddleware");
router.post('/job', fb.validateFirebaseIdToken, scheduling.job); router.post('/job', validateFirebaseIdTokenMiddleware, job);
module.exports = router; module.exports = router;

View File

@@ -1,17 +1,17 @@
const express = require('express'); const express = require('express');
const router = express.Router(); const router = express.Router();
const twilio = require('twilio'); const twilio = require('twilio');
const fb = require('../firebase/firebase-handler'); const {receive} = require('../sms/receive');
const smsReceive = require('../sms/receive'); const {send} = require('../sms/send');
const smsSend = require('../sms/send'); const {status, markConversationRead} = require('../sms/status');
const smsStatus = require('../sms/status'); const validateFirebaseIdTokenMiddleware = require("../middleware/validateFirebaseIdTokenMiddleware");
// Twilio Webhook Middleware for production // Twilio Webhook Middleware for production
const twilioWebhookMiddleware = twilio.webhook({ validate: process.env.NODE_ENV === "PRODUCTION" }); const twilioWebhookMiddleware = twilio.webhook({ validate: process.env.NODE_ENV === "PRODUCTION" });
router.post('/receive', twilioWebhookMiddleware, smsReceive.receive); router.post('/receive', twilioWebhookMiddleware, receive);
router.post('/send', fb.validateFirebaseIdToken, smsSend.send); router.post('/send', validateFirebaseIdTokenMiddleware, send);
router.post('/status', twilioWebhookMiddleware, smsStatus.status); router.post('/status', twilioWebhookMiddleware, status);
router.post('/markConversationRead', fb.validateFirebaseIdToken, smsStatus.markConversationRead); router.post('/markConversationRead', validateFirebaseIdTokenMiddleware, markConversationRead);
module.exports = router; module.exports = router;

View File

@@ -1,8 +1,8 @@
const express = require('express'); const express = require('express');
const router = express.Router(); const router = express.Router();
const fb = require('../firebase/firebase-handler'); const {techLogin} = require('../tech/tech');
const tech = require('../tech/tech'); const validateFirebaseIdTokenMiddleware = require("../middleware/validateFirebaseIdTokenMiddleware");
router.post('/login', fb.validateFirebaseIdToken, tech.techLogin); router.post('/login', validateFirebaseIdTokenMiddleware, techLogin);
module.exports = router; module.exports = router;

View File

@@ -1,9 +1,9 @@
const express = require('express'); const express = require('express');
const router = express.Router(); const router = express.Router();
const fb = require('../firebase/firebase-handler'); const {servertime, jsrAuth} = require('../utils/utils');
const utils = require('../utils/utils'); const validateFirebaseIdTokenMiddleware = require("../middleware/validateFirebaseIdTokenMiddleware");
router.post('/time', utils.servertime); router.post('/time', servertime);
router.post('/jsr', fb.validateFirebaseIdToken, utils.jsrAuth); router.post('/jsr', validateFirebaseIdTokenMiddleware, jsrAuth);
module.exports = router; module.exports = router;

View File

@@ -0,0 +1,13 @@
/**
* List of admin email addresses
* @type {string[]}
*/
const adminEmail = [
"patrick@imex.dev",
//"patrick@imex.test",
"patrick@imex.prod",
"patrick@imexsystems.ca",
"patrick@thinkimex.com",
];
module.exports = adminEmail;