parsidev/randomizr is a Laravel package for generate some random madness..
It currently has 0 GitHub stars and 101 downloads on Packagist (latest version 2.0.1).
Install it with composer require parsidev/randomizr.
Discover more Laravel packages by parsidev
or browse all Laravel packages to compare alternatives.
Last updated
Randomizr is a simple package that helps you generate all kinds of random stuff (hashes, strings, numbers, ...). It can even check whether the created random is unique within a given database table or directory.
Usage
2.1. Charsets
2.2. Aliases
2.3. Generating unique randoms
2.4. Using the Facade
2.5. Additional helpers
Customizing
3.1. Registering custom charsets
3.2. Registering custom aliases
Installation
$ composer require parsidev/randomizr
Register the Service Provider:
'providers' => [
...
Parsidev\Support\Providers\RandomizrServiceProvider::class,
],
// @file app/config/app.php
Additionally, you may register an alias for it, though it's not required (you can also use the helper or include the namespace):
'aliases' => [
...
'Randomizr' => Parsidev\Support\Facades\Randomizr::class,
],
// @file app/config/app.php
To make sure the package will be loaded properly, run:
$ composer update
Randomizr distincs several character sets, which are:
| Name | Contents |
|:--------------|:----------------------------------------------|
| num | 0123456789 |
| vowel | aeijoy |
| consonant | bcdfghklmnpqrstvwxyz |
| special | áäâàæãåāaeéëêèęėēuúüûùūiíïïìiîįīoóöôòõœøōç |
| space | ' ' |
| dash | - |
| underscore | _ |
| punctuation | :,.?!() |
To generate a random using either one of the charset, simply call the make() method on the randomizr() helper and tell it which charset you want to use:
randomizr('vowel')->make();
randomizr('num')->make();
...
The make() method accepts 2 (optional) arguments: $max and $min:
// Set the max length to 16
randomizr('consonant')->make(16);
// Set the minimum length to 2
randomizr('num')->make(16, 2);
You can also mix 'n match different charsets. For example, if you want to generate a random num, but also allow a dash and an underscore in it:
randomizr('num_dash_underscore')->make();
// or, if you prefer
randomizr('numDashUnderscore')->make();
Though camel- or snake casing is a very convenient way to merge various charsets, you may as well register an alias for it. By default, these are the ones provided:
| Name | Combines |
|:--------------|:----------------------------------------------|
| lowercase | vowel, consonant |
| uppercase | uppercased lowercase |
| alpha | uppercase, lowercase |
| string | alpha, num, dash, space, underscore, punctuation, '&$@' |
| hash | alpha, num, dash, underscore, '&$@' |
So in fact, lowercase is an alias to vowel_constant. And lets be honest, it's far more cleaner looking.
As you may have seen it already in the table above, aliases also allow to combine charsets with aliases, or even aliases with each other:
// Using charsets only
randomizr('vowel_consonant_num')->make();
// Using the `alpha` alias to merge `vowel` and `consonant`
randomizr('alpha_num')->make();
Randomizr can generate randoms that are unique either in a directory or in a database table using the unique() method instead of make().
randomizr('alpha_punctuation')->unique('path/to/dir');
randomizr('lowercase_dash')->unique('tablename@field');
Note: Checking for uniqueness against a database table requires the package to run in a Laravel application. You won't be able to use this feature elsewhere.
The same way you can set bouderies for make(), you can do it for unique():
randomizr('string')->unique('path/to/dir', 16, 6);
I personally prefer using the helper method (which doesn't require you to put the full namespace at the top of your file), but you can just as well use the facade or alias (if registered in the app config):
randomizr('alpha_num')->make();
// equals
randomizr('alphaNum')->make();
// equals
Randomizr::alpha_num()->make();
// equals
Randomizr::alphaNum()->make();
In addition to the randomizr() helper, a few other helper functions are included that can be used throughout the entire application:
str_starts_with checks if a given string starts with a specified (group of) character(s).
str_starts_with('a', 'abc'); // returns true
str_starts_with('b', 'abc'); // returns false
str_ends_with checks if a given string ends with a specified (group of) character(s).
str_ends_with('de', 'abcde'); // returns true
str_ends_with('cd', 'abcde'); // returns false
Several charsets and aliases are available by default, but you can add your own ones if you like. All you need to do is config the Randomizr config file:
$ php artisan randomizr:publish
The config file will be published to app/config/packages/luminol/randomizr/randomizr.php.
Note: I made a custom artisan command for this to keep publishing assets the same for both L4 and L5.
Registering custom charsets is pretty straight forward. Just add:
'charsets' => array(
...
'mycharsetname' => 'characters_for_this_charset'
),
Important: Charset names should always consise of one word only. Do not use snake- or camel casing (it'll break the combine functionality).
Custom aliases are a bit more configurable: it uses piping to separate the different components to combine. These components can be a raw string, charset or alias and can even be altered using a basic string functions.
To illustrate all of this, let's image you need to generate a random ID, which can contains alpha characters (both upper- and lowercase), dashes and '.'.
The example above tells us the ID alias may contain alpha characters (which is an alias) and dashes (which is a charset). So to combine them in the id alias:
'aliases' => array(
...
'id' => "alpha|dash"
),
Randomizr will automatically resolve these as an alias and a charset.
In our example above, we also need a '.' (dot) to be added. It is available in the punctuation charset, but all other characters in this one are not allowed in the ID alias.
We could register the single dot as a charset, but we can also pass it as a raw string to the alias. Just wrap it between single quotes:
'aliases' => array(
...
'id' => "alpha|dash|'.'"
),
If you want to add a raw number to the alias, no need to wrap it in single quotes (though it will work as well):
'aliases' => array(
...
'id' => "consonant|6", // the result will be 'aeijoy6'
),
Aliases also allow basic string functions to be used. For example, you might only want an uppercased version of the special charset. In that case, you can seperate the function name and its argument using method:arg1,arg2 format:
'aliases' => array(
...
'uspecial' => "strtoupper:special"
),
The functions arguments can be a charset, an alias or even a raw string (wrapped in single quotes):
'aliases' => array(
...
'notnull' => "str_replace:0,'',num", // results in '123456789'
'custom' => "my_custom_function:'arg1',num"
),