"use strict"; (() => { var exports = {}; exports.id = 5402; exports.ids = [5402]; exports.modules = { /***/ 2029: /***/ ((module) => { module.exports = require("datasquirel/functions/hashPassword"); /***/ }), /***/ 6517: /***/ ((module) => { module.exports = require("lodash"); /***/ }), /***/ 5184: /***/ ((module) => { module.exports = require("nodemailer"); /***/ }), /***/ 6109: /***/ ((module) => { module.exports = require("sanitize-html"); /***/ }), /***/ 2261: /***/ ((module) => { module.exports = require("serverless-mysql"); /***/ }), /***/ 4300: /***/ ((module) => { module.exports = require("buffer"); /***/ }), /***/ 6113: /***/ ((module) => { module.exports = require("crypto"); /***/ }), /***/ 7147: /***/ ((module) => { module.exports = require("fs"); /***/ }), /***/ 3685: /***/ ((module) => { module.exports = require("http"); /***/ }), /***/ 1017: /***/ ((module) => { module.exports = require("path"); /***/ }), /***/ 9210: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (/* binding */ handler) /* harmony export */ }); /* harmony import */ var _functions_backend_handleNodemailer__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6926); /* harmony import */ var _functions_backend_handleNodemailer__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_functions_backend_handleNodemailer__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var datasquirel_functions_hashPassword__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(2029); /* harmony import */ var datasquirel_functions_hashPassword__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(datasquirel_functions_hashPassword__WEBPACK_IMPORTED_MODULE_1__); /* harmony import */ var _functions_backend_userAuth__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(6825); /* harmony import */ var _functions_backend_userAuth__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_functions_backend_userAuth__WEBPACK_IMPORTED_MODULE_2__); /* harmony import */ var _package_shared_functions_backend_db_addDbEntry__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(5338); /* harmony import */ var _package_shared_functions_backend_db_addDbEntry__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_package_shared_functions_backend_db_addDbEntry__WEBPACK_IMPORTED_MODULE_3__); /* harmony import */ var _package_shared_utils_backend_global_db_DB_HANDLER__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(2224); /* harmony import */ var _package_shared_utils_backend_global_db_DB_HANDLER__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_package_shared_utils_backend_global_db_DB_HANDLER__WEBPACK_IMPORTED_MODULE_4__); // @ts-check /** * ============================================================================== * Imports * ============================================================================== */ /** ****************************************************************************** */ /** ****************************************************************************** */ /** ****************************************************************************** */ /** ****************************************************************************** */ /** ****************************************************************************** */ /** ****************************************************************************** */ /** * API handler * ============================================================================== * @type {import("next").NextApiHandler} */ async function handler(req, res) { /** * Check method * * @description Check request method and return if invalid */ if (req.method !== "POST") return res.json({ msg: "Failed!" }); /** * User auth * * @description Authenticate user */ const user = await _functions_backend_userAuth__WEBPACK_IMPORTED_MODULE_2___default()(req, res, true); if (!user) { return res.json({ success: false, msg: "Unauthorized" }); } /** * User auth * * @description Authenticate user */ // const sanitizedReqBody = sanitizeSql(req.body); const sanitizedReqBody = req.body; const paradigm = sanitizedReqBody.paradigm; /** * Input Validation * * @description Input Validation */ if (paradigm?.match(/database/)) { const newUser = await _package_shared_functions_backend_db_addDbEntry__WEBPACK_IMPORTED_MODULE_3___default()({ dbFullName: "datasquirel", tableName: "user_users", data: (()=>{ const reqBodyKeys = Object.keys(sanitizedReqBody); /** @type {any} */ const finalData = {}; reqBodyKeys.forEach((key)=>{ if (key?.match(/paradigm|priviledge|database_access|databases|confirm/)) return; finalData[key] = sanitizedReqBody[key]; }); finalData["user_id"] = user.id; finalData["password"] = datasquirel_functions_hashPassword__WEBPACK_IMPORTED_MODULE_1___default()({ encryptionKey: process.env.DSQL_ENCRYPTION_PASSWORD || "", password: sanitizedReqBody.password }); finalData["user_type"] = "database"; finalData["email"] = sanitizedReqBody.email_address; finalData["image"] = "/images/user-preset.png"; finalData["image_thumbnail"] = "/images/user-preset-thumbnail.png"; delete finalData["email_address"]; return finalData; })() }); res.json({ success: newUser?.insertId ? true : false, msg: "New User User Added", newUserId: newUser.insertId }); //////////////////////////////////////// //////////////////////////////////////// //////////////////////////////////////// } else { if (user?.email === sanitizedReqBody.email_address) { return res.json({ success: false, msg: "Can't Invite yourself" }); } const existingInvitation = await _package_shared_utils_backend_global_db_DB_HANDLER__WEBPACK_IMPORTED_MODULE_4___default()(`SELECT * FROM invitations WHERE invited_user_email=? AND inviting_user_id=?`, [ sanitizedReqBody.email_address, user.id ]); if (existingInvitation && existingInvitation[0]) { return res.json({ success: false, msg: "User Already Invited" }); } const newInvitation = await _package_shared_functions_backend_db_addDbEntry__WEBPACK_IMPORTED_MODULE_3___default()({ dbFullName: "datasquirel", tableName: "invitations", data: { inviting_user_id: user.id, invited_user_email: sanitizedReqBody.email_address, database_access: sanitizedReqBody.database_access, priviledge: sanitizedReqBody.priviledge, db_tables_data: sanitizedReqBody.db_tables } }); const sendInvitationMail = await _functions_backend_handleNodemailer__WEBPACK_IMPORTED_MODULE_0___default()({ to: sanitizedReqBody.email_address, subject: `${user.first_name} ${user.last_name} Invited you`, text: `${user.first_name} ${user.last_name} has invited you to manage a datasquirel account`, html: `