* @return string */ public function sharedGet(string $path) { $contents = ''; $handle = fopen($path, 'rb'); if ($handle) { // try { if (flock($handle, LOCK_SH)) { clearstatcache(true, $path); $contents = fread($handle, $this->size($path) ?: 1); //ini_set('error_log' , '/home/solomono/web/solomono.net/sites/dev/php.log'); error_reporting(E_ALL); set_error_handler(function ($level, $message, $file = '', $line = 0) { $this->handleError($level, $message, $file, $line); }); set_exception_handler(function ($e) { $this->handleException($e); }); * @return string */ public function sharedGet(string $path) { $contents = ''; $handle = fopen($path, 'rb'); if ($handle) { // try { if (flock($handle, LOCK_SH)) { clearstatcache(true, $path); $contents = fread($handle, $this->size($path) ?: 1); * @throws Exception */ public function get(string $path, bool $lock = false) { if ($this->isFile($path)) { return $lock ? $this->sharedGet($path) : file_get_contents($path); } throw new Exception("File does not exist at path {$path}"); } /** // If the file doesn't exist, we obviously cannot return the cache so we will // just return null. Otherwise, we'll get the contents of the file and get // the expiration UNIX timestamps from the start of the file's contents. try { $expire = substr( $contents = $this->files->get($path, true), 0, 10 ); } catch (Exception $e) { return $this->emptyPayload(); * Retrieve an item from the cache by key. * @param string|array $key */ public function get($key) { return $this->getPayload($key)['data'] ?? null; } /** * Store an item in the cache for a given number of seconds. * @param string $key { if (is_array($key)) { return $this->many($key); } $value = $this->store->get($this->itemKey($key)); // If we could not find the cache value, we will fire the missed event and get // the default value for this cache value. This default could be a callback // so we will execute the value function which will resolve it if needed. if (is_null($value)) { * @param Closure $callback * @return mixed */ public function remember($key, $ttl, Closure $callback) { $value = $this->get($key); // If the item exists in the cache we will just return this immediately and if // not we will execute the given Closure and cache the result of that for a // given number of seconds so it's available for all subsequent requests. if (!is_null($value)) { try { if ($isCacheEnabled) { return self::getRepository() ->remember( $key, $ttl, $closure ); } else { return $closure(); md5($cleared_listing_sql) . '_' . __METHOD__, fn() => array_column( tep_db_query($cleared_listing_sql)->fetch_all(MYSQLI_ASSOC), 'products_id' ) );}/** * get count of comments */ $listing_sql .= " order by p.products_quantity > 0 desc, s.products_id desc"; break; } $listing_sql_raw = $listing_sql; // split query to 2 small queries: 1) find all products ids, 2) get info for each product $pids_price_filter_excluded = tep_get_all_pids_price_exclude($listing_sql, $price_filter_statement); $pids_filter_excluded = tep_get_all_pids_price_exclude($listing_sql, str_replace($price_filter_statement, '', $where_filters)); $pids_filter_excluded = $pids_filter_excluded ?: [0]; $where_attr = !empty($manFilter) ? str_replace($manFilter, '', $where_filters) : $where_filters; $pids_filter_attr_axcluded = tep_get_all_pids_price_exclude($listing_sql, str_replace($price_filter_statement, '', $where_attr));|
ErrorException
|
|---|
ErrorException:
fopen(/home/solomono/web/solomono.net/sites/motofix.com.ua/storage/cache/other/93332fcd13c810a75375d37d44f87802_tep_get_all_pids_price_exclude): failed to open stream: No such file or directory
at /mnt/test_sites/sites_new/motofix.com.ua/app/Classes/Filesystem/Filesystem.php:50
at Bootstrap\HandleExceptions->handleError()
(/mnt/test_sites/sites_new/motofix.com.ua/bootstrap/HandleExceptions.php:32)
at Bootstrap\HandleExceptions->Bootstrap\{closure}()
at fopen()
(/mnt/test_sites/sites_new/motofix.com.ua/app/Classes/Filesystem/Filesystem.php:50)
at App\Classes\Filesystem\Filesystem->sharedGet()
(/mnt/test_sites/sites_new/motofix.com.ua/app/Classes/Filesystem/Filesystem.php:38)
at App\Classes\Filesystem\Filesystem->get()
(/mnt/test_sites/sites_new/motofix.com.ua/app/Classes/Cache/Store/FileStore.php:185)
at App\Classes\Cache\Store\FileStore->getPayload()
(/mnt/test_sites/sites_new/motofix.com.ua/app/Classes/Cache/Store/FileStore.php:48)
at App\Classes\Cache\Store\FileStore->get()
(/mnt/test_sites/sites_new/motofix.com.ua/app/Classes/Cache/Repository.php:65)
at App\Classes\Cache\Repository->get()
(/mnt/test_sites/sites_new/motofix.com.ua/app/Classes/Cache/Repository.php:319)
at App\Classes\Cache\Repository->remember()
(/mnt/test_sites/sites_new/motofix.com.ua/app/Classes/Cache/Helpers/FileCacheHelper.php:185)
at App\Classes\Cache\Helpers\FileCacheHelper::remember()
(/mnt/test_sites/sites_new/motofix.com.ua/includes/functions/general.php:102)
at tep_get_all_pids_price_exclude()
(/mnt/test_sites/sites_new/motofix.com.ua/index.php:398)
|