mirror of
https://github.com/nuxsmin/sysPass.git
synced 2026-03-24 17:17:15 +01:00
* [ADD] Config module. Work in progress
This commit is contained in:
@@ -24,17 +24,27 @@
|
||||
|
||||
namespace SP\Modules\Web\Controllers;
|
||||
|
||||
use SP\Bootstrap;
|
||||
use SP\Core\Acl\Acl;
|
||||
use SP\Core\Acl\ActionsInterface;
|
||||
use SP\Core\Crypt\CryptSessionHandler;
|
||||
use SP\Core\CryptMasterPass;
|
||||
use SP\Core\Language;
|
||||
use SP\Core\Plugin\PluginUtil;
|
||||
use SP\Core\Task;
|
||||
use SP\Http\Request;
|
||||
use SP\Modules\Web\Controllers\Helpers\TabsHelper;
|
||||
use SP\Mvc\View\Components\DataTab;
|
||||
use SP\Mvc\View\Components\SelectItemAdapter;
|
||||
use SP\Services\Account\AccountService;
|
||||
use SP\Services\Config\ConfigService;
|
||||
use SP\Services\User\UserService;
|
||||
use SP\Services\UserGroup\UserGroupService;
|
||||
use SP\Services\UserProfile\UserProfileService;
|
||||
use SP\Storage\DBUtil;
|
||||
use SP\Storage\MySQLHandler;
|
||||
use SP\Util\Checks;
|
||||
use SP\Util\Util;
|
||||
|
||||
/**
|
||||
* Class ConfigManagerController
|
||||
@@ -52,6 +62,7 @@ class ConfigManagerController extends ControllerBase
|
||||
* @throws \Psr\Container\ContainerExceptionInterface
|
||||
* @throws \Psr\Container\NotFoundExceptionInterface
|
||||
* @throws \SP\Core\Exceptions\InvalidArgumentException
|
||||
* @throws \SP\Services\Config\ParameterNotFoundException
|
||||
*/
|
||||
public function indexAction()
|
||||
{
|
||||
@@ -64,6 +75,7 @@ class ConfigManagerController extends ControllerBase
|
||||
* @throws \Psr\Container\ContainerExceptionInterface
|
||||
* @throws \Psr\Container\NotFoundExceptionInterface
|
||||
* @throws \SP\Core\Exceptions\InvalidArgumentException
|
||||
* @throws \SP\Services\Config\ParameterNotFoundException
|
||||
*/
|
||||
protected function getTabs()
|
||||
{
|
||||
@@ -90,15 +102,19 @@ class ConfigManagerController extends ControllerBase
|
||||
}
|
||||
|
||||
if ($this->checkAccess(ActionsInterface::ENCRYPTION_CONFIG)) {
|
||||
// $this->tabsHelper->addTab($this->getEncryptionConfig());
|
||||
$this->tabsHelper->addTab($this->getEncryptionConfig());
|
||||
}
|
||||
|
||||
if ($this->checkAccess(ActionsInterface::BACKUP_CONFIG)) {
|
||||
// $this->tabsHelper->addTab($this->getBackupConfig());
|
||||
$this->tabsHelper->addTab($this->getBackupConfig());
|
||||
}
|
||||
|
||||
if ($this->checkAccess(ActionsInterface::IMPORT_CONFIG)) {
|
||||
// $this->tabsHelper->addTab($this->getImportConfig());
|
||||
$this->tabsHelper->addTab($this->getImportConfig());
|
||||
}
|
||||
|
||||
if ($this->checkAccess(ActionsInterface::CONFIG_GENERAL)) {
|
||||
$this->tabsHelper->addTab($this->getInfo());
|
||||
}
|
||||
|
||||
|
||||
@@ -135,14 +151,6 @@ class ConfigManagerController extends ControllerBase
|
||||
return new DataTab(__('General'), $template);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return TabsHelper
|
||||
*/
|
||||
public function getTabsHelper()
|
||||
{
|
||||
return $this->tabsHelper;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return DataTab
|
||||
*/
|
||||
@@ -213,28 +221,130 @@ class ConfigManagerController extends ControllerBase
|
||||
* @return DataTab
|
||||
* @throws \Psr\Container\ContainerExceptionInterface
|
||||
* @throws \Psr\Container\NotFoundExceptionInterface
|
||||
* @throws \SP\Services\Config\ParameterNotFoundException
|
||||
*/
|
||||
protected function getEncryptionConfig()
|
||||
{
|
||||
$template = clone $this->view;
|
||||
$template->setBase('config');
|
||||
$template->addTemplate('mail');
|
||||
$template->addTemplate('encryption');
|
||||
|
||||
$template->assign('mailSecurity', ['SSL', 'TLS']);
|
||||
$template->assign('configData', $this->configData);
|
||||
|
||||
$this->view->assign('numAccounts', AccountUtil::getTotalNumAccounts());
|
||||
$this->view->assign('taskId', Task::genTaskId('masterpass'));
|
||||
$template->assign('numAccounts', $this->dic->get(AccountService::class)->getTotalNumAccounts());
|
||||
$template->assign('taskId', Task::genTaskId('masterpass'));
|
||||
|
||||
$this->view->assign('lastUpdateMPass', isset($this->configDB['lastupdatempass']) ? $this->configDB['lastupdatempass'] : 0);
|
||||
$this->view->assign('tempMasterPassTime', isset($this->configDB['tempmaster_passtime']) ? $this->configDB['tempmaster_passtime'] : 0);
|
||||
$this->view->assign('tempMasterMaxTime', isset($this->configDB['tempmaster_maxtime']) ? $this->configDB['tempmaster_maxtime'] : 0);
|
||||
$this->view->assign('tempMasterAttempts', isset($this->configDB['tempmaster_attempts']) ? sprintf('%d/%d', $this->configDB['tempmaster_attempts'], CryptMasterPass::MAX_ATTEMPTS) : 0);
|
||||
$this->view->assign('tempMasterPass', SessionFactory::getTemporaryMasterPass());
|
||||
$configService = $this->dic->get(ConfigService::class);
|
||||
|
||||
$template->assign('lastUpdateMPass', $configService->getByParam('lastupdatempass', 0));
|
||||
$template->assign('tempMasterPassTime', $configService->getByParam('tempmaster_passtime', 0));
|
||||
$template->assign('tempMasterMaxTime', $configService->getByParam('tempmaster_maxtime', 0));
|
||||
|
||||
$tempMasterAttempts = sprintf('%d/%d', $configService->getByParam('tempmaster_attempts', 0), CryptMasterPass::MAX_ATTEMPTS);
|
||||
|
||||
$template->assign('tempMasterAttempts', $tempMasterAttempts);
|
||||
$template->assign('tempMasterPass', $this->session->getTemporaryMasterPass());
|
||||
|
||||
$template->assign('userGroups', SelectItemAdapter::factory(UserGroupService::getItemsBasic())->getItemsFromModel());
|
||||
$template->assign('userProfiles', SelectItemAdapter::factory(UserProfileService::getItemsBasic())->getItemsFromModel());
|
||||
|
||||
return new DataTab(__('Encriptación'), $template);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return DataTab
|
||||
*/
|
||||
protected function getBackupConfig()
|
||||
{
|
||||
$template = clone $this->view;
|
||||
$template->setBase('config');
|
||||
$template->addTemplate('backup');
|
||||
|
||||
$template->assign('siteName', Util::getAppInfo('appname'));
|
||||
$template->assign('backupDir', Bootstrap::$SERVERROOT . '/backup');
|
||||
$template->assign('backupPath', Bootstrap::$WEBROOT . '/backup');
|
||||
|
||||
$backupHash = $this->configData->getBackupHash();
|
||||
$exportHash = $this->configData->getExportHash();
|
||||
|
||||
$backupFile = $template->siteName . '-' . $backupHash . '.tar.gz';
|
||||
|
||||
$template->assign('backupFile', [
|
||||
'absolute' => $template->backupDir . DIRECTORY_SEPARATOR . $backupFile,
|
||||
'relative' => $template->backupPath . '/' . $backupFile,
|
||||
'filename' => $backupFile
|
||||
]);
|
||||
|
||||
$backupDbFile = $template->siteName . '_db-' . $backupHash . '.sql';
|
||||
|
||||
$template->assign('backupDbFile', [
|
||||
'absolute' => $template->backupDir . DIRECTORY_SEPARATOR . $backupDbFile,
|
||||
'relative' => $template->backupPath . '/' . $backupDbFile,
|
||||
'filename' => $backupDbFile
|
||||
]);
|
||||
|
||||
clearstatcache(true, $template->backupFile['absolute']);
|
||||
clearstatcache(true, $template->backupDbFile['absolute']);
|
||||
|
||||
$template->assign('lastBackupTime', file_exists($template->backupFile['absolute']) ? __('Último backup') . ': ' . date('r', filemtime($template->backupFile['absolute'])) : __('No se encontraron backups'));
|
||||
|
||||
$exportFile = $template->siteName . '-' . $exportHash . '.xml';
|
||||
|
||||
$template->assign('exportFile', [
|
||||
'absolute' => $template->backupDir . DIRECTORY_SEPARATOR . $exportFile,
|
||||
'relative' => $template->backupPath . '/' . $exportFile,
|
||||
'filename' => $exportFile
|
||||
]);
|
||||
|
||||
clearstatcache(true, $template->exportFile['absolute']);
|
||||
|
||||
$template->assign('lastExportTime', file_exists($template->exportFile['absolute']) ? __('Última exportación') . ': ' . date('r', filemtime($template->exportFile['absolute'])) : __('No se encontró archivo de exportación'));
|
||||
|
||||
return new DataTab(__('Copia de Seguridad'), $template);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return DataTab
|
||||
* @throws \Psr\Container\ContainerExceptionInterface
|
||||
* @throws \Psr\Container\NotFoundExceptionInterface
|
||||
*/
|
||||
protected function getImportConfig()
|
||||
{
|
||||
$template = clone $this->view;
|
||||
$template->setBase('config');
|
||||
$template->addTemplate('import');
|
||||
|
||||
$template->assign('userGroups', SelectItemAdapter::factory(UserGroupService::getItemsBasic())->getItemsFromModelSelected([$this->userData->getUserGroupId()]));
|
||||
$template->assign('users', SelectItemAdapter::factory(UserService::getItemsBasic())->getItemsFromModelSelected([$this->userData->getId()]));
|
||||
|
||||
return new DataTab(__('Importar Cuentas'), $template);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return DataTab
|
||||
* @throws \SP\Core\Exceptions\SPException
|
||||
*/
|
||||
protected function getInfo()
|
||||
{
|
||||
$template = clone $this->view;
|
||||
$template->setBase('config');
|
||||
$template->addTemplate('info');
|
||||
|
||||
$template->assign('dbInfo', DBUtil::getDBinfo($this->dic->get(MySQLHandler::class)));
|
||||
$template->assign('dbName', $this->configData->getDbName() . '@' . $this->configData->getDbHost());
|
||||
$template->assign('configBackupDate', date('r', $this->dic->get(ConfigService::class)->getByParam('config_backupdate', 0)));
|
||||
$template->assign('plugins', PluginUtil::getLoadedPlugins());
|
||||
$template->assign('locale', Language::$localeStatus ?: sprintf('%s (%s)', $this->configData->getSiteLang(), __('No instalado')));
|
||||
$template->assign('securedSession', CryptSessionHandler::$isSecured);
|
||||
|
||||
return new DataTab(__('Información'), $template);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return TabsHelper
|
||||
*/
|
||||
public function getTabsHelper()
|
||||
{
|
||||
return $this->tabsHelper;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user