From 4ffa26265b8ad55cf2dd6b9ef23de580d672b411 Mon Sep 17 00:00:00 2001 From: "Ilya A. Zhulin" Date: Tue, 8 Oct 2024 16:29:37 +0300 Subject: [PATCH] Update database.php Changes to compatibility with J5+ --- libraries/cck/_/database.php | 451 +++++++++++++++++------------------ 1 file changed, 216 insertions(+), 235 deletions(-) diff --git a/libraries/cck/_/database.php b/libraries/cck/_/database.php index 7e61d9770..958376d65 100644 --- a/libraries/cck/_/database.php +++ b/libraries/cck/_/database.php @@ -1,240 +1,221 @@ convertUtf8mb4QueryToUtf8( $query ); - } - - $beginningOfQuery = substr( $query, 0, 12 ); - $beginningOfQuery = strtoupper( $beginningOfQuery ); - - if ( !in_array( $beginningOfQuery, array( 'ALTER TABLE ', 'CREATE TABLE' ) ) ) { - return $query; - } - - return str_replace( 'utf8mb4', 'utf8', $query ); - } - - // execute - public static function execute( $query ) - { - $db = JFactory::getDbo(); - $utf8mb4 = false; - - if ( JCck::on( '3.5' ) ) { - $utf8mb4 = $db->hasUTF8mb4Support(); - } - if ( !$utf8mb4 ) { - $query = self::convertUtf8mb4QueryToUtf8( $query ); - } - - $db->setQuery( $query ); - - if ( ! $db->execute() ) { - return false; - } - - return true; - } - - // loadAssocList - public static function loadAssocList( $query, $key = null, $column = null ) - { - $db = JFactory::getDbo(); - - $db->setQuery( $query ); - $res = $db->loadAssocList( $key, $column ); - - return $res; - } - - // loadColumn - public static function loadColumn( $query ) - { - $db = JFactory::getDbo(); - - $db->setQuery( $query ); - $res = $db->loadColumn(); - - return $res; - } - - // loadObject - public static function loadObject( $query ) - { - $db = JFactory::getDbo(); - - $db->setQuery( $query ); - $res = $db->loadObject(); - - return $res; - } - - // loadObjectList - public static function loadObjectList( $query, $key = null ) - { - $db = JFactory::getDbo(); - - $db->setQuery( $query ); - $res = $db->loadObjectList( $key ); - - return $res; - } - - // loadObjectListArray - public static function loadObjectListArray( $query, $akey, $key = null ) - { - $db = JFactory::getDbo(); - - $db->setQuery( $query ); - - $list = $db->loadObjectList(); - $res = array(); - if ( count( $list ) ) { - if ( $key ) { - foreach ( $list as $row ) { - $res[$row->$akey][$row->$key] = $row; - } - } else { - foreach ( $list as $row ) { - $res[$row->$akey][] = $row; - } - } - } - - return $res; - } - - // loadResult - public static function loadResult( $query ) - { - $db = JFactory::getDbo(); - - $db->setQuery( $query ); - $res = $db->loadResult(); - - return $res; - } - - // -------- -------- -------- -------- -------- -------- -------- -------- // Tables - - // getTableColumns - public static function getTableColumns( $table, $flip = false ) - { - return $flip ? array_flip( array_keys( JFactory::getDbo()->getTableColumns( $table ) ) ) : array_keys( JFactory::getDbo()->getTableColumns( $table ) ); - } - - // getTableFullColumns - public static function getTableFullColumns( $table ) - { - return JFactory::getDbo()->getTableColumns( $table, false ); - } - - // getTableCreate - public static function getTableCreate( $tables ) - { - $res = JFactory::getDbo()->getTableCreate( $tables ); - - $res = str_replace( JFactory::getConfig()->get( 'dbprefix' ), '#__', $res ); - $res = str_replace( 'CREATE TABLE `#__', 'CREATE TABLE IF NOT EXISTS `#__', $res ); - - return $res; - } - - // getTableList - public static function getTableList( $flip = false ) - { - return $flip ? array_flip( JFactory::getDbo()->getTableList() ) : JFactory::getDbo()->getTableList(); - } - - // -------- -------- -------- -------- -------- -------- -------- -------- // Misc - - // clean - public static function clean( $text ) - { - if ( is_numeric( $text ) ) { - return (string)$text; - } else { - $len = strlen( $text ); - - if ( $text[0] == "'" && $text[$len - 1] == "'" ) { - $t = substr( $text, 1, - 1 ); - - if ( is_numeric( $t ) ) { - return "'".(string)$t."'"; - } - } - } - - return JCckDatabase::quote( uniqid() ); - } - - // escape - public static function escape( $text, $extra = false ) - { - return JFactory::getDbo()->escape( $text, $extra ); - } - - // match - public static function matchWithin( $column, $text ) - { - if ( $text == '' ) { - return $text; - } - - $glue = ','; - $sql = $column.' = '.self::quote( $text ) - . ' OR '.$column.' LIKE '.self::quote( self::escape( $text, true ).$glue.'%', false ) - . ' OR '.$column.' LIKE '.self::quote( '%'.$glue.self::escape( $text, true ).$glue.'%', false ) - . ' OR '.$column.' LIKE '.self::quote( '%'.$glue.self::escape( $text, true ), false ) - ; - - return '('.$sql.')'; - } - - // null - public static function null() - { - $db = JFactory::getDbo(); - - return JCck::on( '4.0' ) ? 'IS NULL' : '= '.$db->quote( $db->getNullDate() ); - } - - // quote - public static function quote( $text, $escape = true ) - { - return JFactory::getDbo()->quote( $text, $escape ); - } - - // quoteName - public static function quoteName( $name, $as = null ) - { - return JFactory::getDbo()->quoteName( $name, $as ); - } - - // -------- -------- -------- -------- -------- -------- -------- -------- // Deprecated - - // doQuery (deprecated) - public static function doQuery( $query ) - { - return self::execute( $query ); - } +abstract class JCckDatabase { + + // -------- -------- -------- -------- -------- -------- -------- -------- // Queries + // convertUtf8mb4QueryToUtf8 + public static function convertUtf8mb4QueryToUtf8($query) { + if (JCck::on('3.5')) { + + return Factory::getContainer()->get(DatabaseInterface::class)->convertUtf8mb4QueryToUtf8($query); + } + + $beginningOfQuery = substr($query, 0, 12); + $beginningOfQuery = strtoupper($beginningOfQuery); + + if (!in_array($beginningOfQuery, array('ALTER TABLE ', 'CREATE TABLE'))) { + return $query; + } + + return str_replace('utf8mb4', 'utf8', $query); + } + + // execute + public static function execute($query) { + $db = Factory::getContainer()->get(DatabaseInterface::class); + $utf8mb4 = false; + if (JCck::on('3.5')) { + $utf8mb4 = $db->hasUTF8mb4Support($query); + } + if (!$utf8mb4) { + $query = self::convertUtf8mb4QueryToUtf8($query); + } + + $db->setQuery($query); + + if (!$db->execute()) { + return false; + } + + return true; + } + + // loadAssocList + public static function loadAssocList($query, $key = null, $column = null) { + $db = Factory::getContainer()->get(DatabaseInterface::class); + + $db->setQuery($query); + $res = $db->loadAssocList($key, $column); + + return $res; + } + + // loadColumn + public static function loadColumn($query) { + $db = Factory::getContainer()->get(DatabaseInterface::class); + + $db->setQuery($query); + $res = $db->loadColumn(); + + return $res; + } + + // loadObject + public static function loadObject($query) { + $db = Factory::getContainer()->get(DatabaseInterface::class); + + $db->setQuery($query); + $res = $db->loadObject(); + + return $res; + } + + // loadObjectList + public static function loadObjectList($query, $key = null) { + $db = Factory::getContainer()->get(DatabaseInterface::class); + + $db->setQuery($query); + $res = $db->loadObjectList($key); + + return $res; + } + + // loadObjectListArray + public static function loadObjectListArray($query, $akey, $key = null) { + $db = Factory::getContainer()->get(DatabaseInterface::class); + + $db->setQuery($query); + + $list = $db->loadObjectList(); + $res = array(); + if (count($list)) { + if ($key) { + foreach ($list as $row) { + $res[$row->$akey][$row->$key] = $row; + } + } else { + foreach ($list as $row) { + $res[$row->$akey][] = $row; + } + } + } + + return $res; + } + + // loadResult + public static function loadResult($query) { + $db = Factory::getContainer()->get(DatabaseInterface::class); + + $db->setQuery($query); + $res = $db->loadResult(); + + return $res; + } + + // -------- -------- -------- -------- -------- -------- -------- -------- // Tables + // getTableColumns + public static function getTableColumns($table, $flip = false) { + return $flip ? array_flip(array_keys(Factory::getContainer()->get(DatabaseInterface::class)->getTableColumns($table))) : array_keys(Factory::getContainer()->get(DatabaseInterface::class)->getTableColumns($table)); + } + + // getTableFullColumns + public static function getTableFullColumns($table) { + return Factory::getContainer()->get(DatabaseInterface::class)->getTableColumns($table, false); + } + + // getTableCreate + public static function getTableCreate($tables) { + $res = Factory::getContainer()->get(DatabaseInterface::class)->getTableCreate($tables); + + $res = str_replace(JFactory::getConfig()->get('dbprefix'), '#__', $res); + $res = str_replace('CREATE TABLE `#__', 'CREATE TABLE IF NOT EXISTS `#__', $res); + + return $res; + } + + // getTableList + public static function getTableList($flip = false) { + return $flip ? array_flip(Factory::getContainer()->get(DatabaseInterface::class)->getTableList()) : Factory::getContainer()->get(DatabaseInterface::class)->getTableList(); + } + + // -------- -------- -------- -------- -------- -------- -------- -------- // Misc + // clean + public static function clean($text) { + if (is_numeric($text)) { + return (string) $text; + } else { + $len = strlen($text); + + if ($text[0] == "'" && $text[$len - 1] == "'") { + $t = substr($text, 1, - 1); + + if (is_numeric($t)) { + return "'" . (string) $t . "'"; + } + } + } + + return JCckDatabase::quote(uniqid()); + } + + // escape + public static function escape($text, $extra = false) { + return Factory::getContainer()->get(DatabaseInterface::class)->escape($text, $extra); + } + + // match + public static function matchWithin($column, $text) { + if ($text == '') { + return $text; + } + + $glue = ','; + $sql = $column . ' = ' . self::quote($text) + . ' OR ' . $column . ' LIKE ' . self::quote(self::escape($text, true) . $glue . '%', false) + . ' OR ' . $column . ' LIKE ' . self::quote('%' . $glue . self::escape($text, true) . $glue . '%', false) + . ' OR ' . $column . ' LIKE ' . self::quote('%' . $glue . self::escape($text, true), false) + ; + + return '(' . $sql . ')'; + } + + // null + public static function null() { + $db = Factory::getContainer()->get(DatabaseInterface::class); + + return JCck::on('4.0') ? 'IS NULL' : '= ' . $db->quote($db->getNullDate()); + } + + // quote + public static function quote($text, $escape = true) { + return Factory::getContainer()->get(DatabaseInterface::class)->quote($text, $escape); + } + + // quoteName + public static function quoteName($name, $as = null) { + return Factory::getContainer()->get(DatabaseInterface::class)->quoteName($name, $as); + } + + // -------- -------- -------- -------- -------- -------- -------- -------- // Deprecated + // doQuery (deprecated) + public static function doQuery($query) { + return self::execute($query); + } } -?> \ No newline at end of file + +?>