WeatherDenormalizer   A
last analyzed

Complexity

Total Complexity 8

Size/Duplication

Total Lines 59
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 3

Importance

Changes 0
Metric Value
wmc 8
lcom 1
cbo 3
dl 0
loc 59
rs 10
c 0
b 0
f 0

3 Methods

Rating   Name   Duplication   Size   Complexity  
A denormalize() 0 8 2
A denormalizeSingle() 0 22 3
A denormalizeMultiple() 0 12 3
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Marek\OpenWeatherMap\Denormalizer;
6
7
use Marek\OpenWeatherMap\API\Value\Response\APIResponse;
8
use Marek\OpenWeatherMap\API\Value\Response\Clouds;
9
use Marek\OpenWeatherMap\API\Value\Response\GeographicCoordinates;
10
use Marek\OpenWeatherMap\API\Value\Response\Main;
11
use Marek\OpenWeatherMap\API\Value\Response\Rain;
12
use Marek\OpenWeatherMap\API\Value\Response\Snow;
13
use Marek\OpenWeatherMap\API\Value\Response\Sys;
14
use Marek\OpenWeatherMap\API\Value\Response\Weather\AggregatedWeather;
15
use Marek\OpenWeatherMap\API\Value\Response\Weather\Weather;
16
use Marek\OpenWeatherMap\API\Value\Response\WeatherValue;
17
use Marek\OpenWeatherMap\API\Value\Response\Wind;
18
19
class WeatherDenormalizer extends AbstractDenormalizer
20
{
21
    public function denormalize(array $data, APIResponse $response): APIResponse
22
    {
23
        if ($response instanceof AggregatedWeather) {
24
            return $this->denormalizeMultiple($data, $response);
25
        }
26
27
        return $this->denormalizeSingle($data, $response);
0 ignored issues
show
Compatibility introduced by
$response of type object<Marek\OpenWeather...e\Response\APIResponse> is not a sub-type of object<Marek\OpenWeather...sponse\Weather\Weather>. It seems like you assume a child class of the class Marek\OpenWeatherMap\API...ue\Response\APIResponse to be always present.

This check looks for parameters that are defined as one type in their type hint or doc comment but seem to be used as a narrower type, i.e an implementation of an interface or a subclass.

Consider changing the type of the parameter or doing an instanceof check before assuming your parameter is of the expected type.

Loading history...
28
    }
29
30
    /**
31
     * @param $data
32
     * @param Weather $weather
33
     *
34
     * @return Weather
35
     */
36
    protected function denormalizeSingle(array $data, Weather $weather): Weather
37
    {
38
        $innerWeather = [];
39
        foreach ($data['weather'] as $w) {
40
            $innerWeather[] = $this->denormalizer->denormalize($w, WeatherValue::class);
41
        }
42
43
        $weather->id = $data['id'];
44
        $weather->name = $data['name'];
45
        $weather->visibility = empty($data['visibility']) ?? $data['visibility'];
46
        $weather->coord = $this->getValue('coord', $data, GeographicCoordinates::class);
47
        $weather->rain = $this->getValue('rain', $data, Rain::class);
48
        $weather->snow = $this->getValue('snow', $data, Snow::class);
49
        $weather->wind = $this->getValue('wind', $data, Wind::class);
50
        $weather->clouds = $this->getValue('clouds', $data, Clouds::class);
51
        $weather->main = $this->getValue('main', $data, Main::class);
52
        $weather->sys = $this->getValue('sys', $data, Sys::class);
53
        $weather->weather = $innerWeather;
54
        $weather->dt = empty($data['dt']) ? null : new \DateTimeImmutable("@{$data['dt']}");
0 ignored issues
show
Documentation Bug introduced by
It seems like empty($data['dt']) ? nul...table("@{$data['dt']}") of type object<DateTimeImmutable> is incompatible with the declared type object<DateTime> of property $dt.

Our type inference engine has found an assignment to a property that is incompatible with the declared type of that property.

Either this assignment is in error or the assigned type should be added to the documentation/type hint for that property..

Loading history...
55
56
        return $weather;
57
    }
58
59
    /**
60
     * @param array $data
61
     * @param AggregatedWeather $weather
62
     *
63
     * @return AggregatedWeather
64
     */
65
    protected function denormalizeMultiple($data, AggregatedWeather $weather): AggregatedWeather
66
    {
67
        $weathers = [];
68
        foreach ($data['list'] as $datum) {
69
            $weathers[] = $this->denormalizeSingle($datum, new Weather());
70
        }
71
72
        $weather->count = empty($data['cnt']) ? $data['count'] : $data['cnt'];
73
        $weather->weathers = $weathers;
74
75
        return $weather;
76
    }
77
}
78