Tim Young 4a72518ccc Don't lose DHCP range when NIC address changes
When a server or firewall changes the IP address of a network
card, any DHCP ranges associated with that old number were
zeroed out.

Invalidating the range COULD be a nice feature in case the
new IP address falls within the DHCP range - thus preventing
conflicting IP addresses. So just to be nice I did allow the
range to invalidate in that situation. However, in real life
it wouldn't be so nice, and so perhaps it would actually be
better to keep the existing rules intact even if it would
cause a problem.

Scenario: Level 2 Firewall Test
-change firewall eth0 to 192.168.1.10 and eth1 to 192.168.2.20
-click OK
-edit firewall again and look at the DHCP rules
    -notice that 192.168.1 has all zeros.
    -same thing with 192.168.2
    -after the fix, the 192.168.2 rules are retained since
   2.20 doesn't conflict with the range, but 1.10 does
   conflict, so that rule was invalidated.
2019-04-13 10:05:22 -05:00
2017-02-24 14:29:51 +03:00
2017-02-24 14:29:51 +03:00
2017-07-28 13:00:32 -05:00
2019-02-22 14:24:45 -06:00

EduNetworkBuilder is a simple program for teaching network principles. It was inspired by watching a number of people struggling with PacketTracer in an attempt to undestand IP addresses, subnets, and gateways. Most of their struggles were with understanding how to configure an IP on each device; they never got around to learning about how the subnets worked.

EduNetworkBuilder is geared to take all the complexity away, and let you visualize the network and packet flow in a very simple way. It has proven itself already, as a great tool for teaching in lab-settings in Africa.

It is also set up to be a tool for self-teaching; If you can solve all the built-in puzzles, you should be well on your way to mastering networking.

EduNetworkBuilder is a Visual Studio program. You should be able to download the current free edition of Visual Studio, open the project file, and make the project. You should also be able to download pre-compiled versions from: http://tyounglightsys.ddns.info/EduNetworkBuilder

*** Building on Linux with Mono and XBuild ***

This should be the simplest way to install EduNetworkBuilder on Linux. You will need to install git, Mono and XBuild.

On Mint or ubuntu, you can do this by running:

$ sudo apt-get install mono-complete mono-xbuild git

For Ubuntu 18.04 also install libmono-microsoft-visualbasic10.0-cil

On Centos, you need the epel repository

yum install epel-release

yum install mono-complete mono-devel

yum install git

After this, you should be ready to download and compile. Determine where you want to build your source, cd to that directory, and run:

$ git clone https://git.solidcharity.com/timy/EduNetworkBuilder $ cd EduNetworkBuilder $ xbuild

After this, you should see a lot of build messages. In the end, you should be able to find the executable at: EduNetworkBuilder/bin/Debug/EduNetworkBuilder.exe Copy this file wherever you want. For example:

$ sudo cp EduNetworkBuilder/bin/Debug/EduNetworkBuilder.exe /usr/local/bin/

And then you can run it by simply typing:

$ EduNetworkBuilder.exe

*** Building on Linux With MonoDevelop ***

EduNetworkBuilder should compile on Linux using MonoDevelop with one small change to the code. EduNetworkBuilder on Windows uses the Microsoft deployment mechanism, which cannot build on Linux. To make it work, we need to change a configuration option. So, here are the instructions for building on Linux.

  1. Install MonoDevelop for your version of Linux

  2. Install git for your version of Linux

  3. Download the EduNetworkBuilder source code.

    $ git clone https://git.solidcharity.com/timy/EduNetworkBuilder

  4. Choose which git branch you want to use (optional)

    $ cd EduNetworkBuilder

    $ git checkout Development

  5. Change the EduNetworkBuilder.csproj file

    Find the line that says:

    <GenerateManifests>true</GenerateManifests>
    

    Change it to read:

    <GenerateManifests>false</GenerateManifests>   
    
  6. Run MonoDevelop (use the instructions for your specific operating system)

  7. Find and open the EduNetworkBuilder.sln file

  8. Tell EduNetworkBuilder to build using the MonoDevelop interface

  9. Find the exe in the build directory. Chmod that to make it executable, and put it wherever you want it to go:

    $ find . | grep EduNetworkBuilder.exe

    $ chmod 755 [EduNetworkBuilder.exe path]

    $ mv [EduNetworkBuilder.exe path] /usr/local/bin

Description
An educational tool for teaching computer networking concepts.
Readme 5.5 MiB
Languages
Rich Text Format 70.9%
C# 29%