aboutsummaryrefslogtreecommitdiff
path: root/vendor/github.com/dnstap/golang-dnstap/TextOutput.go
diff options
context:
space:
mode:
authorGravatar varyoo <varyoo@users.noreply.github.com> 2017-07-24 23:12:50 +0200
committerGravatar Miek Gieben <miek@miek.nl> 2017-07-24 14:12:50 -0700
commit1b7492be6e07f4b8306c0b4a56d79f37485ae61c (patch)
tree02510da5a7cf228821373a8090bac29055764aba /vendor/github.com/dnstap/golang-dnstap/TextOutput.go
parentf33b02689c564c1de8774f7f99d2400231a76069 (diff)
downloadcoredns-1b7492be6e07f4b8306c0b4a56d79f37485ae61c.tar.gz
coredns-1b7492be6e07f4b8306c0b4a56d79f37485ae61c.tar.zst
coredns-1b7492be6e07f4b8306c0b4a56d79f37485ae61c.zip
WIP: middleware/dnstap (#711)
middleware/dnstap add
Diffstat (limited to 'vendor/github.com/dnstap/golang-dnstap/TextOutput.go')
-rw-r--r--vendor/github.com/dnstap/golang-dnstap/TextOutput.go86
1 files changed, 86 insertions, 0 deletions
diff --git a/vendor/github.com/dnstap/golang-dnstap/TextOutput.go b/vendor/github.com/dnstap/golang-dnstap/TextOutput.go
new file mode 100644
index 000000000..5fa2c00e0
--- /dev/null
+++ b/vendor/github.com/dnstap/golang-dnstap/TextOutput.go
@@ -0,0 +1,86 @@
+/*
+ * Copyright (c) 2014 by Farsight Security, Inc.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package dnstap
+
+import (
+ "bufio"
+ "io"
+ "log"
+ "os"
+
+ "github.com/golang/protobuf/proto"
+)
+
+type TextFormatFunc func(*Dnstap) ([]byte, bool)
+
+type TextOutput struct {
+ format TextFormatFunc
+ outputChannel chan []byte
+ wait chan bool
+ writer *bufio.Writer
+}
+
+func NewTextOutput(writer io.Writer, format TextFormatFunc) (o *TextOutput) {
+ o = new(TextOutput)
+ o.format = format
+ o.outputChannel = make(chan []byte, outputChannelSize)
+ o.writer = bufio.NewWriter(writer)
+ o.wait = make(chan bool)
+ return
+}
+
+func NewTextOutputFromFilename(fname string, format TextFormatFunc) (o *TextOutput, err error) {
+ if fname == "" || fname == "-" {
+ return NewTextOutput(os.Stdout, format), nil
+ }
+ writer, err := os.Create(fname)
+ if err != nil {
+ return
+ }
+ return NewTextOutput(writer, format), nil
+}
+
+func (o *TextOutput) GetOutputChannel() chan []byte {
+ return o.outputChannel
+}
+
+func (o *TextOutput) RunOutputLoop() {
+ dt := &Dnstap{}
+ for frame := range o.outputChannel {
+ if err := proto.Unmarshal(frame, dt); err != nil {
+ log.Fatalf("dnstap.TextOutput: proto.Unmarshal() failed: %s\n", err)
+ break
+ }
+ buf, ok := o.format(dt)
+ if !ok {
+ log.Fatalf("dnstap.TextOutput: text format function failed\n")
+ break
+ }
+ if _, err := o.writer.Write(buf); err != nil {
+ log.Fatalf("dnstap.TextOutput: write failed: %s\n", err)
+ break
+ }
+ o.writer.Flush()
+ }
+ close(o.wait)
+}
+
+func (o *TextOutput) Close() {
+ close(o.outputChannel)
+ <-o.wait
+ o.writer.Flush()
+}