summaryrefslogtreecommitdiffstats
path: root/library/Director/PropertyModifier/PropertyModifierFromAdSid.php
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-14 13:17:31 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-14 13:17:31 +0000
commitf66ab8dae2f3d0418759f81a3a64dc9517a62449 (patch)
treefbff2135e7013f196b891bbde54618eb050e4aaf /library/Director/PropertyModifier/PropertyModifierFromAdSid.php
parentInitial commit. (diff)
downloadicingaweb2-module-director-f66ab8dae2f3d0418759f81a3a64dc9517a62449.tar.xz
icingaweb2-module-director-f66ab8dae2f3d0418759f81a3a64dc9517a62449.zip
Adding upstream version 1.10.2.upstream/1.10.2
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'library/Director/PropertyModifier/PropertyModifierFromAdSid.php')
-rw-r--r--library/Director/PropertyModifier/PropertyModifierFromAdSid.php36
1 files changed, 36 insertions, 0 deletions
diff --git a/library/Director/PropertyModifier/PropertyModifierFromAdSid.php b/library/Director/PropertyModifier/PropertyModifierFromAdSid.php
new file mode 100644
index 0000000..ee306e3
--- /dev/null
+++ b/library/Director/PropertyModifier/PropertyModifierFromAdSid.php
@@ -0,0 +1,36 @@
+<?php
+
+namespace Icinga\Module\Director\PropertyModifier;
+
+use Icinga\Module\Director\Hook\PropertyModifierHook;
+
+class PropertyModifierFromAdSid extends PropertyModifierHook
+{
+ public function getName()
+ {
+ return 'Decode a binary object SID (MSAD)';
+ }
+
+ public function transform($value)
+ {
+ if ($value === null) {
+ return null;
+ }
+
+ // Strongly inspired by
+ // http://www.chadsikorra.com/blog/decoding-and-encoding-active-directory-objectsid-php
+ //
+ // Not perfect yet, but should suffice for now. When improving this please also see:
+ // https://blogs.msdn.microsoft.com/oldnewthing/20040315-00/?p=40253
+
+ $sid = $value;
+ $sidHex = unpack('H*hex', $value);
+ $sidHex = $sidHex['hex'];
+ $subAuths = implode('-', unpack('H2/H2/n/N/V*', $sid));
+
+ $revLevel = hexdec(substr($sidHex, 0, 2));
+ $authIdent = hexdec(substr($sidHex, 4, 12));
+
+ return sprintf('S-%s-%s-%s', $revLevel, $authIdent, $subAuths);
+ }
+}