| /* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ |
| /* |
| * This file is PRIVATE to SSL. |
| * |
| * 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/. */ |
| |
| #ifndef __ssl3exthandle_h_ |
| #define __ssl3exthandle_h_ |
| |
| #include "sslencode.h" |
| |
| SECStatus ssl3_SendRenegotiationInfoXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| SECStatus ssl3_HandleRenegotiationInfoXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl3_ClientHandleNextProtoNegoXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl3_ClientHandleAppProtoXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl3_ServerHandleNextProtoNegoXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl3_ServerHandleAppProtoXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl3_ClientSendNextProtoNegoXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| SECStatus ssl3_ClientSendAppProtoXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| SECStatus ssl3_ServerSendAppProtoXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| SECStatus ssl3_ClientSendUseSRTPXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| SECStatus ssl3_ServerSendUseSRTPXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| SECStatus ssl3_ClientHandleUseSRTPXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl3_ServerHandleUseSRTPXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl3_ServerSendStatusRequestXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| SECStatus ssl3_ServerHandleStatusRequestXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl3_ClientHandleStatusRequestXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl3_ClientSendStatusRequestXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| SECStatus ssl3_SendSigAlgsXtn(const sslSocket *ss, TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| SECStatus ssl3_HandleSigAlgsXtn(const sslSocket *ss, TLSExtensionData *xtnData, |
| SECItem *data); |
| |
| SECStatus ssl3_ClientSendPaddingExtension(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| |
| SECStatus ssl3_ClientSendSignedCertTimestampXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| SECStatus ssl3_ClientHandleSignedCertTimestampXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl3_ServerSendSignedCertTimestampXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| SECStatus ssl3_ServerHandleSignedCertTimestampXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl3_SendExtendedMasterSecretXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| SECStatus ssl3_HandleExtendedMasterSecretXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl3_ProcessSessionTicketCommon(sslSocket *ss, const SECItem *ticket, |
| /* out */ SECItem *appToken); |
| PRBool ssl_ShouldSendSNIExtension(const sslSocket *ss, const char *url); |
| SECStatus ssl3_ClientFormatServerNameXtn(const sslSocket *ss, const char *url, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf); |
| SECStatus ssl3_ClientSendServerNameXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| SECStatus ssl3_HandleServerNameXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl_HandleSupportedGroupsXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl3_HandleSupportedPointFormatsXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl3_ClientHandleSessionTicketXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl3_ServerHandleSessionTicketXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl3_ClientSendSessionTicketXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| |
| SECStatus ssl_SendSupportedGroupsXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| SECStatus ssl3_SendSupportedPointFormatsXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| SECStatus ssl_HandleRecordSizeLimitXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| SECItem *data); |
| SECStatus ssl_SendRecordSizeLimitXtn(const sslSocket *ss, |
| TLSExtensionData *xtnData, |
| sslBuffer *buf, PRBool *added); |
| |
| #endif |