Completed
Pull Request — master (#67)
by Alex
05:36
created

WeatherForecast::__construct()   C

Complexity

Conditions 8
Paths 5

Size

Total Lines 29
Code Lines 19

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 19
CRAP Score 8.0551

Importance

Changes 5
Bugs 1 Features 2
Metric Value
c 5
b 1
f 2
dl 0
loc 29
ccs 19
cts 21
cp 0.9048
rs 5.3846
cc 8
eloc 19
nc 5
nop 3
crap 8.0551
1
<?php
2
/**
3
 * OpenWeatherMap-PHP-API — A php api to parse weather data from http://www.OpenWeatherMap.org .
4
 *
5
 * @license MIT
6
 *
7
 * Please see the LICENSE file distributed with this source code for further
8
 * information regarding copyright and licensing.
9
 *
10
 * Please visit the following links to read about the usage policies and the license of
11
 * OpenWeatherMap before using this class:
12
 *
13
 * @see http://www.OpenWeatherMap.org
14
 * @see http://www.OpenWeatherMap.org/terms
15
 * @see http://openweathermap.org/appid
16
 */
17
18
namespace Cmfcmf\OpenWeatherMap;
19
20
use Cmfcmf\OpenWeatherMap;
21
use Cmfcmf\OpenWeatherMap\Util\City;
22
use Cmfcmf\OpenWeatherMap\Util\Sun;
23
24
/**
25
 * Weather class returned by Cmfcmf\OpenWeatherMap->getWeather().
26
 *
27
 * @see Cmfcmf\OpenWeatherMap::getWeather() The function using it.
28
 */
29
class WeatherForecast implements \Iterator
30
{
31
    /**
32
     * A city object.
33
     *
34
     * @var Util\City
35
     */
36
    public $city;
37
38
    /**
39
     * A sun object
40
     *
41
     * @var Util\Sun
42
     */
43
    public $sun;
44
45
    /**
46
     * The time of the last update of this weather data.
47
     *
48
     * @var \DateTime
49
     */
50
    public $lastUpdate;
51
52
    /**
53
     * An array of {@link Forecast} objects.
54
     *
55
     * @var Forecast[]
56
     *
57
     * @see Forecast The Forecast class.
58
     */
59
    private $forecasts;
60
61
    /**
62
     * @internal
63
     */
64
    private $position = 0;
65
66
    /**
67
     * Create a new Forecast object.
68
     *
69
     * @param        $xml
70
     * @param string $units
71
     * @param int    $days How many days of forecast to receive.
72
     *
73
     * @internal
74
     */
75 2
    public function __construct($xml, $units, $days)
76
    {
77 2
        $this->city = new City(-1, $xml->location->name, $xml->location->location['longitude'], $xml->location->location['latitude'], $xml->location->country);
78 2
        $this->sun = new Sun(new \DateTime($xml->sun['rise']), new \DateTime($xml->sun['set']));
79 2
        $this->lastUpdate = new \DateTime($xml->meta->lastupdate);
80
81 2
        $today = new \DateTime();
82 2
        $today->setTime(0, 0, 0);
83 2
        $counter = 0;
84 2
        foreach ($xml->forecast->time as $time) {
85 2
            $date = new \DateTime(isset($time['day']) ? $time['day'] : $time['to']);
86 2
            if ($date < $today) {
87
                // Sometimes OpenWeatherMap returns results which aren't real
88
                // forecasts. The best we can do is to ignore them.
89
                continue;
90
            }
91 2
            $forecast = new Forecast($time, $units);
92 2
            $forecast->city = $this->city;
93 2
            $this->forecasts[] = $forecast;
94
95 2
            $counter++;
96
            // Make sure to only return the requested number of days.
97 2
            if ($days <= 5 && $counter == $days * 8) {
98
                break;
99 2
            } elseif ($days > 5 && $counter == $days) {
100 2
                break;
101
            }
102 2
        }
103 2
    }
104
105
    /**
106
     * @internal
107
     */
108 2
    public function rewind()
109
    {
110 2
        $this->position = 0;
111 2
    }
112
113
    /**
114
     * @internal
115
     */
116 2
    public function current()
117
    {
118 2
        return $this->forecasts[$this->position];
119
    }
120
121
    /**
122
     * @internal
123
     */
124 2
    public function key()
125
    {
126 2
        return $this->position;
127
    }
128
129
    /**
130
     * @internal
131
     */
132 2
    public function next()
133
    {
134 2
        ++$this->position;
135 2
    }
136
137
    /**
138
     * @internal
139
     */
140 2
    public function valid()
141
    {
142 2
        return isset($this->forecasts[$this->position]);
143
    }
144
}
145