Authors
    
      - Richard Frith-Macdonald (rfm@gnu.org)
- 
      
Date: Generated at 2024-11-15 21:22:27 -0700
    Copyright: (C) 2009 Free Software Foundation, Inc.
        
          
    
    
      
        - Declared in:
- WSSUsernameToken.h
    
      
          
    
    
            Supports the Web Services Security Username Token
            capability. 
 The initial implementation
            only supports plaintext password client use
              
    
      
          
    
    
            Basic usage is simple, you create an instance of this
            class, initialising it with the username and
            password to be used to authenticate requests. Then
            for each request you add the token to the request
            header. This can be done either as a delegate of a
            coder or the delegate of a service. The following
            shows the delegate method for a service:
              
    
      
 - (GWSElement*) webService: (GWSService*)service willEncode: (GWSElement*)e
 {
   if (e == nil || [[e name] isEqual: @"Header"] == YES)
     {
       e = [wsstoken addToHeader: e];	// May return new object.
     }
   return e;
 }
 
      
        
     
    Method summary
    
    
    
    + (NSString*) 
digestHashForPassword: (NSString*)password
 andTimestamp: (NSCalendarDate**)date
 withNonce: (NSString**)nonce;
    
      
            Takes a plaintext password, timestamp, and
            a base64 encoded nonce, and generates and
            returns a base64 encoded hash digest. 
 If the
            supplied date is nil then
            the current timestamp is used and returned, otherwise
            the timestamp has its timezone and format adjusted as
            necessary and is used for the digest. 
 If
            the supplied nonce is nil then
            a new one is generated and returned. 
 If the
            supplied date is actually a string, it
            is parsed to form a date and replaced by the
            resulting calendar date object.
          
    
    
 
    
    + (NSString*) 
digestHashForPassword: (NSString*)password
 andTimestamp: (NSCalendarDate**)date
 withNonce: (NSString**)nonce
 algorithm: (
GWSDigestAlgorithm)algorithm;
    
      
            Takes a plaintext password, timestamp, and
            a base64 encoded nonce, and generates and
            returns a base64 encoded hash digest. 
 If the
            supplied date is nil then
            the current timestamp is used and returned, otherwise
            the timestamp has its timezone and format adjusted as
            necessary and is used for the digest. 
 If
            the supplied nonce is nil then
            a new one is generated and returned. 
 If the
            supplied date is actually a string, it
            is parsed to form a date and replaced by the
            resulting calendar date object. 
            The algorithm argument overrides the default
            behavior of producing the digest using SHA1 (the
            standard).
          
    
    
 
    
    - (
GWSElement*) 
addToHeader: (
GWSElement*)header;
    
      
            Adds a representation of the receiver to the specified
            SOAP header and returns the modified
            header. If the header is
            nil, this simply returns a
            representation of the receiver which can
            then be added to a SOAP header.
          
    
    
 
    
    - (id) 
initWithName: (NSString*)name
 password: (NSString*)password;
    
      
            Initialise the receiver with a name
            and password used to authenticate with a
            remote server.
          
    
    
 
    
    - (id) 
initWithName: (NSString*)name
 password: (NSString*)password
 timeToLive: (unsigned)ttl;
This is a designated initialiser for the class.
    
      
            Initialise the receiver with a name
            and password used to authenticate with a
            remote server. 
 If ttl is non-zero,
            then a hash of the token is used along with a creation
            date and nonce. The actual ttl value is
            only of use for server-side code, which will reject
            any message whose creation date is older than the
            number of seconds specified as the time to live.
          
    
    
 
    
    - (void) 
setAlgorithm: (
GWSDigestAlgorithm)algorithm;
    
      
            Sets the algorithm used for digests.
          
    
    
 
    
    - (
GWSElement*) 
tree;
    
      
            Return a tree representation of the WSS Username
            Token for inclusion in the header of a SOAP request.
          
    
    
 
          
    
    
      
        - Declared in:
- WSSUsernameToken.h
    
      
          Produce a digest of an NSData object. 
 Used
          internally by
          
WSSUsernameToken
            when hash based authentication is in use.
        
    
    
    - (NSData*) 
SHA1;
    
      
            This method produces an SHA1 digest of the receiver
            and returns the resulting value as an autoreleased
            NSData object. 
 NB SHA1 is considered
            insecure.
          
    
    
 
    
    - (NSData*) 
SHA2_256;
    
      
            This method produces an SHA2_256 digest of the
            receiver and returns the resulting value as an
            autoreleased NSData object.
          
    
    
 
    
    - (NSData*) 
SHA2_512;
    
      
            This method produces an SHA2_512 digest of the
            receiver and returns the resulting value as an
            autoreleased NSData object.
          
    
    
 
    
    - (NSData*) 
SHA3_256;
    
      
            This method produces an SHA3_256 digest of the
            receiver and returns the resulting value as an
            autoreleased NSData object.
          
    
    
 
    
    - (NSData*) 
SHA3_512;
    
      
            This method produces an SHA3_512 digest of the
            receiver and returns the resulting value as an
            autoreleased NSData object.
          
    
    
 
          
    
    
    
    typedef enum ... GWSDigestAlgorithm;
    
      
          The GWSDigestAlgorithm enumeration is used to specify
          what algorithm is to be used for working with digests.
          
      
        - GWSDigestSHA1
- 
        
- GWSDigestSHA2_256
- 
        
- GWSDigestSHA2_512
- 
        
- GWSDigestSHA3_256
- 
        
- GWSDigestSHA3_512
-