go to  ForumEasy.com   
LdapPro
Home » Archive » Message


[Email To Friend][View in Live Context][prev topic « prev post | next post » next topic]
  Response Control
 
Subject: Response Control
Author: SteveHB
In response to: Request Control
Posted on: 03/04/2009 08:02:28 PM


If the request control is serviced, this response control is included in the SearchResultDone message as part of the controls field of the LDAPMessage.

The controlType is set to "2.16.840.1.113730.3.4.10". The controlValue, an OCTET STRING, is the BER-encoding of the following SEQUENCE:

    
   VirtualListViewResponse ::= SEQUENCE { 
          targetPosition    INTEGER (0 .. maxInt), 
          contentCount     INTEGER (0 .. maxInt), 
          virtualListViewResult ENUMERATED { 
               success (0), 
               operationsError (1), 
               protocolError (3), 
               unwillingToPerform (53), 
               insufficientAccessRights (50), 
               timeLimitExceeded (3), 
               adminLimitExceeded (11), 
               innapropriateMatching (18), 
               sortControlMissing (60), 
               offsetRangeError (61), 
               other(80), 
               ... }, 
          contextID     OCTET STRING OPTIONAL } 


  • targetPosition gives the list offset for the target entry.


  • contentCount gives the server's estimate of the current number of
    entries in the list. Together these give sufficient information for
    the client to update a list box slider position to match the newly
    retrieved entries and identify the target entry. The contentCount
    value returned SHOULD be used in a subsequent VirtualListViewRequest
    control.


  • contextID is a server-defined octet string. If present, the contents
    of the contextID field SHOULD be returned to the server by a client
    in a subsequent virtual list request. The presence of a contextID
    here indicates that the server is willing to return contiguous data
    from a subsequent search request which uses the same search criteria,
    accompanied by a VirtualListViewRequest which indicates that the
    client wishes to receive an adjoining page of data.


  • The virtualListViewResult codes which are common to the LDAP
    searchResultDone (adminLimitExceeded, timeLimitExceeded,
    operationsError, unwillingToPerform, insufficientAccessRights,
    success, other) have the same meanings as defined in [LDAPPROT], but
    they pertain specifically to the VLV operation. For example, the
    server could exceed a VLV-specific administrative limit while
    processing a SearchRequest with a VirtualListViewRequest control.
    Obviously, the same administrative limit would not be exceeded should
    the same SearchRequest be submitted by the client without the
    VirtualListViewRequest control. In this case, the client can
    determine that the administrative limit has been exceeded in
    servicing the VLV request, and can if it chooses resubmit the
    SearchRequest without the VirtualListViewRequest control, or with
    different parameters.


  • insufficientAccessRights means that the server denied the client
    permission to perform the VLV operation.


  • If the server determines that the results of the search presented
    exceed the range specified in INTEGER values, or if the client
    specifies an invalid offset or contentCount, the server MUST set the
    virtualListViewResult value to offsetRangeError.



     

    > On 03/04/2009 07:57:49 PM SteveHB wrote:

    This control is included in the SearchRequest message as part of the controls field of the LDAPMessage. The controlType is set to "2.16.840.1.113730.3.4.9". If this control is included in a SearchRequest message, a Server Side Sorting request control [SSS] MUST also be present in the message.

    The controlValue, an OCTET STRING, is the BER-encoding of the following SEQUENCE:
        
       VirtualListViewRequest ::= SEQUENCE { 
              beforeCount    INTEGER (0..maxInt), 
              afterCount     INTEGER (0..maxInt), 
              target         CHOICE { 
                               byOffset        [0] SEQUENCE {                           
                                   offset       INTEGER (1 .. maxInt), 
                                   contentCount INTEGER (0 .. maxInt) 
                               }, 
                               greaterThanOrEqual [1] AssertionValue 
                            }, 
              contextID     OCTET STRING OPTIONAL } 
    

  • beforeCount indicates how many entries before the target entry the client wants the server to send.


  • afterCount indicates the number of entries after the target entry the client wants the server to send.


  • offset and contentCount identify the target entry.


  • greaterThanOrEqual is a matching rule assertion value defined in [LDAPPROT]. The assertion value is encoded according to the ORDERING matching rule for the attributeDescription in the sort control [SSS]. If present, the value supplied in greaterThanOrEqual is used to determine the target entry by comparison with the values of the attribute specified as the primary sort key. The first list entry who's value is no less than (less than or equal to when the sort order is reversed) the supplied value is the target entry.


  • contextID contains the value of the most recently received contextID field from a VirtualListViewResponse control for the same list view. If the contextID is not known because no contextID has been sent by the server in a VirtualListViewResponse control, it SHALL be omitted. If the server receives a contextID that is invalid, it SHALL fail the search operation and indicate the failure with a protocolError (3) value in the virtualListViewResult field of the VirtualListViewResponse. The contextID provides state information between the client and server. This state information is used by the server to ensure continuity contiguous virtual list requests. When a server receives a VirtualListViewRequest control that includes a contextID, it SHALL determine whether the client has sent a contiguous virtual list request and SHALL provide contiguous entries if possible. If a valid contextID is sent, and the server is unable to determine whether contiguous data is requested, or is unable to provide requested contiguous data, it SHALL fail the search operation and indicate the failure with an unwillingToPerform (53) value in the virtualListViewResult field of the VirtualListViewResponse. contextID values have no validity outside the connection and query with which they were received. A client MUST NOT submit a contextID which it received from a different connection, a different query, or a different server.






    References:

  •  


     
    Powered by ForumEasy © 2002-2022, All Rights Reserved. | Privacy Policy | Terms of Use
     
    Get your own forum today. It's easy and free.