(file) Return to AuthenticationInfoRep.h CVS log (file) (dir) Up to [Pegasus] / pegasus / src / Pegasus / Common

Diff for /pegasus/src/Pegasus/Common/AuthenticationInfoRep.h between version 1.13 and 1.29

version 1.13, 2004/10/17 20:39:16 version 1.29, 2008/12/02 09:00:42
Line 1 
Line 1 
 //%2004////////////////////////////////////////////////////////////////////////  //%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
 // Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.;  // Source License; you may not use this file except in compliance with the
 // IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group.  // License.
 //  //
 // Permission is hereby granted, free of charge, to any person obtaining a copy  // Permission is hereby granted, free of charge, to any person obtaining a
 // of this software and associated documentation files (the "Software"), to  // copy of this software and associated documentation files (the "Software"),
 // deal in the Software without restriction, including without limitation the  // to deal in the Software without restriction, including without limitation
 // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or  // the rights to use, copy, modify, merge, publish, distribute, sublicense,
 // sell copies of the Software, and to permit persons to whom the Software is  // and/or sell copies of the Software, and to permit persons to whom the
 // furnished to do so, subject to the following conditions:  // Software is furnished to do so, subject to the following conditions:
 //  //
 // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN  // The above copyright notice and this permission notice shall be included
 // ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED  // in all copies or substantial portions of the Software.
 // "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT  //
 // LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR  // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
 // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT  // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN  // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
 // ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION  // IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.  // 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)  
 // //
 //%///////////////////////////////////////////////////////////////////////////// //%/////////////////////////////////////////////////////////////////////////////
  
Line 36 
Line 33 
 #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>
Line 56 
Line 54 
 class PEGASUS_COMMON_LINKAGE AuthenticationInfoRep :  public Sharable class PEGASUS_COMMON_LINKAGE AuthenticationInfoRep :  public Sharable
 { {
 public: public:
     enum AuthStatus { NEW_REQUEST, CHALLENGE_SENT, AUTHENTICATED };  
  
         //ATTN: we should be using an enumeration for the authtype instead of a string.      //ATTN: we should be using an enumeration for the authtype instead of a
       //string.
         //In the AuthenticationManager, the authtype is set to Basic, Digest, etc         //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         //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         //string here to make it less arbitrary.  PEP165
         static const String AUTH_TYPE_SSL;         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
     {     {
Line 82 
Line 77 
  
     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);
  
     String getAuthChallenge() const  #endif
   
       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
Line 122 
Line 128 
  
     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
     {     {
Line 131 
Line 147 
     void setSecurityAssociation();     void setSecurityAssociation();
 #endif #endif
  
     Boolean isExportConnection() const      Array<SSLCertificateInfo*> getClientCertificateChain()
     {     {
         return _exportConnection;          return _clientCertificate;
     }     }
  
     void setExportConnection(Boolean exportConnection);      void setClientCertificateChain(
           Array<SSLCertificateInfo*> clientCertificate);
   
       void setRemotePrivilegedUserAccessChecked()
       {
           _wasRemotePrivilegedUserAccessChecked = true;
       }
   
       Boolean getRemotePrivilegedUserAccessChecked()
       {
           return _wasRemotePrivilegedUserAccessChecked;
       }
  
 private: private:
  
Line 149 
Line 176 
  
     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
     AutoPtr<CIMKerberosSecurityAssociation> _securityAssoc;//PEP101     AutoPtr<CIMKerberosSecurityAssociation> _securityAssoc;//PEP101
 #endif #endif
       Boolean _wasRemotePrivilegedUserAccessChecked;
  
     Boolean _exportConnection;      Array<SSLCertificateInfo*> _clientCertificate;
 }; };
  
 PEGASUS_NAMESPACE_END PEGASUS_NAMESPACE_END


Legend:
Removed from v.1.13  
changed lines
  Added in v.1.29

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2