mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-22 20:16:22 +00:00 
			
		
		
		
	Remove references to help
This commit is contained in:
		| @@ -1,163 +0,0 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Help.php | ||||
|  * Copyright (c) 2019 james@firefly-iii.org | ||||
|  * | ||||
|  * This file is part of Firefly III (https://github.com/firefly-iii). | ||||
|  * | ||||
|  * This program is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Affero General Public License as | ||||
|  * published by the Free Software Foundation, either version 3 of the | ||||
|  * License, or (at your option) any later version. | ||||
|  * | ||||
|  * This program 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 Affero General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU Affero General Public License | ||||
|  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace FireflyIII\Helpers\Help; | ||||
|  | ||||
| use Cache; | ||||
| use Exception; | ||||
| use GuzzleHttp\Client; | ||||
| use GuzzleHttp\Exception\GuzzleException; | ||||
| use League\CommonMark\CommonMarkConverter; | ||||
| use Log; | ||||
| use Route; | ||||
|  | ||||
| /** | ||||
|  * Class Help. | ||||
|  */ | ||||
| class Help implements HelpInterface | ||||
| { | ||||
|     /** @var string The cache key */ | ||||
|     public const CACHEKEY = 'help_%s_%s'; | ||||
|     /** @var string The user agent. */ | ||||
|     protected $userAgent = 'Firefly III v%s'; | ||||
|  | ||||
|     /** | ||||
|      * Constructor. | ||||
|      */ | ||||
|     public function __construct() | ||||
|     { | ||||
|         $this->userAgent = sprintf($this->userAgent, config('firefly.version')); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get from cache. | ||||
|      * | ||||
|      * @codeCoverageIgnore | ||||
|      * | ||||
|      * @param string $route | ||||
|      * @param string $language | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getFromCache(string $route, string $language): string | ||||
|     { | ||||
|         $line = sprintf(self::CACHEKEY, $route, $language); | ||||
|  | ||||
|         return Cache::get($line); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get text from GitHub. | ||||
|      * | ||||
|      * @param string $route | ||||
|      * @param string $language | ||||
|      * | ||||
|      * @return string | ||||
|      * @throws GuzzleException | ||||
|      */ | ||||
|     public function getFromGitHub(string $route, string $language): string | ||||
|     { | ||||
|         $uri = sprintf('https://raw.githubusercontent.com/firefly-iii/help/main/%s/%s.md', $language, $route); | ||||
|         Log::debug(sprintf('Trying to get %s...', $uri)); | ||||
|         $opt        = ['headers' => ['User-Agent' => $this->userAgent]]; | ||||
|         $content    = ''; | ||||
|         $statusCode = 500; | ||||
|         $client     = app(Client::class); | ||||
|         try { | ||||
|             $res        = $client->request('GET', $uri, $opt); | ||||
|             $statusCode = $res->getStatusCode(); | ||||
|             $content    = trim($res->getBody()->getContents()); | ||||
|         } catch (Exception $e) { // @phpstan-ignore-line | ||||
|             Log::info($e->getMessage()); | ||||
|             //Log::info($e->getTraceAsString()); | ||||
|         } | ||||
|  | ||||
|         Log::debug(sprintf('Status code is %d', $statusCode)); | ||||
|  | ||||
|         if ('' !== $content) { | ||||
|             Log::debug('Content is longer than zero. Expect something.'); | ||||
|             $converter = new CommonMarkConverter(); | ||||
|             $content   = (string)$converter->convertToHtml($content); | ||||
|         } | ||||
|  | ||||
|         return $content; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Do we have the route? | ||||
|      * | ||||
|      * @codeCoverageIgnore | ||||
|      * | ||||
|      * @param string $route | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function hasRoute(string $route): bool | ||||
|     { | ||||
|         return Route::has($route); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Is in cache? | ||||
|      * | ||||
|      * @codeCoverageIgnore | ||||
|      * | ||||
|      * @param string $route | ||||
|      * @param string $language | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function inCache(string $route, string $language): bool | ||||
|     { | ||||
|         $line   = sprintf(self::CACHEKEY, $route, $language); | ||||
|         $result = Cache::has($line); | ||||
|         if ($result) { | ||||
|             Log::debug(sprintf('Cache has this entry: %s', 'help.' . $route . '.' . $language)); | ||||
|         } | ||||
|         if (!$result) { | ||||
|             Log::debug(sprintf('Cache does not have this entry: %s', 'help.' . $route . '.' . $language)); | ||||
|         } | ||||
|  | ||||
|         return $result; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Put help text in cache. | ||||
|      * | ||||
|      * @codeCoverageIgnore | ||||
|      * | ||||
|      * @param string $route | ||||
|      * @param string $language | ||||
|      * @param string $content | ||||
|      */ | ||||
|     public function putInCache(string $route, string $language, string $content): void | ||||
|     { | ||||
|         $key = sprintf(self::CACHEKEY, $route, $language); | ||||
|         if ('' !== $content) { | ||||
|             Log::debug(sprintf('Will store entry in cache: %s', $key)); | ||||
|             Cache::put($key, $content, 10080); // a week. | ||||
|  | ||||
|             return; | ||||
|         } | ||||
|         Log::info(sprintf('Will not cache %s because content is empty.', $key)); | ||||
|     } | ||||
| } | ||||
| @@ -1,77 +0,0 @@ | ||||
| <?php | ||||
| /** | ||||
|  * HelpInterface.php | ||||
|  * Copyright (c) 2019 james@firefly-iii.org | ||||
|  * | ||||
|  * This file is part of Firefly III (https://github.com/firefly-iii). | ||||
|  * | ||||
|  * This program is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Affero General Public License as | ||||
|  * published by the Free Software Foundation, either version 3 of the | ||||
|  * License, or (at your option) any later version. | ||||
|  * | ||||
|  * This program 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 Affero General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU Affero General Public License | ||||
|  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace FireflyIII\Helpers\Help; | ||||
|  | ||||
| /** | ||||
|  * Interface HelpInterface. | ||||
|  */ | ||||
| interface HelpInterface | ||||
| { | ||||
|     /** | ||||
|      * Get the help text from cache. | ||||
|      * | ||||
|      * @param string $route | ||||
|      * @param string $language | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getFromCache(string $route, string $language): string; | ||||
|  | ||||
|     /** | ||||
|      * Get the help text from GitHub. | ||||
|      * | ||||
|      * @param string $route | ||||
|      * @param string $language | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getFromGitHub(string $route, string $language): string; | ||||
|  | ||||
|     /** | ||||
|      * Is the route a known route? | ||||
|      * | ||||
|      * @param string $route | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function hasRoute(string $route): bool; | ||||
|  | ||||
|     /** | ||||
|      * Is the help text in cache? | ||||
|      * | ||||
|      * @param string $route | ||||
|      * @param string $language | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function inCache(string $route, string $language): bool; | ||||
|  | ||||
|     /** | ||||
|      * Put the result in cache. | ||||
|      * | ||||
|      * @param string $route | ||||
|      * @param string $language | ||||
|      * @param string $content | ||||
|      */ | ||||
|     public function putInCache(string $route, string $language, string $content); | ||||
| } | ||||
		Reference in New Issue
	
	Block a user