• 01-03-2022, 08:57:37
    #1
    Merhabalar,

    Bu sabah sitede böyle bir hata verdi ( gece çalışan sitede sabah ilk mesai saatlerinde aldığım hata )

    Açıkçası modülü pasif ettiğimde site açılmıyor ancak modül kodlarını kontrol ettiğimde de bir sorun göremedim . Eski yedekte aynı modül dosyasını atıyorum gene de düzelmiyor .

    Fatal error: Call to undefined method Currency::getCodeOrDefault() in /home/tatoglub/uni-t.com.tr/catalog/model/module/navaprakashspecialtimer.php on line 35

    modül içeriği ;

    <?php
    class ModelModuleNavaprakashspecialtimer extends Model {
    
        public function getProduct($product_id) {
            $query = $this->db->query("SELECT DISTINCT *, pd.name AS name, p.image, m.name AS manufacturer, (SELECT price FROM " . DB_PREFIX . "product_discount pd2 WHERE pd2.product_id = p.product_id AND pd2.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND pd2.quantity = '1' AND ((pd2.date_start = '0000-00-00' OR pd2.date_start < NOW()) AND (pd2.date_end = '0000-00-00' OR pd2.date_end > NOW())) ORDER BY pd2.priority ASC, pd2.price ASC LIMIT 1) AS discount, (SELECT price FROM " . DB_PREFIX . "product_special ps WHERE ps.product_id = p.product_id AND ps.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW())) ORDER BY ps.priority ASC, ps.price ASC LIMIT 1) AS special,(SELECT date_end FROM " . DB_PREFIX . "product_special ps WHERE ps.product_id = p.product_id AND ps.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW())) ORDER BY ps.priority ASC, ps.price ASC LIMIT 1) AS date_end,(SELECT points FROM " . DB_PREFIX . "product_reward pr WHERE pr.product_id = p.product_id AND customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "') AS reward, (SELECT ss.name FROM " . DB_PREFIX . "stock_status ss WHERE ss.stock_status_id = p.stock_status_id AND ss.language_id = '" . (int)$this->config->get('config_language_id') . "') AS stock_status, (SELECT wcd.unit FROM " . DB_PREFIX . "weight_class_description wcd WHERE p.weight_class_id = wcd.weight_class_id AND wcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS weight_class, (SELECT lcd.unit FROM " . DB_PREFIX . "length_class_description lcd WHERE p.length_class_id = lcd.length_class_id AND lcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS length_class, (SELECT AVG(rating) AS total FROM " . DB_PREFIX . "review r1 WHERE r1.product_id = p.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating, (SELECT COUNT(*) AS total FROM " . DB_PREFIX . "review r2 WHERE r2.product_id = p.product_id AND r2.status = '1' GROUP BY r2.product_id) AS reviews, p.sort_order FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) LEFT JOIN " . DB_PREFIX . "manufacturer m ON (p.manufacturer_id = m.manufacturer_id) WHERE p.product_id = '" . (int)$product_id . "' AND pd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'");
    
            if ($query->num_rows) {
    
                $date_end = $query->row['date_end'];
                if($date_end=='0000-00-00'){
                $date_end = date('Y-m-d', strtotime('+1 year'));
                }
    
                return array(
                    'product_id'       => $query->row['product_id'],
                    'name'             => $query->row['name'],
                    'description'      => $query->row['description'],
                    'meta_title'       => $query->row['meta_title'],
                    'meta_description' => $query->row['meta_description'],
                    'meta_keyword'     => $query->row['meta_keyword'],
                    'tag'              => $query->row['tag'],
                    'model'            => $query->row['model'],
                    'sku'              => $query->row['sku'],
                    'upc'              => $query->row['upc'],
                    'ean'              => $query->row['ean'],
                    'jan'              => $query->row['jan'],
                    'isbn'             => $query->row['isbn'],
                    'mpn'              => $query->row['mpn'],
                    'location'         => $query->row['location'],
                    'quantity'         => $query->row['quantity'],
                    'stock_status'     => $query->row['stock_status'],
                    'image'            => $query->row['image'],
                    'manufacturer_id'  => $query->row['manufacturer_id'],
                    'manufacturer'     => $query->row['manufacturer'],
                    'price'            =>$this->currency->convert(($query->row['discount'] ? $query->row['discount'] : $query->row['price']), $this->currency->getCodeOrDefault($query->row['currency_id']), $this->config->get('config_currency')),
                    'currency_id' => $query->row['currency_id'],
                    'special'          => $this->currency->convert($query->row['special'], $this->currency->getCodeOrDefault($query->row['currency_id']), $this->config->get('config_currency')),
                    'reward'           => $query->row['reward'],
                    'points'           => $query->row['points'],
                    'tax_class_id'     => $query->row['tax_class_id'],
                    'date_available'   => $query->row['date_available'],
                    'weight'           => $query->row['weight'],
                    'weight_class_id'  => $query->row['weight_class_id'],
                    'length'           => $query->row['length'],
                    'width'            => $query->row['width'],
                    'height'           => $query->row['height'],
                    'length_class_id'  => $query->row['length_class_id'],
                    'subtract'         => $query->row['subtract'],
                    'rating'           => round($query->row['rating']),
                    'reviews'          => $query->row['reviews'] ? $query->row['reviews'] : 0,
                    'minimum'          => $query->row['minimum'],
                    'sort_order'       => $query->row['sort_order'],
                    'status'           => $query->row['status'],
                    'date_added'       => $query->row['date_added'],
                    'date_modified'    => $query->row['date_modified'],
                    'viewed'           => $query->row['viewed'],
                    'date_end'         => $date_end 
                );
            } else {
                return false;
            }
        }
    
    
    
        public function getProductSpecials($data = array()) {
            $sql = "SELECT DISTINCT ps.product_id, (SELECT AVG(rating) FROM " . DB_PREFIX . "review r1 WHERE r1.product_id = ps.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating FROM " . DB_PREFIX . "product_special ps LEFT JOIN " . DB_PREFIX . "product p ON (ps.product_id = p.product_id) LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) WHERE p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "' AND ps.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW())) GROUP BY ps.product_id";
    
            $sort_data = array(
                'pd.name',
                'p.model',
                'ps.price',
                'rating',
                'p.sort_order'
            );
    
            if (isset($data['sort']) && in_array($data['sort'], $sort_data)) {
                if ($data['sort'] == 'pd.name' || $data['sort'] == 'p.model') {
                    $sql .= " ORDER BY LCASE(" . $data['sort'] . ")";
                } else {
                    $sql .= " ORDER BY " . $data['sort'];
                }
            } else {
                $sql .= " ORDER BY p.sort_order";
            }
    
            if (isset($data['order']) && ($data['order'] == 'DESC')) {
                $sql .= " DESC, LCASE(pd.name) DESC";
            } else {
                $sql .= " ASC, LCASE(pd.name) ASC";
            }
    
            if (isset($data['start']) || isset($data['limit'])) {
                if ($data['start'] < 0) {
                    $data['start'] = 0;
                }
    
                if ($data['limit'] < 1) {
                    $data['limit'] = 20;
                }
    
                $sql .= " LIMIT " . (int)$data['start'] . "," . (int)$data['limit'];
            }
    
            $product_data = array();
    
            $query = $this->db->query($sql);
    
            foreach ($query->rows as $result) {
                $product_data[$result['product_id']] = $this->getProduct($result['product_id']);
            }
    
            return $product_data;
        }
    
        
    }
    [B][/B]
  • 01-03-2022, 09:03:58
    #2
    Özelden anydesk iletebilir misiniz inceliyeyim
  • 01-03-2022, 09:04:09
    #3
    Üyeliği durduruldu
    Önbellek temizlediniz mi ?
  • 01-03-2022, 09:17:55
    #4
    Bybitter adlı üyeden alıntı: mesajı görüntüle
    Özelden anydesk iletebilir misiniz inceliyeyim
    Çok teşekkürler ediyorum .

    Konu hakkında bilmeyenler için ;

    Admin , modifikasyonlara girerek Günlük Temizliği butonuna basmanız yeterli . @Bybitter arkadaşımıza teşekkürler ediyorum.

  • 01-03-2022, 10:09:09
    #5
    Üyeliği durduruldu
    Tatoglubilisim adlı üyeden alıntı: mesajı görüntüle
    Çok teşekkürler ediyorum .

    Konu hakkında bilmeyenler için ;

    Admin , modifikasyonlara girerek Günlük Temizliği butonuna basmanız yeterli . @Bybitter arkadaşımıza teşekkürler ediyorum.

    Neden olduğu da : hata eğer bir eklenti kaynaklı ise ve düzenlenmiş ise, önbellekde durur opencartta. önbelleği sıfırladığınızda hata ortadan kalkar. çözüm basit. herkese kolay gelsin