Skip to content

ClamAV virus scanner with REST api docker image

Notifications You must be signed in to change notification settings

o20ne/clamav-rest

 
 

Repository files navigation

This is two in one docker image so it runs open source virus scanner ClamAV (https://www.clamav.net/), automatic virus definition updates as background process and REST api interface to interact with ClamAV process.

Usage:

Run clamav-rest docker image:

docker run -p 9000:9000 -v ./scan-target:/scan-target --rm -it clamav-go-rest

Test that service detects common test virus signature:

$ curl -i -F "file=@eicar.com.txt" http://localhost:9000/scan
HTTP/1.1 100 Continue

HTTP/1.1 406 Not Acceptable
Content-Type: application/json; charset=utf-8
Date: Mon, 28 Aug 2017 20:22:34 GMT
Content-Length: 56

{ Status: "FOUND", Description: "Eicar-Test-Signature" }

Test that service returns 200 for clean file:

$ curl -i -F "file=@clamrest.go" http://localhost:9000/scan

HTTP/1.1 100 Continue

HTTP/1.1 200 OK
Content-Type: application/json; charset=utf-8
Date: Mon, 28 Aug 2017 20:23:16 GMT
Content-Length: 33

{ Status: "OK", Description: "" }

Test that service returns results for scan target directory:

$ curl -i http://localhost:9000/scanPath?path=/scan-target

Status codes:

  • 200 - clean file = no KNOWN infections
  • 406 - INFECTED
  • 400 - ClamAV returned general error for file
  • 412 - unable to parse file
  • 501 - unknown request

Developing:

Build golang (linux) binary and docker image:

# env GOOS=linux GOARCH=amd64 go build
docker build . -t clamav-go-rest
docker run -p 9000:9000 --rm -it clamav-go-rest

About

ClamAV virus scanner with REST api docker image

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 45.1%
  • Dockerfile 36.9%
  • Python 7.4%
  • Shell 6.5%
  • Gherkin 4.1%