/* * Copyright (c) 2002,2000 Apple Computer, Inc. All rights reserved. * * @APPLE_LICENSE_HEADER_START@ * * The contents of this file constitute Original Code as defined in and * are subject to the Apple Public Source License Version 1.1 (the * "License"). You may not use this file except in compliance with the * License. Please obtain a copy of the License at * http://www.apple.com/publicsource and read it before using this file. * * This Original Code and all software distributed under the License are * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the * License for the specific language governing rights and limitations * under the License. * * @APPLE_LICENSE_HEADER_END@ */ /* * ocspdNetwork.h - Network support for ocspd */ #ifndef _OCSPD_NETWORK_H_ #define _OCSPD_NETWORK_H_ #include #include #include #ifdef __cplusplus extern "C" { #endif /* * RFC 2560 says we should be able to perform OCSP transaction with an HTTP GET, * but the real world - e.g., Verisign - doesn't work that way. All transactions * are done with POSTs. */ #define ENABLE_OCSP_VIA_GET 0 #if ENABLE_OCSP_VIA_GET /* fetch via HTTP GET */ CSSM_RETURN ocspdHttpGet( SecAsn1CoderRef coder, const CSSM_DATA &url, const CSSM_DATA &ocspReq, // DER encoded CSSM_DATA &fetched); // mallocd in coder space and RETURNED #endif /* ENABLE_OCSP_VIA_GET */ /* fetch via HTTP POST */ CSSM_RETURN ocspdHttpPost( SecAsn1CoderRef coder, const CSSM_DATA &url, const CSSM_DATA &ocspReq, // DER encoded CSSM_DATA &fetched); // mallocd in coder space and RETURNED /* Fetch cert or CRL from net, we figure out the schema */ typedef enum { LT_Crl = 1, LT_Cert } LF_Type; CSSM_RETURN ocspdNetFetch( Allocator &alloc, const CSSM_DATA &url, LF_Type lfType, CSSM_DATA &fetched); // mallocd in coder space and RETURNED #ifdef __cplusplus } #endif #endif /* _OCSPD_NETWORK_H_ */