diff options
Diffstat (limited to 'TAO/orbsvcs/orbsvcs/Security/SL3_SecurityManager.cpp')
-rw-r--r-- | TAO/orbsvcs/orbsvcs/Security/SL3_SecurityManager.cpp | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/TAO/orbsvcs/orbsvcs/Security/SL3_SecurityManager.cpp b/TAO/orbsvcs/orbsvcs/Security/SL3_SecurityManager.cpp new file mode 100644 index 00000000000..1cf548a4f2e --- /dev/null +++ b/TAO/orbsvcs/orbsvcs/Security/SL3_SecurityManager.cpp @@ -0,0 +1,84 @@ +// $Id$ + +#include "orbsvcs/Security/SL3_SecurityManager.h" +#include "orbsvcs/Security/SL3_ContextEstablishmentPolicy.h" +#include "orbsvcs/Security/SL3_ObjectCredentialsPolicy.h" + + +ACE_RCSID (Security, + SL3_SecurityManager, + "$Id$") + + +TAO_BEGIN_VERSIONED_NAMESPACE_DECL + +TAO::SL3::SecurityManager::SecurityManager ( + SecurityLevel3::CredentialsCurator_ptr cc) + : credentials_curator_ (SecurityLevel3::CredentialsCurator::_duplicate (cc)) +{ +} + +TAO::SL3::SecurityManager::~SecurityManager (void) +{ +} + +SecurityLevel3::CredentialsCurator_ptr +TAO::SL3::SecurityManager::credentials_curator ( + ACE_ENV_SINGLE_ARG_DECL_NOT_USED) + ACE_THROW_SPEC ((CORBA::SystemException)) +{ + return + SecurityLevel3::CredentialsCurator::_duplicate ( + this->credentials_curator_.in ()); +} + +SecurityLevel3::TargetCredentials_ptr +TAO::SL3::SecurityManager::get_target_credentials (CORBA::Object_ptr /* the_object */ + ACE_ENV_ARG_DECL) + ACE_THROW_SPEC ((CORBA::SystemException)) +{ + ACE_THROW_RETURN (CORBA::NO_IMPLEMENT (), + SecurityLevel3::TargetCredentials::_nil ()); +} + +SecurityLevel3::ContextEstablishmentPolicy_ptr +TAO::SL3::SecurityManager::create_context_estab_policy ( + SecurityLevel3::CredsDirective creds_directive, + const SecurityLevel3::OwnCredentialsList & creds_list, + SecurityLevel3::FeatureDirective use_client_auth, + SecurityLevel3::FeatureDirective use_target_auth, + SecurityLevel3::FeatureDirective use_confidentiality, + SecurityLevel3::FeatureDirective use_integrity + ACE_ENV_ARG_DECL) + ACE_THROW_SPEC ((CORBA::SystemException)) +{ + SecurityLevel3::ContextEstablishmentPolicy_ptr policy; + ACE_NEW_THROW_EX (policy, + TAO::SL3::ContextEstablishmentPolicy (creds_directive, + creds_list, + use_client_auth, + use_target_auth, + use_confidentiality, + use_integrity), + CORBA::NO_MEMORY ()); + ACE_CHECK_RETURN (policy); + + return policy; +} + +SecurityLevel3::ObjectCredentialsPolicy_ptr +TAO::SL3::SecurityManager::create_object_creds_policy ( + const SecurityLevel3::OwnCredentialsList & creds_list + ACE_ENV_ARG_DECL) + ACE_THROW_SPEC ((CORBA::SystemException)) +{ + SecurityLevel3::ObjectCredentialsPolicy_ptr policy; + ACE_NEW_THROW_EX (policy, + TAO::SL3::ObjectCredentialsPolicy (creds_list), + CORBA::NO_MEMORY ()); + ACE_CHECK_RETURN (policy); + + return policy; +} + +TAO_END_VERSIONED_NAMESPACE_DECL |