To compile DNS-collector, we assume you have a working Go setup.
First, make sure your golang version is 1.21 or higher
How to userguides:
Building from source
- The very fast way, go to the top of the project and run go command
go run .- Uses the
MakeFile(prefered way)
makeExecute the binary
make run- From the
DockerFile
Install linter
sudo apt install build-essential
go install github.com/golangci/golangci-lint/v2/cmd/golangci-lint@latestExecute linter before to commit
make lintExecute testunits before to commit
sudo make testsExecute a test for one specific testcase in a package
go test -timeout 10s -cover -v ./workers -run Test_SyslogRunRun bench
cd dnsutils/
go test -run=^$ -bench=.Update package dependencies
make depAdd Configuration dnsutils/config.go and config.yml
type ConfigTransformers struct {
MyTransform struct {
Enable bool `yaml:"enable"`
}
}func (c *ConfigTransformers) SetDefault() {
c.MyTransform.Enable = false
}Create the following file transformers/mytransform.go and transformers/mytransform_test.go
type MyTransform struct {
GenericTransformer
}
func MyTransform(config *pkgconfig.ConfigTransformers, logger *logger.Logger, name string, instance int, nextWorkers []chan dnsutils.DNSMessage) *MyTransform {
t := &MyTransform{GenericTransformer: NewTransformer(config, logger, "mytransform", name, instance, nextWorkers)}
return t
}Declare the transfomer in the following file tranformers.go
Finally update the docs doc/transformers.md and README.md
- Add Configuration in
pkgconfig/logger.goorpkgconfig/collectors.go
Loggers struct {
MyLogger struct {
Enable bool `yaml:"enable"`
}
}func (c *Config) SetDefault() {
c.Loggers.MyLogger.Enable = false
}- Create the following file
workers/mylogger.goandloggers/mylogger_test.go
package workers
import (
"github.com/dmachard/go-dnscollector/pkgconfig"
"github.com/dmachard/go-dnscollector/pkgutils"
"github.com/dmachard/go-logger"
)
type MyWorker struct {
*GenericWorker
}
func NewMyWorker(config *pkgconfig.Config, console *logger.Logger, name string) *MyWorker {
s := &MyWorker{GenericWorker: NewGenericWorker(config, console, name, "worker", DefaultBufferSize)}
s.ReadConfig()
return s
}
func (w *DevNull) StartCollect() {
w.LogInfo("starting data collection")
defer w.CollectDone()
// goroutine to process transformed dns messages
go w.StartLogging()
// loop to process incoming messages
for {
select {
case <-w.OnStop():
w.StopLogger()
case _, opened := <-w.GetInputChannel():
if !opened {
w.LogInfo("run: input channel closed!")
return
}
}
}
}
func (w *DevNull) StartLogging() {
w.LogInfo("logging has started")
defer w.LoggingDone()
for {
select {
case <-w.OnLoggerStopped():
return
case _, opened := <-w.GetOutputChannel():
if !opened {
w.LogInfo("process: output channel closed!")
return
}
}
}
}- Update the main file
pkglinkerinpipelines.go
if subcfg.Loggers.MyLogger.Enable && IsLoggerRouted(config, output.Name) {
mapLoggers[output.Name] = loggers.NewMyLogger(subcfg, logger, output.Name)
}- Finally update the docs
doc/loggers.mdordoc/collectors.mdandREADME.md