@@ 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 |