本文整理汇总了Python中fysom.Fysom.disconnect方法的典型用法代码示例。如果您正苦于以下问题:Python Fysom.disconnect方法的具体用法?Python Fysom.disconnect怎么用?Python Fysom.disconnect使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类fysom.Fysom
的用法示例。
在下文中一共展示了Fysom.disconnect方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: ErrorBase
# 需要导入模块: from fysom import Fysom [as 别名]
# 或者: from fysom.Fysom import disconnect [as 别名]
class ErrorBase(object):
def __init__(self, debuglevel=0, debugname='Error Base'):
self.debuglevel = debuglevel
self.debugname = debugname
self._error_string = ''
self.on_error_string_changed = []
# Error
self._error_channel = ErrorSubscribe(debuglevel=debuglevel)
self._error_channel.debugname = '%s - %s' % (self.debugname, 'error')
self._error_channel.on_state_changed.append(self._error_channel_state_changed)
self._error_channel.on_socket_message_received.append(
self._error_channel_message_received
)
# more efficient to reuse protobuf messages
self._error_rx = Container()
# callbacks
self.on_error_message_received = []
self.on_state_changed = []
# fsm
self._fsm = Fysom(
{
'initial': 'down',
'events': [
{'name': 'connect', 'src': 'down', 'dst': 'trying'},
{'name': 'error_up', 'src': 'trying', 'dst': 'up'},
{'name': 'disconnect', 'src': 'trying', 'dst': 'down'},
{'name': 'error_trying', 'src': 'up', 'dst': 'trying'},
{'name': 'disconnect', 'src': 'up', 'dst': 'down'},
],
}
)
self._fsm.ondown = self._on_fsm_down
self._fsm.onafterconnect = self._on_fsm_connect
self._fsm.ontrying = self._on_fsm_trying
self._fsm.onaftererror_up = self._on_fsm_error_up
self._fsm.onafterdisconnect = self._on_fsm_disconnect
self._fsm.onup = self._on_fsm_up
self._fsm.onaftererror_trying = self._on_fsm_error_trying
self._fsm.onenterup = self._on_fsm_up_entry
self._fsm.onleaveup = self._on_fsm_up_exit
def _on_fsm_down(self, _):
if self.debuglevel > 0:
print('[%s]: state DOWN' % self.debugname)
for cb in self.on_state_changed:
cb('down')
return True
def _on_fsm_connect(self, _):
if self.debuglevel > 0:
print('[%s]: event CONNECT' % self.debugname)
self.update_topics()
self.start_error_channel()
return True
def _on_fsm_trying(self, _):
if self.debuglevel > 0:
print('[%s]: state TRYING' % self.debugname)
for cb in self.on_state_changed:
cb('trying')
return True
def _on_fsm_error_up(self, _):
if self.debuglevel > 0:
print('[%s]: event ERROR UP' % self.debugname)
return True
def _on_fsm_disconnect(self, _):
if self.debuglevel > 0:
print('[%s]: event DISCONNECT' % self.debugname)
self.stop_error_channel()
return True
def _on_fsm_up(self, _):
if self.debuglevel > 0:
print('[%s]: state UP' % self.debugname)
for cb in self.on_state_changed:
cb('up')
return True
def _on_fsm_error_trying(self, _):
if self.debuglevel > 0:
print('[%s]: event ERROR TRYING' % self.debugname)
return True
def _on_fsm_up_entry(self, _):
if self.debuglevel > 0:
print('[%s]: state UP entry' % self.debugname)
self.set_connected()
return True
def _on_fsm_up_exit(self, _):
if self.debuglevel > 0:
print('[%s]: state UP exit' % self.debugname)
self.clear_connected()
return True
#.........这里部分代码省略.........
示例2: hsmsHandler
# 需要导入模块: from fysom import Fysom [as 别名]
# 或者: from fysom.Fysom import disconnect [as 别名]
class hsmsHandler(EventProducer):
"""Baseclass for creating Host/Equipment models. This layer contains the HSMS functionality. Inherit from this class and override required functions.
:param address: IP address of remote host
:type address: string
:param port: TCP port of remote host
:type port: integer
:param active: Is the connection active (*True*) or passive (*False*)
:type active: boolean
:param session_id: session / device ID to use for connection
:type session_id: integer
:param name: Name of the underlying configuration
:type name: string
:param event_handler: object for event handling
:type event_handler: :class:`secsgem.common.EventHandler`
:param custom_connection_handler: object for connection handling (ie multi server)
:type custom_connection_handler: :class:`secsgem.hsmsConnections.HsmsMultiPassiveServer`
**Example**::
import secsgem
def S1F1Handler(connection, packet):
print "S1F1 received"
def onConnect(event, data):
print "Connected"
client = secsgem.hsmsHandler("10.211.55.33", 5000, True, 0, "test", eventHandler=secsgem.EventHandler(events={'RemoteConnected': onConnect}))
client.registerCallback(1, 1, S1F1Handler)
client.enable()
time.sleep(3)
client.disable()
"""
def __init__(self, address, port, active, session_id, name, event_handler=None, custom_connection_handler=None):
EventProducer.__init__(self, event_handler)
self.logger = logging.getLogger(self.__module__ + "." + self.__class__.__name__)
self.address = address
self.port = port
self.active = active
self.sessionID = session_id
self.name = name
self.connected = False
# repeating linktest variables
self.linktestTimer = None
self.linktestTimeout = 30
# event and packet queues
self.eventQueue = []
self.packetQueue = []
# hsms connection state fsm
self.connectionState = Fysom({
'initial': 'NOT_CONNECTED',
'events': [
{'name': 'connect', 'src': 'NOT_CONNECTED', 'dst': 'CONNECTED'},
{'name': 'disconnect', 'src': ['CONNECTED', 'NOT_SELECTED', 'SELECTED'], 'dst': 'NOT_CONNECTED'},
{'name': 'select', 'src': 'NOT_SELECTED', 'dst': 'SELECTED'},
{'name': 'deselect', 'src': 'SELECTED', 'dst': 'NOT_SELECTED'},
{'name': 'timeoutT7', 'src': 'NOT_SELECTED', 'dst': 'NOT_CONNECTED'},
],
'callbacks': {
'onNOT_SELECTED': self._on_state_connect,
'onNOT_CONNECTED': self._on_state_disconnect,
'onSELECTED': self._on_state_select,
},
'autoforward': [
{'src': 'CONNECTED', 'dst': 'NOT_SELECTED'}
]
})
# setup connection
if self.active:
if custom_connection_handler is None:
self.connection = HsmsActiveConnection(self.address, self.port, self.sessionID, self)
else:
self.connection = custom_connection_handler.create_connection(self.address, self.port, self.sessionID, self)
else:
if custom_connection_handler is None:
self.connection = HsmsPassiveConnection(self.address, self.port, self.sessionID, self)
else:
self.connection = custom_connection_handler.create_connection(self.address, self.port, self.sessionID, self)
def _on_state_connect(self, data):
"""Connection state model got event connect
:param data: event attributes
:type data: object
"""
# start linktest timer
self.linktestTimer = threading.Timer(self.linktestTimeout, self._on_linktest_timer)
self.linktestTimer.start()
#.........这里部分代码省略.........