Skip to content

Commit

Permalink
implement stream reading
Browse files Browse the repository at this point in the history
  • Loading branch information
solnicki committed Nov 19, 2024
1 parent 487c905 commit efbe87d
Show file tree
Hide file tree
Showing 35 changed files with 684 additions and 1,007 deletions.
62 changes: 62 additions & 0 deletions cmd/logveil/logveil.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
package logveil

import (
"bufio"
"errors"
"fmt"
"io"
"log/slog"

"github.com/logmanager-oss/logveil/internal/anonymizer"
"github.com/logmanager-oss/logveil/internal/config"
"github.com/logmanager-oss/logveil/internal/files"
"github.com/logmanager-oss/logveil/internal/reader"
"github.com/logmanager-oss/logveil/internal/writer"
)

func Start() {
slog.Info("Anonymization process started...")

config := &config.Config{}
config.LoadAndValidate()

if *config.IsVerbose {
slog.SetLogLoggerLevel(slog.LevelDebug)
}

filesHandler := &files.FilesHandler{}
defer filesHandler.Close()

inputReader := reader.CreateInputReader(config, filesHandler)
outputWriter := writer.CreateOutputWriter(config, filesHandler)
anonymizerDoer := anonymizer.CreateAnonymizer(config)

err := RunAnonymizationLoop(inputReader, outputWriter, anonymizerDoer)
if err != nil {
slog.Error("running anonymisation loop", "error", err)
return
}

slog.Info("All done. Exiting...")
}

func RunAnonymizationLoop(inputReader reader.InputReader, outputWriter *bufio.Writer, anonymizer *anonymizer.Anonymizer) error {
defer outputWriter.Flush()

for {
logLine, err := inputReader.ReadLine()
if err != nil {
if errors.Is(err, io.EOF) {
return nil
}
return fmt.Errorf("reading line: %v", err)
}

anonymizedLogLine := anonymizer.Anonymize(logLine)

_, err = fmt.Fprintln(outputWriter, anonymizedLogLine)
if err != nil {
return fmt.Errorf("writing log line to buffer: %v", err)
}
}
}
4 changes: 2 additions & 2 deletions cmd/main.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
package main

import "github.com/logmanager-oss/logveil/internal/anonymizer"
import "github.com/logmanager-oss/logveil/cmd/logveil"

func main() {
anonymizer.Run()
logveil.Start()
}
Loading

0 comments on commit efbe87d

Please sign in to comment.