Passed
Push — master ( d5901e...869fb0 )
by Vladislav
03:02 queued 37s
created

MarkPriceKlineRequest::setCategory()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 2
nc 1
nop 1
dl 0
loc 4
rs 10
c 0
b 0
f 0
1
<?php
2
namespace Carpenstar\ByBitAPI\Derivatives\MarketData\MarkPriceKline\Request;
3
4
use Carpenstar\ByBitAPI\Core\Helpers\DateTimeHelper;
5
use Carpenstar\ByBitAPI\Core\Helpers\StringHelper;
6
use Carpenstar\ByBitAPI\Core\Objects\AbstractParameters;
7
8
class MarkPriceKlineRequest extends AbstractParameters
9
{
10
    /**
11
     * Product type. linear
12
     * @var string $category
13
     */
14
    protected string $category;
15
16
    /**
17
     * Symbol name
18
     * @var string $symbol
19
     */
20
    protected string $symbol;
21
22
    /**
23
     * Kline interval. 1 3 5 15 30 60 120 240 360 720 D M W
24
     * @var string $interval
25
     */
26
    protected string $interval;
27
28
    /**
29
     * The start timestamp (ms)
30
     * @var \DateTime $startTime
31
     */
32
    protected \DateTime $startTime;
33
34
    /**
35
     * The end timestamp (ms)
36
     * @var \DateTime $endTime
37
     */
38
    protected \DateTime $endTime;
39
40
    /**
41
     * Limit for data size per page. [1, 200]. Default: 200
42
     * @var int $limit
43
     */
44
    protected int $limit = 200;
45
46
    public function __construct()
47
    {
48
        $this
49
            ->setRequiredField('symbol')
50
            ->setRequiredField('interval')
51
            ->setRequiredField('startTime')
52
            ->setRequiredField('endTime');
53
    }
54
55
    /**
56
     * @return string
57
     */
58
    public function getCategory(): string
59
    {
60
        return $this->category;
61
    }
62
63
    /**
64
     * @param string $symbol
65
     * @return MarkPriceKlineRequest
66
     */
67
    public function setSymbol(string $symbol): self
68
    {
69
        $this->symbol = $symbol;
70
        return $this;
71
    }
72
73
    /**
74
     * @return string
75
     */
76
    public function getSymbol(): string
77
    {
78
        return $this->symbol;
79
    }
80
81
    /**
82
     * @param string $interval
83
     * @return MarkPriceKlineRequest
84
     */
85
    public function setInterval(string $interval): self
86
    {
87
        $this->interval = StringHelper::clearInterval($interval);
88
        return $this;
89
    }
90
91
    /**
92
     * @return string
93
     */
94
    public function getInterval(): string
95
    {
96
        return $this->interval;
97
    }
98
99
    /**
100
     * @param int $startTime
101
     * @return MarkPriceKlineRequest
102
     */
103
    public function setStartTime(int $startTime): self
104
    {
105
        $this->startTime = DateTimeHelper::makeFromTimestamp($startTime);
106
        return $this;
107
    }
108
109
    /**
110
     * @return \DateTime
111
     */
112
    public function getStartTime(): \DateTime
113
    {
114
        return $this->startTime;
115
    }
116
117
    /**
118
     * @param int $endTime
119
     * @return MarkPriceKlineRequest
120
     */
121
    public function setEndTime(int $endTime): self
122
    {
123
        $this->endTime = DateTimeHelper::makeFromTimestamp($endTime);
124
        return $this;
125
    }
126
127
    /**
128
     * @return \DateTime
129
     */
130
    public function getEndTime(): \DateTime
131
    {
132
        return $this->endTime;
133
    }
134
135
    /**
136
     * @param int $limit
137
     * @return MarkPriceKlineRequest
138
     */
139
    public function setLimit(int $limit): self
140
    {
141
        $this->limit = $limit;
142
        return $this;
143
    }
144
145
    /**
146
     * @return int
147
     */
148
    public function getLimit(): int
149
    {
150
        return $this->limit;
151
    }
152
}