Compare commits

...

78 commits
v2 ... master

Author SHA1 Message Date
Simon Vieille 79d549254f Merge branch 'develop'
All checks were successful
ci/woodpecker/push/woodpecker/2 Pipeline was successful
ci/woodpecker/push/woodpecker/1 Pipeline was successful
2024-03-25 16:00:53 +01:00
Simon Vieille c79e96e291
apply consensus as access decision manager strategy
All checks were successful
ci/woodpecker/push/woodpecker/2 Pipeline was successful
ci/woodpecker/push/woodpecker/1 Pipeline was successful
2024-03-25 16:00:51 +01:00
Simon Vieille 092b490ae2 Merge branch 'develop'
Some checks failed
ci/woodpecker/push/woodpecker/1 Pipeline failed
ci/woodpecker/push/woodpecker/2 Pipeline was successful
2024-03-25 15:46:57 +01:00
Simon Vieille fcecf74f90
add default voter
Some checks failed
ci/woodpecker/push/woodpecker/2 Pipeline failed
ci/woodpecker/push/woodpecker/1 Pipeline failed
2024-03-25 15:46:53 +01:00
Simon Vieille c00723a246 Merge branch 'develop'
Some checks failed
ci/woodpecker/push/woodpecker Pipeline failed
ci/woodpecker/tag/woodpecker Pipeline failed
ci/woodpecker/push/woodpecker/2 Pipeline was successful
ci/woodpecker/push/woodpecker/1 Pipeline was successful
2023-11-01 16:34:57 +01:00
Simon Vieille e81b11c5ec
release v1.23.0
Some checks failed
ci/woodpecker/push/woodpecker Pipeline failed
2023-11-01 16:34:54 +01:00
Simon Vieille af2212ac8c Merge branch 'develop'
Some checks failed
ci/woodpecker/push/woodpecker Pipeline failed
2023-11-01 16:33:49 +01:00
Simon Vieille b57b0e3770
update murph
Some checks failed
ci/woodpecker/push/woodpecker Pipeline failed
2023-11-01 16:33:44 +01:00
Simon Vieille ba76a83163 Merge branch 'develop' 2023-09-28 18:14:35 +02:00
Simon Vieille 2874f579dc
update changelog 2023-09-28 18:14:22 +02:00
Simon Vieille 287e1d66cb
fix #1: add UniqueEntity constraint in the User entity 2023-09-28 18:13:18 +02:00
Simon Vieille b23a4fe9c5
update changelog 2023-09-07 14:11:11 +02:00
Simon Vieille 59bbd24b76
update woodpecker ci base file 2023-09-07 14:10:26 +02:00
Simon Vieille 2dfe6ef1ca Merge branch 'develop' 2023-08-11 09:48:53 +02:00
Simon Vieille 66f82ecc13
release v1.21.0 2023-08-11 09:48:50 +02:00
Simon Vieille 8432fc123e Merge branch 'develop' 2023-07-27 18:17:48 +02:00
Simon Vieille 627927a11e
update murph 2023-07-27 18:17:15 +02:00
Simon Vieille 67871179a8
update murph 2023-07-27 18:16:36 +02:00
Simon Vieille dbec7a884e
update changelog 2023-07-20 09:47:12 +02:00
Simon Vieille 8c6ad05cbd
add chdir in the console entrypoint 2023-07-20 09:21:17 +02:00
Simon Vieille cc0296e6e2
fix user crud controllers 2023-07-19 21:29:52 +02:00
Simon Vieille 4f94bd5640
add user admin controller and simples views in default files 2023-07-19 21:24:15 +02:00
Simon Vieille 9d8d6b510a Merge branch 'develop'
All checks were successful
ci/woodpecker/push/woodpecker Pipeline was successful
ci/woodpecker/tag/woodpecker Pipeline was successful
2023-04-15 10:53:11 +02:00
Simon Vieille edb51485e1
release v1.19.0
All checks were successful
ci/woodpecker/push/woodpecker Pipeline was successful
2023-04-15 10:53:04 +02:00
Simon Vieille c596f1d62d
add image/webp in default configuration documentation
All checks were successful
ci/woodpecker/push/woodpecker Pipeline was successful
2023-03-02 19:11:11 +01:00
Simon Vieille 39e92e949a Merge branch 'develop'
Some checks failed
ci/woodpecker/push/woodpecker Pipeline failed
ci/woodpecker/tag/woodpecker Pipeline was successful
2023-01-13 18:27:52 +01:00
Simon Vieille 75a29b6372 Merge branch 'develop' 2022-11-19 20:35:43 +01:00
Simon Vieille 69ad422624 Merge branch 'develop' 2022-11-19 19:57:09 +01:00
Simon Vieille 310c5076a0 Merge branch 'develop' 2022-11-19 19:54:16 +01:00
Simon Vieille 65b3583411 Merge branch 'develop' 2022-11-19 19:48:32 +01:00
Simon Vieille a0b4137fb3 Merge branch 'develop' 2022-09-06 12:08:26 +02:00
Simon Vieille ab14728bec Merge branch 'develop' 2022-09-06 12:02:29 +02:00
Simon Vieille c364cafd17 Merge branch 'develop' 2022-06-12 19:07:59 +02:00
Simon Vieille 58b5252986 Merge branch 'develop' 2022-05-20 14:24:06 +02:00
Simon Vieille 5f942a904b Merge branch 'develop' 2022-05-14 11:32:17 +02:00
Simon Vieille 325401f37d Merge branch 'develop' 2022-05-13 22:42:12 +02:00
Simon Vieille bda7a4a195 Merge branch 'develop' 2022-05-09 14:58:43 +02:00
Simon Vieille 1113c0a91f Merge branch 'develop' 2022-05-09 14:55:33 +02:00
Simon Vieille b26738fe49 Merge branch 'develop' 2022-05-05 16:41:05 +02:00
Simon Vieille c4c5aa867a Merge branch 'develop' 2022-05-05 14:41:21 +02:00
Simon Vieille 52be00fc77 Merge branch 'develop' 2022-04-30 12:34:23 +02:00
Simon Vieille 5f1111d2a0 Merge branch 'develop' 2022-04-25 21:08:48 +02:00
Simon Vieille f19fdb0ecf Merge branch 'develop' 2022-04-22 15:29:09 +02:00
Simon Vieille 3c52a00bc4 Merge branch 'develop' 2022-04-20 15:32:54 +02:00
Simon Vieille 3c274a14b9 Merge branch 'develop' 2022-04-20 15:28:33 +02:00
Simon Vieille bb62d1ce78 Merge branch 'develop' 2022-04-20 15:27:42 +02:00
Simon Vieille 2a91b5917f Merge branch 'develop' 2022-04-20 14:51:52 +02:00
Simon Vieille 22d7389183 Merge branch 'develop' 2022-04-20 14:48:01 +02:00
Simon Vieille 933e360e26 Merge branch 'develop' 2022-04-17 18:32:39 +02:00
Simon Vieille 9dd0f7376b Merge branch 'develop' 2022-03-26 16:19:12 +01:00
Simon Vieille f240db7ba4 Merge branch 'develop' 2022-03-26 16:13:40 +01:00
Simon Vieille bb01163e84 Merge branch 'develop' 2022-03-22 15:01:33 +01:00
Simon Vieille 2a5d0ae1f4 Merge branch 'develop' 2022-03-21 11:21:22 +01:00
Simon Vieille 27bccc9acd Merge branch 'develop' 2022-03-17 10:59:41 +01:00
Simon Vieille 246c4621c0 Merge branch 'develop' 2022-03-16 12:51:55 +01:00
Simon Vieille 68c6ee8081 Merge branch 'develop' 2022-03-14 10:47:31 +01:00
Simon Vieille 7623546c10 Merge branch 'develop' 2022-03-14 10:14:34 +01:00
Simon Vieille 63237d50e7 Merge branch 'develop' 2022-03-14 10:13:27 +01:00
Simon Vieille 81d1fa9cad Merge branch 'develop' 2022-03-13 21:17:03 +01:00
Simon Vieille 6086ceaf35 Merge branch 'develop' 2022-03-13 21:14:14 +01:00
Simon Vieille a3ef3540c1 Merge branch 'develop' 2022-03-13 12:20:11 +01:00
Simon Vieille a3a1822339 Merge branch 'develop' 2022-03-11 15:24:35 +01:00
Simon Vieille 59d5fed75e Merge branch 'develop' 2022-03-11 09:49:45 +01:00
Simon Vieille 73b82578e2 Merge branch 'develop' 2022-03-10 22:31:19 +01:00
Simon Vieille dc34a954f6 Merge branch 'develop' 2022-03-10 22:29:59 +01:00
Simon Vieille 0424a9457e Merge branch 'develop' 2022-03-10 22:01:06 +01:00
Simon Vieille b32133e7cb Merge branch 'develop' 2022-03-10 21:50:09 +01:00
Simon Vieille 4e1166c19d Merge branch 'develop' 2022-03-10 21:38:33 +01:00
Simon Vieille 23802898b5 Merge branch 'develop' 2022-03-06 22:17:41 +01:00
Simon Vieille 4be92913a5 Merge branch 'develop' 2022-03-06 22:09:21 +01:00
Simon Vieille f3a48cea18 Merge branch 'develop' 2022-03-06 21:39:41 +01:00
Simon Vieille 3b6e89dc63 Merge branch 'develop' 2022-03-06 15:30:17 +01:00
Simon Vieille 4b4a28aee4 Merge branch 'develop' 2022-03-06 15:21:10 +01:00
Simon Vieille 3d8a4de100 Merge branch 'develop' 2022-03-04 23:12:04 +01:00
Simon Vieille 8d02608681 Merge branch 'develop' 2022-03-03 14:29:02 +01:00
Simon Vieille 56eb728821 Merge branch 'develop' 2022-03-03 14:28:04 +01:00
Simon Vieille bf4bd48775 Merge branch 'develop' 2022-03-03 10:39:18 +01:00
Simon Vieille 321c7ed960 refactoring of admin menu 2022-03-03 10:32:56 +01:00
11 changed files with 175 additions and 5 deletions

View file

@ -9,7 +9,7 @@ services:
environment:
- MARIADB_ROOT_PASSWORD=root
pipeline:
steps:
db_wait:
image: gitnet.fr/deblan/timeout:latest
commands:
@ -21,7 +21,7 @@ pipeline:
- mysql -hdb -uroot -proot -e "CREATE DATABASE app"
config:
image: deblan/php:8.1
image: deblan/php:${PHP_VERSION}
commands:
- echo APP_ENV=prod >> .env.local
- echo APP_SECRET=$(openssl rand -hex 32) >> .env.local

View file

@ -1,6 +1,35 @@
## [Unreleased]
## [1.18.0] 2023-01-13
## [v1.23.0] - 2023-09-28
### Changed
* upgrade murph/murph-core
## [v1.22.0] - 2023-09-28
### Added
* update woodpecker ci base file
### Fixed
* fix #1: add UniqueEntity constraint in the User entity
### Changed
* upgrade murph/murph-core
## [1.21.0] - 2023-08-11
### Changed
* upgrade murph/murph-core
## [1.20.0] - 2023-07-27
### Fixed
* fix collection widget: allow_add/allow_delete and prototype
### Added
* add user admin controller and simples views in default files
* add chdir in the console entrypoint
### Changed
* upgrade murph/murph-core
## [1.19.0] - 2023-04-15
### Changed
* upgrade murph/murph-core
## [1.18.0] - 2023-01-13
### Added
* feat(dep): update dependencies
* feat(update): apply new recipe for phpunit
@ -28,7 +57,7 @@
* fix(config): fix firewall config
## [1.17.0] 2022-11-19
## [1.17.0] - 2022-11-19
### Changed
* upgrade murph/murph-core
* replace annotation with attributes

View file

@ -10,6 +10,8 @@ if (!is_file(dirname(__DIR__).'/vendor/autoload_runtime.php')) {
require_once dirname(__DIR__).'/vendor/autoload_runtime.php';
chdir(__DIR__.'/../');
return function (array $context) {
$kernel = new Kernel($context['APP_ENV'], (bool) $context['APP_DEBUG']);

View file

@ -7,7 +7,7 @@
"prefer-stable": true,
"require": {
"php": ">=8.0.0",
"murph/murph-core": "^1.18"
"murph/murph-core": "^1.23"
},
"require-dev": {
"symfony/browser-kit": "^5.4",

View file

@ -18,6 +18,7 @@ core:
# - image/png
# - image/jpg
# - image/jpeg
# - image/webp
# - image/gif
# - image/svg+xml
# - video/mp4

View file

@ -3,6 +3,10 @@ security:
App\Entity\User:
algorithm: auto
access_decision_manager:
strategy: consensus
allow_if_all_abstain: false
# https://symfony.com/doc/current/security.html#where-do-users-come-from-user-providers
enable_authenticator_manager: true
# https://symfony.com/doc/current/security.html#registering-the-user-hashing-passwords

View file

@ -0,0 +1,79 @@
<?php
namespace App\Controller;
use App\Core\Controller\User\UserAdminController as BaseUserAdminController;
use App\Core\Crud\CrudConfiguration;
use App\Core\Factory\UserFactory as Factory;
use App\Core\Manager\EntityManager;
use App\Core\Security\TokenGenerator;
use App\Entity\User as Entity;
use App\Repository\UserRepositoryQuery as RepositoryQuery;
use Symfony\Component\EventDispatcher\EventDispatcherInterface;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\HttpFoundation\Session\Session;
use Symfony\Component\Routing\Annotation\Route;
class UserAdminController extends BaseUserAdminController
{
#[Route(path: '/admin/user/{page}', name: 'admin_user_index', methods: ['GET'], requirements: ['page' => '\d+'])]
public function index(RepositoryQuery $query, Request $request, Session $session, int $page = 1): Response
{
return parent::index($query, $request, $session, $page);
}
#[Route(path: '/admin/user/new', name: 'admin_user_new', methods: ['GET', 'POST'])]
public function new(Factory $factory, EntityManager $entityManager, Request $request, TokenGenerator $tokenGenerator): Response
{
return parent::new($factory, $entityManager, $request, $tokenGenerator);
}
#[Route(path: '/admin/user/show/{entity}', name: 'admin_user_show', methods: ['GET'])]
public function show(Entity $entity): Response
{
return parent::show($entity);
}
#[Route(path: '/admin/user/filter', name: 'admin_user_filter', methods: ['GET'])]
public function filter(Session $session): Response
{
return parent::filter($session);
}
#[Route(path: '/admin/user/edit/{entity}', name: 'admin_user_edit', methods: ['GET', 'POST'])]
public function edit(Entity $entity, EntityManager $entityManager, Request $request): Response
{
return parent::edit($entity, $entityManager, $request);
}
#[Route(path: '/admin/user/inline_edit/{entity}/{context}/{label}', name: 'admin_user_inline_edit', methods: ['GET', 'POST'])]
public function inlineEdit(string $context, string $label, Entity $entity, EntityManager $entityManager, Request $request): Response
{
return parent::inlineEdit($context, $label, $entity, $entityManager, $request);
}
#[Route(path: '/admin/user/delete/{entity}', name: 'admin_user_delete', methods: ['DELETE', 'POST'])]
public function delete(Entity $entity, EntityManager $entityManager, Request $request): Response
{
return parent::delete($entity, $entityManager, $request);
}
#[Route(path: '/admin/user/resetting_request/{entity}', name: 'admin_user_resetting_request', methods: ['POST'])]
public function requestResetting(Entity $entity, EventDispatcherInterface $eventDispatcher, Request $request): Response
{
return parent::requestResetting($entity, $eventDispatcher, $request);
}
protected function getConfiguration(): CrudConfiguration
{
if ($this->configuration) {
return $this->configuration;
}
return parent::getConfiguration()
->setView('form', 'admin/user_admin/_form.html.twig')
->setView('show_entity', 'admin/user_admin/_show.html.twig')
;
}
}

View file

@ -9,9 +9,11 @@ use Doctrine\ORM\Mapping as ORM;
use Scheb\TwoFactorBundle\Model\Google\TwoFactorInterface;
use Symfony\Component\Security\Core\User\PasswordAuthenticatedUserInterface;
use Symfony\Component\Security\Core\User\UserInterface;
use Symfony\Bridge\Doctrine\Validator\Constraints\UniqueEntity;
#[ORM\Entity(repositoryClass: UserRepository::class)]
#[ORM\HasLifecycleCallbacks]
#[UniqueEntity('email')]
class User implements PasswordAuthenticatedUserInterface, UserInterface, TwoFactorInterface, EntityInterface
{
use Timestampable;

View file

@ -0,0 +1,51 @@
<?php
namespace App\Security\Voter;
use App\Core\Entity\EntityInterface;
use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
use Symfony\Component\Security\Core\Authorization\Voter\Voter;
use Symfony\Component\Security\Core\User\UserInterface;
class EntityVoter extends Voter
{
public const EDIT = 'edit';
public const VIEW = 'show';
public const DELETE = 'delete';
protected function supports(string $attribute, mixed $subject): bool
{
// replace with your own logic
// https://symfony.com/doc/current/security/voters.html
return in_array($attribute, [self::EDIT, self::VIEW, self::DELETE])
&& $subject instanceof EntityInterface;
}
protected function voteOnAttribute(string $attribute, mixed $subject, TokenInterface $token): bool
{
$user = $token->getUser();
if (!$user instanceof UserInterface) {
return false;
}
switch ($attribute) {
case self::EDIT:
return true;
break;
case self::VIEW:
return true;
break;
case self::DELETE:
return true;
break;
}
return false;
}
}

View file

@ -0,0 +1 @@
{{ include('@Core/user/user_admin/_form.html.twig') }}

View file

@ -0,0 +1 @@
{{ include('@Core/user/user_admin/_show.html.twig') }}