(file) Return to Authenticator.h CVS log (file) (dir) Up to [Pegasus] / pegasus / src / Pegasus / Security / Authentication

 1 martin 1.13 //%LICENSE////////////////////////////////////////////////////////////////
 2 martin 1.14 //
 3 martin 1.13 // Licensed to The Open Group (TOG) under one or more contributor license
 4             // agreements.  Refer to the OpenPegasusNOTICE.txt file distributed with
 5             // this work for additional information regarding copyright ownership.
 6             // Each contributor licenses this file to you under the OpenPegasus Open
 7             // Source License; you may not use this file except in compliance with the
 8             // License.
 9 martin 1.14 //
10 martin 1.13 // Permission is hereby granted, free of charge, to any person obtaining a
11             // copy of this software and associated documentation files (the "Software"),
12             // to deal in the Software without restriction, including without limitation
13             // the rights to use, copy, modify, merge, publish, distribute, sublicense,
14             // and/or sell copies of the Software, and to permit persons to whom the
15             // Software is furnished to do so, subject to the following conditions:
16 martin 1.14 //
17 martin 1.13 // The above copyright notice and this permission notice shall be included
18             // in all copies or substantial portions of the Software.
19 martin 1.14 //
20 martin 1.13 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
21 martin 1.14 // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
22 martin 1.13 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
23             // IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
24             // CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
25             // TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
26             // SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
27 martin 1.14 //
28 martin 1.13 //////////////////////////////////////////////////////////////////////////
29 mike   1.2  //
30             //%/////////////////////////////////////////////////////////////////////////////
31             
32             #ifndef Pegasus_Authenticator_h
33             #define Pegasus_Authenticator_h
34             
35             #include <Pegasus/Common/Config.h>
36             #include <Pegasus/Common/String.h>
37             #include <Pegasus/Common/AuthenticationInfo.h>
38 kumpf  1.4  #include <Pegasus/Common/AuthenticationInfoRep.h>
39             
40 chuck  1.6  #include <Pegasus/Security/Authentication/Linkage.h>
41 karl   1.14.8.2 #include <Pegasus/Security/Authentication/AuthenticationStatus.h>
42 mike   1.2      
43                 PEGASUS_NAMESPACE_BEGIN
44                 
45 kumpf  1.4      /** This is an abstract class that the authentication handlers will extend and
46                     provide the implementation.
47 mike   1.2      */
48                 class PEGASUS_SECURITY_LINKAGE Authenticator
49                 {
50                 public:
51                 
52                     /** Constructors  */
53                     Authenticator() { };
54                 
55                     /** Destructor  */
56                     virtual ~Authenticator() { };
57                 
58 kumpf  1.12         /** Verify the authentication of the user passed in the HTTP authorization
59                         header.
60 kumpf  1.4              @param authHeader String containing the Authorization header
61                         @param authInfo Reference to AuthenticationInfo object
62 karl   1.14.8.2         @return AuthenticationStatus holding http status code and error detail
63 mike   1.2          */
64 karl   1.14.8.2     virtual AuthenticationStatus authenticate(
65 kumpf  1.12             const String& authHeader,
66 kumpf  1.3              AuthenticationInfo* authInfo) = 0;
67 mike   1.2      
68 kumpf  1.4          /** Construct and return the Basic authentication challenge header
69                         @param authType String containing the authentication type
70                         @param userName String containing the user name
71                         @param authInfo Reference to AuthenticationInfo object
72                         @return A string containing the authentication challenge header.
73 mike   1.2          */
74                     virtual String getAuthResponseHeader(
75 kumpf  1.4              const String& authType = String::EMPTY,
76                         const String& userName = String::EMPTY,
77 kumpf  1.3              AuthenticationInfo* authInfo = 0) = 0;
78 sushma.fernandes 1.10     
79                               /**
80                                   Verify whether the user is valid.
81                                   @param userName String containing the user name
82 karl             1.14.8.1         @param authInfo reference to AuthenticationInfo object that holds the
83                                   authentication information for the given connection.
84 karl             1.14.8.2         @return AuthenticationStatus holding http status code and error detail
85 sushma.fernandes 1.10         */
86 karl             1.14.8.2     virtual AuthenticationStatus validateUser(
87 karl             1.14.8.1         const String& userName,
88                                   AuthenticationInfo* authInfo) = 0;
89 mike             1.2      };
90                           
91                           PEGASUS_NAMESPACE_END
92                           
93                           #endif   /* Pegasus_Authenticator_h*/

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2