Authors
    
      - Richard Frith-Macdonald (rfm@gnu.org)
- 
      
Date: Generated at 2024-09-29 16:19:42 -0600
    Copyright: (C) 2008 Free Software Foundation, Inc.
        
          
    
    
      
        - Declared in:
- GWSCoder.h
    
      
          
    
    
            The GWSCoder class is a semi-abstract class for
            handling encoding to XML and decoding from XML for
            a group of services. 
 With its standard instance
            variables and helper functions it really just
            provides a convenient mechanism to store data in a
            mutable string, but in conjunction with
            GWSElement
              it can be used to serialize a tree of elements to a
              string and will parse an XML document ninto a tree
              of elements. 
 Usually (for RPC and messaging),
              the actual encoding/decoding is handled by a concrete
              subclass. 
 Instances of these classes are
              not expected to be re-entrant or thread-safe, so you
              need to create an instance for each thread in which
              you are working.
                
    
      
            
    
    
              With Web Services, the design of the XML
              specification is that services have an
              abstract definition and then also a concrete
              binding to a particular implementation (generally
              SOAP). 
 Within the GWS classes a similar
              separation is implemented at the level of the
              coders, with the idea being that coders can be
              used separately and their operation can be driven
              entirely from the parameter dictionary passed to
              them (with various special keys in the dictionary
              controlling behavior). 
 Thus to send a
              message for a particular service, the basic
              parameters are placed in a dictionary by the
              application, and that dictionary is then
              passed to the GWSService which invokes
              extensibility classes to modify the
              dictionary contents by adding additional
              keys/values to tell the coder how to handle
              them. 
 A programmer wishing to use the coder
              without web services support to, simply send an
              RPC, merely needs to supply any required additional
              key/value pairs themselves rather than having a
              web service do it.
                
    
      
        
    
 
    
    Instance Variables
    
    Method summary
    
    
    
    + (
GWSCoder*) 
coder;
    
      
            Creates and returns an autoreleased instance.
            
 The default implementation creates an
            instance of the GWSXMLRPCCoder concrete subclass.
          
    
    
 
    
    - (BOOL) 
cdata;
    
      
            Return the value set by a prior call to
            
              -setCDATA:
            
            (or 
NO... the default).
          
    
 
    
    - (BOOL) 
compact;
    
      
            Return the value set by a prior call to
            
              -setCompact:
            
            (or 
NO... the default).
          
    
 
    
    - (BOOL) 
debug;
    
      
            Returns 
YES if debug is enabled,
            
NO otherwise. The default value of this
            is obtained from the GWSDebug user default (or
            
NO if no default is set), but may also
            be adjusted by a call to the
            
              -setDebug:
            
            method.
          
    
 
    
    - (NSData*) 
decodeBase64From: (NSString*)str;
    
      
            Decode the supplied base64 encoded data and return
            the result.
          
    
    
 
    
    - (NSData*) 
decodeBase64UrlFrom: (NSString*)str;
    
      
            Decode the supplied base64url encoded data and
            return the result.
          
    
    
 
    
    - (NSData*) 
decodeHexBinaryFrom: (NSString*)str;
    
      
            Decode the supplied hexBinary encoded data and
            return the result. 
 This is a tolerant parser,
            it accepts lower case hex digits and white space, but it
            does insist on an even number of hexadecimal digits.
            
 A decoding failure results in
            nil being returned.
          
    
    
 
    
    - (NSString*) 
encodeBase64From: (NSData*)source;
    
      
            Take the supplied data and convert it to base64
            encoded text.
          
    
    
 
    
    - (NSString*) 
encodeBase64UrlFrom: (NSData*)source;
    
      
            Take the supplied data and convert it to base64url
            encoded text.
          
    
    
 
    
    - (NSString*) 
encodeHexBinaryFrom: (NSData*)source;
    
      
            Encode the supplied data as hexBinary data in the
            canonical form (as per W3 schema recommendations)
            and return the result. 
 The canonical form uses
            upper case hexadecimal digits.
          
    
    
 
    
    - (NSString*) 
escapeCDATAFrom: (NSString*)str;
    
      
            Takes the supplied string and uses CDATA to escape it
            for use in an XML element where character data is
            allowed.
          
    
    
 
    
    - (NSString*) 
escapeXMLFrom: (NSString*)str;
    
      
            Take the supplied string and add all necessary escapes
            for XML.
          
    
    
 
    
    - (void) 
indent;
    
      
            Increase the indentation level used while creating
            an XML document.
          
    
    
 
    
    - (NSString*) 
legalXMLFrom: (NSString*)str;
    
      
            Removes any characters which are not legal in xm
            version 1.0 leaving a 'legal' string. This does not
            replace special characters such as ampersand with
            entities, for that you need to use the
            
              -escapeXMLFrom:
            
            method.
          
    
 
    
    - (NSMutableString*) 
mutableString;
    
      
            Returns the mutable string currently in use for
            encoding.
          
    
    
 
    
    - (void) 
nl;
    
      
            Add a new line to the temporary string currently in use
            for creating an XML document, and add padding on the
            new line so that the next item written is indented
            correctly. 
 A newline is a linefeed (LF)
            character unless the
            
              -setCRLF
            
            method is used to override that.
          
    
    
 
    
    - (
GWSElement*) 
parseXML: (NSData*)xml;
    
      
            Parses XML data to form a tree of GWSElement
            objects. 
 This method uses the
            NSXMLParser
              class to perform the actual parsing by acting as a
              delegate to build a tree of
              
GWSElement
                objects, so you may use your own subclass and
                override the NSXMLParser delegate methods to
                provide additional control over the parsing
                operation.
          
    
 
    
    - (id) 
parseXSI: (NSString*)type
 string: (NSString*)value;
    
      
            Parses simple XSI typed string data into Objective-C
            objects. 
 The type is the name of
            the simple datatype (if nil,
            'xsd:string'). 
 The value
            is the string to be decoded. 
 The result returned
            may be an NSString, and NSNumber, an NSDate or an
            NSData object. 
 A result of nil
            is returned if the value cannot be decoded as
            the specified type.
          
    
    
 
    
    - (BOOL) 
permitAllUnicode;
    
      
            Whether characters that are illegal in xml 1.0
            should be permitted in our encoding. This should be
            turned on for xml 1.1 use.
          
    
    
 
    
    - (BOOL) 
preferSloppyParser;
    
      
            Whether the more tolerant, non-libxml2 parser in
            GNUstep should be used.
          
    
    
 
    
    - (BOOL) 
preserveSpace;
    
      
            Whether whitespace in contrent adjacent to element
            markup should be stripped/ignored.
          
    
    
 
    
    - (void) 
reset;
    
      
            Resets parsing and/or building, releasing any
            temporary data stored during parse etc. 
            This does not alter the effects of the
            
              -setCompact:
            
            or 
-setCRLF:
            methods.
          
    
 
    
    - (void) 
setCDATA: (BOOL)flag;
    
      
            Specifies whether character data content of
            elements is output using CDATA sections. If this
            is NO, characters are individually escaped
            using numeric entities when required.
          
    
    
 
    
    - (void) 
setCRLF: (BOOL)flag;
    
      
            Specifies whether newlines between elements are
            represented as a single LF or as a CRLF
            sequence when generating output. 
 NB this
            has no effect for compact output (where all output is
            on a single line).
          
    
    
 
    
    - (void) 
setCompact: (BOOL)flag;
    
      
            Specify whether to generate compact XML (omit
            indentation and other white space and omit
            <string> element markup for XMLRPC).
            
 Compact representation saves some space (can
            be important when sent over slow/low bandwidth
            connections), but sacrifices readability.
          
    
    
 
    
    - (int) 
setDebug: (int)flag;
    
      
            Specifies whether debug information is enabled.
            See 
-debug
 for
            more information. 
 A non-zero setting sets debg
            to 
YES while a zero setting sets it to
            
NO. The method returns the previous
            setting.
          
    
 
    
    - (void) 
setPermitAllUnicode: (BOOL)flag;
    
      
            Specifies whether illegal characters (for xml
            1.0) should be permitted in the output when escaping
            unicode text. You should turn this on for xml 1.1
            output.
          
    
    
 
    
    - (void) 
setPreferSloppyParser: (BOOL)flag;
    
      
            Specifies whether the more tolerant, non-libxml2
            parser should be used if available. This supports a
            wider range of not-entirely valid XML, but omits
            features such as external entity support.
          
    
    
 
    
    - (void) 
setPreserveSpace: (BOOL)flag;
    
      
            Specifies whether leading and trailing whie space
            character content of an element is preserved or
            stripped/ignored (standard xml behavior is
            to strip/ignore it).
          
    
    
 
    
    - (void) 
unindent;
    
      
            Decrease the indentation level used while creating
            an XML document. creating an XML document.
          
    
    
 
    
    Instance Variables for GWSCoder Class
    
    @protected NSMutableArray* _stack;
    
      
            Warning the underscore at the start of the
            name of this instance variable indicates that, even
            though it is not technically private, it is
            intended for internal use within the package, and
            you should not use the variable in other code.
          
    
    
    
          
    
    
      
        - Declared in:
- GWSCoder.h
    
      
          
    
    
            The GWSJSONCoder class is a concrete subclass of
            GWSCoder
              which implements coding/decoding for JSON texts.
                
    
      
            
    
    
              The correspondence between JSON values and
              Objective-C objects is as follows -
                
    
      
            
      
        - 
          
                null is the
                NSNull
                  object.
                
        
- 
          
                  true is an
                  NSNumber
                    created as a BOOL.
                  
        
- 
          
                    false is an
                    NSNumber
                      created as a BOOL.
                    
        
- 
          
                      numeric is an
                      NSNumber
                        other than a boolean.
                      
        
- 
          
                        string is an
                        NSString
                          object.
                        
        
- 
          
                          array is an
                          NSArray
                            object.
                          
        
- 
          
                            object is an
                            NSDictionary
object.
        
                            In addition, any
                            NSDate
                              object is encoded as a string
                              using the
                              -encodeDateTimeFrom:
 method, and any NSData
object is encoded as a string by using base64 encoding.    
    
      
                              
    
    
                                If you attempt to use any other type
                                of object in the construction of a
                                JSON text, the
                                [NSObject -description]
 method of that object will be used to create a string, and the resulting object will be encoded as a JSON string element.
                                  
    
      
                              
    
    
                                In particular, the names of members
                                in a JSON object must be
                                strings, so if you provide an
                                NSDictionary
object to represent a JSON object the keys of the dictionary will be converted to strings where necessary.    
    
      
                                
    
    
                                  The JSON coder supports JSON-RPC
                                  versions 1.0 and 2.0 as well
                                  as supporting simple
                                  encoding/decoding
                                  of JSON documents without JSON-RPC
                                  (where the RPC version is set
                                  to nil). 
 To
                                  force parsing as JSON-RPC
                                  rather than simply a JSON
                                  document, call the
                                  -setStrictParsing:
 method. In this case, if the jsonrpc field is missing the request is assumed to be version 1.0 (this field was added in 2.0) and a value of the jsonrpc field other than 2.0 is illegal.
                                    
    
      
        
    
 
    
    Instance Variables
    
    Method summary
    
    
    
    - (id) 
RPCID;
    
      
            Returns the RPC ID set for this coder. See
            
              -setRPCID:
            
            for details.
          
    
 
    
    - (void) 
appendObject: (id)o;
    
      
            This method appends an object to the mutable string in
            use by the coder.
          
    
    
 
    
    - (NSData*) 
buildFaultWithCode: (
GWSRPCFaultCode)code
 andText: (NSString*)text;
    
      
            Builds a simple fault response.
          
    
    
 
    
    - (NSData*) 
buildRequest: (NSString*)method
 parameters: (NSDictionary*)parameters
 order: (NSArray*)order;
    
      
            
    
    
              The JSON-RPC format encoding depends on the
              GWSRPCVersionKey or (if that key is
              missing from the parameters
              dictionary) the version set for the coder
              using the
              
                -setVersion:
              
              method. 
 If the version is
              nil (ie not set using
              GWSRPCVersionKey or using
              
                -setVersion:
              
              then JSON-RPC is not used and data is encoded as a
              simple JSON document. 
 Each RPC must have an
              ID, which is set using the GWSRPCIDKey or (if that is
              missing) using the
              
                -setRPCID:
              
              method (if neither supply an
              id, and an RPC version is set,
              a null is used). 
 The
              
                -setVersion:
              
              and
              
                -setRPCID:
              
              methods are automatically called when a request
              is parsed, so that the default version and
              id of any response built after
              the request was parsed will match those of the
              incoming request. 
 If JSON-RPC is not
              used, a single parameter is encoded directly as a
              JSON object, while multiple parameters
              are encoded as a struct. 
 If an encoding
              order is specified (or if the RPC
              version is 1.0) then the encoded result is an
              array and parameters are passed by
              position as items in that array. 
              Otherwise, if there is a single parameter
              whose name is the constant GWSJSONResultKey (the
              string 'GWSJSONResult'), then that parameter
              parameter is encoded as the result. 
              Otherwise the encoded result is an object, and
              the parameters are passed by name (as
              fields in that object).
                
    
      
          
    
 
    
 
    
    - (NSData*) 
buildResponse: (NSString*)method
 parameters: (NSDictionary*)parameters
 order: (NSArray*)order;
    
      
            This method simply calls the
            
              -buildRequest:parameters:object:
            
            method encoding the supplied
            parameters as the result of the RPC.
          
    
    
 
    
    - (NSCalendarDate*) 
decodeDateTimeFrom: (NSString*)source;
    
      
            A helper method which decodes a timestamp from ISO8601
            format, YYYY-MM-DDTHH:MM:SS.mmmZ 
 This
            tolerates omission of the trailing Z (in which
            case it assumes the local timezone rather than GMT),
            the millisecond part, and (in the case that both
            milliseconds and 'Z' are omitted) also
            tolerates omission of the hyphens and colons
            (YYYYMMDDTHHMMSS). 
 Returns
            nil if the argument cannot be decoded.
          
    
    
 
    
    - (NSString*) 
encodeDateTimeFrom: (NSDate*)source;
    
      
            Take the supplied date and encode it as a string.
            
 There is no standard for JSON timestamps, but
            the recommended value (supported by javascript) is
            ISO8601... YYYY-MM-DDTHH:MM:SS.mmmZ 
 If the
            
              -setTimeZone:
            
            method is used, the format YYYYMMDDTHHMMSS will be
            used relative to the time zone value set (unless a
            
nil argument was supplied).
          
    
 
    
    - (void) 
setRPCID: (id)o;
    
      
            Sets the RPC ID... may be any string, number or
            NSNull, though you should not use NSNull or a
            non-integer number. 
 This value will be
            used as the JSON 'id' when the coder builds a request
            or response, but only if the request/response does not
            contain an GWSRPCIDKey (ie the value supplied in
            the parameters to the method call overrides any value
            set in the coder). 
 If no RPC version is set,
            this value is unused.
          
    
    
 
    
    - (void) 
setStrictParsing: (BOOL)isStrict;
    
      
            If set, parsing only permits strict JSON-RPC
            requests/responses.
          
    
    
 
    
    - (void) 
setTimeZone: (NSTimeZone*)timeZone;
    
      
            Sets a timeZone so that encoding of
            date/time values will be done relative to that
            timeZone as YYYMMDDTHHMMSS format rather
            than the standard YYYY-MM-DDTHH:MM:SS.mmZ format using
            GMT. 
 Setting a nil
            timeZone reverts to standard behavior.
          
    
    
 
    
    - (void) 
setVersion: (NSString*)v;
    
      
            Sets the json-rpc version. 
 May be "2.0" or
            "1.0" (any other non-nil value is currently
            considered to be version 1.0) or
            nil if JSON-RPC is not to be used.
            
 This value will be used as the JSON RPC
            version when the coder builds a request or
            response, but only if the request/response does
            not contain an GWSRPCVersionKey (ie the value supplied
            in the parameters to the method call overrides any value
            set in the coder).
          
    
    
 
    
    - (BOOL) 
strictParsing;
    
      
            Returns whether strict parsing as JSON-RPC has been
            configured.
          
    
    
 
    
    - (NSString*) 
version;
    
      
            Returns the json-rpc version (currently "2.0" or
            "1.0" or 
nil). 
 See
            
              -setVersion:
            
            for details.
          
    
 
    
    Instance Variables for GWSJSONCoder Class
    
    @protected id _jsonID;
    
      
            Default request/response ID 
 Warning
            the underscore at the start of the name of this
            instance variable indicates that, even though it
            is not technically private, it is intended for
            internal use within the package, and you should
            not use the variable in other code.
          
    
    
    
    @protected BOOL _jsonrpc;
    
      
            Set to force strict JSON-RPC parsing 
            Warning the underscore at the start of the
            name of this instance variable indicates that, even
            though it is not technically private, it is
            intended for internal use within the package, and
            you should not use the variable in other code.
          
    
    
    
    @protected NSString* _version;
    
      
            Not retained... default version 
 Warning
            the underscore at the start of the name of this
            instance variable indicates that, even though it
            is not technically private, it is intended for
            internal use within the package, and you should
            not use the variable in other code.
          
    
    
    
          
    
    
      
        - Declared in:
- GWSCoder.h
    
      
          
    
    
            The GWSSOAPCCoder class is a concrete subclass of
            GWSCoder
              which implements coding/decoding for the SOAP
              protocol.
                
    
      
            
    
    
              Dictionaries passed to/from the SOAP coder
              may contain special keys with the
              GWSSOAP prefix which control the
              coding rather than specifying values to be coded
              (this is in addition to the special
              
                GWSOrderKey
              
              used for ordering fields in a complex type). 
              See the section on constants for a description of
              what the keys below are used for:
                
    
      
            
      
      
        
     
    
    Instance Variables
    
    Method summary
    
    
    
    - (NSString*) 
encodeDateTimeFrom: (NSDate*)source;
    
      
            Take the supplied data and return it in the format
            used for an xsd:dateTime typed element. 
 This
            uses the timezone currently set in the receiver to
            determine the time of day encoded and to provide
            the timezone offset in the encoded string.
          
    
    
 
    
    - (NSString*) 
operationStyle;
    
    
 
    
    - (void) 
setOperationStyle: (NSString*)style;
    
    
 
    
    - (void) 
setUseLiteral: (BOOL)use;
    
      
            Sets the encoding usage in operation to be 'literal' (
            YES) or encoded (NO).
          
    
    
 
    
    - (BOOL) 
useLiteral;
    
      
            Returns whether the encoding usage in operation is
            'literal' (YES) or 'encoded' (
            NO).
          
    
    
 
    
    Instance Variables for GWSSOAPCoder Class
    
    @protected NSString* _style;
    
      
            Warning the underscore at the start of the
            name of this instance variable indicates that, even
            though it is not technically private, it is
            intended for internal use within the package, and
            you should not use the variable in other code.
          
    
    
    
    @protected BOOL _useLiteral;
    
      
            Warning the underscore at the start of the
            name of this instance variable indicates that, even
            though it is not technically private, it is
            intended for internal use within the package, and
            you should not use the variable in other code.
          
    
    
    
          
    
    
      
        - Declared in:
- GWSCoder.h
    
      
          
    
    
            The GWSXMLRPCCoder class is a concrete subclass of
            GWSCoder
              which implements coding/decoding for the XMLRPC
              protocol.
                
    
      
            
    
    
              The correspondence between XMLRPC values and
              Objective-C objects is as follows -
                
    
      
            
      
        - 
          
                i4 (or
                int) is an
                NSNumber
                  other than a real/float or boolean.
                
        
- 
          
                  boolean is an
                  NSNumber
                    created as a BOOL.
                  
        
- 
          
                    string is an
                    NSString
                      object.
                    
        
- 
          
                      double is an
                      NSNumber
                        created as a float or
                        double.
                      
        
- 
          
                        dateTime.iso8601 is
                        an
                        NSDate
                          object.
                        
        
- 
          
                          base64 is an
                          NSData
                            object.
                          
        
- 
          
                            array is an
                            NSArray
object.
        
- 
          struct is an NSDictionary
object.
        
                              If you attempt to use any other type
                              of object in the construction of an
                              XMLRPC document, the
                              [NSObject -description]
 method of that object will be used to create a string, and the resulting object will be encoded as an XMLRPC string element.
                                
    
      
                            
    
    
                              In particular, the names of members in
                              a struct must be strings, so
                              if you provide an
                              NSDictionary
object to represent a struct the keys of the dictionary will be converted to strings where necessary.    
    
      
        
    
 
    
    Instance Variables
    
    Method summary
    
    
    
    - (NSData*) 
buildFaultWithCode: (
GWSRPCFaultCode)code
 andText: (NSString*)text;
    
      
            Builds a simple fault response.
          
    
    
 
    
    - (NSString*) 
encodeDateTimeFrom: (NSDate*)source;
    
      
            Take the supplied date and encode it as an XMLRPC
            timestamp. 
 This uses the timezone
            currently set in the receiver to determine the
            time of day encoded. The format is YYYYMMDDTHH:MM:SS
          
    
    
 
    
    - (void) 
setStrictParsing: (BOOL)isStrict;
    
      
            Sets whether parsing requires strict use of plain XML
            elements, or permits attributes and namespaces to
            be attached to them (and ignored).
          
    
    
 
    
    - (BOOL) 
strictParsing;
    
      
            Returns whether parsing requires strict use of
            plain XML elements, or permits attributes and
            namespaces to be attached to them (and ignored).
          
    
    
 
    
    Instance Variables for GWSXMLRPCCoder Class
    
    @protected BOOL _strictParsing;
    
      
            Warning the underscore at the start of the
            name of this instance variable indicates that, even
            though it is not technically private, it is
            intended for internal use within the package, and
            you should not use the variable in other code.
          
    
    
    
          
    
    
      
        - Declared in:
- GWSCoder.h
    
      
          The methods in this category are used to handle web
          services RPC and messaging tasks. Most of these
          methods are implemented by subclasses and cannmot be
          used in the base class.
        
    
    Method summary
    
    
    
    - (NSData*) 
buildFaultWithParameters: (NSDictionary*)parameters
 order: (NSArray*)order;
    
      
            Constructs an XML document for an RPC fault
            response with the specified 
parameters.
            The resulting document is returned as an NSData object.
            
 For XMLRCP the 
parameters should
            be 'faultCode' (an integer), and 'faultString'. 
            For JSONRCP the 
parameters should be 'code'
            (an integer), 'message' (a string), and optionally,
            'data' (any type of item). 
 As a convenience,
            the 
parameters 'faultCode' is mapped to
            'code' and 'faultMessage' is mapped to 'message' in
            a JSON fault. 
 The 
order array is
            ignored, as is the GWSOrderKey value. 
 This
            method simply calls
            
              -setFault:
            
            to say that a fault is being built, then calls
            
              -buildRequest:parameters:order:
            
            with a 
nil request name, and calls
            
              -setFault:
            
            again before returning the result. If you override
            this method in a subclass, you should perform the same
            handling of the fault flag. 
 This method is
            intended for use by applications acting as RPC
            servers.
          
    
 
    
    - (NSData*) 
buildRequest: (NSString*)method
 parameters: (NSDictionary*)parameters
 order: (NSArray*)order;
Subclasses 
must override this method.
    
      
            Given a method name and a set of
            parameters, this method
            constructs the document for the corresponding
            message or RPC call and returns it as an NSData
            object. 
 The parameters dictionary
            may be empty or nil if there are no
            parameters to be passed. 
 The
            order array may be empty or
            nil if the order of the
            parameters is not important, otherwise it
            must contain the names of the parameters in
            the order in which they are to be encoded.
            
 If composite data types within the
            parameters dictionary contain fields which
            must be sent in a specific order, the
            dictionary containing those fields may contain a
            key 'GWSOrderKey' whose value is an array containing
            the names of those fields in the order of
            their encoding. 
 An array keyed on
            'GWSOrderKey' in top level
            parameters dictionary overrides the
            order argument. 
 A dictionary keyed
            on 'GWSParametersKey' in top level parameters
            dictionary overrides the parameters
            argument (ie the content of the lower level
            dictionary is treated as the container of the
            actual parameters). 
 The
            method returns nil if passed
            an invalid method name. 
 This
            method is used internally when sending an
            RPC method call to a remote system, but you
            can also call it yourself.
          
    
    
 
    
    - (NSData*) 
buildResponse: (NSString*)method
 parameters: (NSDictionary*)parameters
 order: (NSArray*)order;
Subclasses 
must override this method.
    
      
            Builds an RPC response with the specified set of
            parameters and returns the document as an
            NSData object. 
 The method name may
            be nil (and is indeed ignored for XMLRPC)
            where any parameters are not wrapped
            inside a method. 
 The
            parameters dictionary may be empty or
            nil if there are no
            parameters to be returned (an empty
            parameters element will be created).
            
 The order array may be empty or
            nil if the order of the
            parameters is not important, otherwise it
            must contain the names of the parameters in
            the order in which they are to be encoded.
            
 This method is intended for use by
            applications acting as RPC servers.
          
    
    
 
    
    - (id) 
delegate;
    
      
            Returns the RPC encoding delegate (if any) set by a
            previous call to the
            
              -setDelegate:
            
            method. 
 Normally the delegate of a coder is
            the GWSService instance which owns it... a service will
            automatically set itsself as the coder's
            delegate when the coder is set in the service, so
            if you need to have a different delegate, you should set
            it after adding the coder to the service.
          
    
 
    
    - (BOOL) 
fault;
    
      
            Returns a flag to say whether this coder is
            encoding/decoding a fault or not.
          
    
    
 
    
    - (NSMutableDictionary*) 
parseMessage: (NSData*)data;
Subclasses 
must override this method.
    
      
            Parses 
data containing an method call or
            message etc. 
 The result dictionary may
            contain
            
              GWSMethodKey
            
            ,
            
              GWSParametersKey
            
            , and
            
              GWSOrderKey
            
            on success, or
            
              GWSErrorKey
            
            on failure. 
 NB. Any containers (arrays or
            dictionaries) in the parsed parameters will
            be mutable, so you can modify this 
data
            structure as you like. 
 This method is
            intended for the use of server applications.
          
    
 
    
    - (void) 
setDelegate: (id)delegate;
    
      
            Sets a delegate to handle decoding and
            encoding of data items. 
 The
            delegate should implement the informal
            GWSCoder protocol to either handle the
            encoding/decoding or to inform the coder
            that it won't do it for a particular case.
          
    
    
 
    
    - (void) 
setFault: (BOOL)flag;
    
      
            Sets the fault flag to indicate that a
            fault is being encoded or decoded.
          
    
    
 
    
    - (void) 
setTimeZone: (NSTimeZone*)timeZone;
    
      
            Sets the time zone for use when sending/receiving
            date/time values. 
 The XMLRPC specification
            says that timezone is server dependent so you will
            need to set it according to the server you are
            connecting to. 
 If this is not set, UCT is
            assumed.
          
    
    
 
    
    - (NSTimeZone*) 
timeZone;
    
      
            Return the time zone currently set.
          
    
    
 
          
    NSArray(JSON)
    
      
        - Declared in:
- GWSCoder.h
    
      
          Description forthcoming.
        
    
    Method summary
    
    
    
    - (NSData*) 
JSONText;
    
      
            Return the receiver encoded as a JSON text in UTF-8
            encoding.
          
    
    
 
          
    
    
      
        - Declared in:
- GWSCoder.h
    
      
          Description forthcoming.
        
    
    Method summary
    
    
    
    - (id) 
JSONPropertyList;
    
      
            Parse the receiver as a JSON property list and return
            the result.
          
    
    
 
          
    NSDictionary(JSON)
    
      
        - Declared in:
- GWSCoder.h
    
      
          Description forthcoming.
        
    
    Method summary
    
    
    
    - (NSData*) 
JSONText;
    
      
            Return the receiver encoded as a JSON text in UTF-8
            encoding.
          
    
    
 
          
    
    
      
        - Declared in:
- GWSCoder.h
    
      
          This informal protocol specifies the methods that a
          coder delegate may implement in order to override
          general encoding/decoding of service arguments.
          
 Generally the delegate is a
          
GWSService
            instance.
        
    
    
    - (id) 
decodeWithCoder: (
GWSCoder*)coder
 item: (
GWSElement*)item
 named: (NSString*)name;
    
      
            This method is called to ask the delegate to decode
            the specified element and return the result. If the
            delegate does not wish to decode the element, it
            should simply return nil. 
 The
            name and ctxt arguments provide context
            for decoding, allowing the delegate to better
            understand how the element should be decoded...
            the ctxt is the parent element of the item
            being decoded, and the name is the
            identifier that will be used for the
            item. 
 The default implementation
            returns nil.
          
    
    
 
    
    - (BOOL) 
encodeWithCoder: (
GWSCoder*)coder
 item: (id)item
 named: (NSString*)name
 in: (
GWSElement*)ctxt;
    
      
            This method is called to ask the delegate to encode
            the specified item with the given
            name into the parent context. 
 The
            delegate must return NO if it does
            not wish to encode the item itsself,
            otherwise it must return YES after
            adding the new element as a child of ctxt
            . 
 The name is the key used to identify
            the item in in its current context (normally
            the name of the element it will be encoded
            to). 
 The default implementation returns
            NO.
          
    
    
 
    
    - (NSString*) 
webServiceOperation;
    
      
            Returns the name of the operation that the receiver
            is being used to implement.
          
    
    
 
    
    - (
GWSPort*) 
webServicePort;
    
      
            Returns the port object defining the binding and
            address of the operation being performed.
          
    
    
 
          
    
    
      
        - Declared in:
- GWSCoder.h
    
      
          This informal protocol specifies the methods that a
          coder delegate may implement in order to modify or
          overriding encoding/decoding of SOAP specific
          message components.
        
    
    Method summary
    
    
    
    - (
GWSElement*) 
coder: (
GWSSOAPCoder*)coder
 didEncode: (
GWSElement*)element;
    
      
            This method is used to inform the delegate of the
            encoded XML request (a
            
GWSElement
              instance) which will be serialised to an
              NSData. 
 The delegate may modify or replace
              this and must return the replacement value or the
              modified 
element tree.
          
    
 
    
    - (
GWSElement*) 
coder: (
GWSSOAPCoder*)coder
 willDecode: (
GWSElement*)element;
    
      
            This method is used to inform the delegate of the
            GWSElement instance being decoded as the SOAP
            Envelope, Header, Body, Fault or Method. 
            The instance to be decoded will contain the children
            from the document being decoded. 
 The delegate
            implementation should return the proposed
            instance (possibly modified) or a different object
            that it wishes the coder to use. 
 The
            default implementation returns element.
          
    
    
 
    
    - (
GWSElement*) 
coder: (
GWSSOAPCoder*)coder
 willEncode: (
GWSElement*)element;
    
      
            This method is used to inform the delegate of the
            proposed
            
GWSElement
              instance used to encode SOAP Envelope, Header,
              Body, Fault or Method elements. 
 The proposed
              instance will not have any children at the point
              where this method is called (they are added later
              in the encoding process. 
 This method may be
              called with a 
nil value for the
              
element parameter in the case where no
              Header 
element would be encoded... in
              this situation the delegate may return a Header
              
element to be used, or may return some
              other 
element, which will be
              automatically inserted into a standard
              header. 
 The delegate implementation should
              return the proposed instance (possibly modified)
              or a different object that it wishes the
              
coder to encode instead. 
 The
              default implementation returns 
element
              . 
 NB. A Fault or Method will obviously only be
              provided where the message contain such an
              
element, and the Header will only be
              provided where the message has been told to
              contain headers by use of the
              
                GWSSOAPMessageHeadersKey
              
              in the parameters dictionary.
          
    
 
          
    NSString(JSON)
    
      
        - Declared in:
- GWSCoder.h
    
      
          Description forthcoming.
        
    
    Method summary
    
    
    
    - (id) 
JSONPropertyList;
    
      
            Parse the receiver as a JSON property list and return
            the result.
          
    
    
 
          
    
    
    
    typedef enum ... GWSRPCFaultCode;
    
      
          This type defines standard JSONRPC and XMLRPC fault
          codes. 
 Use it with the utility methods for
          creating fault respnses. 
 If you wish to use
          your own error codes (because none of the standard ones
          is suitable), you can use almost any other integer value,
          but the range -32099 to -32000 inclusive is reserved for
          implementation defined server errors (so don't
          use this range).
          
      
        - GWSRPCParseError
- 
        
- GWSRPCUnsupportedEncoding
- 
        
- GWSRPCInvalidCharacter
- 
        
- GWSRPCFormatError
- 
        
- GWSRPCUnknownMethod
- 
        
- GWSRPCInvalidParameter
- 
        
- GWSRPCServerError
- 
        
- GWSRPCApplicationError
- 
        
- GWSRPCSystemError
- 
        
- GWSRPCTransportError
-