Package Data | |
---|---|
Maintainer Username: | mjarestad |
Maintainer Contact: | mattias@portfolion.se (Mattias Jarestad) |
Package Create Date: | 2013-11-05 |
Package Last Update: | 2017-01-25 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2024-11-22 03:07:45 |
Package Statistics | |
---|---|
Total Downloads: | 181,305 |
Monthly Downloads: | 2,383 |
Daily Downloads: | 128 |
Total Stars: | 13 |
Total Watchers: | 2 |
Total Forks: | 3 |
Total Open Issues: | 0 |
#Filtry
A package to filter and sanitize input data in Laravel 4/5 or as a standalone package. This is perfect to use with the Laravel 4 Validation class to filter data before validation. You can easily extend and create your own custom filters.
##Requirements php version > 5.6
##Installation
composer require mjarestad/filtry
Add the ServiceProvider to the providers array in app/config/app.php
Laravel 5:
Mjarestad\Filtry\FiltryServiceProviderLaravel5::class,
Laravel 4:
'Mjarestad\Filtry\FiltryServiceProvider',
Add the Facade to the aliases array in app/config/app.php
'Filtry' => 'Mjarestad\Filtry\Facades\Filtry',
##Usage
###Laravel 5
####Form Requests
Extend your Form Request Validation classes with the provided Filtry Request to filter input data before validation.
<?php
use Mjarestad\Filtry\Http\Requests\Request;
class StorePostRequest extends Request
{
public function rules()
{
return [
'author' => 'required',
'slug' => 'required',
];
}
public function filters()
{
return [
'author' => 'trim|ucwords',
'slug' => 'trim|replace:%,percent|slug',
];
}
}
###Laravel 4
Add a the filters property to your Eloquent Model or anywhere else you prefer.
<?php
class Post extends Eloquent {
public static $filters = array(
'author' => 'trim|ucwords',
'slug' => 'trim|replace:%,percent|slug'
);
public static $rules = array(
'author' => 'required',
'slug' => 'required'
);
}
In your controller or service call Filtry::make()
and provide the data to filter and your filters array.
<?php
$filtry = Filtry::make(Input::all(), Post::$filters);
To get the filtered value use $filtry->getFiltered()
<?php
$validator = Validator::make($filtry->getFiltered(), Post::$rules);
To get the unfiltered values, use:
<?php
$filtry->getOld();
Every method can be used to filter a single value.
<?php
Filtry::trim('some string');
Filtry::slug('some string');
Filtry::snakeCase('some string');
###Standalone
<?php
$filters = [
'author' => 'trim|ucwords',
'slug' => 'trim|replace:%,percent|slug',
];
$data = [
'author' => 'John Doe',
'slug' => 'My post title',
];
$filtry = new Mjarestad\Filtry\Filtry;
$filtry->make($data, $filters);
$filteredData = $filtry->getFiltered();
##Create custom filters
###Laravel
Extend with custom filters to use in Filtry::make()
or as dynamic methods.
<?php
Filtry::extend('my_custom_filter', function ($data) {
return str_replace('-', '_', $data);
});
Call the extended filter dynamically
<?php
Filtry::myCustomFilter('some-custom-string');
You can define optional parameters for your filter.
<?php
Filtry::extend('custom_filter', function ($data, $param1, $param2) {
return $data . ($param1 + $param2);
});
And then add the parameters in your request:
<?php
use Mjarestad\Filtry\Http\Requests\Request;
class StorePostRequest extends Request
{
public function rules()
{
return [
'author' => 'required',
];
}
public function filters()
{
return [
'author' => 'custom_filter:1,2',
];
}
}
It will concatenate 3 to your author attribute.
###Standalone
<?php
$filtry = new Mjarestad\Filtry\Filtry;
$filtry->extend('my_custom_filter', function ($data) {
return str_replace('-', '_', $data);
});
$filtry->myCustomFilter('some-custom-string');
##Available filters
###Core PHP filters
###Custom filters
###Laravel filters
Theese filters can still be used in a non-Laravel application.