simon-downes / spf-support
Support library of SPF - Simon's PHP Framework
Requires
- php: ~7.2
- simon-downes/spf-contracts: dev-master
Requires (Dev)
- phpunit/phpunit: ^7
This package is auto-updated.
Last update: 2025-02-07 01:35:52 UTC
README
Provides various supporting elements to SPF, such as:
- Collections
- Configuration
- Fieldsets and Fields
- Twig Extension
- Validation
Requirements
This library requires only PHP 7.2 or later and the SPF Contracts package (simon-downes/spf-contracts
).
Installation
It is installable and autoloadable via Composer as simon-downes/spf-support
.
Alternatively, download a release or clone this repository, and add the \spf\support
namespace to an autoloader.
License
SPF Support is open-sourced software licensed under the MIT license.
Collections
This package provides basic implementation of the Collection
, Dictionary
and
Set
interfaces defined in the spf-contracts
package.
BaseCollection
accepts an array of items in its constructor and provides basic
collection operations such as iteration, counting, emptying and testing for existence.
There is no support for adding or removing individual items, this being provided
by specific subclasses.
BaseDictionary
extends BaseCollection
to add support for adding and removing
key/value pairs - each key being unique.
BaseSet
extends BaseCollection
to add support for adding and removing
unique items.
use spf\support\collections\{BaseCollection, BaseDictionary, BaseSet}; $c = new BaseCollection([123, 456, 789]); $c->count(); // returns 3 $c->contains(456); // returns true $c->contains(234); // returns false $c->isEmpty(); // returns false $c->clear(); // remove all items $c->isEmpty(); // returns true $d = new BaseDictionary(); $d->add('foo', 123); $d->add('bar', 456); $d->has('foo'); // returns true $d->has('baz'); // returns false $d->get('foo'); // returns 123 $d->keys(); // returns ['foo', 'bar'] $d->remove('bar'); $d = new BaseSet(); $d->add('foo'); $d->add('bar'); $d->contains('foo'); // returns true $d->remove('bar'); $d->contains('bar'); // returns false
Configuration
BaseConfig
provides a basic configuration object, the underlying implementation
being an array. The array can be populated from an external file via load()
,
or from an existing array via merge()
. Methods are also provided to allow easy
access to nested elements.
use spf\support\BaseConfig; $c = new BaseConfig([ 'foo' => [ 'bar' => 123, 'baz' => 456, ], ]); $c->get('foo.bar'); // returns 123 $c->set('foo.baz', 789); // changes the value of ['foo']['bar'] // overwrite the 'foo' branch and add an additional value for 'bar' $c->merge([ 'foo' => 'abc', 'bar' => 'def', ]); $c->get('foo.bar'); // returns null (key doesn't exist) $c->get('bar'); // returns 'def' $c->load(__DIR__. 'config.php'); // 'config.php' should return an array
Fieldsets and Fields
A field represents an object property, database column or similar construct.
Fieldsets are collections of Fields and can be used as database table/model definitions, html form definitions, etc.
Fields
A Field must have a name and a type and may optionally have additional rules defining rules for values that are considered valid.
Supported field types are listed in spf\contracts\support\Type
.
use spf\support\Field; $f = new Field('id', Type::INTEGER); $f = new Field('email', Type::EMAIL, ['required' => true, 'unique' => true]); $f = new Field( 'status', Type::ENUM, [ 'required' => true, 'values' => ['EMPLOYEE', 'PARTNER', 'OTHER'] ] );
Available Rules:
required
- [boolean
] if true, must have a non-empty value (default: false)nullable
- [boolean
] determines if null is an acceptable value (default: false)default
- [mixed
] default value to use if none specified (default: empty based on type)label
- [string
] user-friendly label, (default: title-cased name)unique
- [boolean
] determines if values should be unique (default: false)min
- [integer|string
] minimum acceptable valuemax
- [integer|string
] maximum acceptable valuemin-length
- [integer
] minimum length of valuemax-length
- [integer
] maximum length of valueregex
- [string
] a regular expression that acceptable values must matchvalues
- [array
] an array containing all acceptable values
Specified rules are available as properties on a Field object; e.g. $f->required
.
Fields are immutable once instantiated.
There are two methods provided for validation:
cast()
- cast a specified value to the Field's typevalidate()
- validate a specified value against the Field's rules and return a 'cleaned' value and any validation error encountered. Supported errors are defined inspf\contracts\support\Error
.
use spf\contracts\support\Error; use spf\support\Field; $f = new Field('id', Type::INTEGER, ['required' => true, 'min' => 0]); $f->cast(false); // returns 0 $f->cast('123fgh'); // returns 123 $f->cast('fghsdfs'); // returns 0 $f->validate(0); // returns [0, Error::REQUIRED] $f->validate(false); // returns [false, Error::REQUIRED] $f->validate('123fgh'); // returns [123, Error::NONE] $f->validate('fghsdfs'); // returns ['fghsdfs', Error::TYPE] $f->validate(-123); // returns [-123, Error::MIN]
Fieldsets
Fields are added via the add()
method:
use spf\support\Fieldset; $f = new Fieldset(); $f->add($name, $type = Type::TEXT, $rules = []);
All Fields in the Fieldset can be validated at once by calling the validate()
method
and passing an array of field names and values.
The return value is an array containing two elements, the first is an array of 'cleaned'
values, indexed by Field name; the second is an array of validation errors, indexed by
Field name.
use spf\contracts\support\Error; use spf\support\Fieldset; $f = new Fieldset(); $f->add('id', Type::INTEGER); $f->add('email', Type::EMAIL, ['required' => true, 'unique' => true]); $f->validate([ 'id' => '123', 'email' => 'bar', ]); /* returns: [ [ 'id' => 123, 'email' => 'bar', ], [ 'id' => Error::NONE, 'email' => Error::EMAIL, ], ]
Twig Extension
The Twig extension provides additional utility functionality to Twig environments.
Tests (is):
numeric
- determines if a variable contains a numeric valueinteger
- determines if a variable contains an integer valuestring
- determines if a variable is a stringarray
- determines if a variable is an arrayobject
- determines if a variable is an object
Filters
md5
- generate the md5 hash of a valuesha1
- generate the sha1 hash of a valuetruncate
- truncate a value to a specified lengthsum
- generate the sum of an array, viaarray_sum()
shuffle
- shuffle an array, viashuffle()
Functions
ceil
- round a value up to next highest integer, viaceil()
floor
- round a value down to next lowest integer, viafloor()
If the spf-core
package is detected, most Helper methods are included as
filters or functions where there is no corresponding native functionality.
Validation
The spf\support\Validator
class contains static methods for validating values.
Where possible validation is performed using PHP's built-in filter_var()
function
with appropriate flags.
Validation function will return a valid value of the correct type, or an empty
value of the correct type.
isEmpty($v, $type = Type::TEXT)
validateText($v)
validateInteger($v)
validateFloat($v)
validateBoolean($v)
validateTimestamp($v)
validateDateTime($v, $format = 'Y-m-d H:i:s')
validateDate($v)
validateTime($v)
validateYear($v, $min = 1900, $max = 2155)
validateEmail($v)
validateIP($v)
validateURL($v)
validateJSON($v)
validateObject($v, $class, $nullable = false)