Hazelcast C++ Client
Hazelcast C++ Client Library
membership_listener.h
1 /*
2  * Copyright (c) 2008-2021, Hazelcast, Inc. All Rights Reserved.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #pragma once
18 
19 #include <string>
20 #include <boost/uuid/uuid.hpp>
21 
22 #include "hazelcast/util/export.h"
23 #include "hazelcast/util/type_traits.h"
24 #include "hazelcast/util/noop.h"
25 
26 #if defined(WIN32) || defined(_WIN32) || defined(WIN64) || defined(_WIN64)
27 #pragma warning(push)
28 #pragma warning(disable: 4251) //for dll export
29 #endif
30 
31 namespace hazelcast {
32  namespace client {
33 
34  class membership_event;
35  class initial_membership_event;
36 
37  namespace spi {
38  namespace impl {
39  class ClientClusterServiceImpl;
40  }
41  }
42 
57  class HAZELCAST_API membership_listener final {
58  friend class cluster;
59  friend class spi::impl::ClientClusterServiceImpl;
60  public:
65  template<typename Handler,
66  typename = util::enable_if_rvalue_ref_t<Handler &&>>
67  membership_listener& on_joined(Handler &&h) & {
68  joined_ = std::forward<Handler>(h);
69  return *this;
70  };
71 
75  template<typename Handler,
76  typename = util::enable_if_rvalue_ref_t<Handler &&>>
77  membership_listener&& on_joined(Handler &&h) && {
78  on_joined(std::forward<Handler>(h));
79  return std::move(*this);
80  };
81 
86  template<typename Handler,
87  typename = util::enable_if_rvalue_ref_t<Handler &&>>
88  membership_listener& on_left(Handler &&h) & {
89  left_ = std::forward<Handler>(h);
90  return *this;
91  };
92 
96  template<typename Handler,
97  typename = util::enable_if_rvalue_ref_t<Handler &&>>
98  membership_listener&& on_left(Handler &&h) && {
99  on_left(std::forward<Handler>(h));
100  return std::move(*this);
101  };
102 
107  template<typename Handler,
108  typename = util::enable_if_rvalue_ref_t<Handler &&>>
109  membership_listener& on_init(Handler &&h) & {
110  init_ = std::forward<Handler>(h);
111  return *this;
112  };
113 
117  template<typename Handler,
118  typename = util::enable_if_rvalue_ref_t<Handler &&>>
119  membership_listener&& on_init(Handler &&h) && {
120  on_init(std::forward<Handler>(h));
121  return std::move(*this);
122  };
123 
124  private:
125  using handler_t = std::function<void(const membership_event &)>;
126  using init_handler_t = std::function<void(const initial_membership_event &)>;
127 
128  handler_t left_{ util::noop<const membership_event &> },
129  joined_{ util::noop<const membership_event &> };
130  init_handler_t init_{};
131  };
132  }
133 }
134 
135 #if defined(WIN32) || defined(_WIN32) || defined(WIN64) || defined(_WIN64)
136 #pragma warning(pop)
137 #endif
138 
139 
140 
Hazelcast cluster interface.
Definition: cluster.h:36
A event that is sent when a MembershipListener is registered.
Membership event fired when a new member is added to the cluster and/or when a member leaves the clus...
membership_listener && on_init(Handler &&h) &&
Set an handler function to be invoked once when this listener is registered.
membership_listener & on_left(Handler &&h) &
Set an handler function to be invoked when an existing member leaves the cluster.
membership_listener && on_left(Handler &&h) &&
Set an handler function to be invoked when an existing member leaves the cluster.
membership_listener & on_joined(Handler &&h) &
Set an handler function to be invoked when a new member joins the cluster.
membership_listener && on_joined(Handler &&h) &&
Set an handler function to be invoked when a new member joins the cluster.
membership_listener & on_init(Handler &&h) &
Set an handler function to be invoked once when this listener is registered.