0
0
Fork 0
mirror of https://github.com/verdigado/organization_folders.git synced 2024-12-06 11:22:41 +01:00

split principal types into different subclasses, added principal factory, implemented principal friendlyNames and FullHierarchyNames, added parentOrganizationId attribute to organizations

This commit is contained in:
Jonathan Treffler 2024-11-26 18:19:05 +01:00
parent 225072bff7
commit 89ff5415dd
15 changed files with 321 additions and 47 deletions

View file

@ -0,0 +1,50 @@
<?php
namespace OCA\OrganizationFolders\Model;
use OCA\OrganizationFolders\Enum\PrincipalType;
use OCA\OrganizationFolders\OrganizationProvider\OrganizationProviderManager;
class RolePrincipal extends Principal {
private ?OrganizationRole $role;
public function __construct(
private OrganizationProviderManager $organizationProviderManager,
private string $providerId,
private string $roleId,
) {
try {
$this->role = $this->organizationProviderManager->getOrganizationProvider($providerId)->getRole($roleId);
$this->valid = !is_null($this->role);
} catch (\Exception $e) {
$this->valid = false;
}
}
public function getType(): PrincipalType {
return PrincipalType::ROLE;
}
public function getId(): string {
return $this->providerId . ":" . $this->roleId;
}
public function getFriendlyName(): string {
return $this->role->getFriendlyName();
}
public function getFullHierarchyNames(): array {
$result = [];
$result[] = $this->getFriendlyName();
$organizationProvider = $this->organizationProviderManager->getOrganizationProvider($this->providerId);
$organization = $organizationProvider->getOrganization($this->role->getOrganizationId());
$result[] = $organization->getFriendlyName();
while($organization->getParentOrganizationId() && $organization = $organizationProvider->getOrganization($organization->getParentOrganizationId())) {
$result[] = $organization->getFriendlyName();
}
return array_reverse($result);
}
}