summaryrefslogblamecommitdiffstats
path: root/src/HTTPServer/MultipartParser.h
blob: a7395c1cbb63082e758b7d73e5a1e84e2c1dbf20 (plain) (tree)























                                                                                                             


                                                    

                                                   
                                                                                

                                                                                              

                                                                                
                
                                                        


                                                 
                                                                                

                                                                                  

                                                       

          
                                                               

                                 
                                                                                            

                       
                                              

                                         
                                                              

                               
                                                                                     

                           
                                                                                                                                        


                          

                                                                                                       
        

                                                                                                                                        







                                                                                           

// MultipartParser.h

// Declares the cMultipartParser class that parses messages in "multipart/*" encoding into the separate parts





#pragma once

#include "EnvelopeParser.h"





class cMultipartParser :
	protected cEnvelopeParser::cCallbacks
{
public:
	class cCallbacks
	{
	public:
		virtual ~cCallbacks() {}
		
		/** Called when a new part starts */
		virtual void OnPartStart(void) = 0;
		
		/** Called when a complete header line is received for a part */
		virtual void OnPartHeader(const AString & a_Key, const AString & a_Value) = 0;
		
		/** Called when body for a part is received */
		virtual void OnPartData(const char * a_Data, size_t a_Size) = 0;
		
		/** Called when the current part ends */
		virtual void OnPartEnd(void) = 0;
	} ;
	
	/** Creates the parser, expects to find the boundary in a_ContentType */
	cMultipartParser(const AString & a_ContentType, cCallbacks & a_Callbacks);
	
	/** Parses more incoming data */
	void Parse(const char * a_Data, size_t a_Size);
	
protected:
	/** The callbacks to call for various parsing events */
	cCallbacks & m_Callbacks;
	
	/** True if the data parsed so far is valid; if false, further parsing is skipped */
	bool m_IsValid;
	
	/** Parser for each part's envelope */
	cEnvelopeParser m_EnvelopeParser;
	
	/** Buffer for the incoming data until it is parsed */
	AString m_IncomingData;
	
	/** The boundary, excluding both the initial "--" and the terminating CRLF */
	AString m_Boundary;
	
	/** Set to true if some data for the current part has already been signalized to m_Callbacks. Used for proper CRLF inserting. */
	bool m_HasHadData;
	
	
	/** Parse one line of incoming data. The CRLF has already been stripped from a_Data / a_Size */
	void ParseLine(const char * a_Data, size_t a_Size);
	
	/** Parse one line of incoming data in the headers section of a part. The CRLF has already been stripped from a_Data / a_Size */
	void ParseHeaderLine(const char * a_Data, size_t a_Size);
	
	// cEnvelopeParser overrides:
	virtual void OnHeaderLine(const AString & a_Key, const AString & a_Value) override;
} ;