var deviceScripts = { manualRouter: { onPacketReceived: function(device, packet, portNum) { var newpkt = JSON.parse(JSON.stringify(packet)); if (packet.hasOwnProperty("transport") && packet.transport.hasOwnProperty("proto") && packet.transport.proto == "ICMP" && packet.transport.hasOwnProperty("ttl")) { if (packet.transport.ttl > 0) { newpkt.transport.ttl--; } else { newpkt.network.srcip = device.id; newpkt.network.dstip = packet.network.srcip; newpkt.transport.proto = "ICMP_ERROR"; sendPacket(device.id, portNum, newpkt); return; } } if (packet.hasOwnProperty("network") && packet.network.hasOwnProperty("dstip") && packet.network.dstip == device.id && packet.hasOwnProperty("transport") && packet.transport.hasOwnProperty("proto") && packet.transport.proto == "ICMP") { newpkt.network.srcip = device.id; newpkt.network.dstip = packet.network.srcip; sendPacket(device.id, portNum, newpkt); return; } for (var i = 0; i < device.rules.length; i++) { if (device.rules[i].dstip == packet.network.dstip) { sendPacket(device.id, device.rules[i].portNum, newpkt); } } } }, hub: { onPacketReceived: function (device, packet) { //. } }, // proxy device for attacks1. again, this is quick'n'dirty for the workshop proxy: { onPacketReceived: function(device, packet, portNum) { var newpkt = JSON.parse(JSON.stringify(packet)); if (packet.network.dstip == "Proxy") { newpkt.network.dstip = "Blocked Site"; } sendPacket(device.id, portNum == 0 ? 1 : 0, newpkt); } }, ping: { onPacketReceived: function(device, packet) { if(packet.hasOwnProperty("transport") && packet["transport"].hasOwnProperty("proto")){ var proto = packet.transport.proto.trim().toLowerCase(); if (proto == "icmp" || proto == "example") { // did this to make basics5 a little more clear var new_packet = { network: { srcip: packet.network.dstip, dstip: packet.network.srcip }, transport: { proto: packet.transport.proto } }; sendPacket(device.id, 0, new_packet); } } } }, modem: { onPacketReceived: function(device, packet, portNum) { if (!device.hasOwnProperty("rules")) device.rules = {}; if (packet.network.dstip == device.id) { // TODO: use something other than proto for NAT table if (device.rules.hasOwnProperty( packet.transport.proto )) { packet.network.dstip = device.rules[packet.transport.proto].dstip; sendPacket(device.id, device.rules[packet.transport.proto].portNum, packet); } } else { if (packet.hasOwnProperty("transport") && packet.transport.hasOwnProperty("proto")) { device.rules[packet.transport.proto] = {portNum:portNum, dstip: packet.network.srcip}; console.log(device.rules); } packet.network.srcip = device.id; sendPacket(device.id, 0, packet); } } }, /* if(packet.network.dstip == device.id){//look up ip in NAT table var new_packet = {}; for (var i = 0; i < packetFields.length; i++) { if(packet.hasOwnProperty(packetFields[i].layer)){ new_packet[packetFields[i].layer] = {}; for (var j = 0; j < packetFields[i].fields.length; j++) { if(packet[packetFields[i].layer].hasOwnProperty(packetFields[i].fields[j])){ new_packet[packetFields[i].layer][ packetFields[i].fields[j] ] = packet[packetFields[i].layer][ packetFields[i].fields[j] ]; } } } } new_packet.network.dstip = getPortRecipient(device.id, 0); sendPacket(device.id, 0, new_packet); } else { //replace src ip with device IP and save in NAT table var new_packet = {}; for (var i = 0; i < packetFields.length; i++) { if(packet.hasOwnProperty(packetFields[i].layer)){ new_packet[packetFields[i].layer] = {}; for (var j = 0; j < packetFields[i].fields.length; j++) { if(packet[packetFields[i].layer].hasOwnProperty(packetFields[i].fields[j])){ new_packet[packetFields[i].layer][ packetFields[i].fields[j] ] = packet[packetFields[i].layer][ packetFields[i].fields[j] ]; } } } } new_packet.network.srcip = device.id; sendPacket(device.id, 1, new_packet); } } },*/ switch: { onPacketReceived: function(device, packet, portNum) { var found = false; for (var i = 0; (i < device.rules.length) && !found; i++) { if (device.rules[i].dstip == packet.network.dstip) { sendPacket(device.id, device.rules[i].portNum, packet); found = true; } } if(!found){ //broadcast packet to all ports except where it was received for(var i=0; i