/dprfs

Ransomware-proof filesystem

Primary LanguageCGNU General Public License v3.0GPL-3.0

dprfs

Data-poisoning resistant filesystem

Ransomware as a problem would be solved with a filesystem that refuses to allow anything to be overwritten or deleted, even as it appears to behave normally. DPRFS is that filesystem.

To see it in action:
DPRFS vs Ransomware: https://www.youtube.com/watch?v=VsBAKeOQh78

DPRFS vs mass deletes by a rogue user: https://www.youtube.com/watch?v=BeTdFSlHMJY

The whitepaper can be read here.

This project is written in C. This is the main file.

This 2015 project of mine developed from seeing too many ransomware infections in the few years leading up to it. The essential observation is to store files as a linked list, with changes resulting in a new link at the end of the given list. That change might be the addition of a "deleted" flag, for instance. When accessed by the user, however, they can only see the end of each list - and so the file system appears to be otherwise normal.

Behind the scenes, the file "1453.docx", which has been edited three times. DPRFS means the ordinary user only 'sees' :latest.

$ tree
.
└── 1453.docx
    ├── AA00000-20171025203713257670
    │   ├── 1453.docx
    │   ├── :Fmetadata -> :Fmetadata-20171025203759769758
    │   ├── :Fmetadata-20171025203713257670
    │   └── :Fmetadata-20171025203759769758
    ├── AA00001-20171025203759799927
    │   ├── 1453.docx
    │   ├── :Fmetadata -> :Fmetadata-20171025203802916088
    │   ├── :Fmetadata-20171025203759799927
    │   └── :Fmetadata-20171025203802916088
    ├── AA00002-20171025203802949050
    │   ├── 1453.docx
    │   ├── :Fmetadata -> :Fmetadata-20171025203802949050
    │   └── :Fmetadata-20171025203802949050
    └── :latest -> AA00002-20171025203802949050

The project requires Linux and FUSE - everything else is standard networking. The code remains in live use in a small number of installations.