version 1.8.4.2, 2004/04/25 20:39:57
|
version 1.29, 2008/12/02 09:00:42
|
|
|
//%2003//////////////////////////////////////////////////////////////////////// |
//%LICENSE//////////////////////////////////////////////////////////////// |
// | // |
// Copyright (c) 2000, 2001, 2002 BMC Software, Hewlett-Packard Development |
// Licensed to The Open Group (TOG) under one or more contributor license |
// Company, L. P., IBM Corp., The Open Group, Tivoli Systems. |
// agreements. Refer to the OpenPegasusNOTICE.txt file distributed with |
// Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L. P.; |
// this work for additional information regarding copyright ownership. |
// IBM Corp.; EMC Corporation, The Open Group. |
// Each contributor licenses this file to you under the OpenPegasus Open |
// |
// Source License; you may not use this file except in compliance with the |
// Permission is hereby granted, free of charge, to any person obtaining a copy |
// License. |
// of this software and associated documentation files (the "Software"), to |
// |
// deal in the Software without restriction, including without limitation the |
// Permission is hereby granted, free of charge, to any person obtaining a |
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or |
// copy of this software and associated documentation files (the "Software"), |
// sell copies of the Software, and to permit persons to whom the Software is |
// to deal in the Software without restriction, including without limitation |
// furnished to do so, subject to the following conditions: |
// the rights to use, copy, modify, merge, publish, distribute, sublicense, |
// |
// and/or sell copies of the Software, and to permit persons to whom the |
// THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN |
// Software is furnished to do so, subject to the following conditions: |
// ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED |
// |
// "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT |
// The above copyright notice and this permission notice shall be included |
// LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR |
// in all copies or substantial portions of the Software. |
// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT |
// |
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN |
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION |
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. |
|
// IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY |
|
// CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, |
|
// TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE |
|
// SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
// | // |
//============================================================================== |
////////////////////////////////////////////////////////////////////////// |
// |
|
// Author: Nag Boranna, Hewlett-Packard Company(nagaraja_boranna@hp.com) |
|
// |
|
// Modified By: Jair Santos, Hewlett-Packard Company(jair.santos@hp.com) |
|
// Heather Sterling, IBM (hsterl@us.ibm.com) |
|
// | // |
//%///////////////////////////////////////////////////////////////////////////// | //%///////////////////////////////////////////////////////////////////////////// |
| |
|
|
#define Pegasus_AuthenticationInfoRep_h | #define Pegasus_AuthenticationInfoRep_h |
| |
#include <Pegasus/Common/Config.h> | #include <Pegasus/Common/Config.h> |
|
#include <Pegasus/Common/ArrayInternal.h> |
#include <Pegasus/Common/String.h> | #include <Pegasus/Common/String.h> |
#include <Pegasus/Common/Sharable.h> | #include <Pegasus/Common/Sharable.h> |
#include <Pegasus/Common/Linkage.h> | #include <Pegasus/Common/Linkage.h> |
|
|
class PEGASUS_COMMON_LINKAGE AuthenticationInfoRep : public Sharable | class PEGASUS_COMMON_LINKAGE AuthenticationInfoRep : public Sharable |
{ | { |
public: | public: |
enum AuthStatus |
|
{ |
//ATTN: we should be using an enumeration for the authtype instead of a |
NEW_REQUEST, CHALLENGE_SENT, AUTHENTICATED |
//string. |
}; |
//In the AuthenticationManager, the authtype is set to Basic, Digest, etc |
|
//We also need to be able to check whether the type is SSL, so I'm adding a |
|
//string here to make it less arbitrary. PEP165 |
|
static const String AUTH_TYPE_SSL; |
|
static const String AUTH_TYPE_ZOS_LOCAL_DOMIAN_SOCKET; |
|
static const String AUTH_TYPE_ZOS_ATTLS; |
| |
AuthenticationInfoRep(Boolean flag); | AuthenticationInfoRep(Boolean flag); |
| |
~AuthenticationInfoRep(); | ~AuthenticationInfoRep(); |
| |
AuthStatus getAuthStatus() const |
void setConnectionAuthenticated(Boolean connectionAuthenticated); |
{ |
|
return _authStatus; |
|
} |
|
|
|
void setAuthStatus(AuthStatus status); |
|
| |
String getAuthenticatedUser() const | String getAuthenticatedUser() const |
{ | { |
|
|
| |
void setAuthenticatedUser(const String& userName); | void setAuthenticatedUser(const String& userName); |
| |
String getAuthenticatedPassword() const |
#ifdef PEGASUS_OS_ZOS |
|
|
|
// The connection user is for z/OS only. |
|
// On z/OS Unix Local Domain Sockets and sockets |
|
// protected by AT-TLS are able to get the user ID of |
|
// the connected user. |
|
// This information is needed for later authentication |
|
// steps. |
|
|
|
String getConnectionUser() const |
{ | { |
return _authPassword; |
return _connectionUser; |
} | } |
| |
void setAuthenticatedPassword(const String& password); |
void setConnectionUser(const String& userName); |
|
|
|
#endif |
| |
String getAuthChallenge() const |
String getAuthenticatedPassword() const |
{ | { |
return _authChallenge; |
return _authPassword; |
} | } |
| |
void setAuthChallenge(const String& challenge); |
void setAuthenticatedPassword(const String& password); |
| |
String getAuthSecret() const |
String getLocalAuthFilePath() const |
{ | { |
return _authSecret; |
return _localAuthFilePath; |
} | } |
| |
void setAuthSecret(const String& secret); |
void setLocalAuthFilePath(const String& filePath); |
| |
Boolean isPrivileged() const |
String getLocalAuthSecret() const |
{ | { |
return _privileged; |
return _localAuthSecret; |
} | } |
| |
void setPrivileged(Boolean privileged); |
void setLocalAuthSecret(const String& secret); |
| |
Boolean isAuthenticated() const |
Boolean isConnectionAuthenticated() const |
{ | { |
return (_authStatus == AUTHENTICATED) ? true : false; |
return _connectionAuthenticated; |
} | } |
| |
String getAuthType() const | String getAuthType() const |
|
|
| |
void setAuthType(const String& authType); | void setAuthType(const String& authType); |
| |
|
void setIpAddress(const String& ipAddress) |
|
{ |
|
_ipAddress = ipAddress; |
|
} |
|
|
|
String getIpAddress() |
|
{ |
|
return _ipAddress; |
|
} |
|
|
#ifdef PEGASUS_KERBEROS_AUTHENTICATION | #ifdef PEGASUS_KERBEROS_AUTHENTICATION |
CIMKerberosSecurityAssociation* getSecurityAssociation() const | CIMKerberosSecurityAssociation* getSecurityAssociation() const |
{ | { |
return _securityAssoc; |
return _securityAssoc.get(); |
} | } |
| |
void setSecurityAssociation(); | void setSecurityAssociation(); |
#endif | #endif |
| |
#ifdef PEGASUS_USE_232_CLIENT_VERIFICATION |
Array<SSLCertificateInfo*> getClientCertificateChain() |
#ifdef PEGASUS_HAS_SSL |
|
SSLCertificateInfo* getPeerCertificate() const |
|
{ | { |
return _peerCertificate; |
return _clientCertificate; |
} | } |
| |
void setPeerCertificate(SSLCertificateInfo* peerCertificate); |
void setClientCertificateChain( |
|
Array<SSLCertificateInfo*> clientCertificate); |
| |
Sint32 getCertificateStatus() const |
void setRemotePrivilegedUserAccessChecked() |
{ | { |
return _certificateStatus; |
_wasRemotePrivilegedUserAccessChecked = true; |
} | } |
| |
void setCertificateStatus(Sint32 certificateStatus); |
Boolean getRemotePrivilegedUserAccessChecked() |
#endif |
{ |
#endif |
return _wasRemotePrivilegedUserAccessChecked; |
|
} |
| |
private: | private: |
| |
|
|
| |
String _authUser; | String _authUser; |
String _authPassword; | String _authPassword; |
String _authChallenge; |
String _localAuthSecret; |
String _authSecret; |
String _localAuthFilePath; |
Boolean _privileged; |
#ifdef PEGASUS_OS_ZOS |
|
String _connectionUser; |
|
#endif |
String _authType; | String _authType; |
AuthStatus _authStatus; |
Boolean _connectionAuthenticated; |
|
String _ipAddress; |
#ifdef PEGASUS_KERBEROS_AUTHENTICATION | #ifdef PEGASUS_KERBEROS_AUTHENTICATION |
CIMKerberosSecurityAssociation * _securityAssoc; |
AutoPtr<CIMKerberosSecurityAssociation> _securityAssoc;//PEP101 |
#endif | #endif |
|
Boolean _wasRemotePrivilegedUserAccessChecked; |
| |
#ifdef PEGASUS_USE_232_CLIENT_VERIFICATION |
Array<SSLCertificateInfo*> _clientCertificate; |
#ifdef PEGASUS_HAS_SSL |
|
Sint32 _certificateStatus; |
|
SSLCertificateInfo* _peerCertificate; |
|
#endif |
|
#endif |
|
}; | }; |
| |
PEGASUS_NAMESPACE_END | PEGASUS_NAMESPACE_END |