- 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(cors({credentials: true, exposedHeaders: ["set-cookie"]}));
// Helper middleware
app.use((req, res, next) => {
req.logger = logger;
next();
});
// Route groupings
app.use('/', require("./server/routes/miscellaneousRoutes"));
app.use("/notifications", require("./server/routes/notificationsRoutes"));
@@ -85,4 +91,4 @@ main()
})
.catch((error) => {
logger.log(`[${process.env.NODE_ENV || "DEVELOPMENT"}] Server failed to start on port ${port}`, "ERROR", "api", error);
});
});

View File

@@ -8,7 +8,7 @@ require("dotenv").config({
const axios = require("axios");
let nodemailer = require("nodemailer");
let aws = require("@aws-sdk/client-ses");
let { defaultProvider } = require("@aws-sdk/credential-provider-node");
let {defaultProvider} = require("@aws-sdk/credential-provider-node");
const logger = require("../utils/logger");
const client = require("../graphql-client/graphql-client").client;
@@ -23,10 +23,10 @@ const ses = new aws.SES({
});
let transporter = nodemailer.createTransport({
SES: { ses, aws },
SES: {ses, aws},
});
exports.sendServerEmail = async function ({ subject, text }) {
exports.sendServerEmail = async function ({subject, text}) {
if (process.env.NODE_ENV === undefined) return;
try {
transporter.sendMail(
@@ -54,7 +54,7 @@ exports.sendServerEmail = async function ({ subject, text }) {
logger.log("server-email-failure", "error", null, null, error);
}
};
exports.sendTaskEmail = async function ({ to, subject, text, attachments }) {
exports.sendTaskEmail = async function ({to, subject, text, attachments}) {
try {
transporter.sendMail(
{
@@ -172,14 +172,14 @@ exports.sendEmail = async (req, res) => {
subject: req.body.subject,
bodyshopid: req.body.bodyshopid,
});
res.status(500).json({ success: false, error: err });
res.status(500).json({success: false, error: err});
}
}
);
};
async function getImage(imageUrl) {
let image = await axios.get(imageUrl, { responseType: "arraybuffer" });
let image = await axios.get(imageUrl, {responseType: "arraybuffer"});
let raw = Buffer.from(image.data).toString("base64");
return "data:" + image.headers["content-type"] + ";base64," + raw;
}
@@ -211,7 +211,7 @@ async function logEmail(req, email) {
}
}
exports.emailBounce = async function (req, res, next) {
exports.emailBounce = async function (req, res) {
try {
const body = JSON.parse(req.body);
if (body.Type === "SubscriptionConfirmation") {
@@ -252,7 +252,7 @@ ${body.bounce?.bouncedRecipients.map(
(r) =>
`Recipient: ${r.emailAddress} | Status: ${r.action} | Code: ${r.diagnosticCode}
`
)}
)}
`,
},
(err, info) => {

View File

@@ -1,7 +1,8 @@
var admin = require("firebase-admin");
const admin = require("firebase-admin");
const logger = require("../utils/logger");
const path = require("path");
const { auth } = require("firebase-admin");
const {auth} = require("firebase-admin");
require("dotenv").config({
path: path.resolve(
process.cwd(),
@@ -9,7 +10,9 @@ require("dotenv").config({
),
});
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({
credential: admin.credential.cert(serviceAccount),
@@ -18,25 +21,17 @@ admin.initializeApp({
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) => {
logger.log("admin-create-user", "ADMIN", req.user.email, null, {
request: req.body,
ioadmin: true,
});
const { email, displayName, password, shopid, authlevel } = req.body;
const {email, displayName, password, shopid, authlevel} = req.body;
try {
const userRecord = await admin
.auth()
.createUser({ email, displayName, password });
.createUser({email, displayName, password});
// See the UserRecord reference doc for the contents of userRecord.
@@ -53,13 +48,13 @@ exports.createUser = async (req, res) => {
email: email.toLowerCase(),
authid: userRecord.uid,
associations: {
data: [{ shopid, authlevel, active: true }],
data: [{shopid, authlevel, active: true}],
},
},
}
);
res.json({ userRecord, result });
res.json({userRecord, result});
} catch (error) {
logger.log("admin-update-user-error", "ERROR", req.user.email, null, {
error,
@@ -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.
// const uid = "JEqqYlsadwPEXIiyRBR55fflfko1";

View File

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

View File

@@ -1,5 +1,17 @@
const _ = require("lodash");
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;

View File

@@ -9,20 +9,15 @@ const logger = require("../utils/logger");
Dinero.globalRoundingMode = "HALF_EVEN";
const path = require("path");
const client = require("../graphql-client/graphql-client").client;
require("dotenv").config({
path: path.resolve(
process.cwd(),
`.env.${process.env.NODE_ENV || "development"}`
),
});
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 {
id: jobid,
status: value,
@@ -34,7 +29,7 @@ async function StatusTransition(req, res) {
// (Timeline)
// Final status is exported, there is no end date as there is no further transition (has no end date)
try {
const { update_transitions } = await client.request(
const {update_transitions} = await client.request(
queries.UPDATE_OLD_TRANSITION,
{
jobid: jobid,

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) {
if (req.headers["event-secret"] !== process.env.EVENT_SECRET) {
res.status(401).send("Unauthorized");
return;
}
try {
const osClient = await getClient();

View File

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

View File

@@ -1,15 +1,18 @@
const express = require('express');
const router = express.Router();
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('/createshop', fb.validateFirebaseIdToken, fb.validateAdmin, adm.createShop);
router.post('/updateshop', fb.validateFirebaseIdToken, fb.validateAdmin, adm.updateShop);
router.post('/updatecounter', fb.validateFirebaseIdToken, fb.validateAdmin, adm.updateCounter);
router.post('/updateuser', fb.validateFirebaseIdToken, fb.updateUser);
router.post('/getuser', fb.validateFirebaseIdToken, fb.getUser);
router.post('/createuser', fb.validateFirebaseIdToken, fb.createUser);
router.post('/createassociation', validateAdminMiddleware, createAssociation);
router.post('/createshop', validateAdminMiddleware, createShop);
router.post('/updateshop', validateAdminMiddleware, updateShop);
router.post('/updatecounter', validateAdminMiddleware, updateCounter);
router.post('/updateuser', fb.updateUser);
router.post('/getuser', fb.getUser);
router.post('/createuser', fb.createUser);
module.exports = router;

View File

@@ -1,8 +1,10 @@
const express = require('express');
const router = express.Router();
const fb = require('../firebase/firebase-handler');
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;

View File

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

View File

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

View File

@@ -1,15 +1,19 @@
const express = require('express');
const router = express.Router();
const fb = require('../firebase/firebase-handler');
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.post('/statustransition', fb.validateFirebaseIdToken, job.statustransition);
router.post('/totalsssu', fb.validateFirebaseIdToken, job.totalsSsu);
router.post('/costing', fb.validateFirebaseIdToken, job.costing);
router.get('/lifecycle', fb.validateFirebaseIdToken, job.lifecycle);
router.post('/costingmulti', fb.validateFirebaseIdToken, job.costingmulti);
router.post('/partsscan', fb.validateFirebaseIdToken, partsScan.partsScan);
router.use(validateFirebaseIdTokenMiddleware);
router.post('/totals', totals);
router.post('/statustransition', eventAuthorizationMiddleware, statustransition);
router.post('/totalsssu', totalsSsu);
router.post('/costing', costing);
router.get('/lifecycle', lifecycle);
router.post('/costingmulti', costingmulti);
router.post('/partsscan', partsScan);
module.exports = router;

View File

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

View File

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

View File

@@ -2,9 +2,9 @@ const express = require('express');
const router = express.Router();
const multer = require('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;

View File

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

View File

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

View File

@@ -1,9 +1,9 @@
const express = require('express');
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
router.post('/inlinecss', fb.validateFirebaseIdToken, inlineCss.inlinecss);
router.post('/inlinecss', validateFirebaseIdTokenMiddleware, inlinecss);
module.exports = router;

View File

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

View File

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

View File

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

View File

@@ -1,9 +1,9 @@
const express = require('express');
const router = express.Router();
const fb = require('../firebase/firebase-handler');
const utils = require('../utils/utils');
const {servertime, jsrAuth} = require('../utils/utils');
const validateFirebaseIdTokenMiddleware = require("../middleware/validateFirebaseIdTokenMiddleware");
router.post('/time', utils.servertime);
router.post('/jsr', fb.validateFirebaseIdToken, utils.jsrAuth);
router.post('/time', servertime);
router.post('/jsr', validateFirebaseIdTokenMiddleware, jsrAuth);
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;