2021-12-08 23:26:12 +11:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Classes\LDAP\Attribute;
|
|
|
|
|
|
|
|
use Illuminate\Support\Arr;
|
|
|
|
use Illuminate\Support\Facades\Log;
|
|
|
|
|
2023-03-02 09:54:30 +11:00
|
|
|
use App\Classes\LDAP\Attribute;
|
2021-12-08 23:26:12 +11:00
|
|
|
|
2021-12-10 22:39:09 +11:00
|
|
|
/**
|
|
|
|
* This factory is used to return LDAP attributes as an object
|
|
|
|
*
|
|
|
|
* If there is no specific Attribute defined, then the default Attribute::class is return
|
|
|
|
*/
|
2021-12-08 23:26:12 +11:00
|
|
|
class Factory
|
|
|
|
{
|
|
|
|
private const LOGKEY = 'LAf';
|
|
|
|
|
|
|
|
/**
|
2021-12-10 22:39:09 +11:00
|
|
|
* Map of attributes to appropriate class
|
2021-12-08 23:26:12 +11:00
|
|
|
*/
|
|
|
|
public const map = [
|
2023-03-02 18:21:53 +11:00
|
|
|
'createtimestamp' => Internal\Timestamp::class,
|
2023-04-02 22:07:15 +10:00
|
|
|
'creatorsname' => Internal\DN::class,
|
|
|
|
'contextcsn' => Internal\CSN::class,
|
|
|
|
'entrycsn' => Internal\CSN::class,
|
|
|
|
'entrydn' => Internal\DN::class,
|
|
|
|
'entryuuid' => Internal\UUID::class,
|
2023-03-02 18:21:53 +11:00
|
|
|
'gidnumber' => GidNumber::class,
|
|
|
|
'hassubordinates' => Internal\HasSubordinates::class,
|
2023-02-19 20:25:32 +11:00
|
|
|
'jpegphoto' => Binary\JpegPhoto::class,
|
2023-03-02 18:21:53 +11:00
|
|
|
'modifytimestamp' => Internal\Timestamp::class,
|
2023-04-02 22:07:15 +10:00
|
|
|
'modifiersname' => Internal\DN::class,
|
2023-03-02 09:54:30 +11:00
|
|
|
'objectclass' => ObjectClass::class,
|
2023-03-02 18:21:53 +11:00
|
|
|
'structuralobjectclass' => Internal\StructuralObjectClass::class,
|
|
|
|
'subschemasubentry' => Internal\SubschemaSubentry::class,
|
2023-03-02 09:54:30 +11:00
|
|
|
'supportedcontrol' => Schema\OID::class,
|
|
|
|
'supportedextension' => Schema\OID::class,
|
|
|
|
'supportedfeatures' => Schema\OID::class,
|
|
|
|
'supportedsaslmechanisms' => Schema\Mechanisms::class,
|
2023-03-02 18:21:53 +11:00
|
|
|
'userpassword' => Password::class,
|
2021-12-08 23:26:12 +11:00
|
|
|
];
|
|
|
|
|
|
|
|
/**
|
2021-12-10 22:39:09 +11:00
|
|
|
* Create the new Object for an attribute
|
2021-12-08 23:26:12 +11:00
|
|
|
*
|
|
|
|
* @param string $attribute
|
|
|
|
* @param array $values
|
|
|
|
* @return Attribute
|
|
|
|
*/
|
|
|
|
public static function create(string $attribute,array $values): Attribute
|
|
|
|
{
|
2023-03-02 09:54:30 +11:00
|
|
|
$class = Arr::get(self::map,$attribute,Attribute::class);
|
2021-12-08 23:26:12 +11:00
|
|
|
Log::debug(sprintf('%s:Creating LDAP Attribute [%s] as [%s]',static::LOGKEY,$attribute,$class));
|
|
|
|
|
|
|
|
return new $class($attribute,$values);
|
|
|
|
}
|
|
|
|
}
|