2019-01-08 00:37:16 +00:00
|
|
|
package influxdb_test
|
2018-10-30 18:18:54 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"time"
|
|
|
|
|
2019-01-08 00:37:16 +00:00
|
|
|
platform "github.com/influxdata/influxdb"
|
|
|
|
"github.com/influxdata/influxdb/bolt"
|
2018-10-30 18:18:54 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func ExampleKeyValueLog() {
|
|
|
|
c := bolt.NewClient()
|
|
|
|
c.Path = "example.bolt"
|
|
|
|
ctx := context.Background()
|
|
|
|
if err := c.Open(ctx); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
for i := 0; i < 10; i++ {
|
|
|
|
if err := c.AddLogEntry(ctx, []byte("bucket_0_auditlog"), []byte(fmt.Sprintf("abc-%v", i)), time.Now()); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
opts := platform.FindOptions{Limit: 2, Offset: 1, Descending: false}
|
|
|
|
if err := c.ForEachLogEntry(ctx, []byte("bucket_0_auditlog"), opts, func(v []byte, t time.Time) error {
|
|
|
|
fmt.Println(t.UTC())
|
|
|
|
fmt.Println(string(v))
|
|
|
|
fmt.Println()
|
|
|
|
return nil
|
|
|
|
}); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
v, t, err := c.LastLogEntry(ctx, []byte("bucket_0_auditlog"))
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
fmt.Println(t.UTC())
|
|
|
|
fmt.Println(string(v))
|
|
|
|
fmt.Println()
|
|
|
|
|
|
|
|
v, t, err = c.FirstLogEntry(ctx, []byte("bucket_0_auditlog"))
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
fmt.Println(t.UTC())
|
|
|
|
fmt.Println(string(v))
|
|
|
|
fmt.Println()
|
|
|
|
}
|