Merge pull request #35 from GNS3/internet

Internet
This commit is contained in:
Jeremy Grossmann 2016-01-04 19:51:35 -08:00
commit 9946611f70
5 changed files with 103 additions and 1 deletions

41
appliances/internet.gns3a Normal file
View File

@ -0,0 +1,41 @@
{
"versions": [
{
"name": "0.1",
"images": {
"hda_disk_image": "core-linux-6.4-internet-0.1.img"
}
}
],
"qemu": {
"console_type": "telnet",
"arch": "i386",
"adapters": 1,
"adapter_type": "e1000",
"options": "-device e1000,netdev=internet0 -netdev vde,sock=/var/run/vde2/qemu0.ctl,id=internet0",
"ram": 64
},
"vendor_name": "GNS3",
"usage": "Just connect stuff to the appliance. Everything is automated.",
"vendor_url": "http://www.gns3.com",
"product_name": "Internet",
"description": "This appliance simulate a domestic modem. It provide an IP via DHCP and will nat all connection to the internet without the need of using a cloud interface in your topologies. IP will be in the subnet 172.16.0.0/16. Multiple internet will have different IP range from 172.16.1.0/24 to 172.16.253.0/24 .\n\nWARNING USE IT ONLY WITH THE GNS3 VM.",
"symbol": ":/symbols/cloud.svg",
"maintainer": "GNS3 Team",
"name": "Internet",
"category": "router",
"status": "stable",
"registry_version": 1,
"maintainer_email": "developers@gns3.net",
"documentation_url": "http://www.gns3.com",
"images": [
{
"version": "0.1",
"filename": "core-linux-6.4-internet-0.1.img",
"direct_download_url": "http://downloads.sourceforge.net/project/gns-3/Qemu%20Appliances/core-linux-6.4-internet-0.1.img",
"filesize": 16711680,
"md5sum": "8ebc5a6ec53a1c05b7aa101b5ceefe31",
"download_url": "https://sourceforge.net/projects/gns-3/files/Qemu%20Appliances/"
}
]
}

View File

@ -54,6 +54,16 @@ A drone-only VM can be build with:
packer build -var-file=ostinato-drone.json core-linux.json
Internet
''''''''
An appliance for simulating a domestic modem. eth0 as a dhcp and eth1 should be a nat interface.
.. code:: bash
packer build -var-file=core-linux-internet.json core-linux.json
Tiny Core Linux installation
****************************

View File

@ -0,0 +1,4 @@
{
"vm_name": "core-linux-6.4-internet.img",
"setup_script": "internet.sh"
}

View File

@ -25,7 +25,8 @@
"http_directory": "http",
"boot_wait": "5s",
"boot_command": [
"mc user=gns3<enter><wait10><wait10><wait10><wait10><wait10><wait10>",
"mc user=gns3<enter><wait10><wait10><wait10><wait10><wait10><wait10><wait10>",
"sudo udhcpc<enter>",
"sudo passwd gns3<enter>gns3<enter>gns3<enter>",
"tce-load -wi openssh<enter><wait10>",
"cd /usr/local/etc/ssh; [ -f sshd_config.example ] && sudo cp -a sshd_config.example sshd_config; cd<enter>",

View File

@ -0,0 +1,46 @@
set -x
# Enable NAT
echo "iptables -t nat -A POSTROUTING -o eth1 -j MASQUERADE" >> /opt/bootlocal.sh
echo "iptables -A FORWARD -i eth1 -o eth0 -m state --state RELATED,ESTABLISHED -j ACCEPT" >> /opt/bootlocal.sh
echo "iptables -A FORWARD -i eth0 -o eth1 -j ACCEPT" >> /opt/bootlocal.sh
tce-load -wi dnsmasq
# Setup DHCP
# A random IP range is choose at startup allowing user to put multiple access links
cat > setup_dhcp_and_ip.sh << 'EOF2'
#!/bin/sh
killall udhcpc
killall udhcpd
killall dnsmasq
udhcpc -i eth1
IP=$((RANDOM%253+1))
ifconfig eth0 172.16.$IP.1 netmask 255.255.255.0 up
echo "expand-hosts" >> /etc/dnsmasq.conf
echo "no-negcache" >> /etc/dnsmasq.conf
echo "dhcp-authoritative" >> /etc/dnsmasq.conf
echo "dhcp-leasefile=/tmp/dhcp.leases" >> /etc/dnsmasq.conf
echo "dhcp-range=172.16.$IP.2,172.16.$IP.254,12h" >> /etc/dnsmasq.conf
echo "# Netmask" >> /etc/dnsmasq.conf
echo "dhcp-option=1,255.255.255.0" >> /etc/dnsmasq.conf
echo "# Route" >> /etc/dnsmasq.conf
echo "dhcp-option=3,172.16.$IP.1" >> /etc/dnsmasq.conf
dnsmasq
EOF2
sudo mv setup_dhcp_and_ip.sh /sbin/setup_dhcp_and_ip.sh
sudo chmod 700 /sbin/setup_dhcp_and_ip.sh
sudo chown root /sbin/setup_dhcp_and_ip.sh
echo '/sbin/setup_dhcp_and_ip.sh' >> /opt/bootlocal.sh
echo 'etc/dnsmasq.conf' >> /opt/.filetool.lst
echo 'sbin/setup_dhcp_and_ip.sh' >> /opt/.filetool.lst