403Webshell
Server IP : 80.87.202.40  /  Your IP : 216.73.216.169
Web Server : Apache
System : Linux rospirotorg.ru 5.14.0-539.el9.x86_64 #1 SMP PREEMPT_DYNAMIC Thu Dec 5 22:26:13 UTC 2024 x86_64
User : bitrix ( 600)
PHP Version : 8.2.27
Disable Function : NONE
MySQL : OFF |  cURL : ON |  WGET : ON |  Perl : ON |  Python : OFF |  Sudo : ON |  Pkexec : ON
Directory :  /home/bitrix/ext_www/rospirotorg.ru/bitrix/modules/wbs24.ozonexport/lib/

Upload File :
current_dir [ Writeable] document_root [ Writeable]

 

Command :


[ Back ]     

Current File : /home/bitrix/ext_www/rospirotorg.ru/bitrix/modules/wbs24.ozonexport/lib/OffersLog.php
<?php
namespace Wbs24\Ozonexport;

class OffersLog
{
    protected $param;
    protected $table = 'wbs24_ozonexport_offers_log';
    protected $offersLogOn;
    protected $profileId;
    protected $nullOfferLifetime;

    protected $db;

    function __construct($param = [])
    {
        $this->setParam($param);

        $objects = $this->param['objects'] ?? [];
        $this->db = $objects['Db'] ?? new Db();

        $this->offersLogOn = $this->param['offersLogOn'] ?? false;
        $this->profileId = $this->param['profileId'] ?? 0;
        if (!$this->offersLogOn) $this->profileId = 0;
        $nullOfferLifetimeDays = $this->param['nullOfferLifetimeDays'] ?? 1;
        $this->nullOfferLifetime = intval($nullOfferLifetimeDays) * 86400;
    }

    public function setParam($param)
    {
        foreach ($param as $name => $value) {
            $this->param[$name] = $value;
        }
    }

    public function startOffersLog()
    {
        if (!$this->profileId) return;

        $data = [
            'normal_export_time' => 0,
        ];
        $where = [
            'profile_id' => $this->profileId,
        ];
        $this->db->update($this->table, $data, $where);
    }

    public function clearOffersLog()
    {
        $this->clearOldOffersLog(true);
    }

    public function clearOldOffersLog($all = false)
    {
        if (!$this->profileId) return;

        $minNullExportTime = time() - $this->nullOfferLifetime;
        $where = [
            'profile_id' => $this->profileId,
        ];
        if (!$all) {
            $where['<null_export_time'] = $minNullExportTime;
            $where['>null_export_time'] = 0;
        }
        $this->db->clear($this->table, $where);
    }

    public function addOfferToLog($offerInfo)
    {
        if (!$this->profileId) return;

        $offerInfo['profile_id'] = $this->profileId;
        $offerInfo['normal_export_time'] = time();
        $offerInfo['null_export_time'] = 0;

        $this->db->set($this->table, $offerInfo);
    }

    public function getNullOffersAsXml($nullStocksXml)
    {
        $offers = $this->getNullOffers();
        $xml = '';

        foreach ($offers as $offer) {
            $xml .= '<offer id="'.$offer['offer_id'].'">'."\n";
            $xml .= "<price>".$offer['price']."</price>\n";
            $xml .= "<oldprice>0</oldprice>\n";
            $xml .= "<min_price>0</min_price>\n";
            $xml .= $nullStocksXml;
            $xml .= "</offer>\n";
        }

        return $xml;
    }

    protected function getNullOffers()
    {
        if (!$this->profileId) return [];

        $where = [
            'profile_id' => $this->profileId,
            'normal_export_time' => 0,
        ];
        $param = [
            'order' => 'id',
        ];
        $offers = $this->db->get($this->table, $where, $param);

        $data = [
            'null_export_time' => time(),
        ];
        $where = [
            'profile_id' => $this->profileId,
            'normal_export_time' => 0,
            'null_export_time' => 0,
        ];
        $this->db->update($this->table, $data, $where);

        return $offers;
    }
}

Youez - 2016 - github.com/yon3zu
LinuXploit