Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/falcosecurity/kilt
Kilt is a project that defines how to inject foreign apps into containers
https://github.com/falcosecurity/kilt
falco kilt
Last synced: about 1 month ago
JSON representation
Kilt is a project that defines how to inject foreign apps into containers
- Host: GitHub
- URL: https://github.com/falcosecurity/kilt
- Owner: falcosecurity
- License: apache-2.0
- Archived: true
- Created: 2020-10-09T13:15:38.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-12-15T09:01:51.000Z (about 1 year ago)
- Last Synced: 2024-08-21T02:56:42.082Z (5 months ago)
- Topics: falco, kilt
- Language: Go
- Homepage:
- Size: 186 KB
- Stars: 12
- Watchers: 7
- Forks: 8
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-hacking-lists - falcosecurity/kilt - Kilt is a project that defines how to inject foreign apps into containers (Go)
README
# Kilt
[![Falco Ecosystem Repository](https://github.com/falcosecurity/evolution/blob/main/repos/badges/falco-ecosystem-blue.svg)](https://github.com/falcosecurity/evolution/blob/main/REPOSITORIES.md#ecosystem-scope) [![Deprecated](https://img.shields.io/badge/status-deprecated-inactive?style=for-the-badge)](https://github.com/falcosecurity/evolution/blob/main/REPOSITORIES.md#deprecated)Kilt is a definition on how to include additional software inside containers. It was created to run falco in userspace
along other software. It leverages different runtimes to perform modifications to the container## Definition file
The kilt definition file contains instructions on how to change a container to run additional software alongside the
original entry point/command. [HOCON](https://github.com/lightbend/config/blob/master/HOCON.md) was chosen as the
configuration format.There are 2 phases of patching that the definition file covers, build time and run time. Build time is when container
is not running yet. Run time is well, you get it.### Variables
* **original.*** - contains information about the original container. See runtime specific documentation for details.
* **original.entry_point** `str`
* **original.command** `str`
* **build.entry_point** `List[str]` - new entry point
* **build.command** `List[str]` - new command
* **build.environment_variables** `Dict[str,str]` - will merge environment variables
* **build.mount** - add a filesystem inside the target container. Implementation depends on runtime.
* **build.mount.name** `str` - Mount name
* **build.mount.image** `str` - the image that contains the volume of the mount
* **build.mount.volumes** `List(str)` - List of paths to be mounted on the target image
* **build.mount.entry_point** `List(str)` - The entry point of the image (needed for patching runtimes)
* **runtime.upload** `List(Dict(str,str))` - add binaries to the running image
* **runtime.upload[].as** `str` - target path
* **runtime.upload[].uid** `int` - the user id that will own the file (default: 0)
* **runtime.upload[].gid** `int` - the group id that will own the file (default: 0)
* **runtime.upload[].permissions** `int` - permissions for the file (default: 0755)
* **runtime.exec** `List(Dict)` - list of executables to run
* **runtime.exec[].run** `List(str)` - executable to run
### Example
```
build {
# concatenated arrays
entry_point: ["/falco/bin/launcher", "/falco/bin/pdig"] ${?original.entry_point} ${?original.command} ["--"]
command: ["/falco/usr/bin/falco", "-u", "-c", "/falco/falco.yaml", "--alternate-lua-dir", "/falco/share/lua"]
environment_variables: {
"__CW_LOG_GROUP": "FalcoAlerts"
}
mount: [
{
name: "FalcoDistribution"
image: "admiral0/falco:latest"
volumes: ["/falco"]
entry_point: ["/falco/waitforever"]
}
]
}
```