Welcome to mirror list, hosted at ThFree Co, Russian Federation.

PopulateRequestResponse.php « middleware « src - github.com/HuasoFoundries/phpPgAdmin6.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: d3a7f5c645acd9ea05aa2a714627d13f20c85360 (plain)
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
<?php

/**
 * PHPPgAdmin 6.1.3
 */

namespace PHPPgAdmin\Middleware;

use PHPPgAdmin\ContainerUtils;
use PHPPgAdmin\Traits\HelperTrait;
use PHPPgAdmin\ViewManager;
use Slim\Http\Request;
use Slim\Http\Response;
use Slim\Http\Uri;

/**
 * Set the requestobj and responseobj properties of the container
 * as the value of $request and $response, which already contain the route.
 */
class PopulateRequestResponse extends Middleware
{
    use HelperTrait;

    public function __invoke(
        Request $request,
        Response $response,
        $next
    ) {
        $container = $this->container;
        $subfolder = $this->container->getSubfolder();

        $route = $request->getAttribute('route');

        $container['server'] = $request->getParam('server');
        $container['database'] = $request->getParam('database');
        $container['schema'] = $request->getParam('schema');
        $misc = $container->get('misc');

        $view = $this->getViewManager($container);

        $misc->setHREF();
        $view->setForm();

        $view->offsetSet('METHOD', $request->getMethod());

        if ($route) {
            $view->offsetSet('subject', $route->getArgument('subject'));
            $container['server'] = $route->getArgument('server', $request->getParam('server'));
        }

        $request = $request->withUri($this->getUri($request)->withBasePath($subfolder));
        $uri = $request->getUri();
        $query_string = $uri->getQuery();
        $requestPath = $uri->getPath();

        $view->offsetSet('query_string', $query_string);
        $path = $requestPath . ($query_string ? '?' . $query_string : '');
        $view->offsetSet('path', $path);

        $params = $request->getParams();

        $viewparams = [];

        foreach ($params as $key => $value) {
            if (\is_scalar($value)) {
                $viewparams[$key] = $value;
            }
        }

        if (isset($_COOKIE['IN_TEST'])) {
            $in_test = (string) $_COOKIE['IN_TEST'];
        } else {
            $in_test = '0';
        }

        // remove tabs and linebreaks from query
        if (isset($params['query'])) {
            $viewparams['query'] = \str_replace(["\r", "\n", "\t"], ' ', $params['query']);
        }
        $view->offsetSet('params', $viewparams);
        $view->offsetSet('in_test', $in_test);

        if (0 < \count($container['errors'])) {
            return ($container->haltHandler)($request, $response, $container['errors'], 412);
        }
        $enqueued_reload_browser = ($container->flash->getFirstMessage('reload_browser') ?? false);

        if ($enqueued_reload_browser) {
            $view->setReloadBrowser($enqueued_reload_browser);
        }
        // First execute anything else
        $response = $next($request, $response);

        // Any other request, pass on current response
        return $response;
    }

    private function getUri(Request $request): Uri
    {
        return $request->getUri();
    }

    private function getViewManager(ContainerUtils $container): ViewManager
    {
        return $container->get('view');
    }
}