This repository has been archived by the owner on Jul 6, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
HttpFoundationSearchProcessor.php
77 lines (67 loc) · 2.69 KB
/
HttpFoundationSearchProcessor.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
<?php
declare(strict_types=1);
/*
* This file is part of the RollerworksSearch package.
*
* (c) Sebastiaan Stok <s.stok@rollerscapes.net>
*
* This source file is subject to the MIT license that is bundled
* with this source code in the file LICENSE.
*/
namespace Rollerworks\Component\Search\Processor;
use Psr\Http\Message\ServerRequestInterface as ServerRequest;
use Rollerworks\Component\Search\Exception\UnexpectedTypeException;
use Symfony\Bridge\PsrHttpMessage\Factory\DiactorosFactory;
use Symfony\Component\HttpFoundation\Request;
/**
* HttpFoundationSearchProcessor handles a search provided with
* eg. a PSR-7 ServerRequest or a HttpFoundation Request.
*
* @author Sebastiaan Stok <s.stok@rollerscapes.net>
*/
final class HttpFoundationSearchProcessor implements SearchProcessor
{
private $processor;
/**
* Constructor.
*
* @param SearchProcessor $processor
*/
public function __construct(SearchProcessor $processor)
{
$this->processor = $processor;
}
/**
* Process the request for a search operation.
*
* A processor is expected to follow a few simple conventions:
*
* * The processor must return a SearchPayload with the results of the processing.
* * A new condition must mark the payload as changed.
* * The SearchPayload#searchCode property is expected to contain an input processable
* search-condition (like JSON) which can be used safely within an URI, when the condition is valid.
* * The client may provide the input format using the `format` query/parsedBody information, but the
* processor's implementation can choose to ignore this.
*
* A Processor must first check if a new condition is provided and fall-back
* to the `searchCode` as active condition.
*
* @param ServerRequest|Request $request The ServerRequest to extract information from
* @param ProcessorConfig $config Input processor configuration
*
* @return SearchPayload The SearchPayload contains READ-ONLY information about
* the processing, and 'when there were no errors' the SearchCondition
*/
public function processRequest($request, ProcessorConfig $config): SearchPayload
{
if ($request instanceof ServerRequest) {
return $this->processor->processRequest($request, $config);
}
if (!$request instanceof Request) {
throw new UnexpectedTypeException($request, [ServerRequest::class, Request::class]);
}
/** @var ServerRequest $request */
$request = (new DiactorosFactory())->createRequest($request);
return $this->processor->processRequest($request, $config);
}
}