You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							196 lines
						
					
					
						
							5.7 KiB
						
					
					
				
			
		
		
	
	
							196 lines
						
					
					
						
							5.7 KiB
						
					
					
				<?php
 | 
						|
 | 
						|
/* For licensing terms, see /license.txt */
 | 
						|
 | 
						|
use Chamilo\PluginBundle\Entity\XApi\LrsAuth;
 | 
						|
 | 
						|
$cidReset = true;
 | 
						|
 | 
						|
require_once __DIR__.'/../../main/inc/global.inc.php';
 | 
						|
 | 
						|
api_protect_admin_script();
 | 
						|
 | 
						|
$request = \Symfony\Component\HttpFoundation\Request::createFromGlobals();
 | 
						|
$plugin = XApiPlugin::create();
 | 
						|
$em = Database::getManager();
 | 
						|
 | 
						|
$pageBaseUrl = api_get_self();
 | 
						|
$pageActions = '';
 | 
						|
$pageContent = '';
 | 
						|
 | 
						|
/**
 | 
						|
 * @throws \Exception
 | 
						|
 *
 | 
						|
 * @return \FormValidator
 | 
						|
 */
 | 
						|
function createForm(LrsAuth $auth = null)
 | 
						|
{
 | 
						|
    $pageBaseUrl = api_get_self();
 | 
						|
 | 
						|
    $action = $pageBaseUrl.'?action=add';
 | 
						|
 | 
						|
    if (null != $auth) {
 | 
						|
        $action = $pageBaseUrl."?action=edit&id={$auth->getId()}";
 | 
						|
    }
 | 
						|
 | 
						|
    $form = new FormValidator('frm_xapi_auth', 'post', $action);
 | 
						|
    $form->addText('username', get_lang('Username'), true);
 | 
						|
    $form->addText('password', get_lang('Password'), true);
 | 
						|
    $form->addCheckBox('enabled', get_lang('Enabled'), get_lang('Yes'));
 | 
						|
 | 
						|
    $form->addButtonSave(get_lang('Save'));
 | 
						|
 | 
						|
    if (null != $auth) {
 | 
						|
        $form->setDefaults(
 | 
						|
            [
 | 
						|
                'username' => $auth->getUsername(),
 | 
						|
                'password' => $auth->getPassword(),
 | 
						|
                'enabled' => $auth->isEnabled(),
 | 
						|
            ]
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    return $form;
 | 
						|
}
 | 
						|
 | 
						|
switch ($request->query->getAlpha('action')) {
 | 
						|
    case 'add':
 | 
						|
        $form = createForm();
 | 
						|
 | 
						|
        if ($form->validate()) {
 | 
						|
            $values = $form->exportValues();
 | 
						|
 | 
						|
            $auth = new LrsAuth();
 | 
						|
            $auth
 | 
						|
                ->setUsername($values['username'])
 | 
						|
                ->setPassword($values['password'])
 | 
						|
                ->setEnabled(isset($values['enabled']))
 | 
						|
                ->setCreatedAt(
 | 
						|
                    api_get_utc_datetime(null, false, true)
 | 
						|
                );
 | 
						|
 | 
						|
            $em->persist($auth);
 | 
						|
            $em->flush();
 | 
						|
 | 
						|
            Display::addFlash(
 | 
						|
                Display::return_message(get_lang('ItemAdded'), 'success')
 | 
						|
            );
 | 
						|
 | 
						|
            header('Location: '.$pageBaseUrl);
 | 
						|
            exit;
 | 
						|
        }
 | 
						|
 | 
						|
        $pageActions = Display::url(
 | 
						|
            Display::return_icon('back.png', get_lang('Back'), [], ICON_SIZE_MEDIUM),
 | 
						|
            $pageBaseUrl
 | 
						|
        );
 | 
						|
        $pageContent = $form->returnForm();
 | 
						|
        break;
 | 
						|
    case 'edit':
 | 
						|
        $auth = $em->find(LrsAuth::class, $request->query->getInt('id'));
 | 
						|
 | 
						|
        if (null == $auth) {
 | 
						|
            api_not_allowed(true);
 | 
						|
        }
 | 
						|
 | 
						|
        $form = createForm($auth);
 | 
						|
 | 
						|
        if ($form->validate()) {
 | 
						|
            $values = $form->exportValues();
 | 
						|
 | 
						|
            $auth
 | 
						|
                ->setUsername($values['username'])
 | 
						|
                ->setPassword($values['password'])
 | 
						|
                ->setEnabled(isset($values['enabled']))
 | 
						|
                ->setCreatedAt(
 | 
						|
                    api_get_utc_datetime(null, false, true)
 | 
						|
                );
 | 
						|
 | 
						|
            $em->persist($auth);
 | 
						|
            $em->flush();
 | 
						|
 | 
						|
            Display::addFlash(
 | 
						|
                Display::return_message(get_lang('ItemUpdated'), 'success')
 | 
						|
            );
 | 
						|
 | 
						|
            header('Location: '.$pageBaseUrl);
 | 
						|
            exit;
 | 
						|
        }
 | 
						|
 | 
						|
        $pageActions = Display::url(
 | 
						|
            Display::return_icon('back.png', get_lang('Back'), [], ICON_SIZE_MEDIUM),
 | 
						|
            $pageBaseUrl
 | 
						|
        );
 | 
						|
        $pageContent = $form->returnForm();
 | 
						|
        break;
 | 
						|
    case 'delete':
 | 
						|
        $auth = $em->find(LrsAuth::class, $request->query->getInt('id'));
 | 
						|
 | 
						|
        if (null == $auth) {
 | 
						|
            api_not_allowed(true);
 | 
						|
        }
 | 
						|
 | 
						|
        $em->remove($auth);
 | 
						|
        $em->flush();
 | 
						|
 | 
						|
        Display::addFlash(
 | 
						|
            Display::return_message(get_lang('ItemDeleted'), 'success')
 | 
						|
        );
 | 
						|
 | 
						|
        header('Location: '.$pageBaseUrl);
 | 
						|
        exit;
 | 
						|
    case 'list':
 | 
						|
    default:
 | 
						|
        $pageActions = Display::url(
 | 
						|
            Display::return_icon('add.png', get_lang('Add'), [], ICON_SIZE_MEDIUM),
 | 
						|
            $pageBaseUrl.'?action=add'
 | 
						|
        );
 | 
						|
        $pageContent = Display::return_message(get_lang('NoData'), 'warning');
 | 
						|
 | 
						|
        $auths = $em->getRepository(LrsAuth::class)->findAll();
 | 
						|
 | 
						|
        if (count($auths) > 0) {
 | 
						|
            $row = 0;
 | 
						|
 | 
						|
            $table = new HTML_Table(['class' => 'table table-striped table-hover']);
 | 
						|
            $table->setHeaderContents($row, 0, get_lang('Username'));
 | 
						|
            $table->setHeaderContents($row, 1, get_lang('Password'));
 | 
						|
            $table->setHeaderContents($row, 2, get_lang('Enabled'));
 | 
						|
            $table->setHeaderContents($row, 3, get_lang('CreatedAt'));
 | 
						|
            $table->setHeaderContents($row, 4, get_lang('Actions'));
 | 
						|
 | 
						|
            foreach ($auths as $auth) {
 | 
						|
                $row++;
 | 
						|
 | 
						|
                $actions = [
 | 
						|
                    Display::url(
 | 
						|
                        Display::return_icon('edit.png', get_lang('Edit')),
 | 
						|
                        $pageBaseUrl.'?action=edit&id='.$auth->getId()
 | 
						|
                    ),
 | 
						|
                    Display::url(
 | 
						|
                        Display::return_icon('delete.png', get_lang('Edit')),
 | 
						|
                        $pageBaseUrl.'?action=delete&id='.$auth->getId()
 | 
						|
                    ),
 | 
						|
                ];
 | 
						|
 | 
						|
                $table->setCellContents($row, 0, $auth->getUsername());
 | 
						|
                $table->setCellContents($row, 1, $auth->getPassword());
 | 
						|
                $table->setCellContents($row, 2, $auth->isEnabled() ? get_lang('Yes') : get_lang('No'));
 | 
						|
                $table->setCellContents($row, 3, api_convert_and_format_date($auth->getCreatedAt()));
 | 
						|
                $table->setCellContents($row, 4, implode(PHP_EOL, $actions));
 | 
						|
            }
 | 
						|
 | 
						|
            $pageContent = $table->toHtml();
 | 
						|
        }
 | 
						|
        break;
 | 
						|
}
 | 
						|
 | 
						|
$interbreadcrumb[] = [
 | 
						|
    'name' => get_lang('Administration'),
 | 
						|
    'url' => api_get_path(WEB_CODE_PATH).'admin/index.php',
 | 
						|
];
 | 
						|
 | 
						|
$view = new Template($plugin->get_title());
 | 
						|
$view->assign('actions', Display::toolbarAction('xapi_actions', [$pageActions]));
 | 
						|
$view->assign('content', $pageContent);
 | 
						|
$view->display_one_col_template();
 | 
						|
 |