Passed
Push — master ( f0002b...c777f5 )
by Aimeos
08:04 queued 04:27
created

Standard   A

Complexity

Total Complexity 7

Size/Duplication

Total Lines 67
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
eloc 28
dl 0
loc 67
rs 10
c 0
b 0
f 0
wmc 7

1 Method

Rating   Name   Duplication   Size   Complexity  
B process() 0 45 7
1
<?php
2
3
/**
4
 * @license LGPLv3, http://opensource.org/licenses/LGPL-3.0
5
 * @copyright Aimeos (aimeos.org), 2015-2023
6
 * @package Controller
7
 * @subpackage Common
8
 */
9
10
11
namespace Aimeos\Controller\Jobs\Common\Product\Import\Csv\Processor\Stock;
12
13
14
/**
15
 * Product stock processor for CSV imports
16
 *
17
 * @package Controller
18
 * @subpackage Common
19
 */
20
class Standard
21
	extends \Aimeos\Controller\Jobs\Common\Product\Import\Csv\Processor\Base
22
	implements \Aimeos\Controller\Jobs\Common\Product\Import\Csv\Processor\Iface
23
{
24
	/** controller/jobs/product/import/csv/processor/stock/name
25
	 * Name of the stock processor implementation
26
	 *
27
	 * Use "Myname" if your class is named "\Aimeos\Controller\Jobs\Common\Product\Import\Csv\Processor\Stock\Myname".
28
	 * The name is case-sensitive and you should avoid camel case names like "MyName".
29
	 *
30
	 * @param string Last part of the processor class name
31
	 * @since 2015.10
32
	 */
33
34
35
	/**
36
	 * Saves the product stock related data to the storage
37
	 *
38
	 * @param \Aimeos\MShop\Product\Item\Iface $product Product item with associated items
39
	 * @param array $data List of CSV fields with position as key and data as value
40
	 * @return array List of data which hasn't been imported
41
	 */
42
	public function process( \Aimeos\MShop\Product\Item\Iface $product, array $data ) : array
43
	{
44
		$manager = \Aimeos\MShop::create( $this->context(), 'stock' );
45
		$manager->begin();
46
47
		try
48
		{
49
			$stock = 0;
50
			$map = $this->getMappedChunk( $data, $this->getMapping() );
51
			$items = $manager->search( $manager->filter()->add( ['stock.productid' => $product->getId()] ) );
52
			$items = $items->col( null, 'stock.type' );
53
54
			foreach( $map as $pos => $list )
55
			{
56
				if( !array_key_exists( 'stock.stocklevel', $list ) ) {
57
					continue;
58
				}
59
60
				$list['stock.productid'] = $product->getId();
61
				$list['stock.type'] = $this->val( $list, 'stock.type', 'default' );
62
63
				$this->addType( 'stock/type', 'product', $list['stock.type'] );
64
65
				$item = $items->pull( $list['stock.type'] ) ?: $manager->create();
66
				$manager->save( $item->fromArray( $list ), false );
67
68
				if( $item->getStockLevel() === null || $item->getStockLevel() > 0 ) {
69
					$stock = 1;
70
				}
71
			}
72
73
			$manager->delete( $items );
74
			$product->setInStock( $stock );
75
76
			$data = $this->object()->process( $product, $data );
77
78
			$manager->commit();
79
		}
80
		catch( \Exception $e )
81
		{
82
			$manager->rollback();
83
			throw $e;
84
		}
85
86
		return $data;
87
	}
88
}
89