GhostManSec
Server: LiteSpeed
System: Linux premium117.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User: eblama1 (1214)
PHP: 8.2.30
Disabled: NONE
Upload Files
File: /home/eblama1/sms.karnplayinland.com/functions/DBUpsert.php
<?php
/**
 * Insert into or Update DB functions
 *
 * @package RosarioSIS
 * @subpackage functions
 */

/**
 * Get DB INSERT SQL statement
 * Will skip columns with empty values ('', false, null), but not '0' and 0
 *
 * @example $sql = DBInsertSQL( 'config', [ 'CONFIG_VALUE' => $value, 'TITLE' => $item, 'SCHOOL_ID' => $school_id ] );
 *
 * @since 11.0
 * @since 11.2 Only allow column names of string type (not empty)
 *
 * @param string $table   DB table (unescaped).
 * @param array  $columns Columns (values escaped). Associative array, [ 'COLUMN' => 'value' ].
 *
 * @return string Empty if no values to insert, else SQL statement.
 */
function DBInsertSQL( $table, $columns )
{
	if ( ! $table
		|| ! $columns )
	{
		return '';
	}

	$sql = "INSERT INTO " . DBEscapeIdentifier( $table ) . " ";

	$fields = $values = '';

	$go = false;

	foreach ( (array) $columns as $column => $value )
	{
		if ( ! is_string( $column )
			|| $column === '' )
		{
			// Only allow column names of string type (not empty).
			continue;
		}

		if ( (string) $value != '' )
		{
			$fields .= DBEscapeIdentifier( $column ) . ',';
			$values .= "'" . $value . "',";
			$go = true;
		}
	}

	if ( ! $go )
	{
		return '';
	}

	$sql .= '(' . mb_substr( $fields, 0, -1 ) . ') values(' . mb_substr( $values, 0, -1 ) . ');';

	return $sql;
}

/**
 * INSERT into DB
 * Will skip columns with empty values ('', false, null), but not '0' and 0
 *
 * @example DBInsert( 'config', [ 'CONFIG_VALUE' => $value, 'TITLE' => $item, 'SCHOOL_ID' => $school_id ] );
 * @example $id = DBInsert( 'staff', [ 'SYEAR' => UserSyear(), 'PROFILE' => 'parent', ... ], 'id' );
 *
 * @since 11.0
 *
 * @uses DBInsertSQL()
 * @uses DBLastInsertID()
 *
 * @param string $table   DB table (unescaped).
 * @param array  $columns Columns (values escaped). Associative array, [ 'COLUMN' => 'value' ].
 * @param string $return  'true' will return true, 'id' will return DBLastInsertID(). Defaults to 'true'.
 *
 * @return bool|int True or last inserted ID.
 */
function DBInsert( $table, $columns, $return = 'true' )
{
	$sql = DBInsertSQL( $table, $columns );

	if ( ! $sql )
	{
		return false;
	}

	DBQuery( $sql );

	if ( $return === 'id' )
	{
		return DBLastInsertID();
	}

	return true;
}

/**
 * Get DB UPDATE SQL statement
 * Will set columns with empty values ('', false, null) to NULL, but not '0'
 *
 * @example $sql = DBUpdateSQL( 'config', [ 'CONFIG_VALUE' => $value ], [ 'TITLE' => $item, 'SCHOOL_ID' => (int) $school_id ] );
 *
 * @since 11.0
 * @since 11.2 Only allow column names of string type (not empty)
 *
 * @param string $table         DB table (unescaped).
 * @param array  $columns       Columns (values escaped). Associative array, [ 'COLUMN' => 'value' ].
 * @param array  $where_columns WHERE part columns. Associative array, [ 'COLUMN' => 'value' ].
 *
 * @return string Empty if no values to update, else SQL statement.
 */
function DBUpdateSQL( $table, $columns, $where_columns )
{
	if ( ! $table
		|| ! $columns
		|| ! $where_columns )
	{
		return '';
	}

	$sql = "UPDATE " . DBEscapeIdentifier( $table ) . " SET ";

	$go = false;

	foreach ( (array) $columns as $column => $value )
	{
		if ( ! is_string( $column )
			|| $column === '' )
		{
			// Only allow column names of string type (not empty).
			continue;
		}

		if ( (string) $value != '' )
		{
			$sql .= DBEscapeIdentifier( $column ) . "='" . $value . "',";
		}
		else
		{
			$sql .= DBEscapeIdentifier( $column ) . "=NULL,";
		}

		$go = true;
	}

	if ( ! $go )
	{
		return '';
	}

	$sql = mb_substr( $sql, 0, -1 ) . " WHERE ";

	foreach ( (array) $where_columns as $column => $value )
	{
		$sql .= DBEscapeIdentifier( $column ) . "='" . $value . "' AND ";
	}

	$sql = mb_substr( $sql, 0, -5 ) . ";";

	return $sql;
}

/**
 * UPDATE DB
 * Will set columns with empty values ('', false, null) to NULL, but not '0'
 *
 * @example DBUpdate( 'config', [ 'CONFIG_VALUE' => $value ], [ 'TITLE' => $item, 'SCHOOL_ID' => (int) $school_id ] );
 *
 * @since 11.0
 *
 * @uses DBUpdateSQL()
 *
 * @param string $table         DB table (unescaped).
 * @param array  $columns       Columns (values escaped). Associative array, [ 'COLUMN' => 'value' ].
 * @param array  $where_columns WHERE part columns. Associative array, [ 'COLUMN' => 'value' ].
 *
 * @return bool  False if no SQL else true.
 */
function DBUpdate( $table, $columns, $where_columns )
{
	$sql = DBUpdateSQL( $table, $columns, $where_columns );

	if ( ! $sql )
	{
		return false;
	}

	DBQuery( $sql );

	return true;
}

/**
 * INSERT INTO or UPDATE DB
 *
 * @example DBUpsert( 'config', [ 'CONFIG_VALUE' => $value ], [ 'TITLE' => $item, 'SCHOOL_ID' => (int) $school_id ], $mode );
 *
 * @since 11.0
 * @since 11.2 Fix SQL error when $columns is false
 *
 * @uses DBInsert()
 * @uses DBUpdate()
 *
 * @param string $table         DB table (unescaped).
 * @param array  $columns       Columns (values escaped). Associative array, [ 'COLUMN' => 'value' ].
 * @param array  $where_columns WHERE part columns. If INSERT, will be added to $columns. Associative array, [ 'COLUMN' => 'value' ].
 * @param string $mode          'insert' will INSERT, 'insert_id' will INSERT & return DBLastInsertID(), 'update' will UPDATE.
 *
 * @return bool|int True or last inserted ID.
 */
function DBUpsert( $table, $columns, $where_columns, $mode )
{
	if ( ! $table
		|| ! $columns )
	{
		return false;
	}

	if ( $mode === 'insert' )
	{
		return DBInsert( $table, (array) $columns + (array) $where_columns );
	}

	if ( $mode === 'insert_id' )
	{
		return DBInsert( $table, (array) $columns + (array) $where_columns, 'id' );
	}

	if ( $mode === 'update' )
	{
		return DBUpdate( $table, $columns, $where_columns );
	}

	return false;
}