# incubator-teaclave **Repository Path**: ABCDRD/incubator-teaclave ## Basic Information - **Project Name**: incubator-teaclave - **Description**: No description available - **Primary Language**: Unknown - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2021-09-26 - **Last Updated**: 2022-06-14 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # Teaclave: A Universal Secure Computing Platform [![License](https://img.shields.io/badge/license-Apache-green.svg)](LICENSE) [![Release](https://img.shields.io/github/v/tag/apache/incubator-teaclave?label=release&sort=semver)](https://github.com/apache/incubator-teaclave/releases) [![Coverage Status](https://coveralls.io/repos/github/apache/incubator-teaclave/badge.svg?branch=master)](https://coveralls.io/github/apache/incubator-teaclave?branch=master) [![Homepage](https://img.shields.io/badge/site-homepage-blue)](https://teaclave.apache.org/) Apache Teaclave (incubating) is an open source ***universal secure computing*** platform, making computation on privacy-sensitive data safe and simple. ## Highlights - **Secure and Attestable**: Teaclave adopts multiple security technologies to enable secure computing, in particular, Teaclave uses Intel SGX to serve the most security-sensitive tasks with *hardware-based isolation*, *memory encryption* and *attestation*. Also, Teaclave is written in Rust to prevent *memory-safety* issues. - **Function-as-a-Service**: Teaclave is provided as a *function-as-a-service platform*. With many built-in functions, it supports tasks like machine learning, private set intersection, crypto computation, etc. In addition, developers can also deploy and execute Python scripts in Teaclave. More importantly, unlike traditional FaaS, Teaclave supports both general secure computing tasks and *flexible single- and multi-party secure computation*. - **Ease of Use**: Teaclave builds its components in containers, therefore, it supports deployment both locally and within cloud infrastructures. Teaclave also provides convenient endpoint APIs, client SDKs and command line tools. - **Flexible**: Components in Teaclave are designed in modular, and features like remote attestation can be easily embedded in other projects. In addition, Teaclave SGX SDK and Teaclave TrustZone SDK can also be used separately to write TEE apps for other purposes. ## Getting Started ### Try Teaclave - [My First Function](docs/my-first-function.md) - [Write Functions in Python](docs/functions-in-python.md) - [How to Add Built-in Functions](docs/builtin-functions.md) - [Deploying Teaclave on Azure Confidential Computing VM](docs/azure-confidential-computing.md) - [Executing WebAssembly in Teaclave](docs/executing-wasm.md) - [Inference Task with TVM in Teaclave](docs/inference-with-tvm.md) ### Design - [Threat Model](docs/threat-model.md) - [Mutual Attestation: Why and How](docs/mutual-attestation.md) - [Access Control](docs/access-control.md) - [Build System](docs/build-system.md) - [Teaclave Service Internals](docs/service-internals.md) - [Adding Executors](docs/adding-executors.md) - [Papers, Talks, and Related Articles](docs/papers-talks.md) ### Contribute to Teaclave - [Release Guide](docs/release-guide.md) - [Rust Development Guideline](docs/rust-guideline.md) - [Development Tips](docs/development-tips.md) ### Codebase - [Attestation](attestation) - [Binder](binder) - [Built-in Functions](function) - [Client SDK](sdk) - [Command Line Tool](cli) - [Common Libraries](common) - [Configurations in Teaclave](config) - [Crypto Primitives](crypto) - [Data Center Attestation Service](dcap) - [Dockerfile and Compose File](docker) - [Examples](examples) - [Executor Runtime](runtime) - [File Agent](file_agent) - [Function Executors](executor) - [Keys and Certificates](keys) - [RPC](rpc) - [Teaclave Services](services) - [Teaclave Worker](worker) - [Test Harness and Test Cases](tests) - [Third-Party Dependency Vendoring](third_party) - [Tool](tool) - [Types](types) ### API References - [Teaclave SGX SDK](https://teaclave.apache.org/api-docs/sgx-sdk/) - [Teaclave Client SDK (Python)](https://teaclave.apache.org/api-docs/client-sdk-python/) - [Teaclave Client SDK (Rust)](https://teaclave.apache.org/api-docs/client-sdk-rust/) - [Crates in Teaclave (Enclave)](https://teaclave.apache.org/api-docs/crates-enclave/) - [Crates in Teaclave (App)](https://teaclave.apache.org/api-docs/crates-app/) ## Teaclave Projects This is the main repository for the Teaclave FaaS platform. There are several sub-projects under Teaclave: - [Teaclave SGX SDK](https://github.com/apache/incubator-teaclave-sgx-sdk) - [Teaclave TrustZone SDK](https://github.com/apache/incubator-teaclave-trustzone-sdk) ## Contributing Teaclave is open source in [The Apache Way](https://www.apache.org/theapacheway/), we aim to create a project that is maintained and owned by the community. All kinds of contributions are welcome. Read this [document](CONTRIBUTING.md) to learn more about how to contribute. Thanks to our [contributors](https://teaclave.apache.org/contributors/). ## Community - Join us on our [mailing list](https://lists.apache.org/list.html?dev@teaclave.apache.org). - Follow us at [@ApacheTeaclave](https://twitter.com/ApacheTeaclave). - See [more](https://teaclave.apache.org/community/).