RollerworksSearch is a powerful search-system for PHP. Created to make searching in a PHP powered application as simple and fast as possible.
Whether you want to search for users in your SQL database, want to provide a powerful search system for searching products using an ElasticSearch back-end or are looking for a way to abstract filtering for a reporter.
A complex data is structure is no problem, say your customer data is stored in the "customer" table, the "invoices" data is stored in it's own table, and the details of the invoices have there own table.
Instead of writing a very verbose SQL query, your users can use the easy to learn StringQuery syntax:
invoice-price: > $20.00; invoice-row-label: ~*"my cool product"; customer-type: !consumer
.
You just searched in three relational tables using a single condition with a user-friendly syntax. And that is just the start, RollerworksSearch can work with any locale, custom input format, or storage system.
Search conditions can be as simple or complex as you need them to be. Including grouping and nesting for the best possible result.
RollerworksSearch provides you with most of the features you would expect from a search system, including:
- Localized input processing using the StringQuery format;
- User-friendly format validation;
- Integration with API-Platform;
- Integration for Symfony 4.4 and up (Symfony Flex supported).
And support for the most poplar storage systems.
Please ignore the instructions below if your use a framework integration.
Read the Documentation for complete instructions and information.
Install the RollerworksSearch "core" library using Composer:
$ composer install rollerworks/search
And create the SearchFactory
to get started.
use Rollerworks\Component\Search\Searches;
use Rollerworks\Component\Search\Exception\InvalidSearchConditionException;
use Rollerworks\Component\Search\Extension\Core\Type\TextType;
use Rollerworks\Component\Search\Extension\Core\Type\IntegerType;
use Rollerworks\Component\Search\Extension\Core\Type\ChoiceType;
use Rollerworks\Component\Search\Input\ErrorPathHumanizer;
use Rollerworks\Component\Search\Input\StringQueryInput;
use Rollerworks\Component\Search\Input\ProcessorConfig;
// The factory is reusable, you create it only once.
$searchFactory = Searches::createSearchFactory();
// Create a fieldset to inform the system about your configuration.
// Usually you will have a FieldSet for each data structure (users, invoices, etc).
$userFieldSet = $searchFactory->createFieldSetBuilder()
->add('firstName', TextType::class)
->add('lastName', TextType::class)
->add('age', IntegerType::class)
->add('type', ChoiceType::class, [
'choices' => ['Consumer' => 'c', 'Business' => 'b'],
])
->getFieldSet('users');
// Now lets process a string query.
// Tip: the input processor is reusable.
$inputProcessor = new StringQueryInput();
try {
// The ProcessorConfig allows to limit the amount of values, groups
// and maximum nesting level. The defaults should be restrictive enough
// for most situations.
$processorConfig = new ProcessorConfig($userFieldSet);
// The `process` method processes the input and produces
// a valid SearchCondition (or throws an exception when something is wrong).
$condition = $inputProcessor->process('firstName: sebastiaan, melany;');
} catch (InvalidSearchConditionException $e) {
// Each error message can be transformed to a localized version
// using the Symfony Translator contract.
$translator = ...; // \Symfony\Contracts\Translation\TranslatorInterface
// Note: The ErrorPathHumanizer only works for the `StringQueryInput` input processor.
$errorPathHumanizer = new ErrorPathHumanizer($translator);
foreach ($e->getErrors() as $error) {
echo '<span>' $errorPathHumanizer->humanize($error->path) . ' </span><span>' . htmlentities($error->trans($translator), ENT_COMPAT | ENT_IGNORE, 'UTF-8') '</span>' . PHP_EOL;
}
}
That's it! The $condition
contains the SearchCondition in a normalized
data format which can be used in a condition processor (like ElasticSearch),
or be exported into another format like JSON for easier usage in a URL.
Note: RollerworksSearch is composed of multiple separate packages (to keep the architecture slim), the "core" package provides everything you need to get started.
Searching a (document) storage requires the installation of additional packages.
Each field type ensures the value is transformed to the correct format,
either a date input is automatically transformed to a DateTimeImuttable
object.
A field that expects an integer will fail when the provided input is not an integer.
To enforce more strict constraints like a maximum amount for an integer field you can use the Symfony Validator extension.
- Read the Documentation
- RollerworksSearch is maintained under the Semantic Versioning guidelines
RollerworksSearch is brought to you by Sebastiaan Stok.
RollerworksSearch is released under the MIT license.
The types and extensions are largely inspired on the Symfony Form Component, and contain a big amount of code from the Symfony project.
Use the issue tracker to create a new support question.
Note: Please be patient, it might take some time before your question is answered. Do not ping the maintainers.
This is an open source project. If you'd like to contribute, please read the Contributing Guidelines. If you're submitting a pull request, please follow the guidelines in the Submitting a Patch section.
Note: RollerworksSearch is developed in a monolith repository, do not open pull request
against repositories marked as [READ-ONLY]
, thank you.