Blame view

console/controllers/FeedController.php 2.47 KB
731adb96   Alex Savenko   remarketing
1
2
3
4
5
6
7
8
9
10
  <?php
  /**
   * Created by PhpStorm.
   * User: Alex Savenko
   * Date: 05.12.2016
   * Time: 18:36
   */
  
  namespace console\controllers;
  
e71d5d51   Alex Savenko   remarketing
11
  use yii\console\Controller;
731adb96   Alex Savenko   remarketing
12
  use Yii;
fd068f14   Alex Savenko   remarketing
13
  use yii\helpers\Url;
8d17a363   Alex Savenko   remarketing
14
15
  use yii\helpers\ArrayHelper;
  use yii\web\NotFoundHttpException;
64701daa   Alex Savenko   remarketing
16
17
  use common\modules\product\models\Product;
  use common\modules\product\models\ProductVariant;
8d17a363   Alex Savenko   remarketing
18
  
731adb96   Alex Savenko   remarketing
19
20
  class FeedController extends Controller
  {
9b454120   Alex Savenko   remarketing
21
      private $idList = [];
731adb96   Alex Savenko   remarketing
22
23
      private $count = 1;
  
e71d5d51   Alex Savenko   remarketing
24
      public function getProducts() {
99f3201f   Alex Savenko   remarketing
25
          return Product::find()
99f3201f   Alex Savenko   remarketing
26
              ->innerJoin(ProductVariant::tableName(), ProductVariant::tableName() .'.product_id = '. Product::tableName() .'.product_id')
cc601340   Alex Savenko   remarketing
27
              ->where(['and', ProductVariant::tableName().'.status = 0', ProductVariant::tableName().'.stock > 0'])
99f3201f   Alex Savenko   remarketing
28
              ->all();
e71d5d51   Alex Savenko   remarketing
29
      }
731adb96   Alex Savenko   remarketing
30
  
9b454120   Alex Savenko   remarketing
31
32
      public function createRow( $product, &$content ){
          if ($this->checkId($product->product_id)) {
99f3201f   Alex Savenko   remarketing
33
              print $this->count++ . "\r\n";
6a879063   Alex Savenko   remarketing
34
              $url = Url::to(['catalog/product', 'product' => $product]);
bf06fefc   Alex Savenko   remarketing
35
              $image = isset($product->image) ? $product->image->getImageUrl() : '/storage/no_photo.png';
0b1d02d7   Alex Savenko   remarketing
36
              $content[] = [
6c438de0   Alex Savenko   remarketing
37
                  $product->variant->product_variant_id,
0b1d02d7   Alex Savenko   remarketing
38
39
40
                  $product->category->category_id,
                  $product->category->name,
                  $product->name,
0b1d02d7   Alex Savenko   remarketing
41
                  $product->price.' UAH',
cef26674   Alex Savenko   remarketing
42
                  Yii::$app->urlManager->baseUrl.$image,
6a879063   Alex Savenko   remarketing
43
                  $url,
0b1d02d7   Alex Savenko   remarketing
44
              ];
9b454120   Alex Savenko   remarketing
45
46
47
48
49
50
          }
      }
  
      public function checkId($id){
          if(!in_array($id, $this->idList)){
              $this->idList[] = $id;
e71d5d51   Alex Savenko   remarketing
51
52
53
54
55
56
              return true;
          } else {
              return false;
          }
      }
  
731adb96   Alex Savenko   remarketing
57
58
      public function actionProcess() {
  
6a879063   Alex Savenko   remarketing
59
60
61
62
63
64
65
66
          $config = ArrayHelper::merge(
              require(__DIR__ . '/../../frontend/config/main.php'),
              require(__DIR__ . '/../../common/config/main.php')
  
          );
  
          Yii::$app->urlManager->addRules($config['components']['urlManager']['rules']);
  
731adb96   Alex Savenko   remarketing
67
68
69
70
          $dirName = Yii::getAlias('@frontend').'/web';
          $filename = 'feed.csv';
          setlocale(LC_ALL, 'ru_RU.CP1251');
  
0cd58f97   Alex Savenko   remarketing
71
          $handle = fopen($dirName .'/'. $filename, "w");
731adb96   Alex Savenko   remarketing
72
  
5150c258   Alex Savenko   remarketing
73
          $content[] = ['ID', 'ID2', 'Item Category', 'Item title', 'Price', 'Image URL', 'Final URL'];
e71d5d51   Alex Savenko   remarketing
74
  
050681b5   Alex Savenko   remarketing
75
76
77
          foreach ($this->getProducts() as $product) {
              $this->createRow($product, $content);
          }
e71d5d51   Alex Savenko   remarketing
78
79
  
          foreach ($content as $item) {
0b998826   Alex Savenko   remarketing
80
              fputcsv($handle, $item, ',');
e71d5d51   Alex Savenko   remarketing
81
          }
0cd58f97   Alex Savenko   remarketing
82
          fclose($handle);
731adb96   Alex Savenko   remarketing
83
84
85
86
  
          print $dirName .'/'. $filename;
      }
  }