DateTime   A
last analyzed

Complexity

Total Complexity 2

Size/Duplication

Total Lines 30
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 0

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
wmc 2
lcom 0
cbo 0
dl 0
loc 30
ccs 6
cts 6
cp 1
rs 10
c 0
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A createFromDateTime() 0 9 1
A jsonSerialize() 0 4 1
1
<?php declare (strict_types = 1);
2
3
namespace Limoncello\Flute\Types;
4
5
/**
6
 * Copyright 2015-2019 [email protected]
7
 *
8
 * Licensed under the Apache License, Version 2.0 (the "License");
9
 * you may not use this file except in compliance with the License.
10
 * You may obtain a copy of the License at
11
 *
12
 * http://www.apache.org/licenses/LICENSE-2.0
13
 *
14
 * Unless required by applicable law or agreed to in writing, software
15
 * distributed under the License is distributed on an "AS IS" BASIS,
16
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17
 * See the License for the specific language governing permissions and
18
 * limitations under the License.
19
 */
20
21
use DateTimeImmutable;
22
use DateTimeInterface;
23
use Exception;
24
use JsonSerializable;
25
26
/**
27
 * Wrapper class for `DateTimeInterface` value with JSON serialization support.
28
 *
29
 * @package Limoncello\Flute
30
 */
31
class DateTime extends DateTimeImmutable implements JsonSerializable
32
{
33
    /** DateTime format */
34
    const JSON_API_FORMAT = \DateTime::ISO8601;
35
36
    /**
37
     * @param DateTimeInterface $dateTime
38
     *
39
     * @return DateTime
40
     *
41
     * @throws Exception
42
     */
43 37
    public static function createFromDateTime(DateTimeInterface $dateTime): self
44
    {
45 37
        $utcTimestamp = $dateTime->getTimestamp();
46
47
        // yes, PHP DateTime can accept integer timestamp only as a string ¯\_( ͡° ͜ʖ ͡°)_/¯
48 37
        $result = (new self("@$utcTimestamp"))->setTimezone($dateTime->getTimezone());
49
50 37
        return $result;
51
    }
52
53
    /**
54
     * @inheritdoc
55
     */
56 19
    public function jsonSerialize()
57
    {
58 19
        return $this->format(static::JSON_API_FORMAT);
59
    }
60
}
61