Caching added for api
This commit is contained in:
@@ -8,18 +8,21 @@ use App\Source;
|
||||
use Illuminate\Http\JsonResponse;
|
||||
use App\Http\Resources\ArticleResource;
|
||||
use App\Http\Controllers\Controller;
|
||||
use Illuminate\Support\Facades\Cache;
|
||||
|
||||
class SourcesAPIController extends Controller
|
||||
{
|
||||
{
|
||||
/**
|
||||
* Return all the avaialble Sources.
|
||||
*
|
||||
*/
|
||||
public function index()
|
||||
{
|
||||
return SourceResource::collection(Source::all());
|
||||
return Cache::remember('sources.index', 300, function () {
|
||||
return SourceResource::collection(Source::all());
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Return all the articles for a given source
|
||||
*
|
||||
@@ -28,9 +31,11 @@ class SourcesAPIController extends Controller
|
||||
*/
|
||||
public function show(Source $source)
|
||||
{
|
||||
return response()->json([
|
||||
'source' => new SourceResource($source),
|
||||
'articles' => $source->articles()->with('source')->latest('published_date')->paginate(8)
|
||||
]);
|
||||
return Cache::remember($source->slug. '32', 300, function () use ($source) {
|
||||
return response()->json([
|
||||
'source' => new SourceResource($source),
|
||||
'articles' => $source->articles()->with('source')->latest('published_date')->paginate(8)
|
||||
]);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user