コード例 #1
0
ファイル: client.py プロジェクト: spaceone/circuits
 def send(self, event, destination, body, headers=None, receipt=None):
     LOG.debug("send()")
     if not self.connected:
         LOG.error("Can't send when Stomp is disconnected")
         self.fire(on_stomp_error(None, Exception("Message send attempted with stomp disconnected")))
         event.success = False
         return
     try:
         self._client.send(destination, body=body.encode('utf-8'), headers=headers, receipt=receipt)
         LOG.debug("Message sent")
     except StompConnectionError as err:
         event.success = False
         self.fire(disconnected())
     except StompError as err:
         LOG.error("Error sending ack")
         event.success = False
         self.fire(on_stomp_error(None, err))
コード例 #2
0
ファイル: client.py プロジェクト: yugonline/circuits
 def send(self, event, destination, body, headers=None, receipt=None):
     LOG.debug("send()")
     if not self.connected:
         LOG.error("Can't send when Stomp is disconnected")
         self.fire(on_stomp_error(None, Exception("Message send attempted with stomp disconnected")))
         event.success = False
         return
     try:
         self._client.send(destination, body=body.encode('utf-8'), headers=headers, receipt=receipt)
         LOG.debug("Message sent")
     except StompConnectionError:
         event.success = False
         self.fire(disconnected())
     except StompError as err:
         LOG.error("Error sending ack")
         event.success = False
         self.fire(on_stomp_error(None, err))
コード例 #3
0
ファイル: client.py プロジェクト: spaceone/circuits
 def ack_frame(self, event, frame):
     LOG.debug("ack_frame()")
     try:
         self._client.ack(frame)
         LOG.debug("Ack Sent")
     except StompConnectionError as err:
         LOG.error("Error sending ack")
         event.success = False
         self.fire(disconnected())
     except StompError as err:
         LOG.error("Error sending ack")
         event.success = False
         self.fire(on_stomp_error(frame, err))
コード例 #4
0
ファイル: client.py プロジェクト: yugonline/circuits
 def ack_frame(self, event, frame):
     LOG.debug("ack_frame()")
     try:
         self._client.ack(frame)
         LOG.debug("Ack Sent")
     except StompConnectionError:
         LOG.error("Error sending ack")
         event.success = False
         self.fire(disconnected())
     except StompError as err:
         LOG.error("Error sending ack")
         event.success = False
         self.fire(on_stomp_error(frame, err))
コード例 #5
0
ファイル: client.py プロジェクト: spaceone/circuits
 def _unsubscribe(self, event, destination):
     if destination not in self._subscribed:
         LOG.error("Unsubscribe Request Ignored. Not subscribed to %s", destination)
         return
     try:
         token = self._subscribed.pop(destination)
         frame = self._client.unsubscribe(token)
         LOG.debug("Unsubscribed: %s", frame)
     except StompConnectionError as err:
         event.success = False
         self.fire(disconnected())
     except StompError as err:
         LOG.error("Error sending ack")
         event.success = False
         self.fire(on_stomp_error(frame, err))
コード例 #6
0
ファイル: client.py プロジェクト: yugonline/circuits
 def _unsubscribe(self, event, destination):
     if destination not in self._subscribed:
         LOG.error("Unsubscribe Request Ignored. Not subscribed to %s", destination)
         return
     try:
         token = self._subscribed.pop(destination)
         frame = self._client.unsubscribe(token)
         LOG.debug("Unsubscribed: %s", frame)
     except StompConnectionError:
         event.success = False
         self.fire(disconnected())
     except StompError as err:
         LOG.error("Error sending ack")
         event.success = False
         self.fire(on_stomp_error(frame, err))
コード例 #7
0
ファイル: client.py プロジェクト: spaceone/circuits
 def _subscribe(self, event, destination, ack=ACK_CLIENT_INDIVIDUAL):
     if ack not in ACK_MODES:
         raise ValueError("Invalid client ack mode specified")
     LOG.info("Subscribe to message destination %s", destination)
     try:
         # Set ID to match destination name for easy reference later
         frame, token = self._client.subscribe(destination,
                                               headers={StompSpec.ACK_HEADER: ack,
                                                        'id': destination})
         self._subscribed[destination] = token
     except StompConnectionError as err:
         event.success = False
         self.fire(disconnected())
     except StompError as err:
         event.success = False
         LOG.debug(traceback.format_exc())
         self.fire(on_stomp_error(None, err))
コード例 #8
0
ファイル: client.py プロジェクト: yugonline/circuits
 def _subscribe(self, event, destination, ack=ACK_CLIENT_INDIVIDUAL):
     if ack not in ACK_MODES:
         raise ValueError("Invalid client ack mode specified")
     LOG.info("Subscribe to message destination %s", destination)
     try:
         # Set ID to match destination name for easy reference later
         frame, token = self._client.subscribe(destination,
                                               headers={StompSpec.ACK_HEADER: ack,
                                                        'id': destination})
         self._subscribed[destination] = token
     except StompConnectionError:
         event.success = False
         self.fire(disconnected())
     except StompError as err:
         event.success = False
         LOG.debug(traceback.format_exc())
         self.fire(on_stomp_error(None, err))