2edfb901
Mihail
add PriceWriter a...
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
<?php
/**
* Created by PhpStorm.
* User: Cibermag
* Date: 30.09.2015
* Time: 9:34
*/
namespace common\components;
use yii\base\ErrorException;
use backend\models\ImportersFiles;
use backend\models\Importers;
use backend\models\Details;
|
38a1a201
Mihail
add delete func i...
|
17
18
19
20
21
22
23
24
25
26
27
|
/**
* Class PriceWriter
* @package common\components
* записывает в БД отпарсенные данные
* запись происходит в несколько таблиц
*/
class PriceWriter
{
/**
* @var - int - 0 - интерактивный режим, 1 - консольный
*/
|
2edfb901
Mihail
add PriceWriter a...
|
28
|
public $mode;
|
38a1a201
Mihail
add delete func i...
|
29
30
31
32
|
/**
* @var - массив с настройками записи
*/
|
2edfb901
Mihail
add PriceWriter a...
|
33
|
public $configuration;
|
38a1a201
Mihail
add delete func i...
|
34
35
36
37
|
/**
* @var - массив с данными которые нужно записать
*/
|
2edfb901
Mihail
add PriceWriter a...
|
38
|
public $data;
|
2edfb901
Mihail
add PriceWriter a...
|
39
|
|
38a1a201
Mihail
add delete func i...
|
40
41
42
43
44
45
|
function __construct()
{
set_time_limit(300);
}
public function writeDataToDB()
|
2edfb901
Mihail
add PriceWriter a...
|
46
47
48
|
{
// 1. запишем дату старта в таблицу файлов поставщика (ImportersFiles)
// id загруженного файла получим из конфигурации
|
38a1a201
Mihail
add delete func i...
|
49
|
$files_model = ImportersFiles::findOne($this->configuration['record_id']);
|
2edfb901
Mihail
add PriceWriter a...
|
50
|
|
2edfb901
Mihail
add PriceWriter a...
|
51
52
53
54
|
$update_date = date('Y-m-d H:i:s');
$files_model->time_start = $update_date;
// запишем дату начала загрузки
if (!$files_model->save()) {
|
38a1a201
Mihail
add delete func i...
|
55
|
throw new \ErrorException(implode(', ', $files_model->getErrors()));
|
2edfb901
Mihail
add PriceWriter a...
|
56
57
|
}
|
2edfb901
Mihail
add PriceWriter a...
|
58
59
|
// 2. запишем полученные данные в таблицу товаров (Details)
$details_model = new Details();
|
34d480b7
Mihail
temp commit - wor...
|
60
|
// только для ручной загрузки, в авто режиме все делает конвертер при первом же проходе (в процессе парсинга)
|
df629228
Mihail
console csv parsing
|
61
|
if ($this->mode == 0) {
|
34d480b7
Mihail
temp commit - wor...
|
62
63
|
// преобразуем числовые значения
foreach ($this->data as &$row) {
|
ae83e13e
Mihail
finish with xml a...
|
64
|
|
34d480b7
Mihail
temp commit - wor...
|
65
66
67
68
|
$row['PRICE'] = \Yii::$app->multiparser->convertToFloat($row['PRICE']);
$row['BOX'] = \Yii::$app->multiparser->convertToInteger($row['BOX']);
// присвоим полный артикул
$row['FULL_ARTICLE'] = $row['ARTICLE'];
|
38a1a201
Mihail
add delete func i...
|
69
|
if (isset($row['ADD_BOX']))
|
34d480b7
Mihail
temp commit - wor...
|
70
71
72
73
|
$row['ADD_BOX'] = \Yii::$app->multiparser->convertToInteger($row['ADD_BOX']);
// проверим все ли обязательные колонки были указаны пользователем
$details_model->load(['Details' => $row]);
|
34d480b7
Mihail
temp commit - wor...
|
74
75
76
77
78
|
if (!$details_model->validate())
//@todo предоставить более детальную информацию об ошибке
throw new \ErrorException('Ошибка записи товаров');
}
|
2edfb901
Mihail
add PriceWriter a...
|
79
|
}
|
34d480b7
Mihail
temp commit - wor...
|
80
|
|
38a1a201
Mihail
add delete func i...
|
81
82
83
84
|
// дополним данные значением импортера и даты обновления цены
$this->data = \Yii::$app->multiparser->addColumns($this->data, ['IMPORT_ID' => $this->configuration['importer_id'], 'timestamp' => $update_date]);
try {
//@todo add transaction
|
2edfb901
Mihail
add PriceWriter a...
|
85
|
|
38a1a201
Mihail
add delete func i...
|
86
87
88
89
90
91
92
93
|
if ((int)$this->configuration['delete_prefix']) {
$details_model->delete_prefix = true;
}
if ((int)$this->configuration['delete_price']) {
$details_model->delete_price = true;
}
//2. попытаемся вставить данные в БД с апдейтом по ключам
$details_model->ManualInsert($this->data, $this->configuration['importer_id']);
|
2edfb901
Mihail
add PriceWriter a...
|
94
|
|
38a1a201
Mihail
add delete func i...
|
95
96
97
98
|
// 3. зафиксируем дату конца загрузки в файлах поставщика
if (!$files_model->save()) {
throw new \ErrorException(implode(', ', $files_model->getErrors()));
}
|
2edfb901
Mihail
add PriceWriter a...
|
99
|
|
38a1a201
Mihail
add delete func i...
|
100
101
102
|
// 4. зафиксируем дату загрузки в таблице поставщиков
$imp_model = Importers::findOne($this->configuration['importer_id']);
$imp_model->price_date_update = $update_date;
|
2edfb901
Mihail
add PriceWriter a...
|
103
|
|
38a1a201
Mihail
add delete func i...
|
104
105
|
if (!$imp_model->save()) {
throw new \ErrorException(implode(', ', $imp_model->getErrors()));
|
2edfb901
Mihail
add PriceWriter a...
|
106
|
}
|
38a1a201
Mihail
add delete func i...
|
107
108
109
|
} catch (ErrorException $e) {
throw new \ErrorException($e->getMessage());
}
|
2edfb901
Mihail
add PriceWriter a...
|
110
111
112
113
|
return true;
}
|
df629228
Mihail
console csv parsing
|
114
115
|
|
2edfb901
Mihail
add PriceWriter a...
|
116
|
}
|