2024-11-05 11:12:42 +00:00
"use strict" ;
( ( ) => {
var exports = { } ;
exports . id = 2919 ;
exports . ids = [ 2919 ] ;
exports . modules = {
/***/ 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" ) ;
/***/ } ) ,
/***/ 9052 :
/***/ ( ( _ _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 _checkUserRights _ _WEBPACK _IMPORTED _MODULE _1 _ _ = _ _webpack _require _ _ ( 8999 ) ;
/* harmony import */ var _functions _backend _checkUserRights _ _WEBPACK _IMPORTED _MODULE _1 _ _ _default = /*#__PURE__*/ _ _webpack _require _ _ . n ( _functions _backend _checkUserRights _ _WEBPACK _IMPORTED _MODULE _1 _ _ ) ;
/* harmony import */ var _functions _backend _grabDelegatedUserFromCookie _ _WEBPACK _IMPORTED _MODULE _2 _ _ = _ _webpack _require _ _ ( 1352 ) ;
/* harmony import */ var _functions _backend _grabDelegatedUserFromCookie _ _WEBPACK _IMPORTED _MODULE _2 _ _ _default = /*#__PURE__*/ _ _webpack _require _ _ . n ( _functions _backend _grabDelegatedUserFromCookie _ _WEBPACK _IMPORTED _MODULE _2 _ _ ) ;
/* harmony import */ var _functions _backend _serverError _ _WEBPACK _IMPORTED _MODULE _3 _ _ = _ _webpack _require _ _ ( 2163 ) ;
/* harmony import */ var _functions _backend _serverError _ _WEBPACK _IMPORTED _MODULE _3 _ _ _default = /*#__PURE__*/ _ _webpack _require _ _ . n ( _functions _backend _serverError _ _WEBPACK _IMPORTED _MODULE _3 _ _ ) ;
/* harmony import */ var _functions _backend _userAuth _ _WEBPACK _IMPORTED _MODULE _4 _ _ = _ _webpack _require _ _ ( 6825 ) ;
/* harmony import */ var _functions _backend _userAuth _ _WEBPACK _IMPORTED _MODULE _4 _ _ _default = /*#__PURE__*/ _ _webpack _require _ _ . n ( _functions _backend _userAuth _ _WEBPACK _IMPORTED _MODULE _4 _ _ ) ;
/* harmony import */ var _package _shared _functions _backend _db _updateDbEntry _ _WEBPACK _IMPORTED _MODULE _5 _ _ = _ _webpack _require _ _ ( 5886 ) ;
/* harmony import */ var _package _shared _functions _backend _db _updateDbEntry _ _WEBPACK _IMPORTED _MODULE _5 _ _ _default = /*#__PURE__*/ _ _webpack _require _ _ . n ( _package _shared _functions _backend _db _updateDbEntry _ _WEBPACK _IMPORTED _MODULE _5 _ _ ) ;
// @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 _ 4 _ _ _ 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 , tableNameOld , payload , delegated } = sanitizedReqBody ;
const { tableName , tableFullName , tableDescription } = payload ;
/ * *
* User auth
*
* @ description Authenticate user
* / if (!tableName?.match(/ . / ) || tableName . match ( /[^a-zA-Z0-9-_]/ ) ) {
return res . json ( {
success : false ,
msg : "Bad Input"
} ) ;
}
/ * *
* Send Response
*
* @ description Send a boolean response
* / t r y {
/ * *
* Check if user has rights to this table
*
* @ description Check if user has rights to this table
* / c o n s t d e l e g a t e d 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 _ g r a b D e l e g a t e d U s e r F r o m C o o k i e _ _ 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 ( ) ( {
databaseSlug : dbSlug ,
request : req ,
user : user ,
query : req . query
} ) ;
const checkUserRightsBoolean = await _functions _backend _checkUserRights _ _WEBPACK _IMPORTED _MODULE _1 _ _ _default ( ) ( {
user : user ,
confirmedDelegetedUser : delegatedUser ,
database : dbSlug ,
table : tableNameOld ,
dbId : dbId ,
priviledgeRegex : /Edit Table/i
} ) ;
if ( ! checkUserRightsBoolean ) {
console . log ( "User Unauthorized" ) ;
return res . json ( {
success : false ,
msg : "Unauthorized"
} ) ;
}
const userId = delegatedUser ? . rootUserId ? delegatedUser . rootUserId : user . id ;
/ * *
* 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 ] ;
let existingTableIndex ;
let existingTable = targetDatabase . tables . filter ( ( table , index ) => {
if ( table . tableName === tableNameOld ) {
existingTableIndex = index ;
return true ;
}
} ) ;
if ( existingTable && existingTable [ 0 ] ) {
existingTable [ 0 ] . tableName = tableName ;
existingTable [ 0 ] . tableNameOld = tableNameOld ;
existingTable [ 0 ] . tableFullName = tableFullName ;
tableDescription && ( existingTable [ 0 ] . tableDescription = tableDescription ) ;
if ( existingTable [ 0 ] . childrenTables ) {
existingTable [ 0 ] . childrenTables . forEach ( ( childTable ) => {
try {
const childDb = userSchemaData . filter ( ( db ) => db . dbFullName === childTable . dbNameFull ) [ 0 ] ;
const childTableObject = childDb . tables . filter ( ( table ) => {
if ( table . tableName === childTable . tableName ) {
return true ;
}
} ) [ 0 ] ;
childTableObject . childTableName = tableName ;
} catch ( /** @type {any} */ error ) {
_functions _backend _serverError _ _WEBPACK _IMPORTED _MODULE _3 _ _ _default ( ) ( {
component : "/api/updateUserTable/lines-131-138" ,
message : error . message ,
user : user
} ) ;
}
} ) ;
}
} else {
throw new Error ( "Table Does not exist" ) ;
}
fs . writeFileSync ( ` ${ userSchemaMainFilePath } ` , JSON . stringify ( userSchemaData ) , "utf8" ) ;
////////////////////////////////////////
const updateTable = await _package _shared _functions _backend _db _updateDbEntry _ _WEBPACK _IMPORTED _MODULE _5 _ _ _default ( ) ( {
dbFullName : "datasquirel" ,
tableName : "user_database_tables" ,
identifierColumnName : "table_slug" ,
identifierValue : tableNameOld ,
data : {
table _name : tableFullName ,
table _slug : tableName ,
table _description : tableDescription
}
} ) ;
if ( delegated && delegatedUser ) {
const updateDelegatedTable = await _package _shared _utils _backend _global _db _DB _HANDLER _ _WEBPACK _IMPORTED _MODULE _0 _ _ _default ( ) ( ` UPDATE delegated_user_tables SET \` table \` =? WHERE delegated_user_id=? AND root_user_id=? AND \` table \` =? AND \` database \` =? ` , [
tableName ,
user . id ,
delegatedUser . rootUserId ,
tableNameOld ,
dbSlug ,
] ) ;
}
////////////////////////////////////////
const targetPath = path . join ( process . cwd ( ) , "/shell" ) ;
const sanitizedDbName = dbFullName . replace ( /[^a-z\_0-9]/g , "" ) ;
const dbShellUpdate = execSync ( ` node createDbFromSchema.js --user ${ userId } --database ${ sanitizedDbName } ` , {
cwd : targetPath
} ) ;
console . log ( dbShellUpdate . toString ( ) ) ;
////////////////////////////////////////
res . json ( {
success : true
} ) ;
////////////////////////////////////////
} catch ( /** @type {any} */ error ) {
////////////////////////////////////////
_functions _backend _serverError _ _WEBPACK _IMPORTED _MODULE _3 _ _ _default ( ) ( {
component : "/api/updateUserTable/main-catch-error" ,
message : error . message ,
user : user
} ) ;
res . json ( {
success : false ,
msg : "Database Files could not be written!"
} ) ;
////////////////////////////////////////
}
}
/***/ } )
} ;
;
// 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 , 1352 , 8999 ] , ( ) => ( _ _webpack _exec _ _ ( 9052 ) ) ) ;
2024-11-05 11:12:42 +00:00
module . exports = _ _webpack _exports _ _ ;
} ) ( ) ;