| 
									
										
										
										
											2017-12-28 11:38:40 +01:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * VersionCheckEventHandler.php | 
					
						
							|  |  |  |  * Copyright (c) 2017 thegrumpydictator@gmail.com | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This file is part of Firefly III. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Firefly III is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Firefly III is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with Firefly III. If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Handlers\Events; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-28 11:57:38 +01:00
										 |  |  | use FireflyConfig; | 
					
						
							| 
									
										
										
										
											2017-12-28 19:03:15 +01:00
										 |  |  | use FireflyIII\Events\RequestedVersionCheckStatus; | 
					
						
							| 
									
										
										
										
											2018-01-14 19:56:18 +01:00
										 |  |  | use FireflyIII\Exceptions\FireflyException; | 
					
						
							|  |  |  | use FireflyIII\Services\Github\Object\Release; | 
					
						
							|  |  |  | use FireflyIII\Services\Github\Request\UpdateRequest; | 
					
						
							| 
									
										
										
										
											2017-12-28 11:38:40 +01:00
										 |  |  | use FireflyIII\User; | 
					
						
							|  |  |  | use Log; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Class VersionCheckEventHandler | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class VersionCheckEventHandler | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2017-12-28 19:03:15 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-28 11:38:40 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2017-12-28 19:03:15 +01:00
										 |  |  |      * @param RequestedVersionCheckStatus $event | 
					
						
							| 
									
										
										
										
											2017-12-28 11:38:40 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2017-12-28 19:03:15 +01:00
										 |  |  |     public function checkForUpdates(RequestedVersionCheckStatus $event) | 
					
						
							| 
									
										
										
										
											2017-12-28 11:38:40 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         // in Sandstorm, cannot check for updates:
 | 
					
						
							|  |  |  |         $sandstorm = 1 === intval(getenv('SANDSTORM')); | 
					
						
							|  |  |  |         if ($sandstorm === true) { | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-14 19:56:18 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-28 11:38:40 +01:00
										 |  |  |         /** @var User $user */ | 
					
						
							| 
									
										
										
										
											2017-12-28 11:57:38 +01:00
										 |  |  |         $user = $event->user; | 
					
						
							|  |  |  |         if (!$user->hasRole('owner')) { | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $permission    = FireflyConfig::get('permission_update_check', -1); | 
					
						
							|  |  |  |         $lastCheckTime = FireflyConfig::get('last_update_check', time()); | 
					
						
							| 
									
										
										
										
											2017-12-28 11:38:40 +01:00
										 |  |  |         $now           = time(); | 
					
						
							|  |  |  |         if ($now - $lastCheckTime->data < 604800) { | 
					
						
							| 
									
										
										
										
											2018-01-21 11:09:55 +01:00
										 |  |  |             Log::debug(sprintf('Checked for updates less than a week ago (on %s).', date('Y-m-d H:i:s', $lastCheckTime->data))); | 
					
						
							| 
									
										
										
										
											2017-12-28 11:38:40 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         // last check time was more than a week ago.
 | 
					
						
							|  |  |  |         Log::debug('Have not checked for a new version in a week!'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // have actual permission?
 | 
					
						
							|  |  |  |         if ($permission->data === -1) { | 
					
						
							|  |  |  |             // never asked before.
 | 
					
						
							|  |  |  |             session()->flash('info', strval(trans('firefly.check_for_updates_permission', ['link' => route('admin.update-check')]))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-14 19:56:18 +01:00
										 |  |  |         $current = config('firefly.version'); | 
					
						
							|  |  |  |         /** @var UpdateRequest $request */ | 
					
						
							|  |  |  |         $request = app(UpdateRequest::class); | 
					
						
							|  |  |  |         $check   = -2; | 
					
						
							|  |  |  |         $first   = new Release(['id' => '0', 'title' => '0', 'updated' => '2017-01-01', 'content' => '']); | 
					
						
							|  |  |  |         try { | 
					
						
							|  |  |  |             $request->call(); | 
					
						
							|  |  |  |             $releases = $request->getReleases(); | 
					
						
							|  |  |  |             // first entry should be the latest entry:
 | 
					
						
							|  |  |  |             /** @var Release $first */ | 
					
						
							|  |  |  |             $first = reset($releases); | 
					
						
							|  |  |  |             $check = version_compare($current, $first->getTitle()); | 
					
						
							|  |  |  |             FireflyConfig::set('last_update_check', time()); | 
					
						
							|  |  |  |         } catch (FireflyException $e) { | 
					
						
							|  |  |  |             Log::error(sprintf('Could not check for updates: %s', $e->getMessage())); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-01-21 11:09:55 +01:00
										 |  |  |         $string = 'no result: ' . $check; | 
					
						
							| 
									
										
										
										
											2018-01-14 19:56:18 +01:00
										 |  |  |         if ($check === -2) { | 
					
						
							|  |  |  |             $string = strval(trans('firefly.update_check_error')); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if ($check === -1) { | 
					
						
							|  |  |  |             // there is a new FF version!
 | 
					
						
							|  |  |  |             $monthAndDayFormat = (string)trans('config.month_and_day'); | 
					
						
							|  |  |  |             $string            = strval( | 
					
						
							|  |  |  |                 trans( | 
					
						
							|  |  |  |                     'firefly.update_new_version_alert', | 
					
						
							|  |  |  |                     ['your_version' => $current, 'new_version' => $first->getTitle(), 'date' => $first->getUpdated()->formatLocalized($monthAndDayFormat)] | 
					
						
							|  |  |  |                 ) | 
					
						
							|  |  |  |             ); | 
					
						
							| 
									
										
										
										
											2018-01-21 11:09:55 +01:00
										 |  |  |         } | 
					
						
							|  |  |  |         if ($check !== 0) { | 
					
						
							|  |  |  |             // flash info
 | 
					
						
							| 
									
										
										
										
											2018-01-14 19:56:18 +01:00
										 |  |  |             session()->flash('info', $string); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-12-28 19:16:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-14 19:56:18 +01:00
										 |  |  |         return; | 
					
						
							| 
									
										
										
										
											2017-12-28 11:38:40 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |