chamilo/chamilo-lms

View on GitHub
public/plugin/xapi/admin.php

Summary

Maintainability
A
0 mins
Test Coverage
<?php

declare(strict_types=1);

/* For licensing terms, see /license.txt */

use Chamilo\CoreBundle\Entity\XApiLrsAuth;
use Symfony\Component\HttpFoundation\Request;

$cidReset = true;

require_once __DIR__.'/../../main/inc/global.inc.php';

api_protect_admin_script();

$request = Request::createFromGlobals();
$plugin = XApiPlugin::create();
$em = Database::getManager();

$pageBaseUrl = api_get_self();
$pageActions = '';
$pageContent = '';

/**
 * @return FormValidator
 *
 * @throws Exception
 */
function createForm(?XApiLrsAuth $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 XApiLrsAuth();
            $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(XApiLrsAuth::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(XApiLrsAuth::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(XApiLrsAuth::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();