2024-12-06 13:24:26 +00:00
// @ts-check
2025-01-13 08:00:21 +00:00
import { APICreateUserFunctionParams } from "../../../types" ;
import addUsersTableToDb from "../../backend/addUsersTableToDb" ;
import addDbEntry from "../../backend/db/addDbEntry" ;
import updateUsersTableSchema from "../../backend/updateUsersTableSchema" ;
import varDatabaseDbHandler from "../../backend/varDatabaseDbHandler" ;
import hashPassword from "../../dsql/hashPassword" ;
/ * *
* # API Create User
* /
export default async function apiCreateUser ( {
2024-12-06 13:24:26 +00:00
encryptionKey ,
payload ,
database ,
userId ,
useLocal ,
2025-01-13 08:00:21 +00:00
} : APICreateUserFunctionParams ) {
2024-12-06 13:24:26 +00:00
const dbFullName = database ;
2024-12-09 12:27:08 +00:00
const API_USER_ID = userId || process . env . DSQL_API_USER_ID ;
2024-12-06 13:24:26 +00:00
const finalEncryptionKey =
encryptionKey || process . env . DSQL_ENCRYPTION_PASSWORD ;
if ( ! finalEncryptionKey ) {
return {
success : false ,
msg : "No encryption key provided" ,
payload : null ,
} ;
}
if ( ! finalEncryptionKey ? . match ( /.{8,}/ ) ) {
return {
success : false ,
msg : "Encryption key must be at least 8 characters long" ,
payload : null ,
} ;
}
const hashedPassword = hashPassword ( {
encryptionKey : finalEncryptionKey ,
password : String ( payload . password ) ,
} ) ;
payload . password = hashedPassword ;
2025-01-13 08:00:21 +00:00
const fieldsQuery = ` SHOW COLUMNS FROM ${ dbFullName } .users ` ;
2024-12-06 13:24:26 +00:00
2024-12-08 08:57:48 +00:00
let fields = await varDatabaseDbHandler ( {
queryString : fieldsQuery ,
database : dbFullName ,
useLocal ,
} ) ;
if ( ! fields ? . [ 0 ] ) {
2024-12-06 13:24:26 +00:00
const newTable = await addUsersTableToDb ( {
2024-12-09 12:27:08 +00:00
userId : Number ( API_USER_ID ) ,
2024-12-08 08:57:48 +00:00
database : dbFullName ,
2024-12-06 13:24:26 +00:00
useLocal ,
2024-12-08 08:57:48 +00:00
payload : payload ,
2024-12-06 13:24:26 +00:00
} ) ;
fields = await varDatabaseDbHandler ( {
2024-12-08 08:57:48 +00:00
queryString : fieldsQuery ,
2024-12-06 13:24:26 +00:00
database : dbFullName ,
2024-12-08 08:57:48 +00:00
useLocal ,
2024-12-06 13:24:26 +00:00
} ) ;
}
2024-12-08 08:57:48 +00:00
if ( ! fields ? . [ 0 ] ) {
2024-12-06 13:24:26 +00:00
return {
success : false ,
msg : "Could not create users table" ,
} ;
}
2025-01-13 08:00:21 +00:00
const fieldsTitles = fields . map ( ( fieldObject : any ) = > fieldObject . Field ) ;
2024-12-06 13:24:26 +00:00
let invalidField = null ;
for ( let i = 0 ; i < Object . keys ( payload ) . length ; i ++ ) {
const key = Object . keys ( payload ) [ i ] ;
if ( ! fieldsTitles . includes ( key ) ) {
2024-12-08 08:57:48 +00:00
await updateUsersTableSchema ( {
2024-12-09 12:27:08 +00:00
userId : Number ( API_USER_ID ) ,
2024-12-08 08:57:48 +00:00
database : dbFullName ,
newPayload : {
[ key ] : payload [ key ] ,
} ,
} ) ;
2024-12-06 13:24:26 +00:00
}
}
if ( invalidField ) {
return {
success : false ,
msg : ` ${ invalidField } is not a valid field! ` ,
} ;
}
2025-01-13 08:00:21 +00:00
const existingUserQuery = ` SELECT * FROM ${ dbFullName } .users WHERE email = ? ${
2024-12-08 08:57:48 +00:00
payload . username ? " OR username = ?" : ""
} ` ;
const existingUserValues = payload . username
? [ payload . email , payload . username ]
: [ payload . email ] ;
2024-12-06 13:24:26 +00:00
const existingUser = await varDatabaseDbHandler ( {
2024-12-08 08:57:48 +00:00
queryString : existingUserQuery ,
queryValuesArray : existingUserValues ,
2024-12-06 13:24:26 +00:00
database : dbFullName ,
2024-12-08 08:57:48 +00:00
useLocal ,
2024-12-06 13:24:26 +00:00
} ) ;
if ( existingUser ? . [ 0 ] ) {
return {
success : false ,
msg : "User Already Exists" ,
payload : null ,
} ;
}
const addUser = await addDbEntry ( {
dbContext : "Dsql User" ,
paradigm : "Full Access" ,
dbFullName : dbFullName ,
tableName : "users" ,
data : {
. . . payload ,
2024-12-15 11:27:16 +00:00
image :
process . env . DSQL_DEFAULT_USER_IMAGE ||
"/images/user-preset.png" ,
image_thumbnail :
process . env . DSQL_DEFAULT_USER_IMAGE ||
"/images/user-preset-thumbnail.png" ,
2024-12-06 13:24:26 +00:00
} ,
2024-12-09 12:27:08 +00:00
useLocal ,
2024-12-06 13:24:26 +00:00
} ) ;
if ( addUser ? . insertId ) {
2025-01-13 08:00:21 +00:00
const newlyAddedUserQuery = ` SELECT id,first_name,last_name,email,username,phone,image,image_thumbnail,city,state,country,zip_code,address,verification_status,more_user_data FROM ${ dbFullName } .users WHERE id=' ${ addUser . insertId } ' ` ;
2024-12-08 08:57:48 +00:00
2024-12-06 13:24:26 +00:00
const newlyAddedUser = await varDatabaseDbHandler ( {
2024-12-08 08:57:48 +00:00
queryString : newlyAddedUserQuery ,
2024-12-06 13:24:26 +00:00
database : dbFullName ,
2024-12-08 08:57:48 +00:00
useLocal ,
2024-12-06 13:24:26 +00:00
} ) ;
return {
success : true ,
payload : newlyAddedUser [ 0 ] ,
} ;
} else {
return {
success : false ,
msg : "Could not create user" ,
sqlResult : addUser ,
payload : null ,
} ;
}
2025-01-13 08:00:21 +00:00
}