Server : Apache System : Linux indy02.toastserver.com 3.10.0-962.3.2.lve1.5.85.el7.x86_64 #1 SMP Thu Apr 18 15:18:36 UTC 2024 x86_64 User : palandch ( 1163) PHP Version : 7.1.33 Disable Function : NONE Directory : /home/palandch/www/core/model/modx/transport/mysql/ |
<?php /** * @package modx * @subpackage transport.mysql */ require_once (strtr(realpath(dirname(dirname(__FILE__))), '\\', '/') . '/modtransportpackage.class.php'); /** * @package modx * @subpackage mysql */ class modTransportPackage_mysql extends modTransportPackage { public static function listPackages(modX &$modx, $workspace, $limit = 0, $offset = 0,$search = '') { $result = array('collection' => array(), 'total' => 0); $c = $modx->newQuery('transport.modTransportPackage'); $c->leftJoin('transport.modTransportProvider','Provider', array("modTransportPackage.provider = Provider.id")); $c->where(array( 'workspace' => $workspace, )); $c->where(array( "(SELECT `signature` FROM {$modx->getTableName('modTransportPackage')} AS `latestPackage` WHERE `latestPackage`.`package_name` = `modTransportPackage`.`package_name` ORDER BY `latestPackage`.`version_major` DESC, `latestPackage`.`version_minor` DESC, `latestPackage`.`version_patch` DESC, IF(`release` = '' OR `release` = 'ga' OR `release` = 'pl','z',`release`) DESC, `latestPackage`.`release_index` DESC LIMIT 1) = `modTransportPackage`.`signature`", )); if (!empty($search)) { $c->where(array( 'modTransportPackage.signature:LIKE' => '%'.$search.'%', 'OR:modTransportPackage.package_name:LIKE' => '%'.$search.'%', )); } $result['total'] = $modx->getCount('modTransportPackage',$c); $c->select(array( 'modTransportPackage.*', )); $c->select('`Provider`.`name` AS `provider_name`'); $c->sortby('`modTransportPackage`.`signature`', 'ASC'); if ($limit > 0) $c->limit($limit, $offset); $result['collection'] = $modx->getCollection('transport.modTransportPackage',$c); return $result; } public static function listPackageVersions(modX &$modx, $criteria, $limit = 0, $offset = 0) { $result = array('collection' => array(), 'total' => 0); $c = $modx->newQuery('transport.modTransportPackage'); $c->select($modx->getSelectColumns('transport.modTransportPackage','modTransportPackage')); $c->select(array('Provider.name AS provider_name')); $c->leftJoin('transport.modTransportProvider','Provider'); $c->where($criteria); $result['total'] = $modx->getCount('modTransportPackage',$c); $c->sortby('modTransportPackage.version_major', 'DESC'); $c->sortby('modTransportPackage.version_minor', 'DESC'); $c->sortby('modTransportPackage.version_patch', 'DESC'); $c->sortby('IF(modTransportPackage.release = "" OR modTransportPackage.release = "ga" OR modTransportPackage.release = "pl","z",modTransportPackage.release) DESC',''); $c->sortby('modTransportPackage.release_index', 'DESC'); if((int)$limit > 0) { $c->limit((int)$limit, (int)$offset); } $result['collection'] = $modx->getCollection('transport.modTransportPackage',$c); return $result; } }