/ShuLin

GTK4 based hardening application for Linux with flexibility to cater for organizational security policies.

Primary LanguageRust


ShuLin - Ubuntu Hardening

Problem Statement SIH1446

Title: Developing a GUI based hardening script for Ubuntu operating system with flexibility to cater for organizational security policies.

Description: Hardening of an operating system involves implementation of security measure to make the system compliant with the security policies of the organization. The procedure for hardening should be intuitive to allow ease of use by personnel with minimal IT skills. The goal of this problem statement is to generate a script which is undertakes hardening of Ubuntu OS using an GUI based approach. During the hardening process, the user should have the flexibility to make settings based on the organizations IT security policy provision like blocking ssh, usb, ToR etc. The grading of tool will be based on hardening functions implemented, attention to user experience and flexibility to take user settings. Developer should remember that security is of utmost importance.

Organization: National Technical Research Organization(NTRO)

Organizational needs they might have: Since NTRO is an intelligence agency they will adhere to strict security policies and regulatory compliance, I mean they should! I have listed some of the possible needs.

  • Security Policies and Compliance: They might have predefined security policies and compliance standards to safeguard national security. These encompass data security, access control, and information protection.

  • Customization for Security Policies: Like Venkatesh suggested that in the external hackathon, they will suggest a lot of changes so we should design the architecture keep flexibility in mind to accommodate their(judges or NTRO's) unique security policies and guidelines.

  • Access Control and User Permissions:

  • Audit and Logging: Comprehensive auditing and logging are critical for monitoring and auditing system activities, serving as a history reference for a future intrusion!

  • Integration with Existing Tools:

  • Usability and Training: Proper training and documentation are essential to ensure effective use of the system hardening tools(ShuLin).

Now what is hardening?

Since Linux is not a secure OS we have to increase its security and that is called hardening.

System hardening is the process of securing a computer system by reducing its vulnerabilities and strengthening its defenses against potential threats and attacks. It involves implementing a series of security measures and configurations and reducing the attack surface.

Some of the hardening measures listed by Madaidan

  • Kernel hardening: Strengthening the Linux kernel's security by applying patches, reducing attack surfaces, and configuring security features like SELinux or AppArmor.

  • Mandatory access control: MAC systems give fine-grained control over what programs can access. This means that your browser won't have access to your entire home directory or similar. (SELinux >>> Apparmor).

  • Sandboxing: Isolating applications or processes from the rest of the system to limit potential damage if they are compromised.

  • Hardened memory allocator: Using memory allocation techniques that reduce the risk of memory-related vulnerabilities like buffer overflows.

  • Hardened compilation flags: Compiling software with security-focused compiler flags to reduce vulnerabilities and improve code robustness.

  • Memory-safe languages: Choosing programs written in programming languages like Rust or Ada that inherently provide memory safety, reducing the risk of memory-related vulnerabilities.

  • The root account: Restricting the use of the root (superuser) account to essential tasks to minimize the risk of accidental or malicious system changes.

  • Firewalls: Configuring firewalls to control incoming and outgoing network traffic to protect against unauthorized access and threats. (Fail2safe - Venkatesh's suggestion)

  • Identifiers: Ensuring unique user and group identifiers to control access permissions accurately.

  • File permissions: Setting appropriate permissions on files and directories to restrict access to authorized users and groups.

  • Core dumps: Controlling core dumps to prevent the exposure of sensitive information in the event of program crashes.

  • Swap: Managing swap space securely to avoid exposing sensitive data.

  • PAM (Pluggable Authentication Module): Implementing flexible authentication and password policies.

  • Microcode updates: Keeping CPU microcode updated to address hardware vulnerabilities.

  • IPv6 privacy extensions: Enabling privacy extensions for IPv6 addresses to enhance network security or we can disable IPv6 entirely if the organization needs it.

  • Partitioning and mount options: Properly partitioning and configuring mount options to improve security and isolate data.

  • Entropy:

    • Additional entropy sources: Incorporating additional sources of randomness to improve cryptographic security.
    • RDRAND: Using the RDRAND instruction for hardware-based random number generation.
  • Editing files as root: Exercising caution when editing system configuration files as the root user to avoid unintentional changes.

  • Intrusion detection: (Suricata, Snort) Security systems that monitor network traffic and system behavior in real-time to detect and respond to potential threats and attacks."

  • Distribution-specific hardening: Implementing security measures specific to Ubuntu.

  • Physical security: Protecting physical access to servers and systems to prevent unauthorized tampering.

  • Best practices: Adhering to established security best practices, including regular updates, strong password policies, and security awareness training. (Documentation and well-structured guidelines)

  • Firewall(Fail2ban)

  • Identifiers(User access management)

    • We can limit the access of users
    • We can check their passwords and if it is weak then ban them and notify them to change their password.
    • Create a stringent guideline for passwords.
  • Intrusion detection(Suricata, Snort)

  • System update and patching from GUI itself

  • Disable booting from external devices

we have to figure out how can we implement this, whether using BIOS or from the backend itself. If it requires tinkering with BIOS then we can flash a toast suggesting the user to change the setting.

  • Closing hidden ports.

Tech stack

Architecture

architecture architecture

Frontend

  • We will be using GTK4 + Libadwaita with python bindings as everyone is familiar with python and since we are not using tauri so our other option will be to build it in Nextron(Next + Electron) which is just bloat and immature!
  • I've explored(I == @Shivam) gtk4 in python and it's feasible but the documentation sucks!
  • We will develop it after the architecture of backend is ready and the UI mockup is finished.

Some references for gtk4 + python

References

Curated

Dump