PTLib
Version 2.18.8
|
This object describes a HyperText Transport Protocol resource which is a single file. More...
#include <http.h>
Public Member Functions | |
PHTTPFile (const PString &filename) | |
Contruct a new simple file resource for the HTTP space. More... | |
PHTTPFile (const PString &filename, const PHTTPAuthority &auth) | |
PHTTPFile (const PURL &url, const PFilePath &file) | |
PHTTPFile (const PURL &url, const PFilePath &file, const PString &contentType) | |
PHTTPFile (const PURL &url, const PFilePath &file, const PHTTPAuthority &auth) | |
PHTTPFile (const PURL &url, const PFilePath &file, const PString &contentType, const PHTTPAuthority &auth) | |
virtual PHTTPRequest * | CreateRequest (const PURL &url, const PMIMEInfo &inMIME, const PMultiPartList &multipartFormInfo, PHTTPServer &socket) |
Create a new request block for this type of resource. More... | |
virtual PBoolean | LoadHeaders (PHTTPRequest &request) |
Get the headers for block of data (eg HTML) that the resource contains. More... | |
virtual PBoolean | LoadData (PHTTPRequest &request, PCharArray &data) |
Get a block of data that the resource contains. More... | |
virtual PString | LoadText (PHTTPRequest &request) |
Get a block of text data (eg HTML) that the resource contains. More... | |
![]() | |
virtual | ~PHTTPResource () |
const PURL & | GetURL () const |
Get the URL for this resource. More... | |
PString | GetHotLink () const |
Get relative hot link for this resouce. More... | |
const PString & | GetContentType () const |
Get the current content type for the resource. More... | |
PHTTPAuthority * | GetAuthority () const |
Get the current authority for the resource. More... | |
void | SetAuthority (const PHTTPAuthority &auth) |
Set the current authority for the resource. More... | |
void | ClearAuthority () |
Set the current authority for the resource to unrestricted. More... | |
DWORD | GetHitCount () const |
Get the current hit count for the resource. More... | |
void | ClearHitCount () |
Clear the hit count for the resource. More... | |
virtual bool | SupportsWebSocketProtocol (const PString &protocol) const |
Indicate that the web socket protocol is supported by this resource. More... | |
virtual bool | OnWebSocket (PHTTPServer &server, PHTTPConnectionInfo &connectInfo) |
Called when a request indicates a swtch to WebSocket protocol. More... | |
virtual bool | OnGET (PHTTPServer &server, const PHTTPConnectionInfo &conInfo) |
Handle the GET command passed from the HTTP socket. More... | |
virtual PBoolean | OnGETData (PHTTPServer &server, const PURL &url, const PHTTPConnectionInfo &connectInfo, PHTTPRequest &request) |
Send the data associated with a GET command. More... | |
virtual bool | OnHEAD (PHTTPServer &server, const PHTTPConnectionInfo &conInfo) |
Handle the HEAD command passed from the HTTP socket. More... | |
virtual bool | OnPOST (PHTTPServer &server, const PHTTPConnectionInfo &conInfo) |
Handle the POST command passed from the HTTP socket. More... | |
virtual PBoolean | OnPOSTData (PHTTPRequest &request, const PStringToString &data) |
Send the data associated with a POST command. More... | |
virtual PBoolean | IsModifiedSince (const PTime &when) |
Check to see if the resource has been modified since the date specified. More... | |
virtual PBoolean | GetExpirationDate (PTime &when) |
Get a block of data (eg HTML) that the resource contains. More... | |
virtual void | SendData (PHTTPRequest &request) |
Send the data associated with a command. More... | |
virtual void | OnLoadedText (PHTTPRequest &request, PString &text) |
This is called after the text has been loaded and may be used to customise or otherwise mangle a loaded piece of text. More... | |
virtual PBoolean | Post (PHTTPRequest &request, const PStringToString &data, PHTML &replyMessage) |
Get a block of data (eg HTML) that the resource contains. More... | |
![]() | |
__inline unsigned | GetTraceContextIdentifier () const |
Get PTRACE context identifier. More... | |
__inline void | SetTraceContextIdentifier (unsigned id) |
__inline void | SetTraceContextIdentifier (const PObject &obj) |
__inline void | SetTraceContextIdentifier (const PObject *obj) |
__inline void | CopyTraceContextIdentifier (PObject &obj) const |
__inline void | CopyTraceContextIdentifier (PObject *obj) const |
virtual | ~PObject () |
__inline const char * | GetClass () const |
__inline bool | IsClass (const char *name) const |
__inline const PObject * | PTraceObjectInstance () const |
virtual PObject * | Clone () const |
Create a copy of the class on the heap. More... | |
template<class CLS > | |
CLS * | CloneAs () const |
As for Clone() but converts to specified type. More... | |
virtual PINDEX | HashFunction () const |
This function yields a hash value required by the PDictionary class. More... | |
virtual Comparison | Compare (const PObject &obj) const |
Compare the two objects and return their relative rank. More... | |
virtual Comparison | CompareObjectMemoryDirect (const PObject &obj) const |
Determine the byte wise comparison of two objects. More... | |
bool | operator== (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator!= (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator< (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator> (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator<= (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator>= (const PObject &obj) const |
Compare the two objects. More... | |
virtual void | PrintOn (ostream &strm) const |
Output the contents of the object to the stream. More... | |
virtual void | ReadFrom (istream &strm) |
Input the contents of the object from the stream. More... | |
Protected Member Functions | |
PHTTPFile (const PURL &url, int dummy) | |
![]() | |
PHTTPResource (const PURL &url) | |
PHTTPResource (const PURL &url, const PHTTPAuthority &auth) | |
PHTTPResource (const PURL &url, const PString &contentType) | |
PHTTPResource (const PURL &url, const PString &contentType, const PHTTPAuthority &auth) | |
virtual PBoolean | CheckAuthority (PHTTPServer &server, const PHTTPRequest &request, const PHTTPConnectionInfo &conInfo) |
See if the resource is authorised given the mime info. More... | |
virtual bool | InternalOnCommand (PHTTPServer &server, const PHTTPConnectionInfo &conInfo, PHTTP::Commands cmd) |
common code for GET and HEAD commands More... | |
P_REMOVE_VIRTUAL (PBoolean, OnGET(PHTTPServer &, const PURL &, const PMIMEInfo &, const PHTTPConnectionInfo &), false) | |
P_REMOVE_VIRTUAL (PBoolean, OnHEAD(PHTTPServer &, const PURL &, const PMIMEInfo &, const PHTTPConnectionInfo &), false) | |
P_REMOVE_VIRTUAL (PBoolean, OnGETOrHEAD(PHTTPServer &, const PURL &, const PMIMEInfo &, const PHTTPConnectionInfo &, PBoolean), false) | |
P_REMOVE_VIRTUAL (PBoolean, OnPOST(PHTTPServer &, const PURL &, const PMIMEInfo &, const PStringToString &, const PHTTPConnectionInfo &), false) | |
![]() | |
PObject () | |
Constructor for PObject, made protected so cannot ever create one on its own. More... | |
Protected Attributes | |
PFilePath | m_filePath |
![]() | |
PURL | m_baseURL |
Base URL for the resource, may accept URLS with a longer hierarchy. More... | |
PString | m_contentType |
MIME content type for the resource. More... | |
PHTTPAuthority * | m_authority |
Authorisation method for the resource. More... | |
atomic< unsigned > | m_hitCount |
Count of number of times resource was accessed. More... | |
![]() | |
unsigned | m_traceContextIdentifier |
Additional Inherited Members | |
![]() | |
enum | Comparison { LessThan = -1, EqualTo = 0, GreaterThan = 1 } |
Result of the comparison operation performed by the Compare() function. More... | |
![]() | |
static __inline void | CopyTraceContextIdentifier (PObject &to, const PObject &from) |
static __inline void | CopyTraceContextIdentifier (PObject &to, const PObject *from) |
static __inline void | CopyTraceContextIdentifier (PObject *to, const PObject &from) |
static __inline void | CopyTraceContextIdentifier (PObject *to, const PObject *from) |
static __inline const char * | Class () |
static __inline const PObject * | PTraceObjectInstance (const char *) |
static __inline const PObject * | PTraceObjectInstance (const PObject *obj) |
template<typename T > | |
static Comparison | Compare2 (T v1, T v2) |
Compare two types, returning Comparison type. More... | |
static Comparison | InternalCompareObjectMemoryDirect (const PObject *obj1, const PObject *obj2, PINDEX size) |
Internal function caled from CompareObjectMemoryDirect() More... | |
![]() | |
static PBoolean | CheckAuthority (PHTTPAuthority &authority, PHTTPServer &server, const PHTTPRequest &request, const PHTTPConnectionInfo &connectInfo) |
This object describes a HyperText Transport Protocol resource which is a single file.
The file can be anywhere in the file system and is mapped to the specified URL location in the HTTP name space defined by the PHTTPSpace
class.
PHTTPFile::PHTTPFile | ( | const PString & | filename | ) |
Contruct a new simple file resource for the HTTP space.
If no MIME content type is specified then a default type is used depending on the file type. For example, "text/html" is used of the file type is ".html" or ".htm". The default for an unknown type is "application/octet-stream".
PHTTPFile::PHTTPFile | ( | const PString & | filename, |
const PHTTPAuthority & | auth | ||
) |
PHTTPFile::PHTTPFile | ( | const PURL & | url, |
const PFilePath & | file, | ||
const PHTTPAuthority & | auth | ||
) |
PHTTPFile::PHTTPFile | ( | const PURL & | url, |
const PFilePath & | file, | ||
const PString & | contentType, | ||
const PHTTPAuthority & | auth | ||
) |
|
protected |
|
virtual |
Create a new request block for this type of resource.
Reimplemented from PHTTPResource.
Reimplemented in PHTTPDirectory.
|
virtual |
Get a block of data that the resource contains.
Reimplemented from PHTTPResource.
Reimplemented in PHTTPTailFile.
|
virtual |
Get the headers for block of data (eg HTML) that the resource contains.
This will fill in all the fields of the outMIME
parameter required by the resource and return the status for the load.
Reimplemented from PHTTPResource.
Reimplemented in PHTTPDirectory, and PHTTPTailFile.
|
virtual |
Get a block of text data (eg HTML) that the resource contains.
The default behaviour is to assert, one of LoadText()
or LoadData()
functions must be overridden for correct operation.
Reimplemented from PHTTPResource.
Reimplemented in PHTTPDirectory.
|
protected |