1. Go to this page and download the library: Download luciansabo/fields-options library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
luciansabo / fields-options example snippets
/**
* Include fields from given path
*
* @param string|null $fieldPath Base path
* @param array $fields Optional list of
use Lucian\FieldsOptions\FieldsOptionsBuilder;
use Lucian\FieldsOptions\Validator;
$validator = new Validator($this->getSampleDto());
$builder = new FieldsOptionsBuilder($validator);
$fieldsOptions = $builder
->setFieldIncluded('id')
->setFieldExcluded('seo')
->setAllFieldsIncluded('profile.education')
->setFieldOption('profile.education', 'limit', 1)
->setFieldOption('profile.education', 'sort', 'startYear')
->setFieldOption('profile.education', 'sortDir', 'asc')
->build()
$fieldsOptions = $this->builder
->setFieldIncluded(null, ['name']) // this is equivalent to setFieldIncluded('name')
->setFieldIncluded('profile', ['workHistory']) // clude profile.education.id and profile.education.name
->setFieldIncluded('profile', ['education.startYear']) //
$data = $fieldsOptions->toArray();
$builder = new FieldsOptionsBuilder($validator, $data);
$builder->setFieldIncluded('fancyField');
use Lucian\FieldsOptions\FieldsOptions;
// assuming we use the Symfony request
// $request = Request:::createFromGlobals();
$data = json_decode($request->getContent());
$options = new FieldsOptions($data);
$options->isFieldIncluded('id'); // true
$options->isFieldIncluded('missing'); // false
// field is present but value is false
$options->isFieldIncluded('seo'); // false
$options->isFieldIncluded('profile'); // true
$options->isFieldIncluded('profile.education'); // true
$options->getFieldOption('profile.education', 'limit'); // 1
$options->getFieldOption('profile.education', 'missing', 1); // 1 - default
$options->getFieldOption('profile.education', 'missing'); // null - default
// field groups
$options->hasDefaultFields(); // true
$options->hasDefaultFields('profile'); // false
$options->hasAllFields('profile'); // false
$options->hasAllFields('profile.education'); // true
$options->hasAllFields('profiles.missing'); // throws exception
$options->hasGroupField('_basicInfo', 'profile'); // false
// you can export the entire structure
$array = $options->toArray();
/**
* WIll check if the options contain the default fields either by implicit or explicit inclusion
*
* @param string|null $fieldPath
* @return bool true if _defaults is not specified or specified and is not false, false otherwise
*/
public function hasDefaultFields(?string $fieldPath = null): bool
/**
* WIll check if the options contain all fields either by implicit or explicit inclusion
*
* @param string|null $fieldPath
* @return bool false if _all is not specified or specified and is not false, true otherwise
*/
public function hasAllFields(?string $fieldPath = null): bool
/**
* Returns the list of actually explicitly a field is a default field it won't be returned here.
* This will probably change in future versions to also array
interface ExportApplierInterface
{
/**
* This is s used to mark the exported properties on the object.
* It is up to the object and/or whatever serialization method you have to actually only export those.
* The easiest way to do it is to implement the native PHP `JsonSerializable`interface and write the logic right
* inside the object.
*
* @param object|array $data
* @param array|null $fields
* @return object|array $data with exported fields
*/
public function setExportedFields(/*object|array*/ $data, ?array $fields): void;
/**
* Returns the properties exported by default on the object.
*
* @param object|array $data
* @return string[]
*/
public function getExportedFields(/*object|array*/ $data): array;
/**
* Should return the base class of your DTO
* This helps
*
* @return string
*/
public function getSupportedClass(): string;
}
class SampleExportApplier implements ExportApplierInterface
{
public function setExportedFields($data, ?array $fields): void
{
if ($data instanceof AbstractDto) {
// keep valid properties only
if ($fields) {
$fields = array_filter($fields, [$data, 'propertyExists']);
}
$data->setExportedProperties($fields);
}
}
public function getExportedFields($data): array
{
if ($data instanceof AbstractDto) {
return array_keys(iterator_to_array($data->getIterator()));
}
return [];
}
public function getSupportedClass(): string
{
return AbstractDto::class;
}
}
$applier = new FieldsOptionsObjectApplier(new SampleExportApplier());
$dto = $this->getSampleDto();
$fieldsOptions = (new FieldsOptionsBuilder())
->setFieldIncluded('id')
->build();
$applier->apply($dto, $fieldsOptions);
// now DTO should only serialize the id field
echo json_encode($dto);
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.