Note::save()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 6

Duplication

Lines 6
Ratio 100 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 0
Metric Value
dl 6
loc 6
ccs 0
cts 6
cp 0
rs 10
c 0
b 0
f 0
cc 1
nc 1
nop 1
crap 2
1
<?php
2
3
namespace Codexshaper\WooCommerce\Models;
4
5
use Codexshaper\WooCommerce\Facades\Query;
6
use Codexshaper\WooCommerce\Traits\QueryBuilderTrait;
7
8 View Code Duplication
class Note extends BaseModel
0 ignored issues
show
Duplication introduced by
This class seems to be duplicated in your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
9
{
10
    use QueryBuilderTrait;
11
12
    protected $endpoint;
13
14
    /**
15
     * Retrieve all Items.
16
     *
17
     * @param int   $order_id
18
     * @param array $options
19
     *
20
     * @return array
21
     */
22
    protected function all($order_id, $options = [])
23
    {
24
        return Query::init()
25
            ->setEndpoint("orders/{$order_id}/notes")
26
            ->all($options);
27
    }
28
29
    /**
30
     * Retrieve single Item.
31
     *
32
     * @param int   $order_id
33
     * @param int   $note_id
34
     * @param array $options
35
     *
36
     * @return object
37
     */
38
    protected function find($order_id, $note_id, $options = [])
39
    {
40
        return Query::init()
41
            ->setEndpoint("orders/{$order_id}/notes")
42
            ->find($note_id, $options);
43
    }
44
45
    /**
46
     * Create new Item.
47
     *
48
     * @param int   $order_id
49
     * @param array $data
50
     *
51
     * @return object
52
     */
53
    protected function create($order_id, $data)
54
    {
55
        return Query::init()
56
            ->setEndpoint("orders/{$order_id}/notes")
57
            ->create($data);
58
    }
59
60
    /**
61
     * Destroy Item.
62
     *
63
     * @param int   $order_id
64
     * @param int   $note_id
65
     * @param array $options
66
     *
67
     * @return object
68
     */
69
    protected function delete($order_id, $note_id, $options = [])
70
    {
71
        return Query::init()
72
            ->setEndpoint("orders/{$order_id}/notes")
73
            ->delete($note_id, $options);
74
    }
75
76
    /**
77
     * Paginate results.
78
     *
79
     *
80
     * @param int   $order_id
81
     * @param int   $per_page
82
     * @param int   $current_page
83
     * @param array $options
84
     *
85
     * @return array
86
     */
87
    protected function paginate(
88
        $order_id,
89
        $per_page = 10,
90
        $current_page = 1,
91
        $options = []
92
    ) {
93
        return Query::init()
94
            ->setEndpoint("orders/{$order_id}/notes")
95
            ->paginate($per_page, $current_page, $options);
96
    }
97
98
    /**
99
     * Count all results.
100
     *
101
     * @param int $order_id
102
     *
103
     * @return int
104
     */
105
    protected function count($order_id)
106
    {
107
        return Query::init()
108
            ->setEndpoint("orders/{$order_id}/notes")
109
            ->count();
110
    }
111
112
    /**
113
     * Store data.
114
     *
115
     * @param int $order_id
116
     *
117
     * @return array
118
     */
119
    public function save($order_id)
120
    {
121
        return Query::init()
122
            ->setEndpoint("orders/{$order_id}/notes")
123
            ->save();
124
    }
125
}
126