This repository contains some useful helpers for most applications using Laravel.
You can install the package via composer:
composer require maize-tech/laravel-helpers
You can publish the config file with:
php artisan vendor:publish --tag="helpers-config"
This is the content of the published config file:
return [
/*
|--------------------------------------------------------------------------
| Helper class
|--------------------------------------------------------------------------
|
| Here you may specify the fully qualified class name of the helper class.
|
*/
'helper' => Maize\Helpers\Helper::class,
];
To use the package, you can simply call the hlp()
helper function, followed by one of the Available methods methods listed below.
If needed, you could also call the static method directly.
Here's an example using both the helper function and the static method:
hlp()->sanitizeUrl('mywebsite.com'); // using the helper function
\Maize\Helpers\Helper::sanitizeUrl('mywebsite.com'); // using the static method
paginationLimit
anonymizeFilename
sanitizeUrl
instanceofTypes
classUsesTrait
morphClassOf
modelKeyName
The paginationLimit
function returns the amount of items per page.
It is useful when working with queries who need a pagination, and allows to define a default pagination limit and the max amount of items per page.
It will also check whether the request's query string contains a limit
parameter: if true, the given limit overrides the default limit.
use App\Models\Article;
// use the default pagination limit (16 items)
// GET /api/articles
Article::paginate(
hlp()->paginationLimit() // returns 16 items
);
// use the pagination limit given by the request query string
// GET /api/articles?limit=20
Article::paginate(
hlp()->paginationLimit() // returns 20 items
);
// provide a custom default pagination limit
// GET /api/articles
Article::paginate(
hlp()->paginationLimit(30) // returns 30 items
);
// when defined, the request query string limit overrides the default limit
// GET /api/articles?limit=20
Article::paginate(
hlp()->paginationLimit(30) // returns 20 items
);
// provide a max limit of items for each page
// GET /api/articles?limit=200
Article::paginate(
hlp()->paginationLimit(16, 50) // returns 50 items
);
The anonymizeFilename
function returns a randomized name of the given file followed by its extension.
string $filename = 'my-custom-file.xml';
// returns a UUID string followed by the file extension
// e.g. 'd437fd98-68d1-4874-b0e7-fac06e587083.xml'
hlp()->anonymizeFilename($filename);
The sanitizeUrl
function returns the lower case of the given url and prefixes it with the https
protocol if none is set.
hlp()->sanitizeUrl('http://innovation.h-farm.com'); // returns 'http://innovation.h-farm.com'
hlp()->sanitizeUrl('innovation.h-farm.com'); // returns 'https://innovation.h-farm.com'
hlp()->sanitizeUrl('') // returns an empty string
The instanceofTypes
function returns whether a class object is an instance of at least one of the given types or not.
use App\Models\User;
use Exception;
use Illuminate\Database\Eloquent\Model;
$model = User::firstOrFail();
hlp()->instanceofTypes($model, Model::class); // returns true
hlp()->instanceofTypes($model, Exception); // returns false
hlp()->instanceofTypes($model, [
Model::class,
Exception::class,
]); // returns true
The classUsesTrait
function returns whether a class object or name uses the given trait or not.
use App\Models\User;
use Exception;
use Illuminate\Database\Eloquent\Factories\HasFactory;
$model = User::firstOrFail();
hlp()->classUsesTrait(HasFactory::class, $model); // returns true
hlp()->classUsesTrait(HasFactory::class, User::class); // returns true
hlp()->classUsesTrait(Exception::class, $model); // returns false
hlp()->classUsesTrait(Exception::class, User::class); // returns false
The morphClassOf
function returns the morph class name of a given model object or class name.
use App\Models\User;
use Illuminate\Database\Eloquent\Relations\Relation;
$model = User::firstOrFail();
hlp()->morphClassOf($model); // returns 'App\Models\User'
hlp()->morphClassOf(User::class); // returns 'App\Models\User'
Relation::enforceMorphMap([
'user' => User::class,
]);
hlp()->morphClassOf($model); // returns 'user'
hlp()->morphClassOf(User::class); // returns 'user'
The modelKeyName
function returns the key name of a given model object or class name.
use App\Models\User;
$model = User::firstOrFail();
hlp()->modelKeyName($model); // returns 'id'
hlp()->modelKeyName(User::class); // returns 'id'
If needed, you can easily extend the Helper
class to add your own methods.
All you have to do is create a new class which overrides the Helper
base class and adds all the methods you need.
After that, you can override the helper
attribute from config/helpers.php
to match the newly created class.
Here's an example of the output class:
<?php
namespace Support\Helpers;
use Maize\Helpers\Helper as BaseHelper;
class Helper extends BaseHelper
{
public static function awesomeHelper(): string
{
return "Just another awesome helper!";
}
}
Whereas the helpers.php
config file should look like this:
return [
/*
|--------------------------------------------------------------------------
| Helper class
|--------------------------------------------------------------------------
|
| Here you may specify the fully qualified class name of the helper class.
|
*/
'helper' => Support\Helpers\Helper::class,
];
You can then call all your custom-made helper methods using the hlp()
function:
hlp()->awesomeHelper(); // returns "Just another awesome helper!";
composer test
Please see CHANGELOG for more information on what has changed recently.
Please see CONTRIBUTING for details.
Please review our security policy on how to report security vulnerabilities.
The MIT License (MIT). Please see License File for more information.