Completed
Push — master ( 7ff9c7...665628 )
by Yannick
06:59
created

Accident   C

Complexity

Total Complexity 65

Size/Duplication

Total Lines 254
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 5

Importance

Changes 0
Metric Value
dl 0
loc 254
rs 5.7894
c 0
b 0
f 0
wmc 65
lcom 1
cbo 5

8 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 4 1
A get() 0 7 1
F getLatestAccidentData() 0 83 19
B import() 0 16 6
C download_update() 0 37 11
D add() 0 55 21
A check_last_accidents_update() 0 18 4
A insert_last_accidents_update() 0 11 2

How to fix   Complexity   

Complex Class

Complex classes like Accident often do a lot of different things. To break such a class down, we need to identify a cohesive component within that class. A common approach to find such a component is to look for fields/methods that share the same prefixes, or suffixes. You can also have a look at the cohesion graph to spot any un-connected, or weakly-connected components.

Once you have determined the fields that belong together, you can apply the Extract Class refactoring. If the component makes sense as a sub-class, Extract Subclass is also a candidate, and is often faster.

While breaking up the class, it is a good idea to analyze how other classes use Accident, and based on these observations, apply Extract Interface, too.

1
<?php
2
require_once(dirname(__FILE__).'/class.Connection.php');
3
require_once(dirname(__FILE__).'/class.Spotter.php');
4
require_once(dirname(__FILE__).'/class.Image.php');
5
require_once(dirname(__FILE__).'/class.Translation.php');
6
7
class Accident {
8
	public $db;
9
10
	public function __construct($dbc = null) {
11
		$Connection = new Connection($dbc);
12
		$this->db = $Connection->db();
13
	}
14
15
16
	public function get() {
17
		$query = 'SELECT DISTINCT registration FROM accidents ORDER BY date DESC';
18
		$sth = $this->db->prepare($query);
19
		$sth->execute();
20
		$result = $sth->fetchAll(PDO::FETCH_ASSOC);
21
		return $result;
22
	}
23
	
24
	/**
25
	* Get Latest Accidents data from DB
26
	*
27
	* @return Array Return Accidents data in array
28
	*/
29
	public function getLatestAccidentData($limit = '',$type = '') {
30
		global $globalURL, $globalDBdriver;
31
		$Image = new Image($this->db);
32
		$Spotter = new Spotter($this->db);
33
		$Translation = new Translation($this->db);
34
		date_default_timezone_set('UTC');
35
		$result = array();
36
		$limit_query = '';
37
		if ($limit != "")
38
		{
39
			$limit_array = explode(",", $limit);
40
			$limit_array[0] = filter_var($limit_array[0],FILTER_SANITIZE_NUMBER_INT);
41
			$limit_array[1] = filter_var($limit_array[1],FILTER_SANITIZE_NUMBER_INT);
42
			if ($limit_array[0] >= 0 && $limit_array[1] >= 0)
43
			{
44
				$limit_query = " LIMIT ".$limit_array[1]." OFFSET ".$limit_array[0];
45
			}
46
		}
47
48
		if ($type != '') {
49
			$query = "SELECT * FROM accidents WHERE accidents_id IN (SELECT max(accidents_id) FROM accidents WHERE type = :type GROUP BY registration) ORDER BY date DESC".$limit_query;
50
			$query_values = array(':type' => $type);
51
		} else {
52
			//$query = "SELECT * FROM accidents GROUP BY registration ORDER BY date DESC".$limit_query;
53
			$query = "SELECT * FROM accidents WHERE accidents_id IN (SELECT max(accidents_id) FROM accidents GROUP BY registration) ORDER BY date DESC".$limit_query;
54
			$query_values = array();
55
		}
56
57
		try {
58
			$sth = $this->db->prepare($query);
59
			$sth->execute($query_values);
60
		} catch(PDOException $e) {
61
			return "error : ".$e->getMessage();
62
		}
63
		$i = 0;
64
		while ($row = $sth->fetch(PDO::FETCH_ASSOC)) {
65
			$data = array();
66
			if ($row['registration'] != '') {
67
				$image_array = $Image->getSpotterImage($row['registration']);
68
				if (count($image_array) > 0) $data = array_merge($data,array('image' => $image_array[0]['image'],'image_thumbnail' => $image_array[0]['image_thumbnail'],'image_copyright' => $image_array[0]['image_copyright'],'image_source' => $image_array[0]['image_source'],'image_source_website' => $image_array[0]['image_source_website']));
69
				else $data = array_merge($data,array('image' => '','image_thumbnail' => '','image_copyright' => '','image_source' => '','image_source_website' => ''));
70
				$aircraft_type = $Spotter->getAllAircraftTypeByRegistration($row['registration']);
71
				$aircraft_info = $Spotter->getAllAircraftInfo($aircraft_type);
72
				if (!empty($aircraft_info)) {
73
					$data['aircraft_type'] = $aircraft_info[0]['icao'];
74
					$data['aircraft_name'] = $aircraft_info[0]['type'];
75
					$data['aircraft_manufacturer'] = $aircraft_info[0]['manufacturer'];
76
				} else {
77
					$data = array_merge($data,array('aircraft_type' => 'NA'));
78
				}
79
				$owner_data = $Spotter->getAircraftOwnerByRegistration($row['registration']);
80
				if (!empty($owner_data)) {
81
					$data['aircraft_owner'] = $owner_data['owner'];
82
					$data['aircraft_base'] = $owner_data['base'];
83
					$data['aircraft_date_first_reg'] = $owner_data['date_first_reg'];
84
				}
85
			} else $data = array_merge($data,array('image' => '','image_thumbnail' => '','image_copyright' => '','image_source' => '','image_source_website' => ''));
86
			if ($row['registration'] == '') $row['registration'] = 'NA';
87
			if ($row['ident'] == '') $row['ident'] = 'NA';
88
			$identicao = $Spotter->getAllAirlineInfo(substr($row['ident'],0,2));
89
			if (isset($identicao[0])) {
90
				if (substr($row['ident'],0,2) == 'AF') {
91
					if (filter_var(substr($row['ident'],2),FILTER_VALIDATE_INT,array("flags"=>FILTER_FLAG_ALLOW_OCTAL))) $icao = $row['ident'];
92
					else $icao = 'AFR'.ltrim(substr($row['ident'],2),'0');
93
				} else $icao = $identicao[0]['icao'].ltrim(substr($row['ident'],2),'0');
94
				$data = array_merge($data,array('airline_icao' => $identicao[0]['icao'],'airline_name' => $identicao[0]['name']));
95
			} else $icao = $row['ident'];
96
			$icao = $Translation->checkTranslation($icao,false);
97
			//$data = array_merge($data,array('registration' => $row['registration'], 'date' => $row['date'], 'ident' => $icao,'url' => $row['url']));
98
			$data = array_merge($row,$data);
99
			if ($data['ident'] == null) $data['ident'] = $icao;
100
			if ($data['title'] == null) {
101
				$data['message'] = $row['type'].' of '.$row['registration'].' at '.$row['place'].','.$row['country'];
102
			} else $data['message'] = strtolower($data['title']);
103
			$result[] = $data;
104
			$i++;
105
		}
106
		if (isset($result)) {
107
			$result[0]['query_number_rows'] = $i;
108
			return $result;
109
		}
110
		else return array();
111
	}
112
	
113
	
114
	/*
115
	* Import csv accidents file into the DB
116
	* @param String $file filename of the file to import
117
	*/
118
	public function import($file) {
119
		global $globalTransaction, $globalDebug;
120
		require_once('class.Connection.php');
121
		echo 'Import '.$file."\n";
122
		$Connection = new Connection();
0 ignored issues
show
Unused Code introduced by
$Connection is not used, you could remove the assignment.

This check looks for variable assignements that are either overwritten by other assignments or where the variable is not used subsequently.

$myVar = 'Value';
$higher = false;

if (rand(1, 6) > 3) {
    $higher = true;
} else {
    $higher = false;
}

Both the $myVar assignment in line 1 and the $higher assignment in line 2 are dead. The first because $myVar is never used and the second because $higher is always overwritten for every possible time line.

Loading history...
123
		$result = array();
124
		if (($handle = fopen($file,'r')) !== FALSE) {
125
			while (($data = fgetcsv($handle,2000,",")) !== FALSE) {
126
				if (isset($data[1]) && $data[1] != '0000-00-00 00:00:00') {
127
					$result[] = array('registration' => $data[0],'date' => strtotime($data[1]),'url' => $data[2],'country' => $data[3],'place' => $data[4],'title' => $data[5],'fatalities' => $data[6],'latitude' => $data[7],'longitude' => $data[8],'type' => $data[9],'ident' => $data[10],'aircraft_manufacturer' => $data[11],'aircraft_name' => $data[12],'source' => 'website_fam');
128
				}
129
			}
130
			fclose($handle);
131
		}
132
		if (!empty($result)) $this->add($result,true);
133
	}
134
135
	public function download_update() {
136
		require_once('class.Common.php');
137
		$Common = new Common();
138
		$all_md5 = array();
139
		$all_md5_new = array();
140
		if (file_exists(dirname(__FILE__).'/../install/tmp/cr-all.md5')) {
141
			if (($handle = fopen(dirname(__FILE__).'/../install/tmp/cr-all.md5','r')) !== FALSE) {
142
				while (($data = fgetcsv($handle,2000,"\t")) !== FALSE) {
143
					if (isset($data[1])) {
144
						$year = $data[0];
145
						$all_md5[$year] = $data[1];
146
					}
147
				}
148
				fclose($handle);
149
			}
150
		}
151
		$Common->download('https://data.flightairmap.fr/data/cr/cr-all.md5',dirname(__FILE__).'/../install/tmp/cr-all.md5');
152
		if (file_exists(dirname(__FILE__).'/../install/tmp/cr-all.md5')) {
153
			if (($handle = fopen(dirname(__FILE__).'/../install/tmp/cr-all.md5','r')) !== FALSE) {
154
				while (($data = fgetcsv($handle,2000,"\t")) !== FALSE) {
155
					if (isset($data[1])) {
156
						$year = $data[0];
157
						$all_md5_new[$year] = $data[1];
158
					}
159
				}
160
				fclose($handle);
161
			}
162
		}
163
		//print_r($all_md5_new);
164
		//print_r($all_md5);
165
		$result = $Common->arr_diff($all_md5_new,$all_md5);
166
		//print_r($result);
167
		foreach ($result as $file => $md5) {
168
			$Common->download('https://data.flightairmap.fr/data/cr/'.$file,dirname(__FILE__).'/../install/tmp/'.$file);
169
			if (file_exists(dirname(__FILE__).'/../install/tmp/'.$file)) $this->import(dirname(__FILE__).'/../install/tmp/'.$file);
170
		}
171
	}
172
173
	public function add($crash,$new = false) {
174
		global $globalTransaction, $globalDebug;
175
		require_once('class.Connection.php');
176
		require_once('class.Image.php');
177
		$Connection = new Connection();
178
		$Image = new Image();
179
180
		if (empty($crash)) return false;
181
		if (!$new) {
182
			$query_delete = 'DELETE FROM accidents WHERE source = :source';
183
			$sthd = $Connection->db->prepare($query_delete);
184
			$sthd->execute(array(':source' => $crash[0]['source']));
185
		}
186
		if ($globalTransaction) $Connection->db->beginTransaction();
1 ignored issue
show
Bug introduced by
The method beginTransaction cannot be called on $Connection->db (of type null).

Methods can only be called on objects. This check looks for methods being called on variables that have been inferred to never be objects.

Loading history...
187
		$initial_array = array('ident' => null,'type' => 'accident','url' => null,'registration' => null, 'date' => null, 'place' => null,'country' => null, 'latitude' => null, 'longitude' => null, 'fatalities' => null, 'title' => '','source' => '','aircraft_manufacturer' => null,'aircraft_name' => null);
188
		$query_check = 'SELECT COUNT(*) as nb FROM accidents WHERE registration = :registration AND date = :date AND type = :type AND source = :source';
189
		$sth_check = $Connection->db->prepare($query_check);
190
		$query = 'INSERT INTO accidents (aircraft_manufacturer,aircraft_name,ident,registration,date,url,country,place,title,fatalities,latitude,longitude,type,source) VALUES (:aircraft_manufacturer,:aircraft_name,:ident,:registration,:date,:url,:country,:place,:title,:fatalities,:latitude,:longitude,:type,:source)';
191
		$sth = $Connection->db->prepare($query);
192
		$j = 0;
193
		try {
194
			foreach ($crash as $cr) {
195
				//print_r($cr);
196
				$cr = $cr + $initial_array;
197
				$cr = array_map(function($value) {
198
					return $value === "" ? NULL : $value;
199
				}, $cr);
200
				if ($cr['date'] != '' && $cr['registration'] != null && $cr['registration'] != '' && $cr['registration'] != '?' && $cr['registration'] != '-' && $cr['date'] < time() && !preg_match('/\s/',$cr['registration'])) {
201
					$query_check_values = array(':registration' => $cr['registration'],':date' => date('Y-m-d',$cr['date']),':type' => $cr['type'],':source' => $cr['source']);
202
					$sth_check->execute($query_check_values);
203
					$result_check = $sth_check->fetch(PDO::FETCH_ASSOC);
204
					if ($result_check['nb'] == 0) {
205
						$query_values = array(':registration' => trim($cr['registration']),':date' => date('Y-m-d',$cr['date']),':url' => $cr['url'],':country' => $cr['country'],':place' => $cr['place'],':title' => $cr['title'],':fatalities' => $cr['fatalities'],':latitude' => $cr['latitude'],':longitude' => $cr['longitude'],':type' => $cr['type'],':source' => $cr['source'],':ident' => $cr['ident'],':aircraft_manufacturer' => $cr['aircraft_manufacturer'],':aircraft_name' => $cr['aircraft_name']);
206
						$sth->execute($query_values);
207
						if ($cr['date'] > time()-(30*86400)) {
208
							if (empty($Image->getSpotterImage($cr['registration']))) {
209
								//if ($globalDebug) echo 'Get image...'."\n";
210
								$Image->addSpotterImage($cr['registration']);
211
							}
212
							// elseif ($globalDebug) echo 'Image already in DB'."\n";
213
						}
214
					}
215
				}
216
				if ($globalTransaction && $j % 90 == 0) {
217
					$Connection->db->commit();
1 ignored issue
show
Bug introduced by
The method commit cannot be called on $Connection->db (of type null).

Methods can only be called on objects. This check looks for methods being called on variables that have been inferred to never be objects.

Loading history...
218
					$Connection->db->beginTransaction();
1 ignored issue
show
Bug introduced by
The method beginTransaction cannot be called on $Connection->db (of type null).

Methods can only be called on objects. This check looks for methods being called on variables that have been inferred to never be objects.

Loading history...
219
				}
220
			}
221
			if ($globalTransaction) $Connection->db->commit();
1 ignored issue
show
Bug introduced by
The method commit cannot be called on $Connection->db (of type null).

Methods can only be called on objects. This check looks for methods being called on variables that have been inferred to never be objects.

Loading history...
222
		} catch(PDOException $e) {
223
			if ($globalTransaction) $Connection->db->rollBack();
1 ignored issue
show
Bug introduced by
The method rollBack cannot be called on $Connection->db (of type null).

Methods can only be called on objects. This check looks for methods being called on variables that have been inferred to never be objects.

Loading history...
224
			echo $e->getMessage();
225
		}
226
		$sth_check->closeCursor();
227
	}
228
229
	public static function check_last_accidents_update() {
230
		global $globalDBdriver;
231
		if ($globalDBdriver == 'mysql') {
232
			$query = "SELECT COUNT(*) as nb FROM config WHERE name = 'last_update_accident_db' AND value > DATE_SUB(NOW(), INTERVAL 1 DAY)";
233
		} else {
234
			$query = "SELECT COUNT(*) as nb FROM config WHERE name = 'last_update_accident_db' AND value::timestamp > CURRENT_TIMESTAMP - INTERVAL '1 DAYS'";
235
		}
236
		try {
237
			$Connection = new Connection();
238
			$sth = $Connection->db->prepare($query);
239
			$sth->execute();
240
		} catch(PDOException $e) {
241
			return "error : ".$e->getMessage();
242
		}
243
		$row = $sth->fetch(PDO::FETCH_ASSOC);
244
		if ($row['nb'] > 0) return false;
245
		else return true;
246
	}
247
248
	public static function insert_last_accidents_update() {
249
		$query = "DELETE FROM config WHERE name = 'last_update_accident_db';
250
		    INSERT INTO config (name,value) VALUES ('last_update_accident_db',NOW());";
251
		try {
252
			$Connection = new Connection();
253
			$sth = $Connection->db->prepare($query);
254
			$sth->execute();
255
		} catch(PDOException $e) {
256
			return "error : ".$e->getMessage();
257
		}
258
	}
259
260
}
261
?>