-
Notifications
You must be signed in to change notification settings - Fork 66
Creating Custom Filter
Remember, this package firstly checks whether it is or not custom filter. (except constant parameters). If there is a custom filter for query parameter, applies it. Otherwise, searches this parameter in the table columns and applies.
Tablo sütunlarınızın isimlerinin api parametrelerinde açıkca kullanılmasının güvenlik zaafı oluşturacağını düşünüyorsanız özel filtreler ile bu durumu engelleyebilirsiniz.
Özel filtre ile ?name=Selahattin şeklinde gelen sorguyu name
sütunu yerine tablonuzdaki gerçek sütun ismi ile sorgulatabilirsiniz.
- İlk olarak kullanıcağınız model için bir
QueryBuilder
sınıfından türeyen bir sınıf oluşturun. - Daha sonra özel filtreleme uygulanacak olan url ile gelen parametre ismini studly case olacak şekilde ("filterByParameterName") methodunuzu oluşturun.
<?php
use Unlu\Laravel\Api\QueryBuilder;
class UserQueryBuilder extends QueryBuilder
{
public function filterByName($query, $name)
{
return $query->where('fullname', $name);
}
}
?>
Son olarak controller içerisinde QueryBuilder sınıfı yerine oluşturduğunuz sınıfı kullanın.
<?php
namespace App\Whatever\Api\Controllers;
use App\Http\Requests;
use App\User;
use Illuminate\Http\Request;
// Add this line
use YourNameSpace\Path\UserQueryBuilder;
class UsersController extends Controller
{
public function index(Request $request)
{
$queryBuilder = new UserQueryBuilder(new User, $request);
return response->json([
'data' => $queryBuilder->paginate()->result(),
.
.
]);
}
}
?>
Basit where sorgularını yerine çok daha karmaşık sorgulara ihtiyaç duyduğunuz zaman da özel filtre oluşturarak bu ihtiyacınızı giderebilirsiniz.
Bu paket herhangi bir özel filtre olmadığında api/users?city_name=Istanbul
adresine gelen sorguyu kullandığınız modelin tablosundaki city_name
sütununa göre filtrelemeye çalışır.
Fakat sizin users
tablonuzda şehirler ile ilgili ilişkilendirmeyi city_id
sütunu ile yaptığınızı varsayalım. Bu durumda karmaşık bir where sorgusu oluşturmak için özel filtre oluşturmalısınız.
use Unlu\Laravel\Api\QueryBuilder;
class UserQueryBuilder extends QueryBuilder
{
public function filterByCityName($query, $name)
{
return $query->whereHas('city', function($q) use ($name) {
return $q->where('name', $name);
});
}
}