-
-
Notifications
You must be signed in to change notification settings - Fork 3.6k
Expand file tree
/
Copy pathHomeController.php
More file actions
137 lines (115 loc) · 4.66 KB
/
HomeController.php
File metadata and controls
137 lines (115 loc) · 4.66 KB
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
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
<?php
declare(strict_types=1);
namespace PhpMyAdmin\Controllers\Setup;
use Fig\Http\Message\StatusCodeInterface;
use PhpMyAdmin\Config;
use PhpMyAdmin\Config\ServerConfigChecks;
use PhpMyAdmin\Controllers\InvocableController;
use PhpMyAdmin\Current;
use PhpMyAdmin\Http\Factory\ResponseFactory;
use PhpMyAdmin\Http\Response;
use PhpMyAdmin\Http\ServerRequest;
use PhpMyAdmin\I18n\LanguageManager;
use PhpMyAdmin\ResponseRenderer;
use PhpMyAdmin\Session;
use PhpMyAdmin\Setup\Index;
use PhpMyAdmin\Setup\SetupHelper;
use PhpMyAdmin\Template;
use function __;
use function array_keys;
use function file_exists;
use function is_scalar;
use function is_string;
use const CONFIG_FILE;
final class HomeController implements InvocableController
{
private static bool $hasCheckPageRefresh = false;
public function __construct(
private readonly ResponseFactory $responseFactory,
private readonly ResponseRenderer $responseRenderer,
private readonly Template $template,
private readonly Config $config,
) {
}
public function __invoke(ServerRequest $request): Response
{
if (@file_exists(CONFIG_FILE) && ! $this->config->config->debug->demo) {
$response = $this->responseFactory->createResponse(StatusCodeInterface::STATUS_NOT_FOUND);
return $response->write($this->template->render('error/generic', [
'lang' => Current::$lang,
'error_message' => __('Configuration already exists, setup is disabled!'),
]));
}
$response = $this->responseFactory->createResponse();
foreach ($this->responseRenderer->getHeader()->getHttpHeaders() as $name => $value) {
$response = $response->withHeader($name, $value);
}
$pages = SetupHelper::getPages();
// message handling
Index::messagesBegin();
// Check phpMyAdmin version
if ($request->hasQueryParam('version_check')) {
Index::versionCheck();
}
$configFile = SetupHelper::createConfigFile();
// Perform various security, compatibility and consistency checks
$configChecker = new ServerConfigChecks($configFile);
$configChecker->performConfigChecks();
$text = __(
'You are not using a secure connection; all data (including potentially '
. 'sensitive information, like passwords) is transferred unencrypted!',
);
$text .= ' <a href="#">';
$text .= __(
'If your server is also configured to accept HTTPS requests '
. 'follow this link to use a secure connection.',
);
$text .= '</a>';
Index::messagesSet('notice', 'no_https', __('Insecure connection'), $text);
Index::messagesEnd();
$messages = Index::messagesShowHtml();
// prepare unfiltered language list
$sortedLanguages = LanguageManager::getInstance()->sortedLanguages();
$languages = [];
foreach ($sortedLanguages as $language) {
$languages[] = [
'code' => $language->getCode(),
'name' => $language->getName(),
'is_active' => $language->isActive(),
];
}
$servers = [];
foreach (array_keys($configFile->getServers()) as $id) {
$servers[$id] = [
'id' => $id,
'name' => $configFile->getServerName($id),
'auth_type' => $configFile->getValue('Servers/' . $id . '/auth_type'),
'dsn' => $configFile->getServerDSN($id),
'params' => [
'token' => Session::getToken(),
'edit' => ['page' => 'servers', 'mode' => 'edit', 'id' => $id],
'remove' => ['page' => 'servers', 'mode' => 'remove', 'id' => $id],
],
];
}
if (! self::$hasCheckPageRefresh) {
self::$hasCheckPageRefresh = true;
}
return $response->write($this->template->render('setup/home/index', [
'formset' => $this->getFormSetParam($request->getQueryParam('formset')),
'languages' => $languages,
'messages' => $messages,
'server_count' => $configFile->getServerCount(),
'servers' => $servers,
'pages' => $pages,
'has_check_page_refresh' => self::$hasCheckPageRefresh,
'eol' => isset($_SESSION['eol']) && is_scalar($_SESSION['eol'])
? $_SESSION['eol']
: ($this->config->isWindows() ? 'win' : 'unix'),
]));
}
private function getFormSetParam(mixed $formSetParam): string
{
return is_string($formSetParam) ? $formSetParam : '';
}
}