Skip to content

Enclaive Docker Image of Flask running in a Intel SGXv2 enclave

Notifications You must be signed in to change notification settings

enclaive/enclaive-docker-flask-sgx

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

25 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation



Flask-SGX

Flask-SGX: Write Flask applications in the safest Confidential Compute runtime

#intelsgx #confidentialcompute #python #flask #framework
Contribute · Report Bug · Request Feature

TL;DR

git clone -b main git@github.com:enclaive/enclaive-docker-flask-sgx.git
docker compose up -d

Warning: This quick setup is only intended for development environments. You are encouraged to change the insecure default credentials and check out the available configuration options in the build section for a more secure deployment.

What is Flask and SGX?

Flask is a micro web framework written in Python. It is classified as a microframework because it does not require particular tools or libraries. It has no database abstraction layer, form validation, or any other components where pre-existing third-party libraries provide common functions. (w)

Overview of Flask

Intel Security Guard Extension (SGX) delivers advanced hardware and RAM security encryption features, so called enclaves, in order to isolate code and data that are specific to each application. When data and application code run in an enclave additional security, privacy and trust guarantees are given, making the container an ideal choice for (untrusted) cloud environments.

Overview of Intel SGX

Application code executing within an Intel SGX enclave:

  • Remains protected even when the BIOS, VMM, OS, and drivers are compromised, implying that an attacker with full execution control over the platform can be kept at bay
  • Benefits from memory protections that thwart memory bus snooping, memory tampering and “cold boot” attacks on images retained in RAM
  • At no moment in time data, program code and protocol messages are leaked or de-anonymized
  • Reduces the trusted computing base of its parent application to the smallest possible footprint

Why use Flask-SGX (instead of "vanilla" Flask) images?

Following benefits come for free with Flask-SGX :

  • Protect Flask code, files, applications, services, APIs, against intelectual property theft/violation irrespectively where the application runs thanks to full fledge memory container encryption and integrity protection at runtime
  • Shield container application against container escape attacks with hardware-graded security against kernel-space exploits, malicious and accidental privilege insider attacks, UEFI firmware exploits and other "root" attacks using the corruption of the application to infiltrate your network and system
  • Build and deploy Flask applications as usual while inheriting literally for free security and privacy through containerization including
    • strictly better TOMs (technical and organizatorial measures)
    • privacy export regulations compliant deployment anywhere, such as Schrems-II
    • GDPR/CCPA compliant processing ("data in use") of user data (in the cloud) as data is relatively anonymized thanks to the enclave

In addition Flask-SGX:

  • secures data in transit, shielding it from the host system, when acting as a middleware layer between clients and backend components like databases or other services.
  • ensures secure session management by safeguarding the Flask secret key within the secure enclave, enhancing the confidentiality and security of the application.
  • benefits from Flask's modular approach, enabling the ability to run modules within separate enclaves, resulting in isolated and protected execution environments that enhance security.
  • enclaved applications benefit from a small Trusted Computing Base (TCB) due to Flask's lightweight approach. This allows for tailoring the application to its precise requirements, incorporating only the minimal external code necessary.

How to deploy Python-SGX in a zero-trust cloud?

The following cloud infrastractures are SGX-ready out of the box

Confidential compute is a fast growing space. Cloud providers continiously add confidential compute capabilities to their portfolio. Please contact us if the infrastracture provider of your preferred choice is missing.

Getting started

Platform requirements

Check for Intel Security Guard Extension (SGX) presence by running the following

grep sgx /proc/cpuinfo

Alternatively have a thorough look at Intel's processor list. (We remark that macbooks with CPUs transitioned to Intel are unlikely supported. If you find a configuration, please contact us know.)

Note that in addition to SGX the hardware module must support FSGSBASE. FSGSBASE is an architecture extension that allows applications to directly write to the FS and GS segment registers. This allows fast switching to different threads in user applications, as well as providing an additional address register for application use. If your kernel version is 5.9 or higher, then the FSGSBASE feature is already supported and you can skip this step.

There are several options to proceed

  • If: No SGX-ready hardware
    Azure Confidential Compute cloud offers VMs with SGX support. Prices are fair and have been recently reduced to support the developer community. First-time users get $200 USD free credit. Other cloud provider like OVH or Alibaba cloud have similar offerings.

  • Elif: Virtualization
    Ubuntu 21.04 (Kernel 5.11) provides the driver off-the-shelf. Read the release. Go to download page.

  • Elif: Kernel 5.9 or higher
    Install the DCAP drivers from the Intel SGX repo

    sudo apt update
    sudo apt -y install dkms
    wget https://download.01.org/intel-sgx/sgx-linux/2.13.3/linux/distro/ubuntu20.04-server/sgx_linux_x64_driver_1.41.bin -O sgx_linux_x64_driver.bin
    chmod +x sgx_linux_x64_driver.bin
    sudo ./sgx_linux_x64_driver.bin
    
    sudo apt -y install clang-10 libssl-dev gdb libsgx-enclave-common libsgx-quote-ex libprotobuf17 libsgx-dcap-ql libsgx-dcap-ql-dev az-dcap-client open-enclave
  • Else: Kernel older than version 5.9
    Upgrade to Kernel 5.11 or higher. Follow the instructions here.

Software requirements

Install the docker engine

 sudo apt-get update
 sudo apt-get install docker-ce docker-ce-cli containerd.io
 sudo usermod -aG docker $USER    # manage docker as non-root user (obsolete as of docker 19.3) 

Use docker run hello-world to check if you can run docker (without sudo).

Build the image

The following commands let you build and run the sgx enclaved flask application

git clone -b main git@github.com:enclaive/enclaive-docker-flask-sgx.git
docker compose up -d --build

Modify the image

The /app/-folder acts as the root for your flask application. Additional files and modules should be placed here. Build your code structure inside the /app/-folder as usual. A file named app.py or wsgi.py needs to be present and will be automatically recognised by the flask run command.

Currently the flask app port 5000 is not exposed outside the container. Ports can be mapped through docker-compose.yml (docu)

Debuggin the image

Changing the entry point in Dockerfile to /bin/bash allows us to manually start the flask app from within the container with gramine-sgx flask. This way we got access to the log and are able to observe errors occurring from inside the container.

The SGX container is configured to log warnings and errors to flask-gramine-sgx.log. This is a great resource for debugging. Expanding the Flask application might lead to a wider range of files that need to be trusted/allowed.

Setting the manifests filecheck policy to: sgx.file_check_policy = "allow_all_but_log" for debugging purpose will log required files to the above stated file.

Encryption keys are currently provided through the manifests entry fs.insecure__keys.<key_name>. This is insecure and should not be used in production.

Run the image

Run docker-compose up -d to start the enclaved flask application.

Contributing

Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated. If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement".

  1. Fork the Project
  2. Create your Feature Branch (git checkout -b feature/AmazingFeature)
  3. Commit your Changes (git commit -m 'Add some AmazingFeature')
  4. Push to the Branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

Support

Don't forget to give the project a star! Spread the word on social media! Thanks again!

License

Distributed under the Apache 2.0 License. See LICENSE for further information.

Contact

enclaive.io - @enclaive_io - contact@enclaive.io - https://enclaive.io

Acknowledgments

This project greatly celebrates all contributions from the gramine team.

About

Enclaive Docker Image of Flask running in a Intel SGXv2 enclave

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published