summaryrefslogtreecommitdiff
path: root/TAO/orbsvcs/orbsvcs/Security/SL2_EstablishTrustPolicy.h
blob: eeb4bc7ddc9f8c225c013116ccdf739925100cb8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
// -*- C++ -*-

// ===================================================================
/**
 *  @file   SL2_EstablishTrustPolicy.h
 *
 *  $Id$
 *
 *  @author Ossama Othman <ossama@uci.edu>
 */
// ===================================================================


#ifndef TAO_ESTABLISH_TRUST_POLICY_H
#define TAO_ESTABLISH_TRUST_POLICY_H

#include /**/ "ace/pre.h"

#include "security_export.h"

#if !defined (ACE_LACKS_PRAGMA_ONCE)
# pragma once
#endif /* ACE_LACKS_PRAGMA_ONCE */

#include "orbsvcs/SecurityLevel2C.h"

#include "tao/LocalObject.h"

namespace TAO
{
  namespace Security
  {

    /**
     * @class EstablishTrustPolicy
     *
     * @brief Implementation of the
     *        SecurityLevel2::EstablishTrustPolicy.
     *
     * This policy can be used to enable or disable establishment of
     * trust in the client or the target or both on a per-object
     * basis.  For example, it can be set as a policy override using
     * the standard CORBA::Object::_set_policy_overrides() method.
     @par
     * This policy can be created by using the
     * CORBA::ORB::create_policy() method by passing it the
     * Security::SecEstablishTrustPolicy policy type, and the
     *
     * appropriate Security::EstablishTrust structure (inserted into a
     * CORBA::Any).
     */
    class TAO_Security_Export EstablishTrustPolicy
      : public virtual SecurityLevel2::EstablishTrustPolicy,
        public virtual TAO_Local_RefCounted_Object
    {
    public:

      /// Constructor
      EstablishTrustPolicy (const ::Security::EstablishTrust &trust);

      /**
       * @name CORBA::Policy Methods
       */
      //@{
      virtual CORBA::PolicyType policy_type (ACE_ENV_SINGLE_ARG_DECL)
        ACE_THROW_SPEC ((CORBA::SystemException));

      virtual CORBA::Policy_ptr copy (ACE_ENV_SINGLE_ARG_DECL)
        ACE_THROW_SPEC ((CORBA::SystemException));

      virtual void destroy (ACE_ENV_SINGLE_ARG_DECL)
        ACE_THROW_SPEC ((CORBA::SystemException));
      //@}

      /// Return the "establish trust" value associated with this
      /// policy.
      virtual ::Security::EstablishTrust trust (ACE_ENV_SINGLE_ARG_DECL)
        ACE_THROW_SPEC ((CORBA::SystemException));

    protected:

      /// Destructor
      /**
       * Protected destructor to enforce proper memory management
       * through the reference counting mechanism.
       */
      ~EstablishTrustPolicy (void);

    private:

      /// Quality of protection which can be specified for an object
      /// reference and used to protect messages.
      ::Security::EstablishTrust trust_;

    };

  } // End Security namespace
}  // End TAO namespace

#include /**/ "ace/post.h"

#endif  /* TAO_ESTABLISH_TRUST_POLICY_H */