@@ -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"));
|
||||||
|
|||||||
@@ -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") {
|
||||||
|
|||||||
@@ -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";
|
||||||
|
|||||||
@@ -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: {
|
||||||
|
|||||||
@@ -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;
|
||||||
@@ -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,
|
||||||
|
|||||||
15
server/middleware/eventAuthorizationMIddleware.js
Normal file
15
server/middleware/eventAuthorizationMIddleware.js
Normal 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;
|
||||||
15
server/middleware/validateAdminMiddleware.js
Normal file
15
server/middleware/validateAdminMiddleware.js
Normal 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;
|
||||||
59
server/middleware/validateFirebaseIdTokenMiddleware.js
Normal file
59
server/middleware/validateFirebaseIdTokenMiddleware.js
Normal 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;
|
||||||
@@ -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();
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
13
server/utils/adminEmail.js
Normal file
13
server/utils/adminEmail.js
Normal 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;
|
||||||
Reference in New Issue
Block a user