Caching added for api

This commit is contained in:
2020-08-24 16:26:35 +05:00
parent 9e8fc28d3a
commit 4bc1f5448e
5 changed files with 59 additions and 42 deletions

View File

@@ -6,11 +6,14 @@ use Illuminate\Http\Request;
use App\Article; use App\Article;
use App\Http\Resources\ArticleResource; use App\Http\Resources\ArticleResource;
use App\Http\Controllers\Controller; use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Cache;
class ArticlesAPIController extends Controller class ArticlesAPIController extends Controller
{ {
public function show(Article $article) : ArticleResource public function show(Article $article): ArticleResource
{ {
return new ArticleResource($article); return Cache::remember('article_'.$article->id, 300, function () use ($article){
return new ArticleResource($article);
});
} }
} }

View File

@@ -6,6 +6,7 @@ use App\Article;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use App\Http\Resources\ArticleResource; use App\Http\Resources\ArticleResource;
use App\Http\Controllers\Controller; use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Cache;
final class RecentArticles extends Controller final class RecentArticles extends Controller
{ {
@@ -16,10 +17,12 @@ final class RecentArticles extends Controller
*/ */
public function __invoke() public function __invoke()
{ {
return [ return Cache::remember('articles.recent', 300, function () {
"articles" => Article::with('source', 'topics') return [
->latest("published_date") "articles" => Article::with('source', 'topics')
->paginate(20) ->latest("published_date")
]; ->paginate(20)
];
});
} }
} }

View File

@@ -8,6 +8,7 @@ use App\Source;
use Illuminate\Http\JsonResponse; use Illuminate\Http\JsonResponse;
use App\Http\Resources\ArticleResource; use App\Http\Resources\ArticleResource;
use App\Http\Controllers\Controller; use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Cache;
class SourcesAPIController extends Controller class SourcesAPIController extends Controller
{ {
@@ -17,7 +18,9 @@ class SourcesAPIController extends Controller
*/ */
public function index() public function index()
{ {
return SourceResource::collection(Source::all()); return Cache::remember('sources.index', 300, function () {
return SourceResource::collection(Source::all());
});
} }
/** /**
@@ -28,9 +31,11 @@ class SourcesAPIController extends Controller
*/ */
public function show(Source $source) public function show(Source $source)
{ {
return response()->json([ return Cache::remember($source->slug. '32', 300, function () use ($source) {
'source' => new SourceResource($source), return response()->json([
'articles' => $source->articles()->with('source')->latest('published_date')->paginate(8) 'source' => new SourceResource($source),
]); 'articles' => $source->articles()->with('source')->latest('published_date')->paginate(8)
]);
});
} }
} }

View File

@@ -7,6 +7,7 @@ use App\Article;
use Illuminate\Support\Carbon; use Illuminate\Support\Carbon;
use App\Http\Resources\ArticleResource; use App\Http\Resources\ArticleResource;
use App\Http\Controllers\Controller; use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Cache;
class TodaysPick extends Controller class TodaysPick extends Controller
{ {
@@ -19,27 +20,29 @@ class TodaysPick extends Controller
*/ */
public function __invoke() public function __invoke()
{ {
return Article::with('topics', 'source') return Cache::remember('articles.todayspick', 300, function () {
->whereDate('published_date', Carbon::today()) return Article::with('topics', 'source')
->inRandomOrder() ->whereDate('published_date', Carbon::today())
->take(8) ->inRandomOrder()
->get() ->take(8)
->transform(function ($article) { ->get()
return [ ->transform(function ($article) {
"id" => $article->id, return [
"title" => $article->title, "id" => $article->id,
"url" => $article->url, "title" => $article->title,
"author" => $article->author, "url" => $article->url,
"featured_image" => $article->featured_image, "author" => $article->author,
"published_date" => $article->published_date, "featured_image" => $article->featured_image,
"meta" => $article->meta, "published_date" => $article->published_date,
"source" => $article->source, "meta" => $article->meta,
"topics" => $article->topics, "source" => $article->source,
"body" => $article->body, "topics" => $article->topics,
]; "body" => $article->body,
}) ];
->unique('source.name') })
->values() ->unique('source.name')
->toArray(); ->values()
->toArray();
});
} }
} }

View File

@@ -8,6 +8,7 @@ use App\Http\Resources\TopicResource;
use Illuminate\Http\JsonResponse; use Illuminate\Http\JsonResponse;
use App\Http\Resources\ArticleResource; use App\Http\Resources\ArticleResource;
use App\Http\Controllers\Controller; use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Cache;
class TopicsAPIController extends Controller class TopicsAPIController extends Controller
{ {
@@ -29,9 +30,11 @@ class TopicsAPIController extends Controller
*/ */
public function show(Topic $topic) public function show(Topic $topic)
{ {
return response()->json([ return Cache::remember('topic_'.$topic->slug, 300, function () use ($topic) {
'topic' => new TopicResource($topic), return response()->json([
'articles' => $topic->articles()->with('source')->latest('published_date')->paginate(8) 'topic' => new TopicResource($topic),
]); 'articles' => $topic->articles()->with('source')->latest('published_date')->paginate(8)
]);
});
} }
} }