Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/federicoceratto/nim-seccomp
Seccomp (libseccomp2) adapter for the Nim language
https://github.com/federicoceratto/nim-seccomp
nim nim-lang seccomp security
Last synced: 8 days ago
JSON representation
Seccomp (libseccomp2) adapter for the Nim language
- Host: GitHub
- URL: https://github.com/federicoceratto/nim-seccomp
- Owner: FedericoCeratto
- License: lgpl-2.1
- Created: 2016-07-24T12:43:08.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2021-07-31T16:58:18.000Z (over 3 years ago)
- Last Synced: 2024-12-20T13:27:22.039Z (16 days ago)
- Topics: nim, nim-lang, seccomp, security
- Language: Nim
- Size: 49.8 KB
- Stars: 12
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.adoc
- License: LICENSE
Awesome Lists containing this project
README
## nim-seccomp
Nim adapter for the https://en.wikipedia.org/wiki/Seccomp[Seccomp sandbox] facility
image:https://img.shields.io/badge/status-beta-orange.svg[badge]
image:https://img.shields.io/github/tag/FedericoCeratto/nim-seccomp.svg[tags]
image:https://img.shields.io/badge/License-LGPL%20v3-blue.svg[License]### Features
* Provides a high-level adaptor in seccomp.nim
* Low-level wrapper in seccomp_lowlevel.nim
* Tested on Linux
* Basic tests### Installation
[source,bash]
----
sudo apt-get install libseccomp2
nimble install seccomp
----### Usage
Refer to the generated documentation for the
link:https://federicoceratto.github.io/nim-seccomp/docs/0.1.0/seccomp.html[seccomp]
and
link:https://federicoceratto.github.io/nim-seccomp/docs/0.1.0/seccomp_lowlevel.html[seccomp_lowlevel]
modules[source,nim]
----
import seccompsetSeccomp("write exit_group")
echo """Seccomp is now enabled. Future attempts to change the Seccomp configuration
or to call forbidden system calls will cause the process to be terminated"""# e.g. createDir("/tmp/foo")
----or:
[source,nim]
----
import seccomplet ctx = seccomp_ctx()
ctx.add_rule(Allow, "write")
ctx.add_rule(Allow, "exit_group")
ctx.load()----
https://github.com/FedericoCeratto/nim-seccomp/blob/master/tests/trigger_seccomp.nim[tests/trigger_seccomp.nim] contains running examples of syscalls that will be blocked
### Contributing
Testing and PRs are welcome.
Running tests:
[source,bash]
----
nimble test
nimble test_trigger_seccomp
----