devicescripts.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269
  1. var deviceScripts = {
  2. manualRouter: {
  3. onPacketReceived: function(device, packet, portNum) {
  4. var newpkt = JSON.parse(JSON.stringify(packet));
  5. if (packet.hasOwnProperty("transport") && packet.transport.hasOwnProperty("proto") && packet.transport.proto == "ICMP" && packet.transport.hasOwnProperty("ttl")) {
  6. if (packet.transport.ttl > 0) {
  7. newpkt.transport.ttl--;
  8. } else {
  9. newpkt.network.srcip = device.id;
  10. newpkt.network.dstip = packet.network.srcip;
  11. newpkt.transport.proto = "ICMP_ERROR";
  12. sendPacket(device.id, portNum, newpkt);
  13. return;
  14. }
  15. }
  16. if (packet.hasOwnProperty("network") && packet.network.hasOwnProperty("dstip") && packet.network.dstip == device.id &&
  17. packet.hasOwnProperty("transport") && packet.transport.hasOwnProperty("proto") && packet.transport.proto == "ICMP") {
  18. newpkt.network.srcip = device.id;
  19. newpkt.network.dstip = packet.network.srcip;
  20. sendPacket(device.id, portNum, newpkt);
  21. return;
  22. }
  23. for (var i = 0; i < device.rules.length; i++) {
  24. if (device.rules[i].dstip == packet.network.dstip) {
  25. sendPacket(device.id, device.rules[i].portNum, newpkt);
  26. }
  27. }
  28. }
  29. },
  30. hub: {
  31. onPacketReceived: function (device, packet) {
  32. //.
  33. }
  34. },
  35. // proxy device for attacks1. again, this is quick'n'dirty for the workshop
  36. proxy: {
  37. onPacketReceived: function(device, packet, portNum) {
  38. var newpkt = JSON.parse(JSON.stringify(packet));
  39. if (packet.network.dstip == "Proxy") {
  40. newpkt.network.dstip = "Blocked Site";
  41. }
  42. sendPacket(device.id, portNum == 0 ? 1 : 0, newpkt);
  43. }
  44. },
  45. ping: {
  46. onPacketReceived: function(device, packet) {
  47. if(packet.hasOwnProperty("transport") && packet["transport"].hasOwnProperty("proto")){
  48. var proto = packet.transport.proto.trim().toLowerCase();
  49. if (proto == "icmp" || proto == "example") { // did this to make basics5 a little more clear
  50. var new_packet = {
  51. network: {
  52. srcip: packet.network.dstip,
  53. dstip: packet.network.srcip
  54. },
  55. transport: {
  56. proto: packet.transport.proto
  57. }
  58. };
  59. sendPacket(device.id, 0, new_packet);
  60. }
  61. }
  62. }
  63. },
  64. modem: {
  65. onPacketReceived: function(device, packet, portNum) {
  66. if (!device.hasOwnProperty("rules")) device.rules = {};
  67. var newpkt = JSON.parse(JSON.stringify(packet));
  68. if (packet.network.dstip == device.id) {
  69. // TODO: use something other than proto for NAT table
  70. if (device.rules.hasOwnProperty( packet.transport.proto )) {
  71. newpkt.network.dstip = device.rules[packet.transport.proto].dstip;
  72. sendPacket(device.id, device.rules[packet.transport.proto].portNum, newpkt);
  73. }
  74. } else {
  75. if (packet.hasOwnProperty("transport") && packet.transport.hasOwnProperty("proto")) {
  76. device.rules[packet.transport.proto] = {portNum:portNum, dstip: packet.network.srcip};
  77. }
  78. newpkt.network.srcip = device.id;
  79. sendPacket(device.id, 0, newpkt);
  80. }
  81. }
  82. },
  83. /* if(packet.network.dstip == device.id){//look up ip in NAT table
  84. var new_packet = {};
  85. for (var i = 0; i < packetFields.length; i++) {
  86. if(packet.hasOwnProperty(packetFields[i].layer)){
  87. new_packet[packetFields[i].layer] = {};
  88. for (var j = 0; j < packetFields[i].fields.length; j++) {
  89. if(packet[packetFields[i].layer].hasOwnProperty(packetFields[i].fields[j])){
  90. new_packet[packetFields[i].layer][ packetFields[i].fields[j] ] = packet[packetFields[i].layer][ packetFields[i].fields[j] ];
  91. }
  92. }
  93. }
  94. }
  95. new_packet.network.dstip = getPortRecipient(device.id, 0);
  96. sendPacket(device.id, 0, new_packet);
  97. } else { //replace src ip with device IP and save in NAT table
  98. var new_packet = {};
  99. for (var i = 0; i < packetFields.length; i++) {
  100. if(packet.hasOwnProperty(packetFields[i].layer)){
  101. new_packet[packetFields[i].layer] = {};
  102. for (var j = 0; j < packetFields[i].fields.length; j++) {
  103. if(packet[packetFields[i].layer].hasOwnProperty(packetFields[i].fields[j])){
  104. new_packet[packetFields[i].layer][ packetFields[i].fields[j] ] = packet[packetFields[i].layer][ packetFields[i].fields[j] ];
  105. }
  106. }
  107. }
  108. }
  109. new_packet.network.srcip = device.id;
  110. sendPacket(device.id, 1, new_packet);
  111. }
  112. }
  113. },*/
  114. switch: {
  115. onPacketReceived: function(device, packet, portNum) {
  116. var found = false;
  117. for (var i = 0; (i < device.rules.length) && !found; i++) {
  118. if (device.rules[i].dstip == packet.network.dstip) {
  119. sendPacket(device.id, device.rules[i].portNum, packet);
  120. found = true;
  121. }
  122. }
  123. if(!found){
  124. //broadcast packet to all ports except where it was received
  125. for(var i=0; i<device.ports.length; i++){
  126. if(i != portNum){
  127. sendPacket(device.id, i, packet);
  128. }
  129. }
  130. }
  131. //update rules with info from this packet
  132. var found = false;
  133. for (var i = 0; (i < device.rules.length) && !found; i++) {
  134. if (device.rules[i].dstip == packet.network.srcip) {
  135. device.rules[i].portNum = portNum;
  136. found = true;
  137. }
  138. }
  139. if(!found){
  140. device.rules[device.rules.length] = {
  141. dstip: packet.network.srcip,
  142. portNum: portNum
  143. }
  144. }
  145. }
  146. },
  147. firewall: {
  148. onPacketReceived: function(device, packet) {
  149. function checkRules(rule){
  150. return rule.srcip == packet.network.srcip;
  151. }
  152. if(device.rules.find(checkRules) == undefined){
  153. sendPacket(device.id, 0, packet);
  154. }
  155. }
  156. },
  157. broadcast: {
  158. onPacketReceived: function(device, packet, portNum){
  159. function checkRules(rule){
  160. return rule.dstip == packet.network.dstip;
  161. }
  162. var rule = device.rules.find(checkRules);
  163. if (rule != undefined){
  164. sendPacket(device.id, rule.portNum, packet);
  165. } else {
  166. if(packet.network.dstip == "Broadcast"){
  167. for(var i=0; i<device.ports.length; i++){
  168. if((i != portNum) && (getPortRecipient(device.id, i) != "Google")){
  169. newPacket = copyPacket(packet);
  170. newPacket.network.dstip = getPortRecipient(device.id, i);
  171. sendPacket(device.id, i, newPacket);
  172. }
  173. }
  174. }
  175. }
  176. }
  177. },
  178. encryption: {
  179. onPacketReceived: function(device, packet, portNum) {
  180. if(packet.hasOwnProperty("transport") && packet["transport"].hasOwnProperty("proto")){
  181. if(packet.transport.proto == "encryption"){
  182. if(packet.hasOwnProperty("application") && packet["application"].hasOwnProperty("type")){
  183. var type = packet.application.type;
  184. switch(type) {
  185. case "keyrequest":
  186. var new_packet = {
  187. network: {
  188. srcip: packet.network.dstip,
  189. dstip: packet.network.srcip
  190. },
  191. transport: {
  192. proto: "encryption"
  193. },
  194. application: {
  195. type: "keyresponse",
  196. key: "67890"
  197. }
  198. }
  199. sendPacket(device.id, portNum, new_packet);
  200. break;
  201. case "keyresponse":
  202. var new_packet = {
  203. network: {
  204. srcip: packet.network.dstip,
  205. dstip: packet.network.srcip
  206. },
  207. transport: {
  208. proto: "encryption"
  209. },
  210. application: {
  211. type: "message",
  212. key: packet.application.key
  213. }
  214. }
  215. sendPacket(device.id, portNum, new_packet);
  216. break;
  217. default:
  218. break;
  219. }
  220. }
  221. }
  222. }
  223. }
  224. },
  225. tappedRouter: {//Note: port 0 should be hooked up to tap device
  226. onPacketReceived: function(device, packet, portNum) {
  227. for (var i = 0; i < device.rules.length; i++) {
  228. if (device.rules[i].dstip == packet.network.dstip) {
  229. if(portNum == 0){
  230. sendPacket(device.id, device.rules[i].portNum, packet);
  231. } else {
  232. sendPacket(device.id, 0, packet);
  233. }
  234. }
  235. }
  236. }
  237. }
  238. }
  239. function copyPacket (packet) {
  240. newPacket = {};
  241. for (var i = 0; i < packetFields.length; i++) {
  242. if(packet.hasOwnProperty(packetFields[i].layer)){
  243. newPacket[packetFields[i].layer] = {};
  244. for (var j = 0; j < packetFields[i].fields.length; j++) {
  245. if(packet[packetFields[i].layer].hasOwnProperty(packetFields[i].fields[j])){
  246. newPacket[packetFields[i].layer][ packetFields[i].fields[j] ] = packet[packetFields[i].layer][ packetFields[i].fields[j] ];
  247. }
  248. }
  249. }
  250. }
  251. return newPacket;
  252. }