⚝
One Hat Cyber Team
⚝
Your IP:
216.73.216.19
Server IP:
178.33.27.10
Server:
Linux cpanel.dev-unit.com 3.10.0-1160.108.1.el7.x86_64 #1 SMP Thu Jan 25 16:17:31 UTC 2024 x86_64
Server Software:
Apache/2.4.57 (Unix) OpenSSL/1.0.2k-fips
PHP Version:
8.2.11
Buat File
|
Buat Folder
Eksekusi
Dir :
~
/
home
/
id
/
dalily.dev-unit.com
/
app
/
Services
/
View File Name :
PageService.php
<?php /* * LaraClassifier - Classified Ads Web Application * Copyright (c) BeDigit. All Rights Reserved * * Website: https://laraclassifier.com * Author: Mayeul Akpovi (BeDigit - https://bedigit.com) * * LICENSE * ------- * This software is provided under a license agreement and may only be used or copied * in accordance with its terms, including the inclusion of the above copyright notice. * As this software is sold exclusively on CodeCanyon, * please review the full license details here: https://codecanyon.net/licenses/standard */ namespace App\Services; use App\Http\Resources\EntityCollection; use App\Http\Resources\PageResource; use App\Models\Page; use App\Services\Page\PageBy; use Illuminate\Http\JsonResponse; class PageService extends BaseService { use PageBy; /** * List pages * * @param array $params * @return \Illuminate\Http\JsonResponse */ public function getEntries(array $params = []): JsonResponse { $locale = config('app.locale'); $perPage = getNumberOfItemsPerPage('pages', $params['perPage'] ?? null, $this->perPage); $page = (int)($params['page'] ?? 1); $embed = getCommaSeparatedStrAsArray($params['embed'] ?? []); $excludedFromFooter = getIntAsBoolean($params['excludedFromFooter'] ?? 0); $sort = $params['sort'] ?? []; // Cache ID $excludedFromFooterId = '.excludedFromFooter.' . (int)$excludedFromFooter; $cacheEmbedId = !empty($embed) ? '.embed.' . implode(',', $embed) : ''; $cachePageId = '.page.' . $page . '.of.' . $perPage; $cacheId = 'pages.' . $excludedFromFooterId . $cacheEmbedId . $cachePageId . $locale; // Cached Query $pages = cache()->remember($cacheId, $this->cacheExpiration, function () use ($perPage, $excludedFromFooter, $sort) { $pages = Page::query(); if ($excludedFromFooter) { $pages->columnIsEmpty('excluded_from_footer'); } // Sorting $pages = $this->applySorting($pages, ['lft', 'created_at'], $sort); return $pages->paginate($perPage); }); // If the request is made from the app's Web environment, // use the Web URL as the pagination's base URL $pages = setPaginationBaseUrl($pages); $resourceCollection = new EntityCollection(PageResource::class, $pages, $params); $message = ($pages->count() <= 0) ? t('no_pages_found') : null; return apiResponse()->withCollection($resourceCollection, $message); } /** * Get page * * @param $slugOrId * @param array $params * @return \Illuminate\Http\JsonResponse */ public function getEntry($slugOrId, array $params = []): JsonResponse { $page = is_numeric($slugOrId) ? $this->getPageById($slugOrId) : $this->getPageBySlug($slugOrId); abort_if(empty($page), 404, t('page_not_found')); $resource = new PageResource($page, $params); return apiResponse()->withResource($resource); } }