PTLib  Version 2.18.8
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
PHTTPMultiSimpAuth Class Reference

This class describes the simple authorisation mechanism for a Universal Resource Locator, a fixed realm, multiple usernames and passwords. More...

#include <http.h>

Inheritance diagram for PHTTPMultiSimpAuth:
Collaboration diagram for PHTTPMultiSimpAuth:

Public Member Functions

 PHTTPMultiSimpAuth (const PString &realm)
 
 PHTTPMultiSimpAuth (const PString &realm, const PStringToString &userList)
 
virtual PObjectClone () const
 Create a copy of the class on the heap. More...
 
virtual PString GetRealm (const PHTTPRequest &request) const
 Get the realm or name space for the user authorisation name and password as required by the basic authorisation system of HTTP/1.0. More...
 
virtual PBoolean Validate (const PHTTPRequest &request, const PString &authInfo) const
 Validate the user and password provided by the remote HTTP client for the realm specified by the class instance. More...
 
virtual PBoolean IsActive () const
 Determine if the authirisation is to be applied. More...
 
void AddUser (const PString &username, const PString &password)
 Get the user name allocated to this simple authorisation. More...
 
- Public Member Functions inherited from PObject
__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 PObjectPTraceObjectInstance () const
 
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 Attributes

PString m_realm
 
PStringToString m_users
 
- Protected Attributes inherited from PObject
unsigned m_traceContextIdentifier
 

Additional Inherited Members

- Public Types inherited from PObject
enum  Comparison { LessThan = -1, EqualTo = 0, GreaterThan = 1 }
 Result of the comparison operation performed by the Compare() function. More...
 
- Static Public Member Functions inherited from PObject
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 PObjectPTraceObjectInstance (const char *)
 
static __inline const PObjectPTraceObjectInstance (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...
 
- Protected Member Functions inherited from PObject
 PObject ()
 Constructor for PObject, made protected so cannot ever create one on its own. More...
 
- Static Protected Member Functions inherited from PHTTPAuthority
static void DecodeBasicAuthority (const PString &authInfo, PString &username, PString &password)
 

Detailed Description

This class describes the simple authorisation mechanism for a Universal Resource Locator, a fixed realm, multiple usernames and passwords.

Constructor & Destructor Documentation

PHTTPMultiSimpAuth::PHTTPMultiSimpAuth ( const PString realm)
Parameters
realmName space for the username and password.
PHTTPMultiSimpAuth::PHTTPMultiSimpAuth ( const PString realm,
const PStringToString userList 
)
Parameters
realmName space for the usernames.
userListList of usernames and passwords.

Member Function Documentation

void PHTTPMultiSimpAuth::AddUser ( const PString username,
const PString password 
)

Get the user name allocated to this simple authorisation.

Returns
String for the authorisation user name.
Parameters
usernameUsername that this object wiull authorise.
passwordPassword for the above username.
virtual PObject* PHTTPMultiSimpAuth::Clone ( ) const
virtual

Create a copy of the class on the heap.

This is used by the PHTTPResource classes for maintaining authorisation to resources.

Returns
pointer to new copy of the class instance.

Reimplemented from PObject.

virtual PString PHTTPMultiSimpAuth::GetRealm ( const PHTTPRequest request) const
virtual

Get the realm or name space for the user authorisation name and password as required by the basic authorisation system of HTTP/1.0.

Returns
String for the authorisation realm name.
Parameters
requestRequest information.

Implements PHTTPAuthority.

virtual PBoolean PHTTPMultiSimpAuth::IsActive ( ) const
virtual

Determine if the authirisation is to be applied.

This could be used to distinguish between net requiring authorisation and requiring autorisation but having no password.

The default behaviour is to return true.

Returns
true if the authorisation in the realm is to be applied.

Reimplemented from PHTTPAuthority.

virtual PBoolean PHTTPMultiSimpAuth::Validate ( const PHTTPRequest request,
const PString authInfo 
) const
virtual

Validate the user and password provided by the remote HTTP client for the realm specified by the class instance.

Returns
true if the user and password are authorised in the realm.
Parameters
requestRequest information.
authInfoAuthority information string.

Implements PHTTPAuthority.

Member Data Documentation

PString PHTTPMultiSimpAuth::m_realm
protected
PStringToString PHTTPMultiSimpAuth::m_users
protected

The documentation for this class was generated from the following file: