In Files

  • win32/lib/win32/sspi.rb

Parent

Win32::SSPI::SecurityBuffer

Creates binary representations of a SecBufferDesc structure, including the SecBuffer contained inside.

Public Class Methods

new(buffer = nil) click to toggle source
 
               # File win32/lib/win32/sspi.rb, line 91
def initialize(buffer = nil)
  @buffer = buffer || "\0" * TOKENBUFSIZE
  @bufferSize = @buffer.length
  @type = SECBUFFER_TOKEN
end
            

Public Instance Methods

bufferSize() click to toggle source
 
               # File win32/lib/win32/sspi.rb, line 97
def bufferSize
  unpack
  @bufferSize
end
            
bufferType() click to toggle source
 
               # File win32/lib/win32/sspi.rb, line 102
def bufferType
  unpack
  @type
end
            
to_p() click to toggle source
 
               # File win32/lib/win32/sspi.rb, line 112
def to_p
  # Assumption is that when to_p is called we are going to get a packed structure. Therefore,
  # set @unpacked back to nil so we know to unpack when accessors are next accessed.
  @unpacked = nil
  # Assignment of inner structure to variable is very important here. Without it,
  # will not be able to unpack changes to the structure. Alternative, nested unpacks,
  # does not work (i.e. @struct.unpack("LLP12")[2].unpack("LLP12") results in "no associated pointer")
  @sec_buffer ||= [@bufferSize, @type, @buffer].pack("LLP")
  @struct ||= [SECBUFFER_VERSION, 1, @sec_buffer].pack("LLP")
end
            
token() click to toggle source
 
               # File win32/lib/win32/sspi.rb, line 107
def token
  unpack
  @buffer
end
            
There is an updated format of the API docs for this version here.