module type HTTP_CLIENT_MECHANISM =sig..end
val mechanism_name : string
val available : unit -> boolval restart_supported : booltype 
val init_credentials : (string * string * (string * string) list) list ->
       credentials(type,value,params). The mechanism may pick any element
          of this list which are considered as equivalent.
Types are defined per mechanism. All mechanisms understand the "password" type, which is just the cleartext password, e.g.
            [ "password", "ThE sEcReT", [] ]
          The password is encoded in UTF-8. However, note that not all protocols are able to transmit all of UTF-8. If a non-transmittable character is found, the authentication will fail.
The password can have parameters:
val client_match : params:(string * string * bool) list ->
       Nethttp.Header.auth_challenge -> Nethttp.match_resultparams are as for create_client_session.
          On success, returns `Accept(realm,id_opt). On failure, returns 
          `Reject.
          This function usually does not raise exceptions.
If the mechanism does not support the notion of realms, a dummy realm should be returned.
          The id_opt is the session ID (if supported). Session IDs can be
          used to bind reauthentications to the original session.
          The challenge is from a www-authenticate or a 
          proxy-authenticate header.
          There is also the result `Reroute(realm, trans_id), meaning that the
          request would be acceptable if it came over the transport identified
          by trans_id. `Accept_reroute is the combination of accepting
          and rerouting, i.e. the auth protocol can start, but the second
          request should go over the other transport. Both `Reroute and
          `Accept_reroute are only allowed for initial challenges.
type 
val client_state : client_session ->
       Netsys_sasl_types.client_state
val create_client_session : user:string ->
       creds:credentials ->
       params:(string * string * bool) list ->
       unit -> client_sessionuser. The credentials are
          creds.
          user must be encoded in UTF-8.
          The parameters are given as list (name,value,critical). 
          Critical parameters must be interpreted by the mechanism, and
          unknown critical parameters must be rejected by a Failure
          exception. Non-critical parameters are ignored if they are unknown
          to the mechanism.
Available parameters:
client_match returns a session ID)Nethttp_client.transport_layer_id of the
             current HTTP requestval client_configure_channel_binding : client_session ->
       Netsys_sasl_types.cb -> client_sessionval client_restart : params:(string * string * bool) list ->
       client_session ->
       client_session`OK. After the restart the session will be in
          state `Emit.
          The params are the same as for create_client_session, but updated
          where needed.
val client_process_challenge : client_session ->
       string ->
       string ->
       #Nethttp.http_header_ro ->
       Nethttp.Header.auth_challenge -> client_sessionclient_process_challenge cs method uri header challenge:
          Process the challenge from the server. The state must be `Wait.
          As an exception, this function can also be called for the initial
          challenge from the server, even if the state is `Emit.
          method is the request method. uri is the request URI
val client_emit_response : client_session ->
       string ->
       string ->
       #Nethttp.http_header_ro ->
       client_session *
       Nethttp.Header.auth_credentials * (string * string) listlet (creds,new_headers) = client_emit_response cs method uri header:
          Emit a new response as a pair (creds,new_headers). 
          The state must be `Emit. The creds either go into
          the authorization or proxy-authorization header.
          The new_headers are additional headers to modify.
val client_channel_binding : client_session -> Netsys_sasl_types.cbval client_user_name : client_session -> stringval client_stash_session : client_session -> stringval client_resume_session : string -> client_sessionval client_session_id : client_session -> string optionval client_domain : client_session -> string listval client_prop : client_session -> string -> stringval client_gssapi_props : client_session -> Netsys_gssapi.client_propsNot_found