remork watchdogs filter and logic
This commit is contained in:
@@ -679,21 +679,19 @@ class AdminController extends AbstractController
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#[Route('/watchdog', name: 'watchdog')]
|
#[Route('/watchdog/{type?*}/{id?*}/{action?*}', name: 'watchdog')]
|
||||||
#[Route('/watchdog/view/{type}/{id}/{action}', name: 'watchdog_view')]
|
|
||||||
#[Route('/watchdog/{type}', name: 'watchdog_type')]
|
|
||||||
#[Route('/watchdog/{type}/{action}', name: 'watchdog_type_action')]
|
|
||||||
public function watchdog(
|
public function watchdog(
|
||||||
PaginatorInterface $paginator,
|
PaginatorInterface $paginator,
|
||||||
Request $Request,
|
Request $Request,
|
||||||
EntityManagerInterface $EntityManagerInterface,
|
EntityManagerInterface $EntityManagerInterface,
|
||||||
string $type = null,
|
string $type = null,
|
||||||
string $action = null,
|
string $action = null,
|
||||||
int $id = null
|
string $id = null
|
||||||
): Response {
|
): Response {
|
||||||
|
|
||||||
$qb = $EntityManagerInterface->createQueryBuilder();
|
$qb = $EntityManagerInterface->createQueryBuilder();
|
||||||
$qbButtons = $EntityManagerInterface->createQueryBuilder();
|
$qbButtons = $EntityManagerInterface->createQueryBuilder();
|
||||||
|
$qbButtonsAction = $EntityManagerInterface->createQueryBuilder();
|
||||||
|
|
||||||
$qb->select('l')
|
$qb->select('l')
|
||||||
->from('Gedmo\Loggable\Entity\LogEntry', 'l')
|
->from('Gedmo\Loggable\Entity\LogEntry', 'l')
|
||||||
@@ -701,26 +699,25 @@ class AdminController extends AbstractController
|
|||||||
|
|
||||||
$qbButtons->select('DISTINCT l.objectClass')
|
$qbButtons->select('DISTINCT l.objectClass')
|
||||||
->from('Gedmo\Loggable\Entity\LogEntry', 'l')
|
->from('Gedmo\Loggable\Entity\LogEntry', 'l')
|
||||||
->orderBy('l.loggedAt', 'DESC');
|
->orderBy('l.objectClass', 'ASC');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (null != $type) {
|
|
||||||
$qb->where('l.objectClass = :type');
|
|
||||||
$qb->setParameter('type', 'App\Entity\\' . $type);
|
|
||||||
$qbButtonsAction = $EntityManagerInterface->createQueryBuilder();
|
|
||||||
$qbButtonsAction->select('DISTINCT l.action')
|
$qbButtonsAction->select('DISTINCT l.action')
|
||||||
->from('Gedmo\Loggable\Entity\LogEntry', 'l')
|
->from('Gedmo\Loggable\Entity\LogEntry', 'l')
|
||||||
->orderBy('l.loggedAt', 'DESC');
|
->orderBy('l.action', 'ASC');
|
||||||
|
|
||||||
if (null != $action) {
|
|
||||||
|
|
||||||
|
if (null != $type && '*' != $type) {
|
||||||
|
$qb->where('l.objectClass = :type');
|
||||||
|
$qb->setParameter('type', 'App\Entity\\' . $type);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (null != $action && '*' != $action) {
|
||||||
$qb->andWhere('l.action = :action');
|
$qb->andWhere('l.action = :action');
|
||||||
$qb->setParameter('action', $action);
|
$qb->setParameter('action', $action);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (null != $id) {
|
if (null != $id && '*' != $id) {
|
||||||
$qb->andWhere('l.objectId = :id');
|
$qb->andWhere('l.objectId = :id');
|
||||||
$qb->setParameter('id', $id);
|
$qb->setParameter('id', $id);
|
||||||
}
|
}
|
||||||
@@ -732,11 +729,13 @@ class AdminController extends AbstractController
|
|||||||
|
|
||||||
return $this->render('admin/watchdog.html.twig', [
|
return $this->render('admin/watchdog.html.twig', [
|
||||||
'controller_name' => 'AdminController',
|
'controller_name' => 'AdminController',
|
||||||
'pagination' => $pagination,
|
|
||||||
'buttonsType' => $qbButtons->getQuery()->getResult(),
|
|
||||||
'type' => $type,
|
'type' => $type,
|
||||||
'buttonsAction' => (($type != null) ? $qbButtonsAction->getQuery()->getResult() : null),
|
|
||||||
'action' => $action,
|
'action' => $action,
|
||||||
|
'id' => $id,
|
||||||
|
'buttonsType' => $qbButtons->getQuery()->getResult(),
|
||||||
|
'buttonsAction' => $qbButtonsAction->getQuery()->getResult(),
|
||||||
|
'pagination' => $pagination,
|
||||||
|
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -11,7 +11,7 @@
|
|||||||
{% endif %}
|
{% endif %}
|
||||||
</p>
|
</p>
|
||||||
{% if notype is not defined %}
|
{% if notype is not defined %}
|
||||||
<p>{{ i.objectClass }} (# {{ i.objectId }}) {% if is_granted('ROLE_ADMIN') %}<a href="{{ path('admin_watchdog_view', {'type':i.objectClass|replace({'App\\Entity\\': ''}), 'id': i.objectId}) }}" class="btn btn-warning btn-sm" data-bs-toggle="tooltip" data-placement="top" title="{% trans %}tooltip_directory_history{% endtrans %} (Admin)"><i class="fas fa-clock"></i></a>{% endif %}</p>
|
<p>{{ i.objectClass }} (# {{ i.objectId }}) {% if is_granted('ROLE_ADMIN') %}<a href="{{ path('admin_watchdog', {'type':i.objectClass|replace({'App\\Entity\\': ''}), 'id': i.objectId}) }}" class="btn btn-warning btn-sm" data-bs-toggle="tooltip" data-placement="top" title="{% trans %}tooltip_directory_history{% endtrans %} (Admin)"><i class="fas fa-clock"></i></a>{% endif %}</p>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<p>{{ ('title_data_' ~ i.action)|trans }}</p>
|
<p>{{ ('title_data_' ~ i.action)|trans }}</p>
|
||||||
<div class="table-responsive">
|
<div class="table-responsive">
|
||||||
|
|||||||
@@ -8,29 +8,38 @@
|
|||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col mb-5">
|
<div class="col mb-5">
|
||||||
<h4>Filtres</h4>
|
<h4>Filtres</h4>
|
||||||
|
|
||||||
|
{% if id is null or id == '*' %}
|
||||||
<h5>Type: </h5>
|
<h5>Type: </h5>
|
||||||
<a href="{{ path('admin_watchdog') }}" class="btn btn-{{type == null ? 'info' : 'primary'}} m-1">*</a>
|
<a href="{{ path('admin_watchdog', {type:'*', id: id, action: action}) }}" class="btn btn-{{type == '*' ? 'info' : 'primary'}} m-1">*</a>
|
||||||
{% for t in buttonsType %}
|
{% for t in buttonsType %}
|
||||||
{% set btntype = t.objectClass|replace({'App\\Entity\\': ''}) %}
|
{% set btntype = t.objectClass|replace({'App\\Entity\\': ''}) %}
|
||||||
<a href="{{ path('admin_watchdog_type',{type: btntype}) }}" class="btn btn-{{type == btntype ? 'info' : 'primary'}} m-1">{{ btntype }}</a>
|
<a href="{{ path('admin_watchdog',{type: btntype, id: id, action: action}) }}" class="btn btn-{{type == btntype ? 'info' : 'primary'}} m-1">{{ btntype }}</a>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
|
|
||||||
|
{% else %}
|
||||||
|
<a href="{{ path('admin_watchdog', {type: type, id: '*', action: action}) }}" class="btn btn-warning m-1">back to list</a>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
|
||||||
{% if buttonsAction != null %}
|
{% if buttonsAction != null %}
|
||||||
<h5>Action: </h5>
|
<h5>Action: </h5>
|
||||||
<a href="{{ path('admin_watchdog_type',{type: type}) }}" class="btn btn-{{action == null ? 'info' : 'primary'}} m-1">*</a>
|
<a href="{{ path('admin_watchdog',{type: type, id: id, action: '*'}) }}" class="btn btn-{{action == '*' ? 'info' : 'primary'}} m-1">*</a>
|
||||||
{% for a in buttonsAction %}
|
{% for a in buttonsAction %}
|
||||||
<a href="{{ path('admin_watchdog_type_action',{type: type, action: a.action }) }}" class="btn btn-{{action == a.action ? 'info' : 'primary'}} m-1">{{ a.action }}</a>
|
<a href="{{ path('admin_watchdog',{type: type, id: id, action: a.action }) }}" class="btn btn-{{action == a.action ? 'info' : 'primary'}} m-1">{{ a.action }}</a>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col">
|
<div class="col">
|
||||||
{% include '_cells/historyDisplay.html.twig' with {'history': pagination} %}
|
{% include '_cells/historyDisplay.html.twig' with {'history': pagination} %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="row">
|
<div class="row">
|
||||||
{{ knp_pagination_render(pagination) }}
|
{{ knp_pagination_render(pagination) }}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|||||||
Reference in New Issue
Block a user