Skip to content

A malicious file detection engine written with Python and Yara

License

Notifications You must be signed in to change notification settings

Jeffallan/badfiles

Repository files navigation

badfiles

Release Status CI Status

A malicious file detection engine written with Python and Yara.

Introduction

At some point most applications need to accept files from a third party. Since we do not have absolute control over these files they can present a serious threat vector.

The aim of this project is to provide a flexible and expandable solution to triage these files so they can be handled accordingly.

Features

Currently, this project focuses on detecting the following:

Generally Suspicious Files:

✔️ Mime type confusion.

🔲 Files with a root UID or GID (*NIX only).

🔲 Sticky, setuid, or setgit bit (*NIX only).

CSV Files

✔️ CSV Injection.

🔲 Files with a root UID or GID (*NIX only).

🔲 Sticky, setuid, or setgit bit (*NIX only).

Office Documents

✔️ DDE injection.

✔️ Files with a root UID or GID (*NIX only).

✔️ Sticky, setuid, or setgit bit (*NIX only).

Zip Files

✔️ Symlink attacks.

✔️ Zip slips.

✔️ Nested zip bombs.

✔️ Flat zip bombs.

✔️ Sticky, setuid, or setgit bit (*NIX only).

✔️ Files with a root UID or GID (*NIX only).

Tar Files

✔️ Files with a root UID or GID (*NIX only).

✔️ Sticky, setuid, or setgit bit (*NIX only).

🔲 Files with absolute paths (*Nix only).

Additional Features

Please file an issue or a pull request especially if you have found or created malicious files that bypass these detection mechanisms. Please see the contributing guidelines for more details.

Credits

This package was created with This Cookiecutter template.

This project uses zip-bomb to create the nested and flat zip bombs for unit testing and detection rules.

This project uses a custom Yara rule from Reversing Labs to detect obfuscated CSV injection payloads.

Contributors

About

A malicious file detection engine written with Python and Yara

Resources

License

Stars

Watchers

Forks

Packages

No packages published