-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathDatabaseStorage.php
99 lines (83 loc) · 2.62 KB
/
DatabaseStorage.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
<?php
/*
* This file is part of ibrand/laravel-shopping-cart.
*
* (c) iBrand <https://www.ibrand.cc>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace iBrand\Shoppingcart\Storage;
use DB;
use iBrand\Shoppingcart\Item;
use Illuminate\Database\Eloquent\Collection;
/**
* Class DatabaseStorage.
*/
class DatabaseStorage implements Storage
{
/**
* @var string
*/
private $table = 'shopping_cart';
/**
* @var array
*/
private $filed = ['__raw_id', 'id', 'name', 'qty', 'price', 'total', '__model', 'type', 'status'];
/**
* @param $key
* @param $values
*/
public function set($key, $values)
{
if (is_null($values)) {
$this->forget($key);
return;
}
$rawIds = $values->pluck('__raw_id')->toArray();
//Delete the data that has been removed from cart.
DB::table($this->table)->whereNotIn('__raw_id', $rawIds)->where('key', $key)->delete();
$keys = explode('.', $key);
$userId = end($keys);
$guard = prev($keys);
$values = $values->toArray();
foreach ($values as $value) {
$item = array_only($value, $this->filed);
$attr = json_encode(array_except($value, $this->filed));
$insert = array_merge($item, ['attributes' => $attr, 'key' => $key, 'guard' => $guard, 'user_id' => $userId]);
if (DB::table($this->table)->where(['key' => $key, '__raw_id' => $item['__raw_id']])->first()) {
DB::table($this->table)->where(['key' => $key, '__raw_id' => $item['__raw_id']])
->update(array_except($insert, ['key', '__raw_id']));
} else {
DB::table($this->table)->insert($insert);
}
}
}
/**
* @param $key
* @param null $default
*
* @return Collection
*/
public function get($key, $default = null)
{
$items = DB::table($this->table)->where('key', $key)->get();
$items = $items->toArray();
$collection = [];
foreach ($items as $item) {
$item = json_decode(json_encode($item), true);
$attr = json_decode($item['attributes'], true);
$item = array_only($item, $this->filed);
$item = array_merge($item, $attr);
$collection[$item['__raw_id']] = new Item($item);
}
return new Collection($collection);
}
/**
* @param $key
*/
public function forget($key)
{
DB::table($this->table)->where('key', $key)->delete();
}
}