docs: pass updating python examples to be the same as grpc examples and remove extra cruft to focus on simpler example code alone
This commit is contained in:
		
							parent
							
								
									828a68a0cd
								
							
						
					
					
						commit
						2b1b027a11
					
				
					 7 changed files with 438 additions and 290 deletions
				
			
		|  | @ -1,12 +1,4 @@ | |||
| """ | ||||
| This is a standalone script to run a small EMANE scenario and will not interact | ||||
| with the GUI. You also must have installed OSPF MDR as noted in the documentation | ||||
| installation page. | ||||
| """ | ||||
| 
 | ||||
| import logging | ||||
| import time | ||||
| 
 | ||||
| # required imports | ||||
| from core.emane.ieee80211abg import EmaneIeee80211abgModel | ||||
| from core.emane.nodes import EmaneNet | ||||
| from core.emulator.coreemu import CoreEmu | ||||
|  | @ -14,56 +6,51 @@ from core.emulator.data import IpPrefixes, NodeOptions | |||
| from core.emulator.enumerations import EventTypes | ||||
| from core.nodes.base import CoreNode | ||||
| 
 | ||||
| NODES = 2 | ||||
| EMANE_DELAY = 10 | ||||
| # ip nerator for example | ||||
| ip_prefixes = IpPrefixes(ip4_prefix="10.0.0.0/24") | ||||
| 
 | ||||
| # create emulator instance for creating sessions and utility methods | ||||
| coreemu = CoreEmu() | ||||
| session = coreemu.create_session() | ||||
| 
 | ||||
| def main(): | ||||
|     # ip generator for example | ||||
|     prefixes = IpPrefixes(ip4_prefix="10.83.0.0/16") | ||||
| # location information is required to be set for emane | ||||
| session.location.setrefgeo(47.57917, -122.13232, 2.0) | ||||
| session.location.refscale = 150.0 | ||||
| 
 | ||||
|     # create emulator instance for creating sessions and utility methods | ||||
|     coreemu = CoreEmu() | ||||
|     session = coreemu.create_session() | ||||
| # must be in configuration state for nodes to start, when using "node_add" below | ||||
| session.set_state(EventTypes.CONFIGURATION_STATE) | ||||
| 
 | ||||
|     # must be in configuration state for nodes to start, when using "node_add" below | ||||
|     session.set_state(EventTypes.CONFIGURATION_STATE) | ||||
| # create emane | ||||
| options = NodeOptions(x=200, y=200, emane=EmaneIeee80211abgModel.name) | ||||
| emane = session.add_node(EmaneNet, options=options) | ||||
| 
 | ||||
|     # create emane network node, emane determines connectivity based on | ||||
|     # location, so the session and nodes must be configured to provide one | ||||
|     session.set_location(47.57917, -122.13232, 2.00000, 1.0) | ||||
|     options = NodeOptions() | ||||
|     options.set_position(80, 50) | ||||
|     emane_network = session.add_node(EmaneNet, options=options, _id=100) | ||||
|     session.emane.set_model(emane_network, EmaneIeee80211abgModel) | ||||
| # create nodes | ||||
| options = NodeOptions(model="mdr", x=100, y=100) | ||||
| n1 = session.add_node(CoreNode, options=options) | ||||
| options = NodeOptions(model="mdr", x=300, y=100) | ||||
| n2 = session.add_node(CoreNode, options=options) | ||||
| 
 | ||||
|     # create nodes | ||||
|     options = NodeOptions(model="mdr") | ||||
|     for i in range(NODES): | ||||
|         node = session.add_node(CoreNode, options=options) | ||||
|         node.setposition(x=150 * (i + 1), y=150) | ||||
|         interface = prefixes.create_iface(node) | ||||
|         session.add_link(node.id, emane_network.id, iface1_data=interface) | ||||
| # configure general emane settings | ||||
| config = session.emane.get_configs() | ||||
| config.update({"eventservicettl": "2"}) | ||||
| 
 | ||||
|     # instantiate session | ||||
|     session.instantiate() | ||||
| # configure emane model settings | ||||
| # using a dict mapping currently support values as strings | ||||
| session.emane.set_model_config( | ||||
|     emane.id, EmaneIeee80211abgModel.name, {"unicastrate": "3"} | ||||
| ) | ||||
| 
 | ||||
|     # OSPF MDR requires some time for routes to be created | ||||
|     logging.info("waiting %s seconds for OSPF MDR to create routes", EMANE_DELAY) | ||||
|     time.sleep(EMANE_DELAY) | ||||
| # link nodes to emane | ||||
| iface1 = ip_prefixes.create_iface(n1) | ||||
| session.add_link(n1.id, emane.id, iface1) | ||||
| iface1 = ip_prefixes.create_iface(n2) | ||||
| session.add_link(n2.id, emane.id, iface1) | ||||
| 
 | ||||
|     # get nodes to run example | ||||
|     first_node = session.get_node(1, CoreNode) | ||||
|     last_node = session.get_node(NODES, CoreNode) | ||||
|     address = prefixes.ip4_address(first_node.id) | ||||
|     logging.info("node %s pinging %s", last_node.name, address) | ||||
|     output = last_node.cmd(f"ping -c 3 {address}") | ||||
|     logging.info(output) | ||||
| # start session | ||||
| session.instantiate() | ||||
| 
 | ||||
|     # shutdown session | ||||
|     coreemu.shutdown() | ||||
| # do whatever you like here | ||||
| input("press enter to shutdown") | ||||
| 
 | ||||
| 
 | ||||
| if __name__ == "__main__" or __name__ == "__builtin__": | ||||
|     logging.basicConfig(level=logging.INFO) | ||||
|     main() | ||||
| # stop session | ||||
| session.shutdown() | ||||
|  |  | |||
							
								
								
									
										35
									
								
								daemon/examples/python/peertopeer.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								daemon/examples/python/peertopeer.py
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,35 @@ | |||
| # required imports | ||||
| from core.emulator.coreemu import CoreEmu | ||||
| from core.emulator.data import IpPrefixes, NodeOptions | ||||
| from core.emulator.enumerations import EventTypes | ||||
| from core.nodes.base import CoreNode | ||||
| 
 | ||||
| # ip nerator for example | ||||
| ip_prefixes = IpPrefixes(ip4_prefix="10.0.0.0/24") | ||||
| 
 | ||||
| # create emulator instance for creating sessions and utility methods | ||||
| coreemu = CoreEmu() | ||||
| session = coreemu.create_session() | ||||
| 
 | ||||
| # must be in configuration state for nodes to start, when using "node_add" below | ||||
| session.set_state(EventTypes.CONFIGURATION_STATE) | ||||
| 
 | ||||
| # create nodes | ||||
| options = NodeOptions(x=100, y=100) | ||||
| n1 = session.add_node(CoreNode, options=options) | ||||
| options = NodeOptions(x=300, y=100) | ||||
| n2 = session.add_node(CoreNode, options=options) | ||||
| 
 | ||||
| # link nodes together | ||||
| iface1 = ip_prefixes.create_iface(n1) | ||||
| iface2 = ip_prefixes.create_iface(n2) | ||||
| session.add_link(n1.id, n2.id, iface1, iface2) | ||||
| 
 | ||||
| # start session | ||||
| session.instantiate() | ||||
| 
 | ||||
| # do whatever you like here | ||||
| input("press enter to shutdown") | ||||
| 
 | ||||
| # stop session | ||||
| session.shutdown() | ||||
|  | @ -1,54 +1,41 @@ | |||
| """ | ||||
| This is a standalone script to run a small switch based scenario and will not | ||||
| interact with the GUI. | ||||
| """ | ||||
| 
 | ||||
| import logging | ||||
| 
 | ||||
| # required imports | ||||
| from core.emulator.coreemu import CoreEmu | ||||
| from core.emulator.data import IpPrefixes | ||||
| from core.emulator.data import IpPrefixes, NodeOptions | ||||
| from core.emulator.enumerations import EventTypes | ||||
| from core.nodes.base import CoreNode | ||||
| from core.nodes.network import SwitchNode | ||||
| 
 | ||||
| NODES = 2 | ||||
| # ip nerator for example | ||||
| ip_prefixes = IpPrefixes(ip4_prefix="10.0.0.0/24") | ||||
| 
 | ||||
| # create emulator instance for creating sessions and utility methods | ||||
| coreemu = CoreEmu() | ||||
| session = coreemu.create_session() | ||||
| 
 | ||||
| def main(): | ||||
|     # ip generator for example | ||||
|     prefixes = IpPrefixes(ip4_prefix="10.83.0.0/16") | ||||
| # must be in configuration state for nodes to start, when using "node_add" below | ||||
| session.set_state(EventTypes.CONFIGURATION_STATE) | ||||
| 
 | ||||
|     # create emulator instance for creating sessions and utility methods | ||||
|     coreemu = CoreEmu() | ||||
|     session = coreemu.create_session() | ||||
| # create switch | ||||
| options = NodeOptions(x=200, y=200) | ||||
| switch = session.add_node(SwitchNode, options=options) | ||||
| 
 | ||||
|     # must be in configuration state for nodes to start, when using "node_add" below | ||||
|     session.set_state(EventTypes.CONFIGURATION_STATE) | ||||
| # create nodes | ||||
| options = NodeOptions(x=100, y=100) | ||||
| n1 = session.add_node(CoreNode, options=options) | ||||
| options = NodeOptions(x=300, y=100) | ||||
| n2 = session.add_node(CoreNode, options=options) | ||||
| 
 | ||||
|     # create switch network node | ||||
|     switch = session.add_node(SwitchNode, _id=100) | ||||
| # link nodes to switch | ||||
| iface1 = ip_prefixes.create_iface(n1) | ||||
| session.add_link(n1.id, switch.id, iface1) | ||||
| iface1 = ip_prefixes.create_iface(n2) | ||||
| session.add_link(n2.id, switch.id, iface1) | ||||
| 
 | ||||
|     # create nodes | ||||
|     for _ in range(NODES): | ||||
|         node = session.add_node(CoreNode) | ||||
|         interface = prefixes.create_iface(node) | ||||
|         session.add_link(node.id, switch.id, iface1_data=interface) | ||||
| # start session | ||||
| session.instantiate() | ||||
| 
 | ||||
|     # instantiate session | ||||
|     session.instantiate() | ||||
| # do whatever you like here | ||||
| input("press enter to shutdown") | ||||
| 
 | ||||
|     # get nodes to run example | ||||
|     first_node = session.get_node(1, CoreNode) | ||||
|     last_node = session.get_node(NODES, CoreNode) | ||||
|     address = prefixes.ip4_address(first_node.id) | ||||
|     logging.info("node %s pinging %s", last_node.name, address) | ||||
|     output = last_node.cmd(f"ping -c 3 {address}") | ||||
|     logging.info(output) | ||||
| 
 | ||||
|     # shutdown session | ||||
|     coreemu.shutdown() | ||||
| 
 | ||||
| 
 | ||||
| if __name__ == "__main__": | ||||
|     logging.basicConfig(level=logging.INFO) | ||||
|     main() | ||||
| # stop session | ||||
| session.shutdown() | ||||
|  |  | |||
|  | @ -1,45 +0,0 @@ | |||
| """ | ||||
| This is a script to run a small switch based scenario and depends on | ||||
| the user running this script through the "Execute Python Script" option | ||||
| in the GUI. The usage of globals() below allows this script to leverage the | ||||
| same CoreEmu instance the GUI is using. | ||||
| """ | ||||
| 
 | ||||
| import logging | ||||
| 
 | ||||
| from core.emulator.coreemu import CoreEmu | ||||
| from core.emulator.data import IpPrefixes | ||||
| from core.emulator.enumerations import EventTypes | ||||
| from core.nodes.base import CoreNode | ||||
| from core.nodes.network import SwitchNode | ||||
| 
 | ||||
| NODES = 2 | ||||
| 
 | ||||
| 
 | ||||
| def main(): | ||||
|     # ip generator for example | ||||
|     prefixes = IpPrefixes("10.83.0.0/16") | ||||
| 
 | ||||
|     # create emulator instance for creating sessions and utility methods | ||||
|     coreemu: CoreEmu = globals()["coreemu"] | ||||
|     session = coreemu.create_session() | ||||
| 
 | ||||
|     # must be in configuration state for nodes to start, when using "node_add" below | ||||
|     session.set_state(EventTypes.CONFIGURATION_STATE) | ||||
| 
 | ||||
|     # create switch network node | ||||
|     switch = session.add_node(SwitchNode) | ||||
| 
 | ||||
|     # create nodes | ||||
|     for _ in range(NODES): | ||||
|         node = session.add_node(CoreNode) | ||||
|         interface = prefixes.create_iface(node) | ||||
|         session.add_link(node.id, switch.id, iface1_data=interface) | ||||
| 
 | ||||
|     # instantiate session | ||||
|     session.instantiate() | ||||
| 
 | ||||
| 
 | ||||
| if __name__ in {"__main__", "__builtin__"}: | ||||
|     logging.basicConfig(level=logging.INFO) | ||||
|     main() | ||||
|  | @ -1,10 +1,4 @@ | |||
| """ | ||||
| This is a standalone script to run a small WLAN based scenario and will not | ||||
| interact with the GUI. | ||||
| """ | ||||
| 
 | ||||
| import logging | ||||
| 
 | ||||
| # required imports | ||||
| from core.emulator.coreemu import CoreEmu | ||||
| from core.emulator.data import IpPrefixes, NodeOptions | ||||
| from core.emulator.enumerations import EventTypes | ||||
|  | @ -12,47 +6,50 @@ from core.location.mobility import BasicRangeModel | |||
| from core.nodes.base import CoreNode | ||||
| from core.nodes.network import WlanNode | ||||
| 
 | ||||
| NODES = 2 | ||||
| # ip nerator for example | ||||
| ip_prefixes = IpPrefixes(ip4_prefix="10.0.0.0/24") | ||||
| 
 | ||||
| # create emulator instance for creating sessions and utility methods | ||||
| coreemu = CoreEmu() | ||||
| session = coreemu.create_session() | ||||
| 
 | ||||
| def main(): | ||||
|     # ip generator for example | ||||
|     prefixes = IpPrefixes("10.83.0.0/16") | ||||
| # must be in configuration state for nodes to start, when using "node_add" below | ||||
| session.set_state(EventTypes.CONFIGURATION_STATE) | ||||
| 
 | ||||
|     # create emulator instance for creating sessions and utility methods | ||||
|     coreemu = CoreEmu() | ||||
|     session = coreemu.create_session() | ||||
| # create wlan | ||||
| options = NodeOptions(x=200, y=200) | ||||
| wlan = session.add_node(WlanNode, options=options) | ||||
| 
 | ||||
|     # must be in configuration state for nodes to start, when using "node_add" below | ||||
|     session.set_state(EventTypes.CONFIGURATION_STATE) | ||||
| # create nodes | ||||
| options = NodeOptions(model="mdr", x=100, y=100) | ||||
| n1 = session.add_node(CoreNode, options=options) | ||||
| options = NodeOptions(model="mdr", x=300, y=100) | ||||
| n2 = session.add_node(CoreNode, options=options) | ||||
| 
 | ||||
|     # create wlan network node | ||||
|     wlan = session.add_node(WlanNode, _id=100) | ||||
|     session.mobility.set_model(wlan, BasicRangeModel) | ||||
| # configuring wlan | ||||
| session.mobility.set_model_config( | ||||
|     wlan.id, | ||||
|     BasicRangeModel.name, | ||||
|     { | ||||
|         "range": "280", | ||||
|         "bandwidth": "55000000", | ||||
|         "delay": "6000", | ||||
|         "jitter": "5", | ||||
|         "error": "5", | ||||
|     }, | ||||
| ) | ||||
| 
 | ||||
|     # create nodes, must set a position for wlan basic range model | ||||
|     options = NodeOptions(model="mdr") | ||||
|     options.set_position(0, 0) | ||||
|     for _ in range(NODES): | ||||
|         node = session.add_node(CoreNode, options=options) | ||||
|         interface = prefixes.create_iface(node) | ||||
|         session.add_link(node.id, wlan.id, iface1_data=interface) | ||||
| # link nodes to wlan | ||||
| iface1 = ip_prefixes.create_iface(n1) | ||||
| session.add_link(n1.id, wlan.id, iface1) | ||||
| iface1 = ip_prefixes.create_iface(n2) | ||||
| session.add_link(n2.id, wlan.id, iface1) | ||||
| 
 | ||||
|     # instantiate session | ||||
|     session.instantiate() | ||||
| # start session | ||||
| session.instantiate() | ||||
| 
 | ||||
|     # get nodes for example run | ||||
|     first_node = session.get_node(1, CoreNode) | ||||
|     last_node = session.get_node(NODES, CoreNode) | ||||
|     address = prefixes.ip4_address(first_node.id) | ||||
|     logging.info("node %s pinging %s", last_node.name, address) | ||||
|     output = last_node.cmd(f"ping -c 3 {address}") | ||||
|     logging.info(output) | ||||
| # do whatever you like here | ||||
| input("press enter to shutdown") | ||||
| 
 | ||||
|     # shutdown session | ||||
|     coreemu.shutdown() | ||||
| 
 | ||||
| 
 | ||||
| if __name__ == "__main__": | ||||
|     logging.basicConfig(level=logging.INFO) | ||||
|     main() | ||||
| # stop session | ||||
| session.shutdown() | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue