| 
									
										
										
										
											2018-04-11 19:49:35 +02:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Grocy\Controllers; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-29 12:05:32 +02:00
										 |  |  | use Grocy\Controllers\Users\User; | 
					
						
							| 
									
										
										
										
											2020-08-31 20:40:31 +02:00
										 |  |  | use Grocy\Services\ApiKeyService; | 
					
						
							|  |  |  | use Grocy\Services\ApplicationService; | 
					
						
							|  |  |  | use Grocy\Services\BatteriesService; | 
					
						
							|  |  |  | use Grocy\Services\CalendarService; | 
					
						
							|  |  |  | use Grocy\Services\ChoresService; | 
					
						
							|  |  |  | use Grocy\Services\DatabaseService; | 
					
						
							|  |  |  | use Grocy\Services\FilesService; | 
					
						
							|  |  |  | use Grocy\Services\LocalizationService; | 
					
						
							|  |  |  | use Grocy\Services\RecipesService; | 
					
						
							|  |  |  | use Grocy\Services\SessionService; | 
					
						
							|  |  |  | use Grocy\Services\StockService; | 
					
						
							|  |  |  | use Grocy\Services\TasksService; | 
					
						
							|  |  |  | use Grocy\Services\UserfieldsService; | 
					
						
							|  |  |  | use Grocy\Services\UsersService; | 
					
						
							| 
									
										
										
										
											2018-04-11 19:49:35 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | class BaseController | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-08-31 20:40:31 +02:00
										 |  |  | 	protected $AppContainer; | 
					
						
							| 
									
										
										
										
											2018-04-12 21:13:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-31 20:40:31 +02:00
										 |  |  | 	public function __construct(\DI\Container $container) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2020-03-01 23:47:47 +07:00
										 |  |  | 		$this->AppContainer = $container; | 
					
						
							|  |  |  | 		$this->View = $container->get('view'); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-31 20:40:31 +02:00
										 |  |  | 	protected function getApiKeyService() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return ApiKeyService::getInstance(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	protected function getApplicationservice() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return ApplicationService::getInstance(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	protected function getBatteriesService() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return BatteriesService::getInstance(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	protected function getCalendarService() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return CalendarService::getInstance(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	protected function getChoresService() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return ChoresService::getInstance(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	protected function getDatabase() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return $this->getDatabaseService()->GetDbConnection(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	protected function getDatabaseService() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return DatabaseService::getInstance(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	protected function getFilesService() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return FilesService::getInstance(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	protected function getLocalizationService() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return LocalizationService::getInstance(GROCY_LOCALE); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	protected function getRecipesService() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return RecipesService::getInstance(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	protected function getSessionService() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return SessionService::getInstance(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	protected function getStockService() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return StockService::getInstance(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	protected function getTasksService() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return TasksService::getInstance(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	protected function getUserfieldsService() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return UserfieldsService::getInstance(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	protected function getUsersService() | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return UsersService::getInstance(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-01 23:47:47 +07:00
										 |  |  | 	protected function render($response, $page, $data = []) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		$container = $this->AppContainer; | 
					
						
							| 
									
										
										
										
											2018-09-25 08:55:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-01 23:47:47 +07:00
										 |  |  | 		$versionInfo = $this->getApplicationService()->GetInstalledVersion(); | 
					
						
							|  |  |  | 		$this->View->set('version', $versionInfo->Version); | 
					
						
							|  |  |  | 		$this->View->set('releaseDate', $versionInfo->ReleaseDate); | 
					
						
							| 
									
										
										
										
											2020-02-11 17:42:03 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-29 16:41:27 +02:00
										 |  |  | 		$localizationService = $this->getLocalizationService(); | 
					
						
							| 
									
										
										
										
											2020-09-01 21:29:47 +02:00
										 |  |  | 		$this->View->set('__t', function (string $text, ...$placeholderValues) use ($localizationService) { | 
					
						
							| 
									
										
										
										
											2019-05-01 20:19:18 +02:00
										 |  |  | 			return $localizationService->__t($text, $placeholderValues); | 
					
						
							| 
									
										
										
										
											2018-04-16 19:11:32 +02:00
										 |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2020-09-01 21:29:47 +02:00
										 |  |  | 		$this->View->set('__n', function ($number, $singularForm, $pluralForm) use ($localizationService) { | 
					
						
							| 
									
										
										
										
											2019-05-01 20:19:18 +02:00
										 |  |  | 			return $localizationService->__n($number, $singularForm, $pluralForm); | 
					
						
							|  |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2020-03-01 23:47:47 +07:00
										 |  |  | 		$this->View->set('GettextPo', $localizationService->GetPoAsJsonString()); | 
					
						
							| 
									
										
										
										
											2019-05-01 20:19:18 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-01 21:29:47 +02:00
										 |  |  | 		$this->View->set('U', function ($relativePath, $isResource = false) use ($container) { | 
					
						
							| 
									
										
										
										
											2020-02-11 17:42:03 +01:00
										 |  |  | 			return $container->get('UrlManager')->ConstructUrl($relativePath, $isResource); | 
					
						
							| 
									
										
										
										
											2018-04-18 19:03:39 +02:00
										 |  |  | 		}); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-17 12:57:35 +01:00
										 |  |  | 		$embedded = false; | 
					
						
							| 
									
										
										
										
											2020-08-31 20:40:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-11 17:42:03 +01:00
										 |  |  | 		if (isset($_GET['embedded'])) | 
					
						
							| 
									
										
										
										
											2018-11-17 12:57:35 +01:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			$embedded = true; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2020-08-31 20:40:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-01 23:47:47 +07:00
										 |  |  | 		$this->View->set('embedded', $embedded); | 
					
						
							| 
									
										
										
										
											2018-11-17 12:57:35 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-03 18:20:06 +01:00
										 |  |  | 		$constants = get_defined_constants(); | 
					
						
							| 
									
										
										
										
											2020-08-31 20:40:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-03 18:20:06 +01:00
										 |  |  | 		foreach ($constants as $constant => $value) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			if (substr($constant, 0, 19) !== 'GROCY_FEATURE_FLAG_') | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				unset($constants[$constant]); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2020-08-31 20:40:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-01 23:47:47 +07:00
										 |  |  | 		$this->View->set('featureFlags', $constants); | 
					
						
							| 
									
										
										
										
											2019-03-03 18:20:06 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-29 12:05:32 +02:00
										 |  |  | 		if (GROCY_AUTHENTICATED) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			$this->View->set('permissions', User::PermissionList()); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-01 23:47:47 +07:00
										 |  |  | 		return $this->View->render($response, $page, $data); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2019-09-18 16:18:15 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-01 23:47:47 +07:00
										 |  |  | 	protected function renderPage($response, $page, $data = []) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		$this->View->set('userentitiesForSidebar', $this->getDatabase()->userentities()->where('show_in_sidebar_menu = 1')->orderBy('name')); | 
					
						
							| 
									
										
										
										
											2018-11-17 12:57:35 +01:00
										 |  |  | 		try | 
					
						
							|  |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2020-03-01 23:47:47 +07:00
										 |  |  | 			$usersService = $this->getUsersService(); | 
					
						
							| 
									
										
										
										
											2020-08-31 20:40:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-17 12:57:35 +01:00
										 |  |  | 			if (defined('GROCY_USER_ID')) | 
					
						
							|  |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2020-03-01 23:47:47 +07:00
										 |  |  | 				$this->View->set('userSettings', $usersService->GetUserSettings(GROCY_USER_ID)); | 
					
						
							| 
									
										
										
										
											2018-10-20 03:07:05 -04:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2019-06-08 15:54:56 +02:00
										 |  |  | 			else | 
					
						
							|  |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2020-03-01 23:47:47 +07:00
										 |  |  | 				$this->View->set('userSettings', null); | 
					
						
							| 
									
										
										
										
											2019-06-08 15:54:56 +02:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2018-09-30 11:17:28 +02:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		catch (\Exception $ex) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			// Happens when database is not initialised or migrated...
 | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-01 23:47:47 +07:00
										 |  |  | 		return $this->render($response, $page, $data); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2020-10-19 17:19:13 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	private static $htmlPurifierInstance = null; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	protected function GetParsedAndFilteredRequestBody($request) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (self::$htmlPurifierInstance == null) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			self::$htmlPurifierInstance = new \HTMLPurifier(\HTMLPurifier_Config::createDefault()); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		$requestBody = $request->getParsedBody(); | 
					
						
							|  |  |  | 		foreach ($requestBody as $key => &$value) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			// HTMLPurifier removes boolean values (true/false), so explicitly keep them
 | 
					
						
							|  |  |  | 			// Maybe also possible through HTMLPurifier config (http://htmlpurifier.org/live/configdoc/plain.html)
 | 
					
						
							|  |  |  | 			if (!is_bool($value)) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				$value = self::$htmlPurifierInstance->purify($value); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return $requestBody; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-04-11 19:49:35 +02:00
										 |  |  | } |