summaryrefslogtreecommitdiff
path: root/TAO/orbsvcs/orbsvcs/Security/SL3_SecurityManager.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'TAO/orbsvcs/orbsvcs/Security/SL3_SecurityManager.cpp')
-rw-r--r--TAO/orbsvcs/orbsvcs/Security/SL3_SecurityManager.cpp84
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