Source code

Revision control

Copy as Markdown

Other Tools

/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
/*
* pkix_pl_ldapcertstore.h
*
* LDAPCertstore Object Type Definition
*
*/
#ifndef _PKIX_PL_LDAPCERTSTORE_H
#define _PKIX_PL_LDAPCERTSTORE_H
#include "pkix_pl_ldapt.h"
#include "pkix_pl_common.h"
#ifdef __cplusplus
extern "C" {
#endif
/*
* At the time of this version, there are unresolved questions about the LDAP
* protocol. Although RFC1777 describes a BIND and UNBIND message, it is not
* clear whether they are appropriate to this application. We have tested only
* using servers that do not expect authentication, and that reject BIND
* messages. It is not clear what values might be appropriate for the bindname
* and authentication fields, which are currently implemented as char strings
* supplied by the caller. (If this changes, the API and possibly the templates
* will have to change.) Therefore the CertStore_Create API contains a BindAPI
* structure, a union, which will have to be revised and extended when this
* area of the protocol is better understood.
*
* It is further assumed that a given LdapCertStore will connect only to a
* single server, and that the creation of the socket will initiate the
* CONNECT. Therefore the LdapCertStore handles only the case of continuing
* the connection, if nonblocking I/O is being used.
*/
typedef enum {
LDAP_CONNECT_PENDING,
LDAP_CONNECTED,
LDAP_BIND_PENDING,
LDAP_BIND_RESPONSE,
LDAP_BIND_RESPONSE_PENDING,
LDAP_BOUND,
LDAP_SEND_PENDING,
LDAP_RECV,
LDAP_RECV_PENDING,
LDAP_RECV_INITIAL,
LDAP_RECV_NONINITIAL,
LDAP_ABANDON_PENDING
} LDAPConnectStatus;
#define LDAP_CACHEBUCKETS 128
#define RCVBUFSIZE 512
struct PKIX_PL_LdapCertStoreContext {
PKIX_PL_LdapClient *client;
};
/* see source file for function documentation */
PKIX_Error *pkix_pl_LdapCertStoreContext_RegisterSelf(void *plContext);
PKIX_Error *
pkix_pl_LdapCertStore_BuildCertList(
PKIX_List *responseList,
PKIX_List **pCerts,
void *plContext);
#ifdef __cplusplus
}
#endif
#endif /* _PKIX_PL_LDAPCERTSTORE_H */