1 | <?php |
||
28 | class DownloadController { |
||
29 | |||
30 | /** |
||
31 | * @var Fetcher |
||
32 | */ |
||
33 | protected $fetcher; |
||
34 | |||
35 | /** |
||
36 | * @var Registry |
||
37 | */ |
||
38 | protected $registry; |
||
39 | |||
40 | /** |
||
41 | * @var FilesystemHelper |
||
42 | */ |
||
43 | protected $fsHelper; |
||
44 | |||
45 | 4 | public function __construct(Fetcher $fetcher, Registry $registry, FilesystemHelper $fsHelper){ |
|
50 | |||
51 | 2 | public function checkFeed(){ |
|
63 | |||
64 | 2 | public function downloadOwncloud($progressCallback = null){ |
|
65 | 2 | $response = $this->getDefaultResponse(); |
|
66 | 2 | if (is_null($progressCallback)){ |
|
67 | $progressCallback = function (){}; |
||
68 | } |
||
69 | try { |
||
70 | 2 | $feed = $this->getFeed(); |
|
71 | 2 | $path = $this->fetcher->getBaseDownloadPath($feed); |
|
72 | // Fixme: Daily channel has no checksum |
||
73 | 2 | $isDailyChannel = $this->fetcher->getUpdateChannel() == 'daily'; |
|
74 | 2 | if (!$isDailyChannel){ |
|
75 | 2 | $md5 = $this->fetcher->getMd5($feed); |
|
76 | } else { |
||
77 | // We can't check md5 so we don't trust the cache |
||
78 | $this->fsHelper->removeIfExists($path); |
||
79 | } |
||
80 | 2 | if ($isDailyChannel || !$this->checkIntegrity($path, $md5)){ |
|
|
|||
81 | 1 | $this->fetcher->getOwncloud($feed, $progressCallback); |
|
82 | } |
||
83 | |||
84 | 1 | if ($isDailyChannel || $this->checkIntegrity($path, $md5)){ |
|
85 | 1 | $response['success'] = true; |
|
86 | 1 | $response['data']['path'] = $path; |
|
87 | } else { |
||
88 | 1 | $response['exception'] = new \Exception('Deleted ' . $feed->getDownloadedFileName() . ' due to wrong checksum'); |
|
89 | } |
||
90 | 1 | } catch (\Exception $e) { |
|
91 | 1 | if (isset($path)){ |
|
92 | 1 | $this->fsHelper->removeIfExists($path); |
|
93 | } |
||
94 | 1 | $response['exception'] = $e; |
|
95 | } |
||
96 | 2 | return $response; |
|
97 | } |
||
98 | |||
99 | /** |
||
100 | * Check if package is not corrupted on download |
||
101 | * @param string $path |
||
102 | * @param string $md5 |
||
103 | * @return boolean |
||
104 | */ |
||
105 | 2 | protected function checkIntegrity($path, $md5){ |
|
106 | 2 | $fileExists = $this->fsHelper->fileExists($path); |
|
107 | 2 | $checksumMatch = $md5 === $this->fsHelper->md5File($path); |
|
108 | 2 | if ($fileExists && !$checksumMatch){ |
|
109 | 1 | $this->fsHelper->removeIfExists($path); |
|
110 | 1 | $fileExists = false; |
|
111 | } |
||
112 | 2 | return $fileExists; |
|
113 | } |
||
114 | |||
115 | /** |
||
116 | * Get a Feed instance |
||
117 | * @param bool $useCache |
||
118 | * @return \Owncloud\Updater\Utils\Feed |
||
119 | */ |
||
120 | 2 | protected function getFeed($useCache = true){ |
|
126 | |||
127 | /** |
||
128 | * Init response array |
||
129 | * @return array |
||
130 | */ |
||
131 | 4 | protected function getDefaultResponse(){ |
|
139 | } |
||
140 |
If you define a variable conditionally, it can happen that it is not defined for all execution paths.
Let’s take a look at an example:
In the above example, the variable $x is defined if you pass “foo” or “bar” as argument for $a. However, since the switch statement has no default case statement, if you pass any other value, the variable $x would be undefined.
Available Fixes
Check for existence of the variable explicitly:
Define a default value for the variable:
Add a value for the missing path: