client_mananger.py
Go to the documentation of this file.
1 #!/usr/bin/env python
2 # Software License Agreement (BSD License)
3 #
4 # Copyright (c) 2018, Intermodalics
5 # All rights reserved.
6 #
7 # Redistribution and use in source and binary forms, with or without
8 # modification, are permitted provided that the following conditions
9 # are met:
10 #
11 # * Redistributions of source code must retain the above copyright
12 # notice, this list of conditions and the following disclaimer.
13 # * Redistributions in binary form must reproduce the above
14 # copyright notice, this list of conditions and the following
15 # disclaimer in the documentation and/or other materials provided
16 # with the distribution.
17 # * Neither the name of Intermodalics nor the names of its
18 # contributors may be used to endorse or promote products derived
19 # from this software without specific prior written permission.
20 #
21 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24 # FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25 # COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26 # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27 # BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28 # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29 # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31 # ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32 # POSSIBILITY OF SUCH DAMAGE.
33 import rospy
34 import threading
35 from rosbridge_msgs.msg import ConnectedClient, ConnectedClients
36 from std_msgs.msg import Int32
37 
38 
40  def __init__(self):
41  # Publisher for number of connected clients
42  self._client_count_pub = rospy.Publisher(
43  'client_count', Int32, queue_size=10, latch=True)
44  # Publisher for connected clients
45  self._conn_clients_pub = rospy.Publisher(
46  'connected_clients', ConnectedClients, queue_size=10, latch=True)
47  self._lock = threading.Lock()
48  self._client_count = 0
49  self._clients = {}
50  self.__publish()
51 
52  def __publish(self):
53  msg = ConnectedClients()
54  msg.clients = list(self._clients.values())
55  self._conn_clients_pub.publish(msg)
56  self._client_count_pub.publish(len(msg.clients))
57 
58  def add_client(self, client_id, ip_address):
59  with self._lock:
60  client = ConnectedClient()
61  client.ip_address = ip_address
62  client.connection_time = rospy.Time.now()
63  self._clients[client_id] = client
64  self.__publish()
65 
66  def remove_client(self, client_id, ip_address):
67  with self._lock:
68  self._clients.pop(client_id, None)
69  self.__publish()
def add_client(self, client_id, ip_address)
def remove_client(self, client_id, ip_address)


rosbridge_server
Author(s): Jonathan Mace
autogenerated on Wed Jun 3 2020 03:55:18