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: 8a3828ccc3cfd83352f06e9641dcc05a0a8d2bfa (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
<?php

/**
 * PHPPgAdmin 6.0.0
 */

namespace PHPPgAdmin\Middleware;

/**
 * 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 \PHPPgAdmin\Traits\HelperTrait;

    public function __invoke(
        \Slim\Http\Request $request,
        \Slim\Http\Response $response,
        $next
    ) {
        $container = $this->container;
        $subfolder = $this->getSubfolder();
        $container['requestobj'] = $request;
        $container['responseobj'] = $response;
        $route = $request->getAttribute('route');

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

        $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'));
        }

        $query_string = $request->getUri()->getQuery();
        $view->offsetSet('query_string', $query_string);
        $path = ($subfolder ? ($subfolder . '/') : '')
        . $request->getUri()->getPath() . ($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)($container->requestobj, $container->responseobj, $container['errors'], 412);
        }

        // First execute anything else
        $response = $next($request, $response);

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