blob: bb42f9e451dbb6b6e34aa34944b22e4a267a504f (
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
103
104
105
106
107
108
109
110
|
// -*- C++ -*-
//=============================================================================
/**
* @file IOR_Multicast.h
*
* Defines a class that listens to a multicast address for client requests
* for ior of a bootstrappable service.
*
* @author Sergio Flores-Gaitan
*/
//=============================================================================
#ifndef TAO_IOR_MULTICAST_H
#define TAO_IOR_MULTICAST_H
#include /**/ "ace/pre.h"
#include "orbsvcs/svc_utils_export.h"
#include "tao/ORB.h"
#if !defined (ACE_LACKS_PRAGMA_ONCE)
# pragma once
#endif /* ACE_LACKS_PRAGMA_ONCE */
#include "ace/INET_Addr.h"
#include "ace/SOCK_Dgram_Mcast.h"
#include "ace/Reactor.h"
#include "ace/SString.h"
TAO_BEGIN_VERSIONED_NAMESPACE_DECL
/**
* @class TAO_IOR_Multicast
*
* @brief Event Handler that services multicast requests for IOR of a
* bootstrappable service.
*
* This class uses the ACE_SOCK_Dgram_Mcast class and should be
* registered with a reactor and should be initialized with the
* ior of the service to be multicasted.
*/
class TAO_Svc_Utils_Export TAO_IOR_Multicast : public ACE_Event_Handler
{
public:
/// Constructor.
TAO_IOR_Multicast ();
/// Constructor taking the ior of the service.
TAO_IOR_Multicast (const char *ior,
u_short port,
const char *mcast_addr,
TAO_Service_ID service_id);
/// Initialization method.
int init (const char *ior,
u_short port,
const char *mcast_addr,
TAO_Service_ID service_id);
/// Initialization method. Takes in "address:port" string as a
/// parameter.
int init (const char *ior,
const char *mcast_addr,
TAO_Service_ID service_id);
/// Destructor.
virtual ~TAO_IOR_Multicast ();
/// Callback when input is received on the handle.
virtual int handle_input (ACE_HANDLE n);
/// Callback when a timeout has occurred.
virtual int handle_timeout (const ACE_Time_Value &tv,
const void *arg);
/// Returns the internal handle used to receive multicast.
virtual ACE_HANDLE get_handle () const;
private:
/// Factor common functionality from the two init functions.
int common_init (const char *ior,
TAO_Service_ID service_id);
/// Service id that we're waiting for.
TAO_Service_ID service_id_;
/// multicast endpoint of communication
ACE_SOCK_Dgram_Mcast mcast_dgram_;
/// multicast address
ACE_INET_Addr mcast_addr_;
/// object reference to send in response to the multicast
ACE_CString ior_;
/// address of response.
ACE_INET_Addr response_addr_;
/// socket for response to the multicast
ACE_SOCK_Dgram response_;
ACE_CString mcast_nic_;
};
TAO_END_VERSIONED_NAMESPACE_DECL
#include /**/ "ace/post.h"
#endif /* TAO_IOR_MULTICAST_H */
|