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) {
|
0716cf79
Mihail
fixed testing iss...
|
64
65
|
if(isset( $row['PRICE'] ))
$row['PRICE'] = \Yii::$app->converter->convertTo('float',$row['PRICE']);
|
ae83e13e
Mihail
finish with xml a...
|
66
|
|
0716cf79
Mihail
fixed testing iss...
|
67
68
|
if(isset( $row['BOX'] ))
$row['BOX'] = \Yii::$app->converter->convertTo('integer',$row['BOX']);
|
34d480b7
Mihail
temp commit - wor...
|
69
|
// присвоим полный артикул
|
706a1491
Mihail
add form, model a...
|
70
|
|
0716cf79
Mihail
fixed testing iss...
|
71
72
73
|
if( isset( $row['ARTICLE'] ) ) {
$row['FULL_ARTICLE'] = $row['ARTICLE'];
|
706a1491
Mihail
add form, model a...
|
74
|
|
0716cf79
Mihail
fixed testing iss...
|
75
76
77
78
79
80
81
|
if ((int)$this->configuration['delete_prefix']) {
$row = \Yii::$app->converter->convertTo('Article', $row, ['importer_id' => $this->configuration['importer_id']]);
} else {
if (isset($row['ARTICLE']))
$row['ARTICLE'] = \Yii::$app->converter->convertTo('Article', $row['ARTICLE']);
}
}
|
706a1491
Mihail
add form, model a...
|
82
|
|
38a1a201
Mihail
add delete func i...
|
83
|
if (isset($row['ADD_BOX']))
|
6215a30d
Mihail
add converter int...
|
84
|
$row['ADD_BOX'] = \Yii::$app->converter->convertTo( 'integer', $row['ADD_BOX'] );
|
34d480b7
Mihail
temp commit - wor...
|
85
86
87
|
// проверим все ли обязательные колонки были указаны пользователем
$details_model->load(['Details' => $row]);
|
34d480b7
Mihail
temp commit - wor...
|
88
|
if (!$details_model->validate())
|
0716cf79
Mihail
fixed testing iss...
|
89
|
$details_model->throwStringErrorException( key($this->data) );
|
34d480b7
Mihail
temp commit - wor...
|
90
91
|
}
|
2edfb901
Mihail
add PriceWriter a...
|
92
|
}
|
34d480b7
Mihail
temp commit - wor...
|
93
|
|
38a1a201
Mihail
add delete func i...
|
94
|
// дополним данные значением импортера и даты обновления цены
|
6215a30d
Mihail
add converter int...
|
95
|
$this->data = CustomArrayHelper::addColumns( $this->data, ['IMPORT_ID' => $this->configuration['importer_id'], 'timestamp' => $update_date] );
|
38a1a201
Mihail
add delete func i...
|
96
|
try {
|
2edfb901
Mihail
add PriceWriter a...
|
97
|
|
3c4b566f
Mihail
add XlsxParser
|
98
|
if ( isset($this->configuration['delete_price']) && (int)$this->configuration['delete_price'] ) {
|
38a1a201
Mihail
add delete func i...
|
99
100
|
$details_model->delete_price = true;
}
|
0716cf79
Mihail
fixed testing iss...
|
101
|
$transaction = \Yii::$app->db->beginTransaction();
|
38a1a201
Mihail
add delete func i...
|
102
103
|
//2. попытаемся вставить данные в БД с апдейтом по ключам
$details_model->ManualInsert($this->data, $this->configuration['importer_id']);
|
2edfb901
Mihail
add PriceWriter a...
|
104
|
|
38a1a201
Mihail
add delete func i...
|
105
106
|
// 3. зафиксируем дату конца загрузки в файлах поставщика
if (!$files_model->save()) {
|
0716cf79
Mihail
fixed testing iss...
|
107
|
$transaction->rollBack();
|
38a1a201
Mihail
add delete func i...
|
108
109
|
throw new \ErrorException(implode(', ', $files_model->getErrors()));
}
|
2edfb901
Mihail
add PriceWriter a...
|
110
|
|
38a1a201
Mihail
add delete func i...
|
111
112
113
|
// 4. зафиксируем дату загрузки в таблице поставщиков
$imp_model = Importers::findOne($this->configuration['importer_id']);
$imp_model->price_date_update = $update_date;
|
2edfb901
Mihail
add PriceWriter a...
|
114
|
|
38a1a201
Mihail
add delete func i...
|
115
|
if (!$imp_model->save()) {
|
0716cf79
Mihail
fixed testing iss...
|
116
|
$transaction->rollBack();
|
38a1a201
Mihail
add delete func i...
|
117
|
throw new \ErrorException(implode(', ', $imp_model->getErrors()));
|
2edfb901
Mihail
add PriceWriter a...
|
118
|
}
|
0716cf79
Mihail
fixed testing iss...
|
119
120
|
$transaction->commit();
|
38a1a201
Mihail
add delete func i...
|
121
|
} catch (ErrorException $e) {
|
0716cf79
Mihail
fixed testing iss...
|
122
|
$transaction->rollBack();
|
38a1a201
Mihail
add delete func i...
|
123
124
|
throw new \ErrorException($e->getMessage());
}
|
2edfb901
Mihail
add PriceWriter a...
|
125
126
127
128
|
return true;
}
|
df629228
Mihail
console csv parsing
|
129
130
|
|
2edfb901
Mihail
add PriceWriter a...
|
131
|
}
|