123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- class Ldap
- # Class for handling LDAP GUIDs.
- # strongly inspired by
- # https://gist.github.com/astockwell/359c950fbc650c339eea
- # Big thanks to @astockwell
- class Guid
- # Checks if the given string is a valid GUID.
- #
- # @param string [String] The string that should be checked for valid GUID format.
- #
- # @example
- # Ldap::Guid.valid?('f742b361-32c6-4a92-baaa-eaae7df657ee')
- # #=> true
- #
- # @return [Boolean]
- def self.valid?(string)
- string.match?(%r{\w{8}-\w{4}-\w{4}-\w{4}-\w+})
- end
- # Convers a given GUID string into the HEX equivalent.
- #
- # @param string [String] The GUID string that should converted into HEX.
- #
- # @example
- # Ldap::Guid.hex('f742b361-32c6-4a92-baaa-eaae7df657ee')
- # #=> "a\xB3B\xF7\xC62\x92J\xBA\xAA\xEA\xAE}\xF6W\xEE".b
- #
- # @return [String] The HEX equivalent of the given GUID string.
- def self.hex(string)
- new(string).hex
- end
- # Convers a given HEX string into the GUID equivalent.
- #
- # @param string [String] The HEX string that should converted into a GUID.
- #
- # @example
- # Ldap::Guid.string("a\xB3B\xF7\xC62\x92J\xBA\xAA\xEA\xAE}\xF6W\xEE".b)
- # #=> 'f742b361-32c6-4a92-baaa-eaae7df657ee'
- #
- # @return [String] The GUID equivalent of the given HEX string.
- def self.string(hex)
- new(hex).string
- end
- # Initializes an instance for the LDAP::Guid class to convert from/to HEX and GUID strings.
- #
- # @param string [String] The HEX or GUID string that should converted.
- #
- # @example
- # guid = Ldap::Guid.new('f742b361-32c6-4a92-baaa-eaae7df657ee')
- #
- # @return [nil]
- def initialize(guid)
- @guid = guid
- end
- # Convers the GUID string into the HEX equivalent.
- #
- # @example
- # guid.hex
- # #=> "a\xB3B\xF7\xC62\x92J\xBA\xAA\xEA\xAE}\xF6W\xEE".b
- #
- # @return [String] The HEX equivalent of the GUID string.
- def hex
- [oracle_raw16(guid)].pack('H*')
- end
- # Convers the HEX string into the GUID equivalent.
- #
- # @example
- # guid.string
- # #=> 'f742b361-32c6-4a92-baaa-eaae7df657ee'
- #
- # @return [String] The GUID equivalent of the HEX string.
- def string
- oracle_raw16(guid.unpack1('H*'), dashify: true)
- end
- private
- attr_reader :guid
- def oracle_raw16(string, dashify: false)
- # remove dashes
- string.delete!('-')
- # split every two chars
- parts = string.scan(%r{.{1,2}})
- # re-order according to oracle format index and join
- oracle_format_indices = [3, 2, 1, 0, 5, 4, 7, 6, 8, 9, 10, 11, 12, 13, 14, 15]
- result = oracle_format_indices.map { |index| parts[index] }.join
- # add dashes if requested
- return result if !dashify
- [
- result[0..7],
- result[8..11],
- result[12..15],
- result[16..19],
- result[20..result.size]
- ].join('-')
- end
- end
- end
|