2023-02-19 20:25:32 +11:00
< ? php
2023-03-02 09:54:30 +11:00
namespace App\Classes\LDAP\Attribute\Schema ;
2023-02-19 20:25:32 +11:00
2023-04-02 22:07:15 +10:00
use Illuminate\Contracts\View\View ;
2023-03-02 09:54:30 +11:00
use App\Classes\LDAP\Attribute\Schema ;
2023-02-19 20:25:32 +11:00
/**
2023-03-02 18:21:53 +11:00
* Represents a Mechanisms Attribute
2023-02-19 20:25:32 +11:00
*/
2023-03-02 09:54:30 +11:00
final class Mechanisms extends Schema
2023-02-19 20:25:32 +11:00
{
/**
* Given an SASL Mechanism name , returns a verbose description of the Mechanism .
* This function parses ldap_supported_saslmechanisms . txt and looks up the specified
* Mechanism , and returns the verbose message defined in that file .
*
* < code >
* " SCRAM-SHA-1 " => array : 3 [ ▼
* " title " => " Salted Challenge Response Authentication Mechanism (SCRAM) SHA1 "
* " ref " => " RFC 5802 "
* " desc " => " This specification describes a family of authentication mechanisms called the Salted Challenge Response Authentication Mechanism (SCRAM) which addresses the req ▶ "
* ]
* </ code >
*
* @ param string $string The SASL Mechanism ( ie , " SCRAM-SHA-1 " ) of interest .
* @ param string $key The title | ref | desc to return
* @ return string | NULL
*/
2023-04-02 22:07:15 +10:00
public static function get ( string $string , string $key ) : ? string
2023-02-19 20:25:32 +11:00
{
2023-03-02 09:54:30 +11:00
return parent :: _get ( config_path ( 'ldap_supported_saslmechanisms.txt' ), $string , $key );
2023-02-19 20:25:32 +11:00
}
2023-04-02 22:07:15 +10:00
2024-01-20 10:36:30 +11:00
public function render ( bool $edit = FALSE , bool $old = FALSE , bool $new = FALSE ) : View
2023-04-02 22:07:15 +10:00
{
// @note Schema attributes cannot be edited
return view ( 'components.attribute.schema.mechanisms' )
-> with ( 'o' , $this );
}
2023-02-19 20:25:32 +11:00
}