Showing posts with label ns2 AODV. Show all posts
Showing posts with label ns2 AODV. Show all posts

Wednesday, 11 October 2017

Networks AODV

Rushing attack

 Rushing attack is a zero delay attack and more effective when the attacker nearby source or destination node.On-demand routing protocols like AODV and DSR are more vulnerable to this attack, because whenever source node floods the route request packet in the network, an adversary node receives the route request packet and sends without any hop_count update and delay into the network. Whenever the legitimate nodes receive the original source request packets, they are dropped because legitimate nodes,would have already received packet from the attacker and treat the currently received packets as duplicate packets. Thus, adversary is included in active route & disturbs the data forwarding phase. Rushing attack can be taken place at source side or destination side or at the middle.

** The following conditions the rushing attacker is not included in active route
1. When source and destination nodes have direct communication link
2. When source and destination nodes have better route than rushing attackers route
** Rushing attack is more effective when attacker near to source or destination node

Rushing attacks:

 Rushing attacks mainly classified into two types:
1.    Rushing attack followed by jellyfish attack
2.    Rushing attack followed by byzantine attack
Rushing attacker disturbs the data forwarding phase by either jellyfish or byzantine attack.


Rushing attacks implementation in aodv routing protocol

The following scenario consists of 25 nodes. In which 7, 8 and 10 nodes are rushing attacks other nodes are non-malicious.










To create multiple rushing attackers in aodv protocol

·         In aodv.h, the following blue colour lines needs to be added to define rushing attackers

/*
      * History management
      */
    
double               PerHopTime(aodv_rt_entry *rt);

nsaddr_t malicious;




·         In aodv.cc the following blue colour lines needs to be added to initialize the attackers

// To initialize the rushing attackers

int
AODV::command(intargc, const char*const* argv) {
if(argc == 2) {
Tcl&tcl = Tcl::instance();

if(strncasecmp(argv[1], "id", 2) == 0) {
tcl.resultf("%d", index);
return TCL_OK;
    }
                    if(strncasecmp(argv[1], "rushingattack", 13) == 0) {
     malicious= 1000;
        return TCL_OK;
    }
                 

AODV::AODV(nsaddr_t id) : Agent(PT_AODV),
btimer(this), htimer(this), ntimer(this),
rtimer(this), lrtimer(this), rqueue() {
index = id;
seqno = 2;
bid = 1;
  LIST_INIT(&nbhead);
  LIST_INIT(&bihead);
malicious=999;

·         Malicious nodes 7, 8 and 10 generate malicious route requests using following blue colour code


Each rushing attacker do not increase the hop_count and simply broadcast without delay. Other than rushing attackers, they will follow the AODV protocol to broadcast route request

//add blue colour lines in send route request packet

/*
  * Can't reply. So forward the  Route Request
  */

else {
ih->saddr() = index;
ih->daddr() = IP_BROADCAST;
if (malicious==1000)
rq->rq_hop_count += 1;
   // Maximum sequence number seen en route
if (rt) rq->rq_dst_seqno = max(rt->rt_seqno, rq->rq_dst_seqno);
if (malicious==1000)
forward((aodv_rt_entry*) 0, p, 0);
else
forward((aodv_rt_entry*) 0, p, DELAY);
 }


// add the blue colour lines code in forward packet

if (ih->daddr() == (nsaddr_t) IP_BROADCAST) {
 // If it is a broadcast packet
assert(rt == 0);
if ((ch->ptype()==PT_AODV) && (malicious!=1000)) {
     /*
*  Jitter the sending of AODV broadcast packets by 10ms
      */
     Scheduler::instance().schedule(target_, p, 0.01 * Random::uniform());
   } else {

     Scheduler::instance().schedule(target_, p, 0.);  // No jitter
   }
 }

  
·         Rushing Attackers can do two attacks: Byzantine and Jellyfish attacks

/*
  * If the route is up, forward the packet
  */
                                                  
if(rt->rt_flags == RTF_UP) {
assert(rt->rt_hops != INFINITY2);

//Byzantine attack can be done : drop all /selective packets
//                       Modify [or]injectflase packets
//Here,  only dropping packets are considered


if((ch->ptype()!=PT_AODV) && (malicious==1000))
                                                   {
                           if(t < CURRENT_TIME)
                                                   {
                                               t=t+2;
                             drop(p, DROP_RTR_NO_ROUTE);
       }
//Jellyfish attack can be done two ways: delaying packets [or] re-ordering //packets.
//Here, only delaying packets and 0.8 can be varied till the good put is zero

else                                            
forward(rt, p, 0.8); 
 }
else
forward(rt, p, NO_DELAY);
 }

·         Since, all attackers drop the packets due to no route to destination, attackers have to disable the send[error]

The following blue colour lines code disables the send (error)


 // add in route resolve function (AODV::rt_resolve(Packet *p) )
else {
 Packet *rerr = Packet::alloc();
structhdr_aodv_error *re = HDR_AODV_ERROR(rerr);
 /*
  * For now, drop the packet and send error upstream.
  * Now the route errors are broadcast to upstream
  * neighbors - Mahesh 09/11/99
  */    

assert (rt->rt_flags == RTF_DOWN);
re->DestCount = 0;
re->unreachable_dst[re->DestCount] = rt->rt_dst;
re->unreachable_dst_seqno[re->DestCount] = rt->rt_seqno;
re->DestCount += 1;
#ifdef DEBUG
fprintf(stderr, "%s: sending RERR...\n", __FUNCTION__);
#endif
if(malicious==1000) drop(p, DROP_RTR_NO_ROUTE);
else
sendError(rerr, false);

drop(p, DROP_RTR_NO_ROUTE);



To define the rushing attackers in tcl add these lines after node initializations

$ns at 0.0 "[$n5 set ragent_] rushingattack"
$ns at 0.0 "[$n7 set ragent_] rushingattack"
$ns at 0.0 "[$n8 set ragent_] rushingattack"

Above scenario example tcl  file : rushing attacks
Rushing attack aodv.cc file : aodv.cc
                         aodv.h file : aodv.h   

Friday, 1 April 2016

Automated Post Processing (APP) Tool for ns-2 trace files



Automated Post Processing (APP) Tool has been designed and developed by Wireless Information Networking Group (WiNG) at NITK, Surathkal with an aim to help the ns-2 users in processing the trace files and plotting graphs. 

Although several such tools already exist, APP has been designed with a few unique features that are distinct from other tools:

1. APP Tool does not require installation! Just download the APP folder and run the tool.
2. APP Tool helps you to obtain values / graphs for at least 20 parameters!
3. APP Tool uses AWK Scripts in the back end!
4. APP Tool's source code is free and flexible! i.e., you can also add your own AWK Script in APP Tool and use it for plotting a graph.
5. Front end of APP Tool is designed in Python! You can customize it as per your requirements.
6. You need only two packages installed on your machine to run APP Tool: python-gi and python-matplotlib.
A total of 20 AWK Scripts are provided in the APP Tool, one for each of the parameter shown in the image below:

[Click to enlarge the image]
Note: You may have to modify some of the AWK Scripts to meet your requirements. As mentioned before, you can also add your own AWK Script to APP with ease, in case you want to analyze a different parameter. Moreover, not every parameter among the 20 mentioned above need graphs. Hence, APP plots graphs only for the parameter for which graphs are required. 
Instructions on "How to run APP Tool" have been provided in the Readme file available on the download link given above.

APP Tool has been dual licensed under the MIT or GPL v3 Licenses. Contributors to this project: Sayan Paul, Jay Priyadarshi, Sasank Channapradaga, Spriha Awinpushpam and Mohit P. Tahiliani

Kindly Note: Please report to us in case you find any errors while working with the APP Tool. You can write to us at wing@nitk.ac.in or place a comment in this post itself.

Hope it helps.
Regards,

Saturday, 2 May 2015


 


INTRODUCTION

Network Simulator is software used to simulate a wide range of real world networks and study the behavior of the network without using physical network components. The program performs this by tracing the interactions between the different network entities (hosts/routers, data links, packets, etc) using mathematical formulas. The behavior of the network can be observed for the various user inputs. Various attributes of the environment can also be modified in a controlled manner to access these behaviors under different conditions.
Simulation processes are based on the actual behaviors of network devices and protocols. We have presented a practical use for the implementation of network design and analysis tools.

Problem statement
The SNiP Network Simulator helps in design, study and observe the behavior of various networks without using the actual networking components. It also plots required graphs to study the data transfers carried out, packets dropped and collisions occurred.

SYSTEM DESIGN

4.1 Architecture

2.1.1 Drawing the network topology
The network devices are drawn on the work panel by clicking on the appropriate network device in the toolbox provided at the top of the editor.
As we see in other editing software’s, the SNiP Network Simulator provides a toolbox containing the network devices such as node, router, switch etc to draw the network topology.
The network devices are drawn on a work panel by clicking on the appropriate device icon from the toolbox and on the work panel. The properties are set by selecting the properties option from the context menu, which can be invoked by right clicking the network device icon drawn on the work panel.

2.1.2 Setting up properties
The properties are the characteristics associated with the network devices. All the network devices are set to the default property when it is drawn. The properties of different types of network devices are maintained differently in structure and all the objects which represent the same network device are stored in the same array. The properties of a network device are displayed by just right clicking on the appropriate device and selecting properties option from the context menu. The properties then changed and saved. The saved properties overwrite the existing value and the array list is updated.

2.1.3 Compiler: To compile the topology
The compilation unit compiles the topology drawn. Two different branches are used for the compilation of algorithmic simulation and real world simulation. The compiler checks for the syntax error in the properties of all the network devices and connection errors if any mismatch occurred in connection.


The compilation unit further generates warnings and messages. Warnings are not errors but some cautions generated may be remembering the user to set some properties for network devices or remembering to connect the network device if any connection is left out. Once the topology becomes error free, then the compiler translates all the properties set to the network topology to commands for the simulation engine.

2.1.4 Command Prompt
The command prompt is used to enter commands to set the properties of network entities and replaces all GUI interfaces with commands. As shown in the above figure, the command prompt interacts with network topology and compiler.
Example “add node 1 stcp 127.0.0.1” adds the “stcp 127.0.0.1” to node 1.
The user can use to compile the simulation by the command “compile”. The connection establishment details can be entered directly into the command prompt. The sequence of connection establishment is dumped by the simulation engine to the command prompt.

2.1.5 Simulation engine
The simulation engine does data transfer as simulation. It establishes the connection, generates the packets, sends them to the router, and forwards to the other network devices and thus controls the data transfer. It also logs all the packets sent to the network.
The simulation engine is associated with the algorithms. It calculates the shortest path for the connection establishment, generates the packets in constant rate from a sender and sends through the link in link speed, stores in router buffer and does the data transfer as data transfer occurs in real network.

Elements of simulation engine are
• Packet generator
• Data transfer unit
• Timer.


2.1.6 Packet generator
The packet generator generates the packets. The packet size is pre defined in the properties of a node. The packet generator is associated with the timer. The packet generator generates the packets in a definite time intervals.
The packet generator generates TPDUs for the acknowledgements from a active sender or receiver.

2.1.7 Data transfer unit
The data transfer unit transfers the data packets in the network. Path for the packet transfer, speed of connection, and the packet itself is the input to the data transfer unit. The data transfer unit is synchronized with the timer. Depending on the bandwidth and time the data transfer unit transmits the packet as it occurs in real network.

2.1.8 Timer
The timer gives the timing signals to the simulation engine. When it updates the time, it gives the signal to the simulation engine. The simulation calls the packet generator and transmits the generated packets to the network.

2.1.9 Stack Trace: Packet details
The stack trace gives the details of all packets. It has the following fields
Time: Gives the exact time in which the packet is transmitted.
Size: Gives the size of the packet.
From: Gives the source host name from where the packet is transferred.
To: Gives the destination host number to where the packet is transferred.
Route: Gives the route for the packet transfer.
Status: Contains the status of the packet. If the packet is dropped it contains “dropped” else “transmitted”.

2.1.10 Graph Plotting: Selecting log details for graph plotting
Graph of transmitted and dropped packet can be plotted using graph plot tool. The graph plot tool takes the stack trace as input. Depending on the status in stack trace, the graph plot tool divides the entire packet history into transmitted and dropped packets and thus plots the graph.

2.1.11 Play back of the data transfer
After the simulation is finished, the simulation server will send back the simulation result files to the GUI program. A log file is created and the file will be the input for playback. The playback gives the packet transfer information in GUI.

The packet animation trace file can be replayed later by the packet animation player. The performance curve of these log files can be plotted by the performance monitor.

2.2 Features
The SNiP Network Simulator has many useful features listed as follows:

• Its simulation speed is high and its simulation results are repeatable.
• The SNiP Simulator runs on windows platform.
• There is no need for kernel up-gradation and manual invocation of external processes.
• It provides a highly integrated and professional GUI environment. This GUI can help a user

 Draw network topologies.
 Configure the protocol modules used inside a node.
 Specify the moving paths of nodes.
 Plot network performance graphs.
 Playing back the animation of a logged packet transfer trace, etc. All these operations can be easily and intuitively done with the GUI.

SNiP uses a simple but effective syntax to describe the settings and configurations of a simulation job. These descriptions' are generated by the GUI and stored in a file. Normally the GUI will automatically transfer the file to the simulation engine for execution. However, if a researcher wants to try his (her) novel device or network configurations that the current GUI does not support, he (she) can totally bypass the GUI and generate the suite of description file by himself (herself) using the command prompt . The commands entered in the command prompt are directly transferred to the simulation engine for execution.



Chapter 3
DETAILED DESIGN

3.1 Front end design
The front end is designed using .NET and visual C#. The front end includes a network editor and GUI design. The network editor contains toolbox and menus.
The SNiP Simulator model contains 32 windows forms and 7 separate code files. The starting Windows form is SimCont.cs which is a Multiple Document Interface (MDI) parent. The SimCont form holds the instance of WorkPanel form as MDI child. The SimCont form contains a toolbox, which contains different icons for network devices. SimCont also contains a menu strip. The menu strip holds File, Edit, Tools, Simulate and Help menus and submenus.
The first form which loads into the memory is loadingfrm.cs. It calls SimCont.cs and further AObj.cs. The AObj.cs allocates objects and memory for those objects.
Network devices are drawn by clicking on the toolbar and then Work Panel. Every network device is associated with a form and some procedures inside the form for construction of new devices, to set the properties. When the new devices are created default properties are set. All the network devices including link are associated with different structure and an array list. The structure maintains the behavior of the device whereas the array list contains instances of those structures.
Every Network device is linked with a context menu strip. Right-clicking the device invokes the menu. The menu contains items such as Cut, Copy, Delete, Properties etc. Clicking on the properties invoke the form associated with the network device which contains the characteristics of the device. Lines can be drawn from one network device to other. Line drawing procedure is written in LineFrm.cs. The line drawing is done by calling DrawALine function inside the LineFrm.cs. The DrawALine function calls midpoint line algorithm written inside Midline.cs code module, to find out all points of the line for packet transfer animation.
The CompPro.cs windows form contains the definition for errors and warnings. It contains definition for 7 errors and 3 warnings. All the errors and warnings are associated with an ID.
ConnectionFrm.cs establishes the connection. It establishes a path from an active sender to receiver. It finds a shortest path among them and establishes the connection and makes the sender and receiver ready for packet transfer.
It contains a structure STCP which contains three fields. The first field represents the active sender of the connection. Second field gives the active receiver. The last field gives the path for data transfer.
LineFrm.cs, RouterFrm.cs, NodeFrm.cs, HubFrm.cs, SwitchFrm.cs are the Windows forms for the represents the characteristics of Network Connector, Router, Node, Hub and Switch respectively. Selecting properties of the respective device by right clicking on it invokes particular Windows form associated with it.
Other windows forms
Windows Forms Description
SettingsFrm.cs This is designed for the customization of the simulator. The form contains options to set the colors in playback, data and time limit for simulation etc
StackTrace.cs is designed to display a stack trace window after the simulation. The form contains a listbox which contains ID, Size, Source, Destination and for status of the packet.

GraphControl.cs Draws a graph. The input for the control is the x co-ordinate and y co-ordinate points and scale for drawing.
GraphFrm.cs This provides a Windows form for GraphControl.cs. Along with this it also mines the data form the simulation to draw the graph and adds GraphControl.cs.

ImgList.cs Contains a list of icons for toolbox.
TransactionLdFrm.cs Displays a loading form signifying the completion of transaction.
GraphSelectFrm.cs Displays all nodes in a combo box and provides options to select the graph type such as transfer graph of drop graph
CmdPromptFrm Invokes the command prompt. The command prompt can be used to interact with all the network devices and used to run the simulation.

3.2 Algorithms
Algorithm/Function Description
MidLine Algorithm Mid Point line algorithm.
Upon drawing every link, this algorithm is called.
Saves all X and Y points of a line in an Arraylist.
FileWrite FileRead Functions Writes and reads the entire network drawn in the WorkPanel. All network devices are written into the file in a format and the same format is used for reading the file.
CompileAll Compiles the simulation. If any syntax error exists in the topology then it displays the error else the simulation is ready to run. The run button is enabled.
TransferData Animation for transfer of data in real time. The procedure takes bandwidth and data size to be transferred and calculates the time required for data transfer.
DrawGraph This function draws the graph. The input is X co-ordinate points and Y co-ordinate points and scale.
StackTrace This function displays the status of every packet transferred from a source to a destination.
CnctNetDFrm Contains information about the network links. The bandwidth and type of the links can be changed here.
GetAIp This function gets a random IP address. The IP address returned from this function contains 4 fields, and all fields within the range 0-255
SimulateAll Simulates the entire network from the connection establishment phase until the end of the data transfer. This procedure creates log files, which gives the details of data transfer.
FlushAll Flushes all the buffer arrays associated with the actual buffer of routers, switches hubs. Also clears all the file transfers.
TCPpiar Finds out shortest path form a source to a destination and stores for shortest path for TCP connection.
FwdRouterToRouter Forwards packets from router to router.
FwdRouterToSwitch Forwards packets from router to switch.
FwdRouterToHub Forwards packets from router to hub.
FwdSwitchToRouter Forwards packets from switch to router.
FwdSwitchToSwitch Forwards packets from switch to switch.
FwdSwitchToHub Forwards packets from switch to hub.
FwdHubToRouter Forwards packets from hub to router.
FwdHubToSwitch Forwards packets from hub to switch.
FwdHubToHub Forwards packets from hub to hub.

STRUCTURES Description

SNODE
To hold the properties of a node. A Node has the following properties.
Node Number: All the nodes are numbered to identify the node.
IP Address: This field holds the IP address of the node
X and Y hold the position of the node icon.
Pb holds the picture box which contains icon of the node.
DCmd holds the command entered into a node.


SROUTER To hold the properties of a router. A router has the following properties.
Router Name: Holds the name of the router.
Router Number: All the routers are numbered to identify the router.
Pb holds the picture box which contains icon of the router.
X and Y hold the position of the node icon.
ConD : Holds the connection information
maxBuf : Holds the buffer size of the router

fillBuf : Holds the filled buffer information
pckTs: Arraylist that holds the packets as a queue.

SLINE Holds the link information. The line link information includes the bandwidth of the link and description about the link.

SHUB Holds the properties of hub. This includes the buffer size of the hub, unique number assigned to the hub for identification.

SPACKET
Holds packet information. Packet information includes size of the packet, source and destination of the packet.

SSTACK Holds a stack entry. The stack entry includes a SPACKET, source and destination of the packet and status of the packet which gives the information about whether the packet is sent successfully or not.

STCP Holds the source, destination and path for TCP connection.

SNODECMD Holds the command entered at the node.
The command includes the command string start time to start the data transfer.
3.1 Introduction
A simulation is an imitation of some real thing, state of affairs, or process. The act of simulating something generally entails representing certain key characteristics or behaviors of a selected physical or abstract system.
A computer simulation is an attempt to model a real-life situation on a computer so that it can be studied to see how the system works. By changing variables, predictions may be made about the behavior of the system.

3.2 Network simulator
A network simulator is a piece of software that simulates a network, without an actual network being present. Network simulators serve a variety of needs. Compared to the cost and time involved in setting up an entire test bed containing multiple networked computers, routers and infrastructure, network simulators are relatively fast and inexpensive. They allow engineers to test scenarios that might be particularly difficult or expensive to simulate using real hardware- for instance, simulating the effects of a sudden burst in traffic on a network service. Networking simulators are particularly useful in allowing designers to test new networking protocols or changes to existing protocols in a controlled and reproducible environment.
Network Simulators, as the name suggests are used by researchers to design various kinds of networks, simulate and then analyze the effect of various parameters on the network performance. A typical network simulator like NS2, encompasses a wide range of networking technologies and help the users to build complex networks from basic building blocks like variety of nodes and links. With the help of simulators one can design hierarchical networks using various types of nodes like computers, hubs, bridges, routers, optical cross connects, multicast routers, mobile units, etc. Various types of Wide Area Network (WAN) technologies like packet, circuit, burst switching etc and Local Area Network (LAN) technologies like Ethernet, token rings etc can all be simulated with a typical simulator and the user can test, analyze various standard results apart from devising some novel protocol or strategy for routing etc.
There are a wide variety of network simulators, ranging from the very simple to the very complex. Minimally, a network simulator must enable a user to represent a graph of a network, specifying the nodes on the network and the links between those nodes. More complicated systems may allow the user to specify everything about the protocols used to handle network traffic. Graphical applications allow users to easily visualize the workings of their simulated environment. Text-based applications may provide a less intuitive interface, but may permit more advanced forms of customization. Others, such as GTNets, are programming-oriented, providing a programming framework that the user then customizes to create an application that simulates the networking environment that he or she wishes to test.

3.3 Introduction to TCP Protocol
Introduction to TCP (Transmission Control Protocol)
TCP was specially designed to provide a reliable end-to-end byte stream over an unreliable inter network. An inter-network differs from a single network because different parts may have widely different topologies, bandwidths, delays, packet sizes, and other parameters. TCP was designed to dynamically adapt to properties of the inter network and to be robust in the face of many kinds of failures.
Each machine supporting TCP has a TCP transport entity, either a library procedure, a user process, or part of the kernel. In all cases, it manages TCP streams and interfaces to the IP layer. A TCP entity accepts user data streams from local processes breaks them up into pieces not exceeding 64KB and sends each piece as a separate IP datagram. When datagrams containing TCP data arrive at a machine, they are given to the TCP entity, which reconstructs the original byte streams.
The IP layer gives no guarantee that datagrams will be delivered properly, so it is up to TCP to time out and retransmit them as needed. Datagrams that do arrive may well do so in the wrong order; it is also up to TCP to reassemble them into messages in the proper sequence. In short, TCP must furnish the reliability that most users want and that IP does not provide.

TCP 7000
FTP 21 file transfer
Tenet 23 remote login

3.4 The SNiP Network Simulator
SNiP Network simulator attempts to provide real world network simulation. Real world network simulation is associated with the protocols used in real world. It includes TCP/IP, UDP, FTP, etc. SNiP provides a user friendly interface to draw and simulate the topology, playback to view the data transfers, stack trace to view the data transfer of each and every packet transferred. Along with this it also provides graph drawing tool, which can be used to plot the graph giving details about in-throughput, out-throughput, collisions occurred at all the network devices.
The real time network simulation tool provides the user exact time required for data transfer for a specified bandwidth and datum under various conditions.
The SNiP Network simulator can be used by professionals for studying real world networks, problems encountered, and for educational purposes.

3.5 System Requirement Specification
Once the analysis is complete, the requirements must be written or specified. The final output is the Software Requirements Specification document (SRS).The SRS captures the complete software requirements for the project Network Simulator. This SRS will describe the different functionalities of GUI Network Simulator. This SRS outlines the product requirements on functional basis. The SRS will define how our team envision the final product and the characteristics or functionalities it must have

--> The system should have a work panel or work window to design the network topology.
--> The system should have a toolbox with different tools to draw network devices.
--> The system should contain a compiler for compilation and running of network drawn.
-->The system should have facilities like editing the network topology, setting up properties for network devices and playback.
--> The system should provide some tools such as graph plotting tool, stack trace, command prompt which helps to study the behavior of the simulation.
--> The system should provide printing tool to print the network topology.
--> The system should implement some algorithm such as Prims algorithm to find out the shortest path spanning tree with in the topology.

Work Panel: To design the network topology
The work panel is a tool to draw the network. The network devices are drawn on work panel by selecting appropriate network device on the toolbox provided at the top of the editor and drawing on the work panel.

Tool box: To draw network devices
The SNiP Network Simulator provides a toolbox which contains standard tools for standard operation such as “open” to open a file or “save” to save the file and Network toolbox containing network devices such as node, router, switch etc to draw the network topology.

Properties: Setting up properties
The properties are the network characteristics of particular network device. The properties are set by right-clicking on the network devices and selecting “Properties” option. Different types of network devices have different properties.
Example: Node has the properties like IP address, transmission mode, commands required for establishment of connections.
Router contains properties like buffer size, router name, router ID and routing table.

Compiler: compiles the simulation
The SNiP Simulator contains a compiler which compiles the topology before the simulation. The compiler detects the errors and warnings and displays if any. If no errors found, then it converts properties of all network devices to commands.

Command Prompt
The command prompt is used to control the topology and properties of network devices. The connection establishment details can be entered directly to the command prompt. The command prompt replaces all GUI interfaces with commands. The sequence of connection establishment is dumped by the system to the command prompt.

Stack Trace: Packet details
Stack trace gives the information about all the packets transmitted in the network form one network device to other.

Graph Plotting: Selecting log details for graph plotting
Graph of transmitted and dropped packets can be plotted using graph plot tool. The graph plot tool takes the log file of the simulation.

Algorithmic simulation: Simulation of standard algorithms
The algorithmic simulation is used to simulate the algorithm. Algorithmic simulation uses only nodes and network links. Distances are assigned to the links directly from the link properties.


3.6 Configuration
3.6.1 Hardware Configuration
No special hardware configuration is required. Hardware configuration which is sufficient to run Windows XP is sufficient.

3.6.2 Software Configuration
A software package is created from software package building provided by visual studio. The software package should be installed. Before installing the software the existing system should be upgraded to Windows XP Service Pack 2.0 and .NET framework should be installed. After the installation of framework the package is ready to run. The package creates a desktop icon and start menu icon.

FEASIBILITY STUDY

2.1 Introduction
In the feasibility study we check whether the SNiP simulator project can be developed within the available software and hardware technologies. We also check whether the system to be developed is cost effective and whether it satisfies all the proposed requirements.
During feasibility study various constraints such as time constraints, budgetary constraints, resource constraints etc are studied.
The network simulator accounts for great amount of feasibility since the actual behavior of the system is simulated in a stand alone system which allows us to test the characteristics of the network by giving various inputs and analyzing the respective outputs in a short time and less amount of people involved
The project is developed in Visual C# under .NET framework using Visual Studio 2005. The Visual Studio 2005 facilitates the development of Graphical User Interface (GUI) comprising various forms for different purposes using languages like Visual C#, Visual J#, Visual C++, VB .NET. The software developed in Visual Studio is compatible to run in any newer version of Windows.

2.2 Existing System
Whenever a new system is developed it is either a new product or is a further development of some existing product. There can be some drawback in the existing product. Most of the simulators do not have good user interfaces. Often being command oriented, they demand trained users. Some simulators require a Kernel up gradation which requires reinstallation of the operating systems. It acts as an over head and thus making it less user friendly.


2.3 Proposed System
The SNiP Network Simulator has a good Graphical User Interface. It can be installed and run on windows without any kernel upgradation. SNiP Network simulator attempts to provide real world network simulation. Real world network simulation is associated with the protocols used in real world. It includes TCP/IP, UDP, FTP, etc. SNiP provides a user friendly interface to draw and simulate the topology, playback to view the data transfers, stack trace to view the data transfer of each and every packet transferred. Along with this it also provides graph drawing tool, which can be used to plot the graph giving details about in-throughput, out-throughput, collisions occurred at all the network devices. The real time network simulation tool provides the user exact time required for data transfer for a specified bandwidth and datum under various conditions. The SNiP Network simulator can be used by professionals for studying real world networks, problems encountered, and for educational purposes.

2.4 System Feasibility
This study checks whether the proposed system satisfies all the requirements that are specified in the proposal. The SNiP Network simulator can simulate a variety of networks accurately.

2.4.1 Operational Feasibility
What are the users’ needs and how does a developer system meets them? A user interactive system is provided and the user can build the topology, specify the working environment and put constraints according to the needs.

2.4.2 Technical Feasibility
Technical feasibility is concerned with determining whether it is possible to code the project using the language selected. Visual C# is used and the developer software is Visual Studio 2005.
Visual studio is a toolkit to develop windows based applications. It supports a variety of languages for the software development.
The .NET framework is a completely new model for building systems on the windows family of operating systems.

Features of .NET and Visual Studio
• Full interoperability with existing win32 code: .NET allows invoking raw C based functions from managed code.
• Complete and total language interaction: Unlike classic COM, .NET supports cross language inheritance, cross-language exception handling and cross language debugging. A common runtime engine shared by all .NET aware languages.
• Multithreading: .NET provides multithreading. This allows the software to run modules in parallel.
• Direct access to Windows APIs: .NET provides a direct access to windows APIs. The APIs including the DLL (Dynamic Link Library) functions.
• Visual studio provides GUI design tools for designing the software. It simplifies the overhead of coding to an extent, and helps to reduce the software development time and provides a better user friendly system.

2.4.3 Economical Feasibility
Economical feasibility is used for evaluating the effectiveness of a system. The project does not involve any special hardware other than standard specifications.

TESTING

6.1 Introduction
Software Testing is the process used to help identify the correctness, completeness, security, and quality of developed computer software. Testing is a process of technical investigation, performed on behalf of stakeholders, that is intended to reveal quality-related information about the product with respect to the context in which it is intended to operate. This includes, but is not limited to, the process of executing a program or application with the intent of finding errors. Quality is not an absolute; it is value to some person. With that in mind, testing can never completely establish the correctness of arbitrary computer software; testing furnishes a 'criticism' or comparison that compares the state and behavior of the product against a specification. An important point is that software testing should be distinguished from the separate discipline of Software Quality Assurance (SQA), which encompasses all business process areas, not just testing.

6.2 White box and black box testing
White box and black box testing are terms used to describe the point of view a test engineer takes when designing test cases. Black box being an external view of the test object and white box being an internal view. Software Testing is the process of executing software in a controlled manner; in order to answer the question “Does this software behave as specified?” Software testing is used in association with verification and validation. Verification is the checking of or testing of items, including software, for conformance and consistency with an associated specification. Software testing is just one kind of verification, which also uses techniques such as reviews, inspections, and walk-throughs. Validation is the process of checking what has been specified is what the user actually wanted.
Validation: Are we doing the right job?
Verification: Are we doing the job right?

6.3 Unit Testing
In unit testing each unit (basic component) of the software is tested to verify that the detailed design for the unit has been correctly implemented.
The basic components such as command prompt, packet generator, timer, simulation engine are checked and verified to ensure that the detailed design is implemented.

6.4 Integration testing
In integration testing progressively larger groups of tested software components corresponding to elements of the architectural design are integrated and tested until the software works as a whole.
After testing all the basic software components, the components are integrated to work as a single system and tested until the software works as whole.

6.5 System testing
In system testing the software is integrated to the overall product and tested to show that all requirements are met.
In this step the software is tested to weather it meets the requirements to work as a network simulator.

6.6 Regression Testing
Changes made in order to fix bugs or develop further functionality may cause previously successful tests to fail, so regression testing is used to repeat the earlier successful tests to ensure that changes made in the software have not introduced new bugs/side effects.


6.7 Test the front-end actions
It has been checked whether the front end is responding properly for different user actions.

Monday, 23 February 2015

Answer Post for Akourmis Akourmis

IDSAODV attack modul for ns2 Communication 

The problem of intrusion detection has been studied and received a lot of attention in machine learning and data mining,
IDS introduced the application of network intrusion detection
Prepared to use visual basic intrusion detection code, easy to use, good code portability.
This is an intrusion detection code. I hope this will help people doing work in IDS with secure AODV.
1. Intrusion detection for black hole attack on AODV protocol. 
IDS AODV Code in C++ ns 2 idsaodv.zip
Attack modul for ns2 

https://www.mediafire.com/?98k4nhasq4ak6akDownload Link


2.Intrusion detection system using AODV routing protocol 

idsaodv.rar
https://www.mediafire.com/?cpdp8encp8j99ppDownload Link
https://www.mediafire.com/?cpdp8encp8j99ppDownload Link
Answer Post for Akourmis Akourmis

IDSAODV attack modul for ns2 Communication 

The problem of intrusion detection has been studied and received a lot of attention in machine learning and data mining,
IDS introduced the application of network intrusion detection
Prepared to use visual basic intrusion detection code, easy to use, good code portability.
This is an intrusion detection code. I hope this will help people doing work in IDS with secure AODV.
1. Intrusion detection for black hole attack on AODV protocol. 
IDS AODV Code in C++ ns 2 idsaodv.zip
Attack modul for ns2 

https://www.mediafire.com/?98k4nhasq4ak6akDownload Link


2.Intrusion detection system using AODV routing protocol 

idsaodv.rar
https://www.mediafire.com/?cpdp8encp8j99ppDownload Link
https://www.mediafire.com/?cpdp8encp8j99ppDownload Link

Wednesday, 5 November 2014

Intrusion Detection System In BLACK Hole

Intrusion Detection System: IDS system which generates first aodv scenario and then it can implement the black hole attack after that it is also detecting the attacker node and preventing the packets routing through them 

[blackhole20-1-vbr.rar]

Sunday, 2 November 2014

AODV simulation for a Sensor network 802.15.4

           The reason to write this topic is many people asked me how to simulate sensor networks.
Obviously, authors of 802.15.4/Zigbee protocol developers on NS2 have given a sample examples. But, these examples do not run correctly, and give some kind of unknown error (at least I don’t know what errors mean).
Therefore, I have decided to test AODV using 802.15.4 MAC/PHY. Thus, if my tests work, I hope you can test your own routing protocols using this source code.

Alright, the TCL file is fairly simple. I briefly explain what means what. We first set simulation environment. We are going to deploy 500 nodes, in 1000×500 sqm area, simulation time is 500 seconds. And we are using 802.15.4 MAC/PHY and interface queue is 100. We also set simulator and files to trace the simulation.
1# Generated by Topology Generator for Network Simulator
2set val(chan)          Channel/WirelessChannel      ;# channel type
3set val(prop)          Propagation/TwoRayGround     ;# radio-propagation model
4set val(netif)         Phy/WirelessPhy/802_15_4     ;# network interface type
5set val(mac)           Mac/802_15_4                 ;# MAC type
6set val(ifq)           Queue/DropTail/PriQueue      ;# interface queue type
7set val(ll)            LL                           ;# link layer type
8set val(ant)           Antenna/OmniAntenna          ;# antenna model
9set val(ifqlen)        100                  ;# max packet in ifq
10set val(nn)            500              ;# number of mobilenodes
11set val(rp)            AODV             ;# protocol tye
12set val(x)             1000             ;# X dimension of topography
13set val(y)             500              ;# Y dimension of topography
14set val(stop)          500              ;# simulation period
15set val(energymodel)   EnergyModel          ;# Energy Model
16set val(initialenergy) 100              ;# value
17 
18set ns              [new Simulator]
19set tracefd         [open trace-aodv-802-15-4.tr w]
20set namtrace        [open nam-aodv-802-15-4.nam w]
21 
22$ns trace-all $tracefd
23$ns namtrace-all-wireless $namtrace $val(x) $val(y)
Let’s set radio transmission range to 40 meters, but this does not mean exactly 40 meters. The code below filters packet with receiving signal strength above “40 meters”.
1set dist(5m7.69113e-06
2set dist(9m2.37381e-06
3set dist(10m) 1.92278e-06
4set dist(11m) 1.58908e-06
5set dist(12m) 1.33527e-06
6set dist(13m) 1.13774e-06
7set dist(14m) 9.81011e-07
8set dist(15m) 8.54570e-07
9set dist(16m) 7.51087e-07
10set dist(20m) 4.80696e-07
11set dist(25m) 3.07645e-07
12set dist(30m) 2.13643e-07
13set dist(35m) 1.56962e-07
14set dist(40m) 1.20174e-07
15Phy/WirelessPhy set CSThresh_ $dist(40m)
16Phy/WirelessPhy set RXThresh_ $dist(40m)
And lets set topography as flat, deploy nodes randomly in an area of 1000 x 500 sqm.
1# set up topography object
2set topo       [new Topography]
3$topo load_flatgrid $val(x) $val(y)
4 
5create-god $val(nn)
6 
7# configure the nodes
8$ns node-config -adhocRouting $val(rp)
9            -llType $val(ll)
10             -macType $val(mac)
11             -ifqType $val(ifq)
12             -ifqLen $val(ifqlen)
13             -antType $val(ant)
14             -propType $val(prop)
15             -phyType $val(netif)
16             -channel [new $val(chan)]
17             -topoInstance $topo
18             -agentTrace ON
19             -routerTrace ON
20             -macTrace  OFF
21             -movementTrace OFF
22             -energyModel $val(energymodel)
23             -initialEnergy $val(initialenergy)
24             -rxPower 35.28e-3
25             -txPower 31.32e-3
26         -idlePower 712e-6
27         -sleepPower 144e-9
28 
29             #-IncomingErrProc MultistateErrorProc
30             #-OutgoingErrProc MultistateErrorProc
31 
32for {set i 0} {$i < $val(nn) } { incr i } {
33        set mnode_($i) [$ns node]
34}
35 
36for {set i 1} {$i < $val(nn) } { incr i } {
37    $mnode_($i) set X_ [ expr {$val(x) * rand()} ]
38    $mnode_($i) set Y_ [ expr {$val(y) * rand()} ]
39    $mnode_($i) set Z_ 0
40}
And we are goig to deploy sink node in the center of area, i.e. at [500, 250].
1# Position of Sink
2$mnode_(0) set X_ [ expr {$val(x)/2} ]
3$mnode_(0) set Y_ [ expr {$val(y)/2} ]
4$mnode_(0) set Z_ 0.0
5$mnode_(0) label "Sink" 

The code below is useful how big the nodes are going to be shown in NAM (network animator), thus it does not have meaning in real simulation.
1for {set i 0} {$i < $val(nn)} { incr i } {
2    $ns initial_node_pos $mnode_($i) 10
3}
Finally, we have deployed nodes, and remained important thing is establish connection. We are going to use UDP protocol with CBR (constant bit rate, interval (interval_) is set to 2 seconds)
1#Setup a UDP connection
2set udp [new Agent/UDP]
3$ns attach-agent $mnode_(10) $udp
4 
5set sink [new Agent/Null]
6$ns attach-agent $mnode_(0) $sink
7 
8$ns connect $udp $sink
9$udp set fid_ 2
10 
11#Setup a CBR over UDP connection
12set cbr [new Application/Traffic/CBR]
13$cbr attach-agent $udp
14$cbr set type_ CBR
15$cbr set packet_size_ 50
16$cbr set rate_ 0.1Mb
17$cbr set interval_ 2
18#$cbr set random_ false
19 
20$ns at 5.0 "$cbr start"
21$ns at [expr $val(stop) - 5] "$cbr stop"
22 
23# Telling nodes when the simulation ends
24for {set i 0} {$i < $val(nn) } { incr i } {
25    $ns at $val(stop) "$mnode_($i) reset;"
26}
27 
28# ending nam and the simulation
29$ns at $val(stop) "$ns nam-end-wireless $val(stop)"
30$ns at $val(stop) "stop"
31$ns at [expr $val(stop) + 0.01] "puts "end simulation"; $ns halt"
32proc stop {} {
33    global ns tracefd namtrace
34    $ns flush-trace
35    close $tracefd
36    close $namtrace
37}
38 
39$ns run
We have finished writing sample AODV TCL script, we can run it
1ns aodv_802_15_4.tcl
Download whole source code here : aodv_802_15_4.tcl . If you find any problem with that, leave comment here. If you want to test your own routing protocol simply change $val(rp) AODV with your own.