Caching added for api
This commit is contained in:
@@ -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);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -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)
|
||||||
|
];
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -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)
|
||||||
|
]);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -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();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -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)
|
||||||
|
]);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user