2024-11-05 11:12:42 +00:00
"use strict" ;
( ( ) => {
var exports = { } ;
exports . id = 9372 ;
exports . ids = [ 9372 ] ;
exports . modules = {
/***/ 6517 :
/***/ ( ( module ) => {
module . exports = require ( "lodash" ) ;
/***/ } ) ,
/***/ 6109 :
/***/ ( ( module ) => {
module . exports = require ( "sanitize-html" ) ;
/***/ } ) ,
/***/ 2261 :
/***/ ( ( module ) => {
module . exports = require ( "serverless-mysql" ) ;
/***/ } ) ,
/***/ 4300 :
/***/ ( ( module ) => {
module . exports = require ( "buffer" ) ;
/***/ } ) ,
/***/ 2081 :
/***/ ( ( module ) => {
module . exports = require ( "child_process" ) ;
/***/ } ) ,
/***/ 6113 :
/***/ ( ( module ) => {
module . exports = require ( "crypto" ) ;
/***/ } ) ,
/***/ 7147 :
/***/ ( ( module ) => {
module . exports = require ( "fs" ) ;
/***/ } ) ,
/***/ 3685 :
/***/ ( ( module ) => {
module . exports = require ( "http" ) ;
/***/ } ) ,
/***/ 1017 :
/***/ ( ( module ) => {
module . exports = require ( "path" ) ;
/***/ } ) ,
/***/ 2066 :
/***/ ( ( _ _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 _package _shared _utils _backend _global _db _DB _HANDLER _ _WEBPACK _IMPORTED _MODULE _0 _ _ = _ _webpack _require _ _ ( 2224 ) ;
/* harmony import */ var _package _shared _utils _backend _global _db _DB _HANDLER _ _WEBPACK _IMPORTED _MODULE _0 _ _ _default = /*#__PURE__*/ _ _webpack _require _ _ . n ( _package _shared _utils _backend _global _db _DB _HANDLER _ _WEBPACK _IMPORTED _MODULE _0 _ _ ) ;
/* harmony import */ var _functions _backend _serverError _ _WEBPACK _IMPORTED _MODULE _1 _ _ = _ _webpack _require _ _ ( 2163 ) ;
/* harmony import */ var _functions _backend _serverError _ _WEBPACK _IMPORTED _MODULE _1 _ _ _default = /*#__PURE__*/ _ _webpack _require _ _ . n ( _functions _backend _serverError _ _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 _ _ ) ;
// @ts-check
/ * *
* === === === === === === === === === === === === === === === === === === === === === === === === === ===
* Imports
* === === === === === === === === === === === === === === === === === === === === === === === === === ===
* / c o n s t f s = _ _ w e b p a c k _ r e q u i r e _ _ ( 7 1 4 7 ) ;
const path = _ _webpack _require _ _ ( 1017 ) ;
const { execSync } = _ _webpack _require _ _ ( 2081 ) ;
/** ****************************************************************************** */ /** ****************************************************************************** */ /** ****************************************************************************** */ /** ****************************************************************************** */ /** ****************************************************************************** */ /** ****************************************************************************** */ / * *
* API handler
* === === === === === === === === === === === === === === === === === === === === === === === === === ===
* @ type { import ( "next" ) . NextApiHandler }
* / a s y n c f u n c t i o n h a n d l e r ( r e q , r e s ) {
/ * *
* Check method
*
* @ description Check request method and return if invalid
* / i f ( r e q . m e t h o d ! = = " P O S T " ) r e t u r n r e s . j s o n ( {
msg : "Failed!"
} ) ;
/ * *
* User auth
*
* @ description Authenticate user
* / c o n s t u s e r = a w a i t _ f u n c t i o n s _ b a c k e n d _ u s e r A u t h _ _ W E B P A C K _ I M P O R T E D _ M O D U L E _ 2 _ _ _ d e f a u l t ( ) ( r e q , r e s , t r u e ) ;
if ( ! user ) {
return res . json ( {
success : false ,
msg : "Unauthorized"
} ) ;
}
/ * *
* User auth
*
* @ description Authenticate user
* / c o n s t s a n i t i z e d R e q B o d y = r e q . b o d y ;
const { dbFullName , dbSlug , dbId } = sanitizedReqBody ;
const userPreset = _ _webpack _require _ _ ( 9258 ) ;
const defaultFields = _ _webpack _require _ _ ( 2439 ) ;
const finalFields = [
... defaultFields . slice ( 0 , 2 ) ,
... userPreset . fields ,
... defaultFields . slice ( 2 ) ,
] ;
userPreset . fields = [
... finalFields
] ;
/ * *
* Send Response
*
* @ description Send a boolean response
* / t r y {
/ * *
* Create new user folder and file
*
* @ description Create new user folder and file
2024-11-05 14:18:40 +00:00
* / c o n s t u s e r S c h e m a M a i n F i l e P a t h = ` $ { p r o c e s s . e n v . D S Q L _ U S E R _ D B _ S C H E M A _ P A T H } / u s e r - $ { u s e r . i d } / m a i n . j s o n ` ;
2024-11-05 11:12:42 +00:00
/** @type {import("@/package-shared/types").DSQL_DatabaseSchemaType[]} */ let userSchemaData = JSON . parse ( fs . readFileSync ( userSchemaMainFilePath , "utf8" ) ) ;
let targetDatabase = userSchemaData . filter ( ( db ) => db . dbFullName === dbFullName ) [ 0 ] ;
/** @type {number | undefined} */ let existingTableIndex ;
let existingTable = targetDatabase . tables . filter ( ( table , index ) => {
if ( table . tableName === "users" ) {
existingTableIndex = index ;
return true ;
}
} ) ;
// if (typeof existingTableIndex !== "number")
// return res.json({ success: false });
if ( existingTable ? . [ 0 ] && typeof existingTableIndex == "number" ) {
targetDatabase . tables [ existingTableIndex ] = userPreset ;
} else {
targetDatabase . tables . push ( userPreset ) ;
}
////////////////////////////////////////
////////////////////////////////////////
////////////////////////////////////////
/ * *
* Check Children Databases
*
* @ description Check Children Databases
* / i f ( t a r g e t D a t a b a s e . c h i l d r e n D a t a b a s e s ) {
for ( let i = 0 ; i < targetDatabase . childrenDatabases . length ; i ++ ) {
const childDb = targetDatabase . childrenDatabases [ i ] ;
try {
const targetChild = userSchemaData . filter ( ( db ) => db . dbFullName === childDb . dbFullName ) [ 0 ] ;
targetChild . tables = targetDatabase . tables ;
const targetDbRecord = await _package _shared _utils _backend _global _db _DB _HANDLER _ _WEBPACK _IMPORTED _MODULE _0 _ _ _default ( ) ( ` SELECT * FROM user_databases WHERE user_id = ? AND db_full_name = ? ` , [
user . id ,
childDb . dbFullName
] ) ;
const newChildTableEntry = await _package _shared _functions _backend _db _addDbEntry _ _WEBPACK _IMPORTED _MODULE _3 _ _ _default ( ) ( {
dbFullName : "datasquirel" ,
tableName : "user_database_tables" ,
data : {
user _id : user . id ,
db _id : targetDbRecord [ 0 ] . id ,
db _slug : targetDbRecord [ 0 ] . db _slug ,
table _name : "Users" ,
table _slug : "users"
}
} ) ;
} catch ( /** @type {any} */ error ) {
_functions _backend _serverError _ _WEBPACK _IMPORTED _MODULE _1 _ _ _default ( ) ( {
component : "/api/addUsersTableToDatabase/lines-100-115" ,
message : error . message ,
user : user
} ) ;
}
}
}
////////////////////////////////////////
////////////////////////////////////////
////////////////////////////////////////
fs . writeFileSync ( ` ${ userSchemaMainFilePath } ` , JSON . stringify ( userSchemaData ) , "utf8" ) ;
////////////////////////////////////////
////////////////////////////////////////
////////////////////////////////////////
const newTableEntry = await _package _shared _functions _backend _db _addDbEntry _ _WEBPACK _IMPORTED _MODULE _3 _ _ _default ( ) ( {
dbFullName : "datasquirel" ,
tableName : "user_database_tables" ,
data : {
user _id : user . id ,
db _id : dbId ,
db _slug : dbSlug ,
table _name : "Users" ,
table _slug : "users"
}
} ) ;
////////////////////////////////////////
const targetPath = path . join ( process . cwd ( ) , "/shell" ) ;
const sanitizedDbName = dbFullName . replace ( /[^a-z\_0-9]/g , "" ) ;
const dbShellUpdate = execSync ( ` node createDbFromSchema.js --user ${ user . id } --database ${ sanitizedDbName } ` , {
cwd : targetPath
} ) ;
console . log ( dbShellUpdate . toString ( ) ) ;
////////////////////////////////////////
res . json ( {
success : true
} ) ;
////////////////////////////////////////
} catch ( /** @type {any} */ error1 ) {
////////////////////////////////////////
_functions _backend _serverError _ _WEBPACK _IMPORTED _MODULE _1 _ _ _default ( ) ( {
component : "/api/addUsersTableToDatabase/main-catch-error" ,
message : error1 . message ,
user : user
} ) ;
res . json ( {
success : false ,
msg : "Database Files could not be written!"
} ) ;
////////////////////////////////////////
}
}
/***/ } ) ,
/***/ 2439 :
/***/ ( ( module ) => {
module . exports = JSON . parse ( '[{"fieldName":"id","dataType":"BIGINT","notNullValue":true,"primaryKey":true,"autoIncrement":true},{"fieldName":"uuid","dataType":"UUID","defaultValueLiteral":"UUID()"},{"fieldName":"date_created","dataType":"VARCHAR(250)","nullValue":true},{"fieldName":"date_created_code","dataType":"BIGINT","nullValue":true},{"fieldName":"date_created_timestamp","dataType":"TIMESTAMP","defaultValueLiteral":"CURRENT_TIMESTAMP"},{"fieldName":"date_updated","dataType":"VARCHAR(250)","nullValue":true},{"fieldName":"date_updated_code","dataType":"BIGINT","nullValue":true},{"fieldName":"date_updated_timestamp","dataType":"TIMESTAMP","defaultValueLiteral":"CURRENT_TIMESTAMP","onUpdateLiteral":"CURRENT_TIMESTAMP"}]' ) ;
/***/ } )
} ;
;
// load runtime
var _ _webpack _require _ _ = require ( "../../webpack-api-runtime.js" ) ;
_ _webpack _require _ _ . C ( exports ) ;
var _ _webpack _exec _ _ = ( moduleId ) => ( _ _webpack _require _ _ ( _ _webpack _require _ _ . s = moduleId ) )
2024-11-05 14:18:40 +00:00
var _ _webpack _exports _ _ = _ _webpack _require _ _ . X ( 0 , [ 2224 , 2163 , 6825 , 3017 , 3403 , 7547 , 5886 , 5338 , 9258 ] , ( ) => ( _ _webpack _exec _ _ ( 2066 ) ) ) ;
2024-11-05 11:12:42 +00:00
module . exports = _ _webpack _exports _ _ ;
} ) ( ) ;