| @@ 8-87 (lines=80) @@ | ||
| 5 | use Psr\Log\LoggerAwareTrait; |
|
| 6 | use Psr\Log\NullLogger; |
|
| 7 | ||
| 8 | class PdoAddPermission |
|
| 9 | { |
|
| 10 | ||
| 11 | use LoggerAwareTrait; |
|
| 12 | ||
| 13 | /** |
|
| 14 | * @var \PDO |
|
| 15 | */ |
|
| 16 | public $pdo; |
|
| 17 | ||
| 18 | /** |
|
| 19 | * @var \PDOStatement |
|
| 20 | */ |
|
| 21 | public $stmt; |
|
| 22 | ||
| 23 | /** |
|
| 24 | * @var string |
|
| 25 | */ |
|
| 26 | public $permissions_table = "permissions"; |
|
| 27 | ||
| 28 | /** |
|
| 29 | * @var Seperator string for roles in SELECT statement |
|
| 30 | */ |
|
| 31 | protected $separator = ","; |
|
| 32 | ||
| 33 | ||
| 34 | /** |
|
| 35 | * @param \PDO $pdo PDO instance |
|
| 36 | * @param string $permissions_table Permissions table name |
|
| 37 | * @param LoggerInterface|null $logger Optional: PSR-3 Logger |
|
| 38 | */ |
|
| 39 | public function __construct( \PDO $pdo, $permissions_table, LoggerInterface $logger = null ) |
|
| 40 | { |
|
| 41 | $this->setLogger( $logger ?: new NullLogger ); |
|
| 42 | ||
| 43 | // Prerequisites |
|
| 44 | $this->pdo = $pdo; |
|
| 45 | $this->permissions_table = $permissions_table; |
|
| 46 | ||
| 47 | // Read pages and allowed roles |
|
| 48 | $sql = "INSERT INTO {$this->permissions_table} |
|
| 49 | (permission_name, permission_description, info ) |
|
| 50 | VALUES |
|
| 51 | (:name, :description, :info)"; |
|
| 52 | ||
| 53 | // Prepare business |
|
| 54 | $this->stmt = $pdo->prepare( $sql ); |
|
| 55 | } |
|
| 56 | ||
| 57 | ||
| 58 | /** |
|
| 59 | * @return int Last Insert ID or FALSE when something errored |
|
| 60 | * @throws PermissionNameExistsException On duplicate name |
|
| 61 | */ |
|
| 62 | public function __invoke( array $permission ) |
|
| 63 | { |
|
| 64 | $permission = array_merge([ 'info' => null, ], $permission); |
|
| 65 | ||
| 66 | try { |
|
| 67 | $result = $this->stmt->execute( $permission ); |
|
| 68 | if ($result): |
|
| 69 | $this->logger->info("Added new permission", $permission); |
|
| 70 | return (int) $this->pdo->lastInsertId(); |
|
| 71 | endif; |
|
| 72 | ||
| 73 | $this->logger->error("Could not execute 'Add permission' statement", $permission); |
|
| 74 | return false; |
|
| 75 | } |
|
| 76 | catch( \PDOException $e ) |
|
| 77 | { |
|
| 78 | // SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry ... |
|
| 79 | if ($e->getCode() == 23000): |
|
| 80 | throw new PermissionNameExistsException("Permission name already exists", 23000, $e); |
|
| 81 | endif; |
|
| 82 | ||
| 83 | throw $e; |
|
| 84 | } |
|
| 85 | ||
| 86 | } |
|
| 87 | } |
|
| 88 | ||
| @@ 8-90 (lines=83) @@ | ||
| 5 | use Psr\Log\LoggerAwareTrait; |
|
| 6 | use Psr\Log\NullLogger; |
|
| 7 | ||
| 8 | class PdoAssignRoleToPermission |
|
| 9 | { |
|
| 10 | ||
| 11 | use LoggerAwareTrait; |
|
| 12 | ||
| 13 | /** |
|
| 14 | * @var \PDO |
|
| 15 | */ |
|
| 16 | public $pdo; |
|
| 17 | ||
| 18 | /** |
|
| 19 | * @var \PDOStatement |
|
| 20 | */ |
|
| 21 | public $stmt; |
|
| 22 | ||
| 23 | /** |
|
| 24 | * @var string |
|
| 25 | */ |
|
| 26 | public $permissions_roles_table = "permissions_roles"; |
|
| 27 | ||
| 28 | /** |
|
| 29 | * @var Seperator string for roles in SELECT statement |
|
| 30 | */ |
|
| 31 | protected $separator = ","; |
|
| 32 | ||
| 33 | ||
| 34 | /** |
|
| 35 | * @param \PDO $pdo PDO instance |
|
| 36 | * @param string $permissions_roles_table Permissions/Roles table name |
|
| 37 | * @param LoggerInterface|null $logger Optional: PSR-3 Logger |
|
| 38 | */ |
|
| 39 | public function __construct( \PDO $pdo, $permissions_roles_table, LoggerInterface $logger = null ) |
|
| 40 | { |
|
| 41 | $this->setLogger( $logger ?: new NullLogger ); |
|
| 42 | ||
| 43 | // Prerequisites |
|
| 44 | $this->pdo = $pdo; |
|
| 45 | $this->permissions_roles_table = $permissions_roles_table; |
|
| 46 | ||
| 47 | // Read pages and allowed roles |
|
| 48 | $sql = "INSERT INTO {$this->permissions_roles_table} |
|
| 49 | (permission_id, role_id ) |
|
| 50 | VALUES |
|
| 51 | (:permission_id, :role_id)"; |
|
| 52 | ||
| 53 | // Prepare business |
|
| 54 | $this->stmt = $pdo->prepare( $sql ); |
|
| 55 | } |
|
| 56 | ||
| 57 | ||
| 58 | /** |
|
| 59 | * @return int Last Insert ID or FALSE when something errored |
|
| 60 | * @throws PermissionNameExistsException On duplicate name |
|
| 61 | */ |
|
| 62 | public function __invoke( $permission_id, $role_id ) |
|
| 63 | { |
|
| 64 | try { |
|
| 65 | $info = [ |
|
| 66 | 'permission_id' => $permission_id, |
|
| 67 | 'role_id' => $role_id |
|
| 68 | ]; |
|
| 69 | ||
| 70 | $result = $this->stmt->execute( $info ); |
|
| 71 | if ($result): |
|
| 72 | $this->logger->info("Assigned new role to permission", $info); |
|
| 73 | return (int) $this->pdo->lastInsertId(); |
|
| 74 | endif; |
|
| 75 | ||
| 76 | $this->logger->error("Could not execute 'Assign role to permission' statement", $info); |
|
| 77 | return false; |
|
| 78 | } |
|
| 79 | catch( \PDOException $e ) |
|
| 80 | { |
|
| 81 | // SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry ... |
|
| 82 | if ($e->getCode() == 23000): |
|
| 83 | throw new RolePermissionAssignmentExistsException("Role/Permission assignment already exists", 23000, $e); |
|
| 84 | endif; |
|
| 85 | ||
| 86 | throw $e; |
|
| 87 | } |
|
| 88 | ||
| 89 | } |
|
| 90 | } |
|
| 91 | ||