go-clamav/README.md

123 lines
3.1 KiB
Markdown
Raw Permalink Normal View History

2022-03-23 10:47:29 +00:00
# go-clamav
2022-03-23 13:22:45 +00:00
[![GoDoc](https://pkg.go.dev/badge/github.com/ca110us/go-clamav?status.svg)](https://pkg.go.dev/github.com/ca110us/go-clamav?tab=doc)
2022-03-23 10:47:29 +00:00
go-clamav is go wrapper for [libclamav](https://docs.clamav.net/manual/Development/libclamav.html)
## Environment
### Ubuntu
```bash
apt-get update && apt-get install -y \
`# install tools` \
gcc make pkg-config python3 python3-pip python3-pytest valgrind \
`# install clamav dependencies` \
check libbz2-dev libcurl4-openssl-dev libjson-c-dev libmilter-dev \
libncurses5-dev libpcre2-dev libssl-dev libxml2-dev zlib1g-dev
python3 -m pip install --user cmake / apt-get install cmake
```
Download the source from the clamav [downloads page](https://www.clamav.net/downloads)
```bash
tar xzf clamav-[ver].tar.gz
cd clamav-[ver]
mkdir build && cd build
cmake ..
cmake --build .
ctest
sudo cmake --build . --target install
```
For other Linux distributions, see [clamav documentation](https://docs.clamav.net/manual/Installing/Installing-from-source-Unix.html)
## Quick Start
2022-03-30 06:12:40 +00:00
### Dynamic linking
2022-03-23 13:22:45 +00:00
```bash
$ cd example && cat main.go
```
```go
package main
import (
"fmt"
2023-04-06 07:41:08 +00:00
clamav "git.cyber.gent/friedkiwi/go-clamav"
2022-03-23 13:22:45 +00:00
)
func main() {
// new clamav instance
c := new(clamav.Clamav)
err := c.Init(clamav.SCAN_OPTIONS{
General: 0,
Parse: clamav.CL_SCAN_PARSE_ARCHIVE | clamav.CL_SCAN_PARSE_ELF,
Heuristic: 0,
Mail: 0,
Dev: 0,
})
if err != nil {
panic(err)
}
// free clamav memory
defer c.Free()
// load db
signo, err := c.LoadDB("./db", uint(clamav.CL_DB_DIRECTORY))
if err != nil {
panic(err)
}
fmt.Println("db load succeed:", signo)
// compile engine
err = c.CompileEngine()
if err != nil {
panic(err)
}
c.EngineSetNum(clamav.CL_ENGINE_MAX_SCANSIZE, 1024*1024*40)
c.EngineSetNum(clamav.CL_ENGINE_MAX_SCANTIME, 9000)
2022-03-23 13:30:38 +00:00
// fmt.Println(c.EngineGetNum(clamav.CL_ENGINE_MAX_SCANSIZE))
2022-03-23 13:22:45 +00:00
// scan
2022-03-23 13:30:38 +00:00
scanned, virusName, ret := c.ScanFile("./test_file/nmap")
fmt.Println(scanned, virusName, ret)
2022-03-23 13:22:45 +00:00
}
```
```bash
2022-03-30 06:12:40 +00:00
$ CGO_LDFLAGS="-L/usr/local/lib -lclamav" go run main.go
2022-03-23 13:22:45 +00:00
db load succeed: 9263
209 YARA.Unix_Packer_UpxDetail.UNOFFICIAL Virus(es) detected
```
2022-03-23 10:47:29 +00:00
2022-03-30 06:12:40 +00:00
If the `libclamav.so` file is not found, try it:
```bash
$ LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib CGO_LDFLAGS="-L/usr/local/lib -lclamav" go run main.go
db load succeed: 9263
209 YARA.Unix_Packer_UpxDetail.UNOFFICIAL Virus(es) detected
```
### Static build
```bash
2022-03-30 06:39:03 +00:00
$ sudo bash ./prepare.sh
$ SRCDIR=$(pwd)
$ export CGO_CFLAGS="-g -Wall -I${SRCDIR}/clamav-mussels-cookbook/mussels/install/include"
$ export CGO_LDFLAGS="-L${SRCDIR}/clamav-mussels-cookbook/mussels/install/lib -lclamav_static -lbz2_static -lclammspack_static -lclamunrar_iface_static -lclamunrar_static -lcrypto -ljson-c -lpcre2-8 -lpcre2-posix -lssl -lxml2 -lz -lm -ldl -lstdc++"
$ CGO_ENABLED=1 go build --ldflags '--extldflags "-static -fpic"' main.go
2022-03-30 06:12:40 +00:00
```
2022-03-23 10:47:29 +00:00
## Reference
[mirtchovski/clamav](https://github.com/mirtchovski/clamav)
2023-04-06 07:41:08 +00:00
[ca110us/go-clamav](https://github.com/ca110us/go-clamav)
2022-03-23 10:47:29 +00:00
2023-04-06 07:41:08 +00:00
This is an adaptation of `mirtchovski/clamav` because it fails to compile on newer versions of go on macOS.