-
Step 1. Checking user The script should be run by user root and by console, if it was run by another user then it will warn and exit.
-
Step 2. Checking Platform The all software intended to run on Debian 8 , so if script finds another platform it will output an error and exit.
-
Step 3. Checking Hardware As software can be installed either on ARM boards or Physical/Virtual x86 64b machine, in this step we need to determine hardware. After determining hardware type we can determine the next step.
-
Step 4. Checking requirements There are a list of minimum requirements that Physical/Virtual machine needs to meet. 2 at least network interfaces (ethernet or wlan) 1 GB of Physical memory 16 GB of Free disk space If machine meets the requirements then script goes to next step, otherwise it will warn and exit.
-
Step 5. Getting DHCP client on interfaces In this step script first DHCP request from ethX to get an ip address. If succeed, it will check for Internet connection and if Internet connection is established this step is done successfully. In any case of failure (no DHCP response or on Internet connection) script will try the same scenario for next interface. Order to try is - eth1, wlan1, eth0, wlan0 (list of available interfaces are available from step 4). Of no success in any interface, then script will warn user to plug the machine to Internet and will exit.
-
Step 6. Preparing repositories and updating sources In this step script adds repository links for necessary packages into package manager sources and updates them. Script will output an error ant exit if it is not possible to add repositories or update sources.
-
Step 7. Downloading and Installing packages As we already have repository sources updated in step 6, so at this point script will download and install packages using package manager tools. If something goes wrong during download or installation, script will output an error ant exit. If step 7 finished successfully it's time to run the next script “app-installation-script.sh”.
-
Step 4.2. Check if the ARM board assembled. There are list of modules that need to be connected to ARM boards, so script will check if that modules are connected. You can fine information about necessary modules later. If any module is missed user will get warning and script will exit.
-
Step 6.2. Preparing repositories and updating sources The same as in Physical/Virtual machine case.
-
Step 7.2. Downloading and Installing packages The same as in Physical/Virtual machine case. If step 7 finished successfully then test.sh execution for odroid board is finished successfully and it's time to run the next script “app-installation-script.sh”.
#Setting up a lab to start to contribute:
ESXi,VirtualBox,other vitrual lab:
Internet Router<-----eth0----Debian64----eth1---Virtual Lan vswitch<---eth---Windows10
DHCPserver--eth0---sameDebian64-----eth1--(Debian will start a dhcpserver internally)--------Win10
First of all you should install latest Debian version in a virtual machine:
- 2GB RAM, 2 procesor, 2NICs (network interfaces)
Second a non privacy friendly OS like Win 10:
- VM requirements in microsoft
- Office 2016
- All possible browsers.dropbox client, seamonkey,firefox,chrome,edge,iexplorer,opera,chromiun.
Hardware resources:
- NIC1 will be NAT/bridged to your Internet dhcp server router.
- NIC2 will be a attached via virtual switch or vlan to the other VM Windows10. From debian to win 10 will be a private LAN in bridge mode. (would require promiscous because arp request from client to server)
You can use any virtualization software you prefer. Its transparent for us.
As shown in the following figure.
Resume of steps:
- In Virtualbox in ubuntu like: https://jtreminio.com/2012/07/setting-up-a-debian-vm-step-by-step/
- Or any physical machine like https://www.debian.org/doc/manuals/debian-handbook/sect.installation-steps.ru.html
- In the Debian please do a Snapshot in the Virtual machine just after being install.
- go shell command console in debian and execute as root:
- wget --no-check-certificate https://bit.ly/2gbKstn | bash 2gbKstn
or
- apt-get install curl
- curl -L http://bit.ly/2gbKstn | bash
Important note before testing :
- Do NOT try to install the scripts via ssh session.
- The scripts FAIL if you do that, due to problems with ethernet connection.
- install the scripts via direct console access.
Lab done!
Try to navigate normally from the windows 10 Report us problems Investigate and play while we continue developing it. New version of the instalaltion-configuration scripts,ISOs and OVA virtual machine export will be upcoming.
#Networking in Librerouter:
There are two bridges with two interfaces each in the machine like two bridges (only 2 separated zone NICs):
- External area red bridge acting as WAN (2 nics): cable or wireless interface as DHCP client of your internet router.
- Internal area gren bridge acting as LAN (2 nics): cable or wireless interface as an AP for being DHCP server for your new secure LAN.
-
Four possible PHySICAL scenarios:
-
WAN is WiFi, LAN is WiFi
-
WAN is WiFi, LAN is Cabled Ethernet
-
WAN is Cabled Ethernet, LAN is WiFi
-
WAN is Cabled Ethernet, LAN is Cabled Ethernet
#Librerouter has 4 ways to work in the network:
-
Server (no protection but services)
-
Network Router (services and network protection) (dont mix with NIC bridges that we have to separate 4 interfaces in 2 zones)
-
Pasive Security Sensor (not yet done)
-
Transparent Man in the Middle Interception (hacking pentesting security testers) (not yet done)
##Server mode
The way networking works in Librerouter will be:
- Fix serviceable IPs in 10.0.0.x can be wireless or Cabled Ethernet connected to the existing internet router LAN.
- Server mode with both WAN and LAN interfaces in the same DMZ or VLAN or area and not threating the network traffic (not hable to defend against web browsing leaks,tracking,ads and malware)
##Router bridge mode Where the trafic is filtered by dns , by ip via iptables, by protocol, application layer signature and reputationally.
#How Librerouter will threat the network traffic as a Privacy Firewall in router mode (most common).
- a) Clean network web browsing traffic (IoT, cookies tracks, scripts tracks, malware, exploits, attackes, non privacy friendly corporations web servers)
- b) Blocking not privacy friendly protocols and inspecting inside ssl tunnels.
- c) Monitoring for abnormal behaviours.
- d) Offering decentralized alternatives of the such called cloud services.
- e) Will clean files in storage erasing metadata Sanitization (optional to classified and personal information)
- f) Will protect the access to your webs publically in TOR-I2P and clearnet.(normal internet).
- d) Will selfhost search engine,email,storage,conference,collaborative,git,project managing,socialnetwork, TOR shop.
#DNS:
- Unbound-dns is the DNS SERVER hsts domain list goes to dns hsts bypass engine.
- If it is not resolved then using cached then we use DNSCRYPT to ask D.I.A.N.A and OpenNIC.
- If it can not resolved, then we need to ask through TOR aleatory.
- Further integration will include Bitname,others like DjDNS (this last need maintenance is not workinghttps://github.com/DJDNS/djdns)).
- Search engines - will be resolved to ip address 10.0.0.251 (Yacy) by unbound. and hsts downgraded and dns hardredirected.
- Social network - will be resolved to ip address 10.0.0.252 (friendics) by unbound. and hsts downgraded and dns hardredirected.
- Online Storage - Will be resolved to ip address 10.0.0.253 (Owncloud) by unbound. and hsts downgraded and dns hardredirected.
- Webmails - Will be resolved to ip address 10.0.0.254 (MailPile) by unbound. and hsts downgraded and dns hardredirected.
- .local - will be resolved to local ip address (10.0.0.0/24 network) by unbound.
- .i2p - will be resolved to ip address 10.191.0.1 by unbound.
- .onion - unbound will forward this zone to Tor DNS running on 10.0.0.1:9053
-Freenet domains:> not yet implemented
- http://ftp.mirrorservice.org/sites/ftp.wiretapped.net/pub/security/cryptography/apps/freenet/fcptools/linux/gateway.html
- Bit domains> blockchain bitcoin> not yet implemented
- https://en.wikipedia.org/wiki/Namecoin https://bit.namecoin.info/
- Zeronet> not yet implemented
- Openbazaar> not yet implemented
Yes in the future via GUI should be possible to reconfigure this cage enabling services as plugins.
#Temporary architecture
#Engines especifications and configuration dependencies:
##Privoxy and Privacy options for TOR traffic:
#TOR configurations. Tor dns configuration is implemented like this...
#I2P configuration.
#NGINX configuration.
#Multiple Squids (darknet bumping and clearnet ssl NObump) configurations.
#Privoxy configuration.
#Iptables configuration.
##Rules Description
$INT_INTERFACE - is internal network interface
$EXT_INTERFACE - is external network interface
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p tcp -d 10.0.0.245 -j ACCEPT
- accepts all of the tcp traffic on interface 10.0.0.245 which is webmin ip of librerouter service
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p tcp -d 10.0.0.11 -j ACCEPT
- accepts all of the tcp traffic on interface 10.0.0.11 which is kibana ip of librerouter service
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p tcp -d 10.0.0.12 -j ACCEPT
- accepts all of the tcp traffic on interface 10.0.0.12 which is snorby ip of librerouter service
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p tcp -d 10.0.0.246 -j ACCEPT
- accepts all of the tcp traffic on interface 10.0.0.246 which is squidguard ip of librerouter service
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p tcp -d 10.0.0.250 -j ACCEPT
- accepts all of the tcp traffic on interface 10.0.0.250 which is easyrtc ip of librerouter service
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p tcp -d 10.0.0.251 -j ACCEPT
- accepts all of the tcp traffic on interface 10.0.0.251 which is yacy ip of librerouter service
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p tcp -d 10.0.0.252 -j ACCEPT
- accepts all of the tcp traffic on interface 10.0.0.252 which is friendica ip of librerouter service
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p tcp -d 10.0.0.253 -j ACCEPT
- accepts all of the tcp traffic on interface 10.0.0.253 which is owncloud ip of librerouter service
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p tcp -d 10.0.0.254 -j ACCEPT
- accepts all of the tcp traffic on interface 10.0.0.254 which is mailpile ip of librerouter service
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p tcp -d 10.0.0.1 --dport 22 -j REDIRECT --to-ports 22
- avoids NATing 22 port for an external ssh access
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p udp -d 10.0.0.1 --dport 53 -j REDIRECT --to-ports 53
- avoids NATing 53 port for an external DNS access
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p tcp -d 10.0.0.1 --dport 80 -j REDIRECT --to-ports 80
- avoids NATing 80 port for an external HTTP access
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p tcp -d 10.0.0.1 --dport 443 -j REDIRECT --to-ports 443
- avoids NATing 443 port for an external HTTPS access
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p tcp -d 10.0.0.1 --dport 7000 -j REDIRECT --to-ports 7000
- avoids NATing 7000 port for an external access
iptables -t nat -A OUTPUT -d 10.191.0.1 -p tcp --dport 80 -j REDIRECT --to-port 3128
- redirects all output tcp traffic to destanation http port and destanation address 10.191.0.1 to squid-i2p service port
iptables -t nat -A PREROUTING -d 10.191.0.1 -p tcp --dport 80 -j REDIRECT --to-port 3128
- redirects all tcp traffic to destanation http and destanation address 10.191.0.1 to squid-i2p service port
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p tcp -m tcp --sport 80 -d 10.191.0.1 -j REDIRECT --to-ports 3128
- redirects all tcp traffic with source http port and destanation address 10.191.0.1 to squid-i2p service port
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p tcp -d 10.0.0.0/8 -j DNAT --to 10.0.0.1:3129
- redirects all tcp traffic from internal interface to 10.0.0.0/8 network to squid-tor service port
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p tcp --dport 80 -j DNAT --to 10.0.0.1:3130
- redirects http traffic from internal interface to squid-http service port
iptables -t nat -A PREROUTING -i $INT_INTERFACE -p tcp --dport 443 -j REDIRECT --to-ports 3131
- redirects https traffic from internal interface to squid-https service port
iptables -t nat -A POSTROUTING -o $EXT_INTERFACE -j MASQUERADE
- rule for NATing traffic from internal to extarnal interface
When user is using HTTPS connection to a darknet domain, this traffic it's considered dangerus and insecure. (the goverment try to explodes the browser for deanonymization) On darknet onion and i2p domains, squid will open the SSL tunnel and inspect for possible exploits, virus and attacks to the user. If this connection it's to a HTTPS regular/banking domain, this SSL tunnel will be not open Bumped/inspected. Will be routed directly to the clearnet internet (ex: https://yourbank.com)
When the user is using HTTP, because is considered insecure itself this clear traffic is going to go through TOR to add anonymization but after a threatment from the local engines to add privacy on it.. The user can also decide in the future about which things he dont want to use TOr for HTTP. To provide full internet security, we want IDS/IPS to inspect all kind of communications in our network: tor, i2p and direct. But we also want to inspect all secure connections. To do so, we use squid proxy with ssl-bump feature to perform mitm. All decrypted traffic goes to icap server, where it's being scanned by clam antivirus.
To accomplish our goal, we are going to make Suricata listen on two interfaces:
- On LAN Suricata is going to detect potentially bad traffic (incoming and outgoing), block attackers/compromised hosts, tor exit nodes, etc. Suricata will inspect packets using default sets of rules: Botnet Command and Control Server Rules (BotCC), ciarmy.com Top Attackers List, Known CompromisedHost List, Spamhaus.org DROP List, Dshield Top Attackers List, Tor exit Nodes List, Protocol events List.
- On localhost Suricata is supposed to scan icap port for bad content: browser/activex exploits, malware, attacks, etc. Modified emerging signatures for browsers will be implemented for this purpose.
Suricata will prevent the following sets of attacks:
a) Web Browsers
- ActiveX Remote Code Execution
- Microsoft IE ActiveX vulnerabilities
- Microsoft Video ActiveX vulnerabilities
- Snapshot Viewer for Microsoft Access ActiveX vulnerabilities
- http backdoors (get/post)
- DNS Poisoning
- Suspicious/compromises hosts
- ClickFraud URLs
- Tor exit nodes
- Chats vulnerabilities (Google Talk/Facebook)
- Gaming sites vulnerabilities (Alien Arena/Battle.net/Steam)
- Suspicious add-ins and add-ons downloading/execution
- Javascript backdoors
- trojans injections
- Microsoft Internet Explorer vulnerabilities
- Firefox vulnerabilities
- Firefox plug-ins vulnerabilities
- Google Chrome vulnerabilities
- Malicious Chrome extencions
- Android Browser vulnerabilities
- PDF vulnerabilities
- Stealth code execution
- Adobe Shockwave Flash vulnerabilities
- Adobe Flash Player vulnerabilities
- Browser plug-in commands injections
- Microsoft Office format vulnerabilities
- Adobe PDF Reader vulnerabilities
- spyware
- adware
- Web scans
- SQL Injection Points
- Suspicious self-signed sertificates
- Dynamic DNS requests to suspicious domains
- Metasploits
- Suspicious Java requests
- Suspicious python requests
- Phishing pages
- java.runtime execution
- Malicious files downloading
b) Librerouter (router services)
- mysql attacks
- Apache/nginx Brute Force Attacks
- GPL attack responses
- php remote code injections
- Apache vulnerabilities
- Apache OGNL exploits
- Oracle Java vulnerabilities
- PHP exploits
- node.js exploits
- ssh attacks
c) User devices
- GPL attack responses
- Metasploit Meterpreter
- Remote Windows command execution
- Remote Linux command execution
- IMAP attacks
- pop3 attacks
- smtp attacks
- Messengers vulnerabilities (ICQ/MSN/Jabber/TeamSpeak)
- Gaming software vulnerabilities (Steam/PunkBuster/Minecraft/UT/TrackMania/WoW)
- Microsoft Windows vulnerabilities
- OSX vulnerabilities
- FreeBSD vulnerabilities
- Redhat 7 vulnerabilities
- Apple QuickTime vulnerabilities
- RealPlayer/VLC exploits
- Adobe Acrobat vulnerabilities
- Worms, spambots
- Web specific apps vulnerabilities
- voip exploits
- Android trojans
- SymbOS trojans
- Mobile Spyware
- iOS malware
- NetBios exploits
- Oracle Java vulnerabilities
- RPC vulnerabilities
- telnet vulnerabilities
- MS-SQL exploits
- dll injections
- Microsoft Office vulnerabilities
- rsh exploits
Loopback issue:
Suricata >=3.1 is unable to listen on loopback in afp mode. When run with -i lo option, it dies with this messages:
<Error> - [ERRCODE: SC_ERR_INVALID_VALUE(130)] - Frame size bigger than block size
<Error> - [ERRCODE: SC_ERR_AFP_CREATE(190)] - Couldn't init AF_PACKET socket, fatal error
Same configuration works fine with Suricata v3.0.0.
Possible solutions:
- Use pcap mode on lo and af-packet on eth0. May not be possible, because since 3.1 Suricata use af-packet mode by default
- Reduce the MTU size
###HSTS https://en.wikipedia.org/wiki/HTTP_Strict_Transport_Security
Problem: when a use uses the google/bing search by a direct query keyword in the browsers The browser enfoces hsts then the certificate from our redirected yacy fails. Then we cant inspect the traffic for this big list of domains: https://cs.chromium.org/chromium/src/net/http/transport_security_state_static.json We inspect for protecting the browser against exploitation of bugs and attacks. Who can guaranteed this entities are not doing it?
We inspect the HSTS domains with Snort,Suricata BRO and CLamAV via ICAP CCAP and Squid bumping
The problem is that the redirection we made when the user tries gmail for instance in to local service mailpile fails with multiple browser because hsts.
Why we redirect gmail to mailpile or roundcube? obvious we offer s elfhosted solution better than corporate centralized.
##Squid tuning conf for Privacy : squid.conf
- via off
- forwarded_for off
- header_access From deny all
- header_access Server deny all
- header_access WWW-Authenticate deny all
- header_access Link deny all
- header_access Cache-Control deny all
- header_access Proxy-Connection deny all
- header_access X-Cache deny all
- header_access X-Cache-Lookup deny all
- header_access Via deny all
- header_access Forwarded-For deny all
- header_access X-Forwarded-For deny all
- header_access Pragma deny all
- header_access Keep-Alive deny all
- request_header_access Authorization allow all
- request_header_access Proxy-Authorization allow all
- request_header_access Cache-Control allow all
- request_header_access Content-Length allow all
- request_header_access Content-Type allow all
- request_header_access Date allow all
- request_header_access Host allow all
- request_header_access If-Modified-Since allow all
- request_header_access Pragma allow all
- request_header_access Accept allow all
- request_header_access Accept-Charset allow all
- request_header_access Accept-Encoding allow all
- request_header_access Accept-Language allow all
- request_header_access Connection allow all
- request_header_access All deny all
- forwarded_for delete
- follow_x_forwarded_for deny all
- request_header_access X-Forwarded-For deny all
- request_header_access From deny all
- request_header_access Referer deny all
- request_header_access User-Agent deny all