1
0
mirror of https://github.com/Ylianst/MeshAgent synced 2025-12-06 00:13:33 +00:00
Files
MeshAgent/microstack/ILibWebServer.h

272 lines
13 KiB
C

/*
Copyright 2006 - 2018 Intel Corporation
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
/*! \file ILibWebServer.h
\brief MicroStack APIs for HTTP Server functionality
*/
#ifndef __ILibWebServer__
#define __ILibWebServer__
#include "ILibParsers.h"
#include "ILibAsyncServerSocket.h"
#include "ILibCrypto.h"
#ifdef __cplusplus
extern "C" {
#endif
#define ILibTransports_WebServer 0x10
#define ILibTransports_WebSocket 0x20
extern const int ILibMemory_WEBSERVERSESSION_CONTAINERSIZE;
typedef enum
{
ILibWebServer_WebSocket_DataType_UNKNOWN = 0x0,
ILibWebServer_WebSocket_DataType_REQUEST = 0xFF,
ILibWebServer_WebSocket_DataType_BINARY = 0x2,
ILibWebServer_WebSocket_DataType_TEXT = 0x1
}ILibWebServer_WebSocket_DataTypes;
typedef enum
{
ILibWebServer_DoneFlag_NotDone = 0,
ILibWebServer_DoneFlag_Done = 1,
ILibWebServer_DoneFlag_Partial = 10,
ILibWebServer_DoneFlag_LastPartial = 11
}ILibWebServer_DoneFlag;
typedef enum
{
ILibWebServer_WebSocket_FragmentFlag_Incomplete = 0,
ILibWebServer_WebSocket_FragmentFlag_Complete = 1
}ILibWebServer_WebSocket_FragmentFlags;
/*! \defgroup ILibWebServer ILibWebServer Module
\{
*/
typedef enum ILibWebServer_Status
{
ILibWebServer_ALL_DATA_SENT = 1, /*!< All of the data has already been sent */
ILibWebServer_NOT_ALL_DATA_SENT_YET = 0, /*!< Not all of the data could be sent, but is queued to be sent as soon as possible */
ILibWebServer_SEND_RESULTED_IN_DISCONNECT = -2, /*!< A send operation resulted in the socket being closed */
ILibWebServer_INVALID_SESSION = -3, /*!< The specified ILibWebServer_Session was invalid */
ILibWebServer_TRIED_TO_SEND_ON_CLOSED_SOCKET = -4, /*!< A send operation was attmepted on a closed socket */
}ILibWebServer_Status;
/*! \typedef ILibWebServer_ServerToken
\brief The handle for an ILibWebServer module
*/
typedef void* ILibWebServer_ServerToken;
struct ILibWebServer_Session;
/*! \typedef ILibWebServer_Session_OnReceive
\brief OnReceive Handler
\param sender The associate \a ILibWebServer_Session object
\param InterruptFlag boolean indicating if the underlying chain/thread is disposing
\param header The HTTP headers that were received
\param bodyBuffer Pointer to the HTTP body
\param[in,out] beginPointer Starting offset of the body buffer. Advance this pointer when the data is consumed.
\param endPointer Length of available data pointed to by \a bodyBuffer
\param done boolean indicating if the entire packet has been received
*/
typedef void (*ILibWebServer_Session_OnReceive)(struct ILibWebServer_Session *sender, int InterruptFlag, struct packetheader *header, char *bodyBuffer, int *beginPointer, int endPointer, ILibWebServer_DoneFlag done);
/*! \typedef ILibWebServer_Session_OnDisconnect
\brief Handler for when an ILibWebServer_Session object is disconnected
\param sender The \a ILibWebServer_Session object that was disconnected
*/
typedef void (*ILibWebServer_Session_OnDisconnect)(struct ILibWebServer_Session *sender);
/*! \typedef ILibWebServer_Session_OnSendOK
\brief Handler for when pending send operations have completed
\par
<B>Note:</B> This handler will only be called after all pending data from any call(s) to
\a ILibWebServer_Send, \a ILibWebServer_Send_Raw, \a ILibWebServer_StreamBody,
\a ILibWebServer_StreamHeader, and/or \a ILibWebServer_StreamHeader_Raw, have completed. You will need to look at the return values
of those methods, to determine if there is any pending data that still needs to be sent. That will determine if this handler will get called.
\param sender The \a ILibWebServer_Session that has completed sending all of the pending data
*/
typedef void (*ILibWebServer_Session_OnSendOK)(struct ILibWebServer_Session *sender);
/*! \struct ILibWebServer_Session
\brief A structure representing the state of an HTTP Session
*/
typedef struct ILibWebServer_Session
{
ILibTransport Reserved_Transport;
//
// DO NOT MODIFY STRUCTURE DEFINITION ABOVE THIS COMMENT LINE (ILibTransport)
//
/*! \var OnReceive
\brief A Function Pointer that is triggered whenever data is received
*/
ILibWebServer_Session_OnReceive OnReceive;
/*! \var OnDisconnect
\brief A Function Pointer that is triggered when the session is disconnected
*/
ILibWebServer_Session_OnDisconnect OnDisconnect;
/*! \var OnSendOK
\brief A Function Pointer that is triggered when the send buffer is emptied
*/
ILibWebServer_Session_OnSendOK OnSendOK;
void *Parent;
/*! \var User
\brief A reserved pointer that you can use for your own use
*/
void *User;
/*! \var User2
\brief A reserved pointer that you can use for your own use
*/
void *User2;
/*! \var User3
\brief A reserved pointer that you can use for your own use
*/
void *User3;
/*! \var User4
\brief A reserved pointer that you can use for your own use
*/
unsigned int User4;
unsigned int User5;
char* CertificateHashPtr; // Points to the certificate hash (next field) if set
char CertificateHash[32]; // Used by the Mesh to store NodeID of this session
char *buffer;
int bufferLength;
int done;
int SessionInterrupted;
void *ParentExtraMemory;
}ILibWebServer_Session;
void ILibWebServer_AddRef(struct ILibWebServer_Session *session);
void ILibWebServer_Release(struct ILibWebServer_Session *session);
/*! \typedef ILibWebServer_Session_OnSession
\brief New Session Handler
\param SessionToken The new Session
\param User The \a User object specified in \a ILibWebServer_Create
*/
typedef void (*ILibWebServer_Session_OnSession)(struct ILibWebServer_Session *SessionToken, void *User);
/*! \typedef ILibWebServer_VirtualDirectory
\brief Request Handler for a registered Virtual Directory
\param session The session that received the request
\param header The HTTP headers
\param bodyBuffer Pointer to the HTTP body
\param[in,out] beginPointer Starting index of \a bodyBuffer. Advance this pointer as data is consumed
\param endPointer Length of available data in \a bodyBuffer
\param done boolean indicating that the entire packet has been read
\param user The \a user specified in \a ILibWebServer_Create
*/
typedef void (*ILibWebServer_VirtualDirectory)(struct ILibWebServer_Session *session, struct packetheader *header, char *bodyBuffer, int *beginPointer, int endPointer, int done, void *user);
#ifndef MICROSTACK_NOTLS
typedef int(*ILibWebServer_OnHttpsConnection)(ILibWebServer_ServerToken sender, int preverify_ok, STACK_OF(X509) *certs, struct sockaddr_in6* addr);
int ILibWebServer_EnableHTTPS(ILibWebServer_ServerToken object, struct util_cert* leafCert, X509* nonLeafCert, int requestClientCert, ILibWebServer_OnHttpsConnection onHTTPS);
X509 *ILibWebServer_Session_SslGetCert(ILibWebServer_Session* session);
STACK_OF(X509) *ILibWebServer_Session_SslGetCerts(ILibWebServer_Session* session);
#ifdef MICROSTACK_TLS_DETECT
void ILibWebServer_SetTLS(ILibWebServer_ServerToken object, void *ssl_ctx, int enableTLSDetect);
#define ILibWebServer_IsUsingTLS(session) ILibAsyncSocket_IsUsingTls(ILibWebServer_Session_GetConnectionToken(session))
#else
void ILibWebServer_SetTLS(ILibWebServer_ServerToken object, void *ssl_ctx);
#endif
#endif
void ILibWebServer_SetTag(ILibWebServer_ServerToken WebServerToken, void *Tag);
void *ILibWebServer_GetTag(ILibWebServer_ServerToken WebServerToken);
void *ILibWebServer_Session_GetConnectionToken(ILibWebServer_Session *session);
ILibWebServer_ServerToken ILibWebServer_CreateEx(void *Chain, int MaxConnections, unsigned short PortNumber, int loopbackFlag, ILibWebServer_Session_OnSession OnSession, void *User);
ILibExportMethod ILibWebServer_ServerToken ILibWebServer_CreateEx2(void *Chain, int MaxConnections, unsigned short PortNumber, int loopbackFlag, ILibWebServer_Session_OnSession OnSession, int ExtraMemorySize, void *User);
#define ILibWebServer_Create(Chain, MaxConnections, PortNumber, OnSession, User) ILibWebServer_CreateEx(Chain, MaxConnections, PortNumber, INADDR_ANY, OnSession, User)
#define ILibWebServer_Create2(Chain, MaxConnections, PortNumber, OnSession, ExtraMemorySize, User) ILibWebServer_CreateEx2(Chain, MaxConnections, PortNumber, INADDR_ANY, OnSession, ExtraMemorySize, User)
ILibAsyncServerSocket_ServerModule ILibWebServer_GetServerSocketModule(ILibWebServer_ServerToken server);
void ILibWebServer_StopListener(ILibWebServer_ServerToken server);
void ILibWebServer_RestartListener(ILibWebServer_ServerToken server);
int ILibWebServer_RegisterVirtualDirectory(ILibWebServer_ServerToken WebServerToken, char *vd, int vdLength, ILibWebServer_VirtualDirectory OnVirtualDirectory, void *user);
int ILibWebServer_UnRegisterVirtualDirectory(ILibWebServer_ServerToken WebServerToken, char *vd, int vdLength);
// Checks if the Web Request is uses digest authentication. Returns non zero if the request is using digest authentication
ILibExportMethod int ILibWebServer_Digest_IsAuthenticated(struct ILibWebServer_Session *session, char* realm, int realmLen);
// Gets the username that the client used to authenticate
ILibExportMethod char* ILibWebServer_Digest_GetUsername(struct ILibWebServer_Session *session);
// Validates the client's digest authentication response. Returns 0 on failure, 1 on success
ILibExportMethod int ILibWebServer_Digest_ValidatePassword(struct ILibWebServer_Session *session, char* password, int passwordLen);
// Send un-autorized response
ILibExportMethod void ILibWebServer_Digest_SendUnauthorized(struct ILibWebServer_Session *session, char* realm, int realmLen, char* html, int htmllen);
// Returns NULL if the request was not CrossSite, otherwise returns the contents of the Origin header
ILibExportMethod char* ILibWebServer_IsCrossSiteRequest(ILibWebServer_Session* session);
ILibExportMethod int ILibWebServer_UpgradeWebSocket(struct ILibWebServer_Session *session, int autoFragmentReassemblyMaxBufferSize);
ILibExportMethod enum ILibWebServer_Status ILibWebServer_WebSocket_Send(struct ILibWebServer_Session *session, char* buffer, int bufferLen, ILibWebServer_WebSocket_DataTypes bufferType, enum ILibAsyncSocket_MemoryOwnership userFree, ILibWebServer_WebSocket_FragmentFlags fragmentStatus);
ILibExportMethod void ILibWebServer_WebSocket_Close(struct ILibWebServer_Session *session);
/* Gets the WebSocket DataFrame type from the ILibWebServer_Session object 'x' */
ILibExportMethod ILibWebServer_WebSocket_DataTypes ILibWebServer_WebSocket_GetDataType(ILibWebServer_Session *session);
ILibExportMethod enum ILibWebServer_Status ILibWebServer_Send(struct ILibWebServer_Session *session, struct packetheader *packet);
ILibExportMethod enum ILibWebServer_Status ILibWebServer_Send_Raw(struct ILibWebServer_Session *session, char *buffer, size_t bufferSize, enum ILibAsyncSocket_MemoryOwnership userFree, ILibWebServer_DoneFlag done);
/*! \def ILibWebServer_Session_GetPendingBytesToSend
\brief Returns the number of outstanding bytes to be sent
\param session The ILibWebServer_Session object to query
*/
unsigned int ILibWebServer_Session_GetPendingBytesToSend(struct ILibWebServer_Session *session);
/*! \def ILibWebServer_Session_GetTotalBytesSent
\brief Returns the total number of bytes sent
\param session The ILibWebServer_Session object to query
*/
#define ILibWebServer_Session_GetTotalBytesSent(session) ILibAsyncServerSocket_GetTotalBytesSent(session->Reserved1,session->Reserved2)
/*! \def ILibWebServer_Session_ResetTotalBytesSent
\brief Resets the total bytes set counter
\param session The ILibWebServer_Session object to query
*/
#define ILibWebServer_Session_ResetTotalBytesSent(session) ILibAsyncServerSocket_ResetTotalBytesSent(session->Reserved1,session->Reserved2)
unsigned short ILibWebServer_GetPortNumber(ILibWebServer_ServerToken WebServerToken);
int ILibWebServer_GetLocalInterface(struct ILibWebServer_Session *session, struct sockaddr *localAddress);
int ILibWebServer_GetRemoteInterface(struct ILibWebServer_Session *session, struct sockaddr *remoteAddress);
enum ILibWebServer_Status ILibWebServer_StreamHeader(struct ILibWebServer_Session *session, struct packetheader *header);
enum ILibWebServer_Status ILibWebServer_StreamBody(struct ILibWebServer_Session *session, char *buffer, int bufferSize, enum ILibAsyncSocket_MemoryOwnership userFree, ILibWebServer_DoneFlag done);
// ResponseHeaders must start with \r\n. Do not trail with \r\n
enum ILibWebServer_Status ILibWebServer_StreamHeader_Raw(struct ILibWebServer_Session *session, int StatusCode, char *StatusData, char *ResponseHeaders, enum ILibAsyncSocket_MemoryOwnership ResponseHeaders_FREE);
void ILibWebServer_DisconnectSession(struct ILibWebServer_Session *session);
ILibExportMethod void ILibWebServer_Pause(struct ILibWebServer_Session *session);
ILibExportMethod void ILibWebServer_Resume(struct ILibWebServer_Session *session);
void ILibWebServer_OverrideReceiveHandler(struct ILibWebServer_Session *session, ILibWebServer_Session_OnReceive OnReceive);
void ILibWebServer_StreamFile(struct ILibWebServer_Session *session, FILE* pfile);
#ifdef __cplusplus
}
#endif
/* \} */
#endif