Skip to content

Latest commit

 

History

History
96 lines (72 loc) · 4.82 KB

README.md

File metadata and controls

96 lines (72 loc) · 4.82 KB

fscrub

Go Report Card License: GPL v3 Build Status Docker Repository on Quay Join Discord at https://discord.gg/dWZkR6R

Tool watching and crawling the file-system for files containing sensitive information to clean them.

Description

The whole idea for fscrub arose on a public forum where some people posted log files from their apache or game servers to get help from the community. Those log files contained not only ip addresses of the clients but also other sensitive information.

To prevent this from happening we had the idea to provide the board with a tool to monitor the servers attachments directory and acting on relevant files. This project is WIP and only a small side project. Aside from that, any community project is free to use it so their users and their user's clients stay safe.

fscrub has several modus operandi:

  • watching a provided folder for file-system changes and acting on creation/change of files
  • crawling a provided folder for files of interest and acting on find
  • [TODO] watching a provided folder for new changes while also crawling to ensure past changes are covered
  • [TODO] crawling a folder every x minutes (using internal cron)

Status

For a detailed status and todo's please check our project board or the issues.

The actions fscrub is currently capable of are:

  • crawling multiple directories for files
  • watching multiple directories for file change and creation events
  • checking found files for patterns and replacing those findings
  • ignoring files with a certain header
  • adding an information header to modified files

Further actions fscrub is planed to take are:

  • finding personal or security relevant data based on provided patterns and replacing them (ip's, passwords, hostnames, etc.)
  • checking files against virus check api's or antivir tools
  • moving found files to a safe backup location
  • notifying a pool of users on certain events

Dependencies

This project has a pretty complex Makefile and therefore requires make.

Go Version: 1.8

Install all further requirements by running make deps

Usage

NOTE: At the moment, it is not possible to crawl and watch directories simultaneously. This is WIP.

Crawl a directory for defined patterns

fscrub -crawl -dir=./testdata/data -patterns=./testdata/config/patterns.json

Watch a directory for defined patterns

fscrub -watch -dir=./testdata/data -patterns=./testdata/config/patterns.json

It is possible to provide multiple dirs to handle. To do so, simply use the -dir parameter multiple times:

fscrub -dir=./pkg -dir=./cmd

Patterns

Fscrub is planed to have several built-in patterns (like the intelligent IP scrubber), but it is still possible to inject additional patterns via a json config. Those patterns then get used just as the default ones.

An example of such config can be found here.

Development

This project is using a basic template for developing PlayNet command-line tools. Refer to this template for further information and usage docs. The Makefile is configurable to some extent by providing variables at the top. Any further changes should be thought of carefully as they might brake CI/CD compatibility.

One project might contain multiple tools whose main packages reside under cmd. Other packages like libraries go into the pkg directory. Single projects can be handled by calling make toolname maketarget like for example:

make template dev

All tools at once can be handled by calling make full maketarget like for example:

make full build

Build output is being sent to ./build/.

If you only package one tool this might seam slightly redundant but this is meant to provide consistence over all projects. To simplify this, you can simply call make maketarget when only one tool is located beneath cmd. If there are more than one, this won't do anything (including not return 1) so be careful.

Contributions

Pull Requests and Issue Reports are welcome. If you are interested in contributing, feel free to get in touch