Skip to content

A 42-school project. Involves the use of basic sysadmin/network tools and the creation of my first web server.

Notifications You must be signed in to change notification settings

Vellamo/Roger-Skyline-1

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

29 Commits
 
 
 
 

Repository files navigation

Roger-Skyline-1

A 42-school project. Involves the use of basic sysadmin/network tools and the creation of my first web server. Due to the size of the VDI (and the nature of the project), it is not included as part of this repository.

Workflow

  1. Installed VM to specifications -- I used Debian. Ensure VM filesize/disk space is 8GB.
  2. Check partition sizes with cfdisk.
    • Ensure one partition is "4.2GB". Diffentiation between Gigabyte and Gibibyte in the brief left ambigous. Make your own decision on this matter.
  3. apt-get install required services.
    • Nginx, ufw, fail2ban, portsentry were all tools that I utilised.
  4. adduser & give them Sudo permissions.
    • adduser <name>
    • usermod -Ag sudo <name>
  5. Modify /etc/network/interfaces.d/ to specifications outlined in the brief (Static IP, etc).
  6. Modify /etc/ssh/sshd_config to alter the default SSH port, as outlined in the brief.
  7. ssh-keygen a new SSH key for accessing the remote. Copy it to the remote and use this to connect.
  8. Configure UFW to default to deny incoming and allow outgoing. Open only required ports.
    • Ensure SSH connections still work and use a portscan tool to check for any ports that remain open.
    • I limited UFW to allowing only 80/tcp, <ssh_port>/tcp and 443/tcp.
  9. Configure F2B for DOS protection. Modify jail.local and create appropriate filters.
    • Modify ignoreip if needed, as well as bantime, findtime and maxretry.
    • Use sendmail as the mta.
    • Ensure the correct default action is taken action = %(action_mwl)s so that you recieve mail.
    • You can use several default apache filters as Nginx filters, some will require configuration.
    • Create a new DOS jail and filter.
    • (Optional) You can also use F2B to detect and attempt to ban portscans.
  10. Configure PortSentry for port scanning protection. Modify /etc/default/portsentry & /etc/portsentry/portsentry.conf
  11. Use systemctl --type=service --state=active to find non-vital services running and systemctl disable <service> to disable them. service --status-all and serivce <service> disable is another option.
  12. Create/configure Crontab scripts, as outlined in the brief.
  13. (OPTIONAL) Create pretty website.
    • Create and configure SSL certificates.
    • Use HTML/CSS etc. to make an amazing website. Put it someplace safe, I used /var/www/
    • Modifiy /etc/nginx/sites-available/<website.conf> to ensure that SSL is enabled and that traffic is being correctly routed (from HTTP to HTTPS).
    • Remove the symlink to "default" from the /etc/nginx/sites-available/ to ensure Nginx is publishing your content.
  14. Success!

Tools used:

  • Nginx
  • UFW
  • Fail2ban
  • Portsentry
  • nmap
  • Cron
  • HTML & CSS

Useful commands!

  • sudo <cmd\>
  • ufw
  • service --status-all
  • service <service name\> stop/restart/start
  • ssh -i <keyfile\> <IP\> -p <port\>
  • crontab -e
  • nc -z -v {host-name-here} {port-range-here}

Useful files/locations!

  • /etc/aliases
  • /etc/default/portsentry
  • /etc/fail2ban/jail.local
  • /etc/hosts.deny
  • /etc/network/interfaces.d/
  • /var/mail/

Useful links!

About

A 42-school project. Involves the use of basic sysadmin/network tools and the creation of my first web server.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages