2023-09-21 14:00:04 +00:00
|
|
|
// @ts-check
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Imports
|
|
|
|
*/
|
|
|
|
const https = require("https");
|
2023-09-21 16:51:08 +00:00
|
|
|
const http = require("http");
|
2023-09-21 14:00:04 +00:00
|
|
|
const path = require("path");
|
|
|
|
const fs = require("fs");
|
2024-11-13 13:13:10 +00:00
|
|
|
const grabHostNames = require("../../package-shared/utils/grab-host-names");
|
2023-09-21 14:00:04 +00:00
|
|
|
|
|
|
|
/** ****************************************************************************** */
|
|
|
|
/** ****************************************************************************** */
|
|
|
|
/** ****************************************************************************** */
|
|
|
|
/** ****************************************************************************** */
|
|
|
|
/** ****************************************************************************** */
|
|
|
|
/** ****************************************************************************** */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @typedef {Object} PostReturn
|
|
|
|
* @property {boolean} success - Did the function run successfully?
|
|
|
|
* @property {*} [payload] - The Y Coordinate
|
|
|
|
* @property {string} [error] - The Y Coordinate
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* # Update API Schema From Local DB
|
|
|
|
*
|
|
|
|
* @async
|
|
|
|
*
|
|
|
|
* @returns { Promise<PostReturn> } - Return Object
|
|
|
|
*/
|
|
|
|
async function updateApiSchemaFromLocalDb() {
|
|
|
|
try {
|
|
|
|
/**
|
|
|
|
* Initialize
|
|
|
|
*/
|
|
|
|
const dbSchemaPath = path.resolve(process.cwd(), "dsql.schema.json");
|
|
|
|
const key = process.env.DSQL_KEY || "";
|
|
|
|
|
|
|
|
const dbSchema = JSON.parse(fs.readFileSync(dbSchemaPath, "utf8"));
|
2024-11-27 10:02:03 +00:00
|
|
|
const { host, port, scheme, user_id } = grabHostNames();
|
2023-09-21 16:51:08 +00:00
|
|
|
|
2023-09-21 14:00:04 +00:00
|
|
|
/**
|
|
|
|
* Make https request
|
|
|
|
*
|
|
|
|
* @description make a request to datasquirel.com
|
|
|
|
*/
|
|
|
|
const httpResponse = await new Promise((resolve, reject) => {
|
|
|
|
const reqPayloadString = JSON.stringify({
|
|
|
|
schema: dbSchema,
|
|
|
|
}).replace(/\n|\r|\n\r/gm, "");
|
|
|
|
|
|
|
|
try {
|
|
|
|
JSON.parse(reqPayloadString);
|
|
|
|
} catch (error) {
|
|
|
|
console.log(error);
|
|
|
|
console.log(reqPayloadString);
|
|
|
|
|
|
|
|
return {
|
|
|
|
success: false,
|
|
|
|
payload: null,
|
|
|
|
error: "Query object is invalid. Please Check query data values",
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
const reqPayload = reqPayloadString;
|
|
|
|
|
2024-11-13 13:13:10 +00:00
|
|
|
const httpsRequest = scheme.request(
|
2023-09-21 14:00:04 +00:00
|
|
|
{
|
|
|
|
method: "POST",
|
|
|
|
headers: {
|
|
|
|
"Content-Type": "application/json",
|
|
|
|
"Content-Length": Buffer.from(reqPayload).length,
|
2024-11-15 14:37:53 +00:00
|
|
|
Authorization:
|
|
|
|
key ||
|
|
|
|
process.env.DSQL_FULL_ACCESS_API_KEY ||
|
|
|
|
process.env.DSQL_API_KEY,
|
2023-09-21 14:00:04 +00:00
|
|
|
},
|
2024-11-13 13:13:10 +00:00
|
|
|
port,
|
|
|
|
hostname: host,
|
2024-11-27 10:02:03 +00:00
|
|
|
path: `/api/query/${user_id}/update-schema-from-single-database`,
|
2023-09-21 14:00:04 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Callback Function
|
|
|
|
*
|
|
|
|
* @description https request callback
|
|
|
|
*/
|
|
|
|
(response) => {
|
|
|
|
var str = "";
|
|
|
|
|
|
|
|
response.on("data", function (chunk) {
|
|
|
|
str += chunk;
|
|
|
|
});
|
|
|
|
|
|
|
|
response.on("end", function () {
|
|
|
|
try {
|
|
|
|
resolve(JSON.parse(str));
|
|
|
|
} catch (error) {
|
|
|
|
console.log(error);
|
|
|
|
console.log("Fetched Payload =>", str);
|
|
|
|
|
|
|
|
resolve({
|
|
|
|
success: false,
|
|
|
|
payload: null,
|
|
|
|
error: error,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
response.on("error", (err) => {
|
|
|
|
resolve({
|
|
|
|
success: false,
|
|
|
|
payload: null,
|
|
|
|
error: err.message,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
httpsRequest.write(reqPayload);
|
|
|
|
|
|
|
|
httpsRequest.on("error", (error) => {
|
|
|
|
console.log("HTTPS request ERROR =>", error);
|
|
|
|
});
|
|
|
|
|
|
|
|
httpsRequest.end();
|
|
|
|
});
|
|
|
|
|
|
|
|
/** ********************************************** */
|
|
|
|
/** ********************************************** */
|
|
|
|
/** ********************************************** */
|
|
|
|
|
|
|
|
return httpResponse;
|
|
|
|
} catch (/** @type {*} */ error) {
|
|
|
|
return {
|
|
|
|
success: false,
|
|
|
|
payload: null,
|
|
|
|
error: error.message,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/** ********************************************** */
|
|
|
|
/** ********************************************** */
|
|
|
|
/** ********************************************** */
|
|
|
|
|
|
|
|
module.exports = updateApiSchemaFromLocalDb;
|