Completed
Pull Request — master (#593)
by thomas
15:02
created

TimeLock::__construct()   A

Complexity

Conditions 4
Paths 3

Size

Total Lines 13
Code Lines 8

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 20

Importance

Changes 0
Metric Value
cc 4
eloc 8
nc 3
nop 1
dl 0
loc 13
ccs 0
cts 12
cp 0
crap 20
rs 9.2
c 0
b 0
f 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace BitWasp\Bitcoin\Transaction\Factory;
6
7
use BitWasp\Bitcoin\Transaction\Factory\ScriptInfo\CheckLocktimeVerify;
8
use BitWasp\Bitcoin\Transaction\Factory\ScriptInfo\CheckSequenceVerify;
9
10
class TimeLock
11
{
12
    /**
13
     * @var CheckLocktimeVerify|CheckSequenceVerify
14
     */
15
    private $info;
16
17
    /**
18
     * TimeLock constructor.
19
     * @param CheckLocktimeVerify|CheckSequenceVerify $info
20
     */
21
    public function __construct($info)
22
    {
23
        if (is_object($info)) {
24
            $class = get_class($info);
25
            if ($class !== CheckLocktimeVerify::class && $class !== CheckSequenceVerify::class) {
26
                throw new \RuntimeException("Invalid script info for TimeLock, must be CLTV/CSV");
27
            }
28
        } else {
29
            throw new \RuntimeException("Invalid script info for TimeLock, must be a script info object");
30
        }
31
32
        $this->info = $info;
33
    }
34
35
    /**
36
     * @return CheckLocktimeVerify|CheckSequenceVerify
37
     */
38
    public function getInfo()
39
    {
40
        return $this->info;
41
    }
42
}
43