parsidev / randomizr
Generate some random madness.
Requires
- php: >=7.2
- illuminate/support: ~7.0 | ~8.0
README
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.
Table of contents
-
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
- Usage
2.1. Charsets
Randomizr distincs several character sets, which are:
Simple usage
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(); ...
Setting bounderies
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);
Combining charsets
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();
2.2. Aliases
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:
So in fact, lowercase
is an alias to vowel_constant
. And lets be honest, it's far more cleaner looking.
Combining aliases and/or charsets
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();
2.3 Generating unique randoms
Randomizr can generate randoms that are unique either in a directory or in a database table using the unique()
method instead of make()
.
Unique in a directory
randomizr('alpha_punctuation')->unique('path/to/dir');
Unique in a database table (for a field)
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.
Setting bounderies
The same way you can set bouderies for make()
, you can do it for unique()
:
randomizr('string')->unique('path/to/dir', 16, 6);
2.4. Using the Facade
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();
2.5. Additional helpers
In addition to the randomizr()
helper, a few other helper functions are included that can be used throughout the entire application:
Strings
str_starts_with
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
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
- Customizing
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.
3.1. Registering custom charsets
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).
3.2. Registering custom aliases
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 '.'.
Combining charsets and/or aliases
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.
Adding a raw string to an alias
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' ),
Using simple string functions
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" ),