12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076 |
- """
- Generated by Statechart compiler by Glenn De Jonghe and Joeri Exelmans
- Date: Tue Jan 19 08:40:10 2016
- Model author: Yentl Van Tendeloo
- Model name: MvK Server interface
- Model description:
- MvK Server interface that receives events through the Socket2Event layer.
- Incoming messages are processed as HTTP requests and are forwarded to the MvK.
- """
- from python_runtime.statecharts_core import *
- import urlparse
- import urllib
- import sys
- import traceback
- import json
- from modelverse_state.main import ModelverseState
- # package "MvK Server interface"
- class Server(RuntimeClassBase):
- def __init__(self, controller, bootfile):
- RuntimeClassBase.__init__(self, controller)
-
- self.semantics.big_step_maximality = StatechartSemantics.TakeMany
- self.semantics.internal_event_lifeline = StatechartSemantics.Queue
- self.semantics.input_event_lifeline = StatechartSemantics.FirstComboStep
- self.semantics.priority = StatechartSemantics.SourceParent
- self.semantics.concurrency = StatechartSemantics.Single
-
- # Call user defined constructor
- Server.user_defined_constructor(self, bootfile)
-
- def user_defined_constructor(self, bootfile):
- self.socket = None
-
- self.processing_association_name = None
- self.processing_data = None
- self.queue = []
- self.mvs = ModelverseState(bootfile)
- self.mvs_operations = {
- "CN": self.mvs.create_node,
- "CE": self.mvs.create_edge,
- "CNV": self.mvs.create_nodevalue,
- "CD": self.mvs.create_dict,
-
- "RV": self.mvs.read_value,
- "RO": self.mvs.read_outgoing,
- "RI": self.mvs.read_incoming,
- "RE": self.mvs.read_edge,
- "RD": self.mvs.read_dict,
- "RDN": self.mvs.read_dict_node,
- "RDE": self.mvs.read_dict_edge,
- "RRD": self.mvs.read_reverse_dict,
- "RR": self.mvs.read_root,
- "RDK": self.mvs.read_dict_keys,
-
- "DE": self.mvs.delete_edge,
- "DN": self.mvs.delete_node,
-
- "DG": self.mvs.dump,
- }
-
- def user_defined_destructor(self):
- pass
-
-
- # User defined method
- def process_message(self, operation_name, parameters):
- op = self.mvs_operations[operation_name]
- return op(*parameters)
-
- def initializeStatechart(self):
- self.current_state[self.Root] = []
- self.current_state[self.Root_main] = []
- self.current_state[self.Root_main_queue] = []
- self.current_state[self.Root_main_processor] = []
- self.current_state[self.Root_main_server] = []
- self.current_state[self.Root_main_close_socket] = []
-
- # Enter default state
- self.enterDefault_Root_main()
-
- # Unique IDs for all statechart nodes
- Root = 0
- Root_main = 1
- Root_main_queue = 2
- Root_main_processor = 3
- Root_main_server = 4
- Root_main_close_socket = 5
- Root_main_queue_queue = 6
- Root_main_processor_wait_for_input = 7
- Root_main_processor_process_input = 8
- Root_main_server_init = 9
- Root_main_server_binding = 10
- Root_main_server_listening = 11
- Root_main_server_accepting = 12
- Root_main_close_socket_close = 13
-
- # Statechart enter/exit action method(s)
-
- def enter_Root_main(self):
- self.current_state[self.Root].append(self.Root_main)
-
- def exit_Root_main(self):
- self.exit_Root_main_queue()
- self.exit_Root_main_processor()
- self.exit_Root_main_server()
- self.exit_Root_main_close_socket()
- self.current_state[self.Root] = []
-
- def enter_Root_main_queue(self):
- self.current_state[self.Root_main].append(self.Root_main_queue)
-
- def exit_Root_main_queue(self):
- if self.Root_main_queue_queue in self.current_state[self.Root_main_queue]:
- self.exit_Root_main_queue_queue()
- self.current_state[self.Root_main] = []
-
- def enter_Root_main_processor(self):
- self.current_state[self.Root_main].append(self.Root_main_processor)
-
- def exit_Root_main_processor(self):
- if self.Root_main_processor_wait_for_input in self.current_state[self.Root_main_processor]:
- self.exit_Root_main_processor_wait_for_input()
- if self.Root_main_processor_process_input in self.current_state[self.Root_main_processor]:
- self.exit_Root_main_processor_process_input()
- self.current_state[self.Root_main] = []
-
- def enter_Root_main_server(self):
- self.current_state[self.Root_main].append(self.Root_main_server)
-
- def exit_Root_main_server(self):
- if self.Root_main_server_init in self.current_state[self.Root_main_server]:
- self.exit_Root_main_server_init()
- if self.Root_main_server_binding in self.current_state[self.Root_main_server]:
- self.exit_Root_main_server_binding()
- if self.Root_main_server_listening in self.current_state[self.Root_main_server]:
- self.exit_Root_main_server_listening()
- if self.Root_main_server_accepting in self.current_state[self.Root_main_server]:
- self.exit_Root_main_server_accepting()
- self.current_state[self.Root_main] = []
-
- def enter_Root_main_close_socket(self):
- self.current_state[self.Root_main].append(self.Root_main_close_socket)
-
- def exit_Root_main_close_socket(self):
- if self.Root_main_close_socket_close in self.current_state[self.Root_main_close_socket]:
- self.exit_Root_main_close_socket_close()
- self.current_state[self.Root_main] = []
-
- def enter_Root_main_queue_queue(self):
- self.current_state[self.Root_main_queue].append(self.Root_main_queue_queue)
-
- def exit_Root_main_queue_queue(self):
- self.current_state[self.Root_main_queue] = []
-
- def enter_Root_main_processor_wait_for_input(self):
- self.current_state[self.Root_main_processor].append(self.Root_main_processor_wait_for_input)
-
- def exit_Root_main_processor_wait_for_input(self):
- self.current_state[self.Root_main_processor] = []
-
- def enter_Root_main_processor_process_input(self):
- self.current_state[self.Root_main_processor].append(self.Root_main_processor_process_input)
-
- def exit_Root_main_processor_process_input(self):
- self.current_state[self.Root_main_processor] = []
-
- def enter_Root_main_server_init(self):
- self.big_step.outputEvent(Event("create_socket", "socket_out", []))
- self.current_state[self.Root_main_server].append(self.Root_main_server_init)
-
- def exit_Root_main_server_init(self):
- self.current_state[self.Root_main_server] = []
-
- def enter_Root_main_server_binding(self):
- self.big_step.outputEvent(Event("bind_socket", "socket_out", [self.socket, ('', 8000)]))
- self.current_state[self.Root_main_server].append(self.Root_main_server_binding)
-
- def exit_Root_main_server_binding(self):
- self.current_state[self.Root_main_server] = []
-
- def enter_Root_main_server_listening(self):
- self.big_step.outputEvent(Event("listen_socket", "socket_out", [self.socket]))
- self.current_state[self.Root_main_server].append(self.Root_main_server_listening)
-
- def exit_Root_main_server_listening(self):
- self.current_state[self.Root_main_server] = []
-
- def enter_Root_main_server_accepting(self):
- self.big_step.outputEvent(Event("accept_socket", "socket_out", [self.socket]))
- self.current_state[self.Root_main_server].append(self.Root_main_server_accepting)
-
- def exit_Root_main_server_accepting(self):
- self.current_state[self.Root_main_server] = []
-
- def enter_Root_main_close_socket_close(self):
- self.current_state[self.Root_main_close_socket].append(self.Root_main_close_socket_close)
-
- def exit_Root_main_close_socket_close(self):
- self.current_state[self.Root_main_close_socket] = []
-
- # Statechart enter/exit default method(s)
-
- def enterDefault_Root_main(self):
- self.enter_Root_main()
- self.enterDefault_Root_main_queue()
- self.enterDefault_Root_main_processor()
- self.enterDefault_Root_main_server()
- self.enterDefault_Root_main_close_socket()
-
- def enterDefault_Root_main_queue(self):
- self.enter_Root_main_queue()
- self.enter_Root_main_queue_queue()
-
- def enterDefault_Root_main_processor(self):
- self.enter_Root_main_processor()
- self.enter_Root_main_processor_wait_for_input()
-
- def enterDefault_Root_main_server(self):
- self.enter_Root_main_server()
- self.enter_Root_main_server_init()
-
- def enterDefault_Root_main_close_socket(self):
- self.enter_Root_main_close_socket()
- self.enter_Root_main_close_socket_close()
-
- # Statechart transitions
-
- def generateCandidatesChildren_Root(self):
- if self.current_state[self.Root][0] == self.Root_main:
- return self.generateCandidates_Root_main()
- return False
-
- def generateCandidates_Root(self):
- if not self.combo_step.isArenaChanged(self.Root):
- return self.generateCandidatesChildren_Root()
- else:
- return True
-
- def generateCandidatesChildren_Root_main(self):
- branch_done = False
- branch_done = (self.generateCandidates_Root_main_queue() or branch_done)
- branch_done = (self.generateCandidates_Root_main_processor() or branch_done)
- branch_done = (self.generateCandidates_Root_main_server() or branch_done)
- branch_done = (self.generateCandidates_Root_main_close_socket() or branch_done)
- return branch_done
-
- def generateCandidates_Root_main(self):
- if not self.combo_step.isArenaChanged(self.Root_main):
- return self.generateCandidatesChildren_Root_main()
- else:
- return True
-
- def generateCandidatesChildren_Root_main_queue(self):
- if self.current_state[self.Root_main_queue][0] == self.Root_main_queue_queue:
- return self.generateCandidates_Root_main_queue_queue()
- return False
-
- def generateCandidates_Root_main_queue(self):
- if not self.combo_step.isArenaChanged(self.Root_main_queue):
- return self.generateCandidatesChildren_Root_main_queue()
- else:
- return True
-
- def generateCandidatesCurrent_Root_main_queue_queue(self):
- enabled_events = self.getEnabledEvents()
- for e in enabled_events:
- if e.name == "HTTP_output":
- self.small_step.addCandidate(self.transition_Root_main_queue_queue_1, e.parameters)
- return True
- return False
-
- def generateCandidates_Root_main_queue_queue(self):
- if not self.combo_step.isArenaChanged(self.Root_main_queue_queue):
- return self.generateCandidatesCurrent_Root_main_queue_queue()
- else:
- return True
-
- def transition_Root_main_queue_queue_1(self, parameters):
- association_name = parameters[0]
- data = parameters[1]
- self.exit_Root_main_queue_queue()
- self.queue.append((association_name, data))
- self.combo_step.setArenaChanged(self.Root_main_queue)
- self.enter_Root_main_queue_queue()
-
- def generateCandidatesChildren_Root_main_processor(self):
- if self.current_state[self.Root_main_processor][0] == self.Root_main_processor_wait_for_input:
- return self.generateCandidates_Root_main_processor_wait_for_input()
- elif self.current_state[self.Root_main_processor][0] == self.Root_main_processor_process_input:
- return self.generateCandidates_Root_main_processor_process_input()
- return False
-
- def generateCandidates_Root_main_processor(self):
- if not self.combo_step.isArenaChanged(self.Root_main_processor):
- return self.generateCandidatesChildren_Root_main_processor()
- else:
- return True
-
- def generateCandidatesCurrent_Root_main_processor_wait_for_input(self):
- enabled_events = self.getEnabledEvents()
- if len(self.queue) > 0:
- self.small_step.addCandidate(self.transition_Root_main_processor_wait_for_input_1, [])
- return True
- return False
-
- def generateCandidates_Root_main_processor_wait_for_input(self):
- if not self.combo_step.isArenaChanged(self.Root_main_processor_wait_for_input):
- return self.generateCandidatesCurrent_Root_main_processor_wait_for_input()
- else:
- return True
-
- def transition_Root_main_processor_wait_for_input_1(self, parameters):
- self.exit_Root_main_processor_wait_for_input()
- self.processing_association_name, self.processing_data = self.queue.pop(0)
- try:
- self.processing_data = json.loads(self.processing_data["requests"])
- except:
- print("Error in deserialization: " + str(self.processing_data))
- self.combo_step.setArenaChanged(self.Root_main_processor)
- self.enter_Root_main_processor_process_input()
-
- def generateCandidatesCurrent_Root_main_processor_process_input(self):
- enabled_events = self.getEnabledEvents()
- self.small_step.addCandidate(self.transition_Root_main_processor_process_input_1, [])
- return True
- return False
-
- def generateCandidates_Root_main_processor_process_input(self):
- if not self.combo_step.isArenaChanged(self.Root_main_processor_process_input):
- return self.generateCandidatesCurrent_Root_main_processor_process_input()
- else:
- return True
-
- def transition_Root_main_processor_process_input_1(self, parameters):
- self.exit_Root_main_processor_process_input()
- reply = []
- print(self.processing_data)
- for op, params in self.processing_data:
- try:
- result = self.process_message(op, params)
- try:
- reply.append(result)
- except:
- traceback.print_exc()
- reply.append([None, 496])
- except:
- traceback.print_exc()
- reply.append([None, 497])
- self.big_step.outputEventOM(Event("narrow_cast", None, [self, self.processing_association_name, Event("HTTP_input", None, [{'data': json.dumps(reply)}])]))
- self.combo_step.setArenaChanged(self.Root_main_processor)
- self.enter_Root_main_processor_wait_for_input()
-
- def generateCandidatesChildren_Root_main_server(self):
- if self.current_state[self.Root_main_server][0] == self.Root_main_server_init:
- return self.generateCandidates_Root_main_server_init()
- elif self.current_state[self.Root_main_server][0] == self.Root_main_server_binding:
- return self.generateCandidates_Root_main_server_binding()
- elif self.current_state[self.Root_main_server][0] == self.Root_main_server_listening:
- return self.generateCandidates_Root_main_server_listening()
- elif self.current_state[self.Root_main_server][0] == self.Root_main_server_accepting:
- return self.generateCandidates_Root_main_server_accepting()
- return False
-
- def generateCandidates_Root_main_server(self):
- if not self.combo_step.isArenaChanged(self.Root_main_server):
- return self.generateCandidatesChildren_Root_main_server()
- else:
- return True
-
- def generateCandidatesCurrent_Root_main_server_init(self):
- enabled_events = self.getEnabledEvents()
- for e in enabled_events:
- if (e.name == "created_socket") and (e.port == "socket_in"):
- self.small_step.addCandidate(self.transition_Root_main_server_init_1, e.parameters)
- return True
- return False
-
- def generateCandidates_Root_main_server_init(self):
- if not self.combo_step.isArenaChanged(self.Root_main_server_init):
- return self.generateCandidatesCurrent_Root_main_server_init()
- else:
- return True
-
- def transition_Root_main_server_init_1(self, parameters):
- socket = parameters[0]
- self.exit_Root_main_server_init()
- self.socket = socket
- self.combo_step.setArenaChanged(self.Root_main_server)
- self.enter_Root_main_server_binding()
-
- def generateCandidatesCurrent_Root_main_server_binding(self):
- enabled_events = self.getEnabledEvents()
- for e in enabled_events:
- if (e.name == "bound_socket") and (e.port == "socket_in"):
- parameters = e.parameters
- socket = parameters[0]
- if self.socket == socket:
- self.small_step.addCandidate(self.transition_Root_main_server_binding_1, e.parameters)
- return True
- return False
-
- def generateCandidates_Root_main_server_binding(self):
- if not self.combo_step.isArenaChanged(self.Root_main_server_binding):
- return self.generateCandidatesCurrent_Root_main_server_binding()
- else:
- return True
-
- def transition_Root_main_server_binding_1(self, parameters):
- socket = parameters[0]
- self.exit_Root_main_server_binding()
- self.combo_step.setArenaChanged(self.Root_main_server)
- self.enter_Root_main_server_listening()
-
- def generateCandidatesCurrent_Root_main_server_listening(self):
- enabled_events = self.getEnabledEvents()
- for e in enabled_events:
- if (e.name == "listened_socket") and (e.port == "socket_in"):
- parameters = e.parameters
- socket = parameters[0]
- if self.socket == socket:
- self.small_step.addCandidate(self.transition_Root_main_server_listening_1, e.parameters)
- return True
- return False
-
- def generateCandidates_Root_main_server_listening(self):
- if not self.combo_step.isArenaChanged(self.Root_main_server_listening):
- return self.generateCandidatesCurrent_Root_main_server_listening()
- else:
- return True
-
- def transition_Root_main_server_listening_1(self, parameters):
- socket = parameters[0]
- self.exit_Root_main_server_listening()
- self.combo_step.setArenaChanged(self.Root_main_server)
- self.enter_Root_main_server_accepting()
-
- def generateCandidatesCurrent_Root_main_server_accepting(self):
- enabled_events = self.getEnabledEvents()
- for e in enabled_events:
- if (e.name == "accepted_socket") and (e.port == "socket_in"):
- parameters = e.parameters
- socket = parameters[0]
- connected_socket = parameters[1]
- if self.socket == socket:
- self.small_step.addCandidate(self.transition_Root_main_server_accepting_1, e.parameters)
- return True
- enabled_events = self.getEnabledEvents()
- for e in enabled_events:
- if e.name == "instance_created":
- self.small_step.addCandidate(self.transition_Root_main_server_accepting_2, e.parameters)
- return True
- return False
-
- def generateCandidates_Root_main_server_accepting(self):
- if not self.combo_step.isArenaChanged(self.Root_main_server_accepting):
- return self.generateCandidatesCurrent_Root_main_server_accepting()
- else:
- return True
-
- def transition_Root_main_server_accepting_1(self, parameters):
- socket = parameters[0]
- connected_socket = parameters[1]
- self.exit_Root_main_server_accepting()
- self.big_step.outputEventOM(Event("create_instance", None, [self, 'sockets', 'Socket', connected_socket]))
- self.combo_step.setArenaChanged(self.Root_main_server)
- self.enter_Root_main_server_accepting()
-
- def transition_Root_main_server_accepting_2(self, parameters):
- instancename = parameters[0]
- self.exit_Root_main_server_accepting()
- self.big_step.outputEventOM(Event("start_instance", None, [self, instancename]))
- self.big_step.outputEventOM(Event("narrow_cast", None, [self, instancename, Event("set_association_name", None, [instancename])]))
- self.combo_step.setArenaChanged(self.Root_main_server)
- self.enter_Root_main_server_accepting()
-
- def generateCandidatesChildren_Root_main_close_socket(self):
- if self.current_state[self.Root_main_close_socket][0] == self.Root_main_close_socket_close:
- return self.generateCandidates_Root_main_close_socket_close()
- return False
-
- def generateCandidates_Root_main_close_socket(self):
- if not self.combo_step.isArenaChanged(self.Root_main_close_socket):
- return self.generateCandidatesChildren_Root_main_close_socket()
- else:
- return True
-
- def generateCandidatesCurrent_Root_main_close_socket_close(self):
- enabled_events = self.getEnabledEvents()
- for e in enabled_events:
- if e.name == "close":
- self.small_step.addCandidate(self.transition_Root_main_close_socket_close_1, e.parameters)
- return True
- return False
-
- def generateCandidates_Root_main_close_socket_close(self):
- if not self.combo_step.isArenaChanged(self.Root_main_close_socket_close):
- return self.generateCandidatesCurrent_Root_main_close_socket_close()
- else:
- return True
-
- def transition_Root_main_close_socket_close_1(self, parameters):
- association_name = parameters[0]
- self.exit_Root_main_close_socket_close()
- self.big_step.outputEventOM(Event("delete_instance", None, [self, association_name]))
- self.combo_step.setArenaChanged(self.Root_main_close_socket)
- self.enter_Root_main_close_socket_close()
-
- # Generate transition candidates for current small step
- def generateCandidates(self):
- self.generateCandidates_Root()
- class Socket(RuntimeClassBase):
- def __init__(self, controller, my_socket):
- RuntimeClassBase.__init__(self, controller)
-
- self.semantics.big_step_maximality = StatechartSemantics.TakeMany
- self.semantics.internal_event_lifeline = StatechartSemantics.Queue
- self.semantics.input_event_lifeline = StatechartSemantics.FirstComboStep
- self.semantics.priority = StatechartSemantics.SourceParent
- self.semantics.concurrency = StatechartSemantics.Single
-
- # Call user defined constructor
- Socket.user_defined_constructor(self, my_socket)
-
- def user_defined_constructor(self, my_socket):
- self.socket = my_socket
- self.received_data = ""
- self.send_data = ""
- self.closed = False
- self.association_name = None
-
- def user_defined_destructor(self):
- pass
-
- def initializeStatechart(self):
- self.current_state[self.Root] = []
- self.current_state[self.Root_connected] = []
- self.current_state[self.Root_connected_listening] = []
- self.current_state[self.Root_connected_sending] = []
- self.current_state[self.Root_connected_queueing] = []
- self.current_state[self.Root_connected_parsing] = []
-
- # Enter default state
- self.enter_Root_init()
-
- # Unique IDs for all statechart nodes
- Root = 0
- Root_connected = 1
- Root_connected_listening = 2
- Root_connected_sending = 3
- Root_connected_queueing = 4
- Root_connected_parsing = 5
- Root_init = 6
- Root_connected_listening_listen = 7
- Root_connected_listening_closed = 8
- Root_connected_sending_waiting_for_data = 9
- Root_connected_sending_transferring = 10
- Root_connected_queueing_queueing = 11
- Root_connected_parsing_wait_for_header = 12
- Root_connected_parsing_closing = 13
- Root_connected_parsing_wait_for_payload = 14
- Root_close = 15
-
- # Statechart enter/exit action method(s)
-
- def enter_Root_connected(self):
- self.current_state[self.Root].append(self.Root_connected)
-
- def exit_Root_connected(self):
- self.exit_Root_connected_listening()
- self.exit_Root_connected_sending()
- self.exit_Root_connected_queueing()
- self.exit_Root_connected_parsing()
- self.current_state[self.Root] = []
-
- def enter_Root_connected_listening(self):
- self.current_state[self.Root_connected].append(self.Root_connected_listening)
-
- def exit_Root_connected_listening(self):
- if self.Root_connected_listening_listen in self.current_state[self.Root_connected_listening]:
- self.exit_Root_connected_listening_listen()
- if self.Root_connected_listening_closed in self.current_state[self.Root_connected_listening]:
- self.exit_Root_connected_listening_closed()
- self.current_state[self.Root_connected] = []
-
- def enter_Root_connected_sending(self):
- self.current_state[self.Root_connected].append(self.Root_connected_sending)
-
- def exit_Root_connected_sending(self):
- if self.Root_connected_sending_waiting_for_data in self.current_state[self.Root_connected_sending]:
- self.exit_Root_connected_sending_waiting_for_data()
- if self.Root_connected_sending_transferring in self.current_state[self.Root_connected_sending]:
- self.exit_Root_connected_sending_transferring()
- self.current_state[self.Root_connected] = []
-
- def enter_Root_connected_queueing(self):
- self.current_state[self.Root_connected].append(self.Root_connected_queueing)
-
- def exit_Root_connected_queueing(self):
- if self.Root_connected_queueing_queueing in self.current_state[self.Root_connected_queueing]:
- self.exit_Root_connected_queueing_queueing()
- self.current_state[self.Root_connected] = []
-
- def enter_Root_connected_parsing(self):
- self.current_state[self.Root_connected].append(self.Root_connected_parsing)
-
- def exit_Root_connected_parsing(self):
- if self.Root_connected_parsing_wait_for_header in self.current_state[self.Root_connected_parsing]:
- self.exit_Root_connected_parsing_wait_for_header()
- if self.Root_connected_parsing_closing in self.current_state[self.Root_connected_parsing]:
- self.exit_Root_connected_parsing_closing()
- if self.Root_connected_parsing_wait_for_payload in self.current_state[self.Root_connected_parsing]:
- self.exit_Root_connected_parsing_wait_for_payload()
- self.current_state[self.Root_connected] = []
-
- def enter_Root_init(self):
- self.current_state[self.Root].append(self.Root_init)
-
- def exit_Root_init(self):
- self.current_state[self.Root] = []
-
- def enter_Root_connected_listening_listen(self):
- self.big_step.outputEvent(Event("recv_socket", "socket_out", [self.socket]))
- self.current_state[self.Root_connected_listening].append(self.Root_connected_listening_listen)
-
- def exit_Root_connected_listening_listen(self):
- self.current_state[self.Root_connected_listening] = []
-
- def enter_Root_connected_listening_closed(self):
- self.closed = True
- self.current_state[self.Root_connected_listening].append(self.Root_connected_listening_closed)
-
- def exit_Root_connected_listening_closed(self):
- self.current_state[self.Root_connected_listening] = []
-
- def enter_Root_connected_sending_waiting_for_data(self):
- self.current_state[self.Root_connected_sending].append(self.Root_connected_sending_waiting_for_data)
-
- def exit_Root_connected_sending_waiting_for_data(self):
- self.current_state[self.Root_connected_sending] = []
-
- def enter_Root_connected_sending_transferring(self):
- self.current_state[self.Root_connected_sending].append(self.Root_connected_sending_transferring)
-
- def exit_Root_connected_sending_transferring(self):
- self.current_state[self.Root_connected_sending] = []
-
- def enter_Root_connected_queueing_queueing(self):
- self.current_state[self.Root_connected_queueing].append(self.Root_connected_queueing_queueing)
-
- def exit_Root_connected_queueing_queueing(self):
- self.current_state[self.Root_connected_queueing] = []
-
- def enter_Root_connected_parsing_wait_for_header(self):
- self.current_state[self.Root_connected_parsing].append(self.Root_connected_parsing_wait_for_header)
-
- def exit_Root_connected_parsing_wait_for_header(self):
- self.current_state[self.Root_connected_parsing] = []
-
- def enter_Root_connected_parsing_closing(self):
- self.timers[0] = 0.0
- self.current_state[self.Root_connected_parsing].append(self.Root_connected_parsing_closing)
-
- def exit_Root_connected_parsing_closing(self):
- self.timers.pop(0, None)
- self.current_state[self.Root_connected_parsing] = []
-
- def enter_Root_connected_parsing_wait_for_payload(self):
- self.current_state[self.Root_connected_parsing].append(self.Root_connected_parsing_wait_for_payload)
-
- def exit_Root_connected_parsing_wait_for_payload(self):
- self.current_state[self.Root_connected_parsing] = []
-
- def enter_Root_close(self):
- self.big_step.outputEvent(Event("close_socket", "socket_out", [self.socket]))
- self.big_step.outputEventOM(Event("narrow_cast", None, [self, 'parent', Event("close_socket", None, [self.association_name])]))
- self.current_state[self.Root].append(self.Root_close)
-
- def exit_Root_close(self):
- self.current_state[self.Root] = []
-
- # Statechart enter/exit default method(s)
-
- def enterDefault_Root_connected(self):
- self.enter_Root_connected()
- self.enterDefault_Root_connected_listening()
- self.enterDefault_Root_connected_sending()
- self.enterDefault_Root_connected_queueing()
- self.enterDefault_Root_connected_parsing()
-
- def enterDefault_Root_connected_listening(self):
- self.enter_Root_connected_listening()
- self.enter_Root_connected_listening_listen()
-
- def enterDefault_Root_connected_sending(self):
- self.enter_Root_connected_sending()
- self.enter_Root_connected_sending_waiting_for_data()
-
- def enterDefault_Root_connected_queueing(self):
- self.enter_Root_connected_queueing()
- self.enter_Root_connected_queueing_queueing()
-
- def enterDefault_Root_connected_parsing(self):
- self.enter_Root_connected_parsing()
- self.enter_Root_connected_parsing_wait_for_header()
-
- # Statechart transitions
-
- def generateCandidatesChildren_Root(self):
- if self.current_state[self.Root][0] == self.Root_init:
- return self.generateCandidates_Root_init()
- elif self.current_state[self.Root][0] == self.Root_connected:
- return self.generateCandidates_Root_connected()
- elif self.current_state[self.Root][0] == self.Root_close:
- return self.generateCandidates_Root_close()
- return False
-
- def generateCandidates_Root(self):
- if not self.combo_step.isArenaChanged(self.Root):
- return self.generateCandidatesChildren_Root()
- else:
- return True
-
- def generateCandidatesCurrent_Root_init(self):
- enabled_events = self.getEnabledEvents()
- for e in enabled_events:
- if e.name == "set_association_name":
- self.small_step.addCandidate(self.transition_Root_init_1, e.parameters)
- return True
- return False
-
- def generateCandidates_Root_init(self):
- if not self.combo_step.isArenaChanged(self.Root_init):
- return self.generateCandidatesCurrent_Root_init()
- else:
- return True
-
- def transition_Root_init_1(self, parameters):
- association_name = parameters[0]
- self.exit_Root_init()
- self.association_name = association_name
- self.combo_step.setArenaChanged(self.Root)
- self.enterDefault_Root_connected()
-
- def generateCandidatesChildren_Root_connected(self):
- branch_done = False
- branch_done = (self.generateCandidates_Root_connected_listening() or branch_done)
- branch_done = (self.generateCandidates_Root_connected_sending() or branch_done)
- branch_done = (self.generateCandidates_Root_connected_queueing() or branch_done)
- branch_done = (self.generateCandidates_Root_connected_parsing() or branch_done)
- return branch_done
-
- def generateCandidatesCurrent_Root_connected(self):
- enabled_events = self.getEnabledEvents()
- for e in enabled_events:
- if e.name == "close":
- self.small_step.addCandidate(self.transition_Root_connected_1, e.parameters)
- return True
- return False
-
- def generateCandidates_Root_connected(self):
- if not self.combo_step.isArenaChanged(self.Root_connected):
- branch_done = False
- if self.semantics.priority == StatechartSemantics.SourceParent:
- branch_done = self.generateCandidatesCurrent_Root_connected()
- if not branch_done:
- branch_done = self.generateCandidatesChildren_Root_connected()
- elif self.semantics.priority == StatechartSemantics.SourceChild:
- branch_done = self.generateCandidatesChildren_Root_connected()
- if not branch_done:
- branch_done = self.generateCandidatesCurrent_Root_connected()
- return branch_done
- else:
- return True
-
- def transition_Root_connected_1(self, parameters):
- self.exit_Root_connected()
- self.combo_step.setArenaChanged(self.Root)
- self.enter_Root_close()
-
- def generateCandidatesChildren_Root_connected_listening(self):
- if self.current_state[self.Root_connected_listening][0] == self.Root_connected_listening_listen:
- return self.generateCandidates_Root_connected_listening_listen()
- elif self.current_state[self.Root_connected_listening][0] == self.Root_connected_listening_closed:
- return self.generateCandidates_Root_connected_listening_closed()
- return False
-
- def generateCandidates_Root_connected_listening(self):
- if not self.combo_step.isArenaChanged(self.Root_connected_listening):
- return self.generateCandidatesChildren_Root_connected_listening()
- else:
- return True
-
- def generateCandidatesCurrent_Root_connected_listening_listen(self):
- enabled_events = self.getEnabledEvents()
- for e in enabled_events:
- if (e.name == "received_socket") and (e.port == "socket_in"):
- parameters = e.parameters
- socket = parameters[0]
- data = parameters[1]
- if (self.socket == socket) and (len(data) > 0):
- self.small_step.addCandidate(self.transition_Root_connected_listening_listen_1, e.parameters)
- return True
- enabled_events = self.getEnabledEvents()
- for e in enabled_events:
- if (e.name == "received_socket") and (e.port == "socket_in"):
- parameters = e.parameters
- socket = parameters[0]
- data = parameters[1]
- if (self.socket == socket) and (len(data) == 0):
- self.small_step.addCandidate(self.transition_Root_connected_listening_listen_2, e.parameters)
- return True
- return False
-
- def generateCandidates_Root_connected_listening_listen(self):
- if not self.combo_step.isArenaChanged(self.Root_connected_listening_listen):
- return self.generateCandidatesCurrent_Root_connected_listening_listen()
- else:
- return True
-
- def transition_Root_connected_listening_listen_1(self, parameters):
- socket = parameters[0]
- data = parameters[1]
- self.exit_Root_connected_listening_listen()
- self.received_data += data
- self.raiseInternalEvent(Event("received_data", None, []))
- self.combo_step.setArenaChanged(self.Root_connected_listening)
- self.enter_Root_connected_listening_listen()
-
- def transition_Root_connected_listening_listen_2(self, parameters):
- socket = parameters[0]
- data = parameters[1]
- self.exit_Root_connected_listening_listen()
- self.raiseInternalEvent(Event("received_data", None, []))
- self.combo_step.setArenaChanged(self.Root_connected_listening)
- self.enter_Root_connected_listening_closed()
-
- def generateCandidates_Root_connected_listening_closed(self):
- return False
-
- def generateCandidatesChildren_Root_connected_sending(self):
- if self.current_state[self.Root_connected_sending][0] == self.Root_connected_sending_waiting_for_data:
- return self.generateCandidates_Root_connected_sending_waiting_for_data()
- elif self.current_state[self.Root_connected_sending][0] == self.Root_connected_sending_transferring:
- return self.generateCandidates_Root_connected_sending_transferring()
- return False
-
- def generateCandidates_Root_connected_sending(self):
- if not self.combo_step.isArenaChanged(self.Root_connected_sending):
- return self.generateCandidatesChildren_Root_connected_sending()
- else:
- return True
-
- def generateCandidatesCurrent_Root_connected_sending_waiting_for_data(self):
- enabled_events = self.getEnabledEvents()
- if len(self.send_data) > 0:
- self.small_step.addCandidate(self.transition_Root_connected_sending_waiting_for_data_1, [])
- return True
- return False
-
- def generateCandidates_Root_connected_sending_waiting_for_data(self):
- if not self.combo_step.isArenaChanged(self.Root_connected_sending_waiting_for_data):
- return self.generateCandidatesCurrent_Root_connected_sending_waiting_for_data()
- else:
- return True
-
- def transition_Root_connected_sending_waiting_for_data_1(self, parameters):
- self.exit_Root_connected_sending_waiting_for_data()
- self.big_step.outputEvent(Event("send_socket", "socket_out", [self.socket, self.send_data]))
- self.combo_step.setArenaChanged(self.Root_connected_sending)
- self.enter_Root_connected_sending_transferring()
-
- def generateCandidatesCurrent_Root_connected_sending_transferring(self):
- enabled_events = self.getEnabledEvents()
- for e in enabled_events:
- if (e.name == "sent_socket") and (e.port == "socket_in"):
- parameters = e.parameters
- socket = parameters[0]
- sent_bytes = parameters[1]
- if self.socket == socket:
- self.small_step.addCandidate(self.transition_Root_connected_sending_transferring_1, e.parameters)
- return True
- return False
-
- def generateCandidates_Root_connected_sending_transferring(self):
- if not self.combo_step.isArenaChanged(self.Root_connected_sending_transferring):
- return self.generateCandidatesCurrent_Root_connected_sending_transferring()
- else:
- return True
-
- def transition_Root_connected_sending_transferring_1(self, parameters):
- socket = parameters[0]
- sent_bytes = parameters[1]
- self.exit_Root_connected_sending_transferring()
- self.send_data = self.send_data[sent_bytes:]
- self.combo_step.setArenaChanged(self.Root_connected_sending)
- self.enter_Root_connected_sending_waiting_for_data()
-
- def generateCandidatesChildren_Root_connected_queueing(self):
- if self.current_state[self.Root_connected_queueing][0] == self.Root_connected_queueing_queueing:
- return self.generateCandidates_Root_connected_queueing_queueing()
- return False
-
- def generateCandidates_Root_connected_queueing(self):
- if not self.combo_step.isArenaChanged(self.Root_connected_queueing):
- return self.generateCandidatesChildren_Root_connected_queueing()
- else:
- return True
-
- def generateCandidatesCurrent_Root_connected_queueing_queueing(self):
- enabled_events = self.getEnabledEvents()
- for e in enabled_events:
- if e.name == "HTTP_input":
- self.small_step.addCandidate(self.transition_Root_connected_queueing_queueing_1, e.parameters)
- return True
- return False
-
- def generateCandidates_Root_connected_queueing_queueing(self):
- if not self.combo_step.isArenaChanged(self.Root_connected_queueing_queueing):
- return self.generateCandidatesCurrent_Root_connected_queueing_queueing()
- else:
- return True
-
- def transition_Root_connected_queueing_queueing_1(self, parameters):
- data = parameters[0]
- self.exit_Root_connected_queueing_queueing()
- post_data = "&".join(["%s=%s" % (k, v) for k, v in data.iteritems()])
- self.send_data += "HTTP/1.0 200 OK\r\n"
- self.send_data += "Content-Length: %s\r\n" % len(post_data)
- self.send_data += "Content-Type: %s; charset=UTF-8\r\n" % "text/plain"
- self.send_data += "\r\n"
- self.send_data += str(post_data)
- self.combo_step.setArenaChanged(self.Root_connected_queueing)
- self.enter_Root_connected_queueing_queueing()
-
- def generateCandidatesChildren_Root_connected_parsing(self):
- if self.current_state[self.Root_connected_parsing][0] == self.Root_connected_parsing_wait_for_header:
- return self.generateCandidates_Root_connected_parsing_wait_for_header()
- elif self.current_state[self.Root_connected_parsing][0] == self.Root_connected_parsing_closing:
- return self.generateCandidates_Root_connected_parsing_closing()
- elif self.current_state[self.Root_connected_parsing][0] == self.Root_connected_parsing_wait_for_payload:
- return self.generateCandidates_Root_connected_parsing_wait_for_payload()
- return False
-
- def generateCandidates_Root_connected_parsing(self):
- if not self.combo_step.isArenaChanged(self.Root_connected_parsing):
- return self.generateCandidatesChildren_Root_connected_parsing()
- else:
- return True
-
- def generateCandidatesCurrent_Root_connected_parsing_wait_for_header(self):
- enabled_events = self.getEnabledEvents()
- if '\r\n\r\n' in self.received_data and self.received_data.startswith('POST'):
- self.small_step.addCandidate(self.transition_Root_connected_parsing_wait_for_header_1, [])
- return True
- enabled_events = self.getEnabledEvents()
- if self.closed and len(self.received_data) == 0:
- self.small_step.addCandidate(self.transition_Root_connected_parsing_wait_for_header_2, [])
- return True
- return False
-
- def generateCandidates_Root_connected_parsing_wait_for_header(self):
- if not self.combo_step.isArenaChanged(self.Root_connected_parsing_wait_for_header):
- return self.generateCandidatesCurrent_Root_connected_parsing_wait_for_header()
- else:
- return True
-
- def transition_Root_connected_parsing_wait_for_header_1(self, parameters):
- self.exit_Root_connected_parsing_wait_for_header()
- header, self.received_data = self.received_data.split("\r\n\r\n", 1)
- header = header.lower()
- if "content-length" in header:
- _, after = header.split("content-length:", 1)
- after = after.split("\r\n", 1)[0]
- after = after.strip()
- self.length = int(after)
- else:
- self.length = float('inf')
- self.combo_step.setArenaChanged(self.Root_connected_parsing)
- self.enter_Root_connected_parsing_wait_for_payload()
-
- def transition_Root_connected_parsing_wait_for_header_2(self, parameters):
- self.exit_Root_connected_parsing_wait_for_header()
- self.combo_step.setArenaChanged(self.Root_connected_parsing)
- self.enter_Root_connected_parsing_closing()
-
- def generateCandidatesCurrent_Root_connected_parsing_closing(self):
- enabled_events = self.getEnabledEvents()
- for e in enabled_events:
- if e.name == "_0after":
- self.small_step.addCandidate(self.transition_Root_connected_parsing_closing_1, e.parameters)
- return True
- return False
-
- def generateCandidates_Root_connected_parsing_closing(self):
- if not self.combo_step.isArenaChanged(self.Root_connected_parsing_closing):
- return self.generateCandidatesCurrent_Root_connected_parsing_closing()
- else:
- return True
-
- def transition_Root_connected_parsing_closing_1(self, parameters):
- self.exit_Root_connected_parsing_closing()
- self.raiseInternalEvent(Event("close", None, []))
- self.combo_step.setArenaChanged(self.Root_connected_parsing)
- self.enter_Root_connected_parsing_closing()
-
- def generateCandidatesCurrent_Root_connected_parsing_wait_for_payload(self):
- enabled_events = self.getEnabledEvents()
- if len(self.received_data) >= self.length or self.closed:
- self.small_step.addCandidate(self.transition_Root_connected_parsing_wait_for_payload_1, [])
- return True
- return False
-
- def generateCandidates_Root_connected_parsing_wait_for_payload(self):
- if not self.combo_step.isArenaChanged(self.Root_connected_parsing_wait_for_payload):
- return self.generateCandidatesCurrent_Root_connected_parsing_wait_for_payload()
- else:
- return True
-
- def transition_Root_connected_parsing_wait_for_payload_1(self, parameters):
- self.exit_Root_connected_parsing_wait_for_payload()
- if self.length == float('inf'):
- data = self.received_data
- self.received_data = ""
- else:
- data = self.received_data[:self.length]
- self.received_data = self.received_data[self.length:]
-
- # We support POST data only, so everything is in the data
- try:
- params = dict([p.split('=') for p in data.split('&')])
- data = {k: urllib.unquote_plus(v) for k, v in params.iteritems()}
- except:
- import traceback
- traceback.print_exc()
- print("Could not parse: " + str(data))
- data = {}
- self.big_step.outputEventOM(Event("narrow_cast", None, [self, 'parent', Event("HTTP_output", None, [self.association_name, data])]))
- self.combo_step.setArenaChanged(self.Root_connected_parsing)
- self.enter_Root_connected_parsing_wait_for_header()
-
- def generateCandidates_Root_close(self):
- return False
-
- # Generate transition candidates for current small step
- def generateCandidates(self):
- self.generateCandidates_Root()
- class ObjectManager(ObjectManagerBase):
- def __init__(self, controller):
- ObjectManagerBase.__init__(self, controller)
-
- def instantiate(self, class_name, construct_params):
- if class_name == "Server":
- instance = Server(self.controller, construct_params[0])
- instance.associations = {}
- instance.associations["sockets"] = Association("Socket", 0, -1)
- elif class_name == "Socket":
- instance = Socket(self.controller, construct_params[0])
- instance.associations = {}
- instance.associations["parent"] = Association("Server", 1, 1)
- return instance
- class Controller(ThreadsControllerBase):
- def __init__(self, bootfile, keep_running = None):
- if keep_running == None: keep_running = True
- ThreadsControllerBase.__init__(self, ObjectManager(self), keep_running)
- self.addInputPort("socket_in")
- self.addOutputPort("socket_out")
- self.object_manager.createInstance("Server", [bootfile])
|