-
Notifications
You must be signed in to change notification settings - Fork 20
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Finally, we are getting rid of C and libbpf here. This PR replaces all the eBPF programs with Rust programs written in Aya. The part of this PR is also: * fetching recent, relevant changes in aya-template * using LpmTrie maps for mount policies (TODO) * detecting new processes only with tracepoints, the task LSM program was removed Fixes: #49 Fixes: #134 Fixes: #137 Fixes: #138 Signed-off-by: Michal Rostecki <[email protected]>
- Loading branch information
1 parent
abd4967
commit 50e07a9
Showing
41 changed files
with
41,873 additions
and
2,299 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,2 @@ | ||
[alias] | ||
xtask = "run --package xtask --" | ||
|
||
[target.x86_64-unknown-linux-gnu] | ||
runner = "sudo -E" | ||
xtask = "run --package xtask --" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,29 +1,13 @@ | ||
### https://raw.github.com/github/gitignore/master/Rust.gitignore | ||
|
||
# Generated by Cargo | ||
# will have compiled files and executables | ||
**/debug/ | ||
**/target/ | ||
debug/ | ||
target/ | ||
|
||
# Remove Cargo.lock from gitignore if creating an executable, leave it for libraries | ||
# More information here https://doc.rust-lang.org/cargo/guide/cargo-toml-vs-cargo-lock.html | ||
Cargo.lock | ||
|
||
# These are backup files generated by rustfmt | ||
**/*.rs.bk | ||
|
||
# BTF headers | ||
**/vmlinux.h | ||
|
||
# Output (BPF) | ||
**/.output/ | ||
|
||
# Misc | ||
**/*~ | ||
|
||
# mdBook output | ||
**/docs/book/ | ||
|
||
# IDE | ||
.idea | ||
|
||
# Dapper | ||
Dockerfile.dapper* |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
{ | ||
"rust-analyzer.linkedProjects": ["Cargo.toml", "lockc-ebpf/Cargo.toml"] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
{ | ||
"rust-analyzer.linkedProjects": ["Cargo.toml", "lockc-ebpf/Cargo.toml"] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,2 @@ | ||
[workspace] | ||
members = [ | ||
"lockc", | ||
"xtask", | ||
] | ||
members = ["lockc", "lockc-common", "xtask"] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,38 +1,28 @@ | ||
![lockc](https://raw.githubusercontent.com/lockc-project/assets/main/logo-horizontal-lockc.png) | ||
# lockc | ||
|
||
[![Crate](https://img.shields.io/crates/v/lockc)](https://crates.io/crates/lockc) | ||
[![Book](https://img.shields.io/website?url=https%3A%2F%2Flockc-project.github.io%2Flockc%2F)](https://lockc-project.github.io/lockc/) | ||
[![Discord](https://img.shields.io/discord/874314181191565453?label=discord&logo=discord)](https://discord.gg/799cmsYB4q) | ||
[![Docs](https://docs.rs/lockc/badge.svg)](https://docs.rs/lockc/) | ||
[![Build Status](https://github.com/lockc-project/lockc/actions/workflows/rust.yml/badge.svg)](https://github.com/lockc-project/lockc/actions/workflows/rust.yml) | ||
## Prerequisites | ||
|
||
**lockc** is open source sofware for providing MAC (Mandatory Access Control) | ||
type of security audit for container workloads. | ||
1. Install a rust stable toolchain: `rustup install stable` | ||
1. Install a rust nightly toolchain: `rustup install nightly` | ||
1. Install bpf-linker: `cargo install bpf-linker` | ||
|
||
The main reason why **lockc** exists is that **containers do not contain**. | ||
Containers are not as secure and isolated as VMs. By default, they expose | ||
a lot of information about host OS and provide ways to "break out" from the | ||
container. **lockc** aims to provide more isolation to containers and make them | ||
more secure. | ||
## Build eBPF | ||
|
||
The [Containers do not contain](https://lockc-project.github.io/book/containers-do-not-contain.html) | ||
documentation section explains what we mean by that phrase and what kind of | ||
behavior we want to restrict with **lockc**. | ||
```bash | ||
cargo xtask build-ebpf | ||
``` | ||
|
||
The main technology behind lockc is [eBPF](https://ebpf.io/) - to be more | ||
precise, its ability to attach to [LSM hooks](https://www.kernel.org/doc/html/latest/bpf/bpf_lsm.html) | ||
To perform a release build you can use the `--release` flag. | ||
You may also change the target architecture with the `--target` flag | ||
|
||
Please note that currently lockc is an experimental project, not meant for | ||
production environment and without any official binaries or packages to use - | ||
currently the only way to use it is building from sources. | ||
## Build Userspace | ||
|
||
See [the full documentation here](https://lockc-project.github.io/book/). | ||
And [the code documentation here](https://docs.rs/lockc/). | ||
```bash | ||
cargo build | ||
``` | ||
|
||
If you need help or want to talk with contributors, plese come chat with us | ||
on `#lockc` channel on the [Rust Cloud Native Discord server](https://discord.gg/799cmsYB4q). | ||
## Run | ||
|
||
**lockc's** userspace part is licensed under [Apache License, version 2.0](https://github.com/lockc-project/lockc/blob/main/LICENSE). | ||
|
||
eBPF programs inside [lockc/src/bpf directory](https://github.com/lockc-project/lockc/tree/main/lockc/src/bpf) | ||
are licensed under [GNU General Public License, version 2](https://github.com/lockc-project/lockc/blob/main/lockc/src/bpf/LICENSE). | ||
```bash | ||
cargo xtask run | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
[package] | ||
name = "lockc-common" | ||
version = "0.1.0" | ||
edition = "2021" | ||
|
||
[features] | ||
default = [] | ||
user = [ "aya", "thiserror" ] | ||
|
||
[dependencies] | ||
aya = { version = "0.10", optional = true } | ||
thiserror = { version = "1.0", optional = true } | ||
|
||
[lib] | ||
path = "src/lib.rs" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,97 @@ | ||
#![cfg_attr(not(feature = "user"), no_std)] | ||
|
||
/// Max configurable PID limit (for x86_64, for the other architectures it's | ||
/// less or equal). | ||
// TODO(vadorovsky): I need to teach aya to be able to resize maps before they | ||
// are loaded into the kernel. So far aya doesn't differentiate between open() | ||
// and load(), it opens the ELF object and loads it immediately in one step. | ||
// I need to change it. | ||
// After that, we will be able to set the limit again up to the upper possible | ||
// limit. And resize according to the max PID limit in sysctl. | ||
// Before it's done - let's stick to the default value to not use too much RAM. | ||
// pub const PID_MAX_LIMIT: u32 = 4194304; | ||
pub const PID_MAX_LIMIT: u32 = 32768; | ||
|
||
pub const MOUNT_TYPE_LEN: usize = 5; | ||
|
||
pub const PATH_LEN: usize = 64; | ||
|
||
const CONTAINER_ID_LEN: usize = 64; | ||
|
||
#[cfg_attr(feature = "user", derive(Debug))] | ||
#[derive(Copy, Clone)] | ||
#[repr(C)] | ||
pub enum ContainerPolicyLevel { | ||
NotFound = -1, | ||
|
||
Lockc, | ||
|
||
// Policy levels. | ||
Restricted, | ||
Baseline, | ||
Privileged, | ||
} | ||
|
||
#[derive(Copy, Clone)] | ||
#[repr(C)] | ||
pub struct ContainerID { | ||
pub id: [u8; CONTAINER_ID_LEN], | ||
} | ||
|
||
#[cfg(feature = "user")] | ||
#[derive(thiserror::Error, Debug)] | ||
pub enum NewContainerIDError { | ||
#[error(transparent)] | ||
NulError(#[from] std::ffi::NulError), | ||
|
||
#[error("could not convert Vec<u8> to CString")] | ||
VecU8CStringConv, | ||
} | ||
|
||
#[cfg(feature = "user")] | ||
impl ContainerID { | ||
/// Creates a new container_id instance and converts the given Rust string | ||
/// into C fixed size char array. | ||
pub fn new(id: &str) -> Result<Self, NewContainerIDError> { | ||
let mut id_b = std::ffi::CString::new(id)?.into_bytes_with_nul(); | ||
id_b.resize(CONTAINER_ID_LEN, 0); | ||
Ok(ContainerID { | ||
id: id_b | ||
.try_into() | ||
.map_err(|_| NewContainerIDError::VecU8CStringConv)?, | ||
}) | ||
} | ||
} | ||
|
||
#[derive(Copy, Clone)] | ||
#[repr(C)] | ||
pub struct Container { | ||
pub policy_level: ContainerPolicyLevel, | ||
} | ||
|
||
#[derive(Copy, Clone)] | ||
#[repr(C)] | ||
pub struct Process { | ||
pub container_id: ContainerID, | ||
} | ||
|
||
#[derive(Copy, Clone)] | ||
#[repr(C)] | ||
pub struct MountType { | ||
pub mount_type: [u8; MOUNT_TYPE_LEN], | ||
} | ||
|
||
#[derive(Copy, Clone)] | ||
#[repr(C)] | ||
pub struct ContainerPath { | ||
pub path: [u8; PATH_LEN], | ||
} | ||
|
||
#[cfg(feature = "user")] | ||
mod user { | ||
use super::*; | ||
|
||
unsafe impl aya::Pod for ContainerID {} | ||
unsafe impl aya::Pod for Container {} | ||
unsafe impl aya::Pod for Process {} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
[build] | ||
target-dir = "../target" | ||
target = "bpfel-unknown-none" | ||
|
||
[unstable] | ||
build-std = ["core"] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
{ | ||
"rust-analyzer.cargo.target": "bpfel-unknown-none", | ||
"rust-analyzer.checkOnSave.allTargets": false | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
{ | ||
"rust-analyzer.cargo.target": "bpfel-unknown-none", | ||
"rust-analyzer.checkOnSave.allTargets": false, | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
[package] | ||
name = "lockc-ebpf" | ||
version = "0.1.0" | ||
edition = "2021" | ||
|
||
[dependencies] | ||
aya-bpf = { git = "https://github.com/aya-rs/aya", branch = "main" } | ||
aya-log-ebpf = { git = "https://github.com/aya-rs/aya-log", branch = "main" } | ||
lockc-common = { path = "../lockc-common" } | ||
|
||
[[bin]] | ||
name = "lockc" | ||
path = "src/main.rs" | ||
|
||
[profile.dev] | ||
opt-level = 3 | ||
debug = false | ||
debug-assertions = false | ||
overflow-checks = false | ||
lto = true | ||
panic = "abort" | ||
incremental = false | ||
codegen-units = 1 | ||
rpath = false | ||
|
||
[profile.release] | ||
lto = true | ||
panic = "abort" | ||
codegen-units = 1 | ||
|
||
[workspace] | ||
members = [] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
[toolchain] | ||
channel="nightly" |
Oops, something went wrong.