package main import ( "context" "flag" "fmt" "os" "time" "github.com/localhots/bocadillo/reader" "github.com/localhots/gobelt/log" ) func main() { dsn := flag.String("dsn", "", "Database source name") id := flag.Uint("id", 1000, "Server ID (arbitrary, unique)") file := flag.String("file", "", "Binary log file name") offset := flag.Uint("offset", 0, "Log offset in bytes") flag.Parse() ctx := context.Background() validate((*dsn != ""), "Database source name is not set") validate((*id != 0), "Server ID is not set") validate((*file != ""), "Binary log file is not set") conf := reader.Config{ ServerID: uint32(*id), File: *file, Offset: uint32(*offset), } conn, err := reader.Connect(*dsn, conf) if err != nil { log.Fatalf(ctx, "Failed to establish connection: %v", err) } reader, err := reader.NewReader(conn) if err != nil { log.Fatalf(ctx, "Failed to create reader: %v", err) } off := conf.Offset for i := 0; i < 100; i++ { // for { evt, err := reader.ReadEvent() if err != nil { log.Fatalf(ctx, "Failed to read event: %v", err) } ts := time.Unix(int64(evt.Header.Timestamp), 0).Format(time.RFC3339) log.Info(ctx, "Event received", log.F{ "type": evt.Header.Type, "timestamp": ts, "offset": off, }) off = evt.Header.NextOffset } } func validate(cond bool, msg string) { if !cond { fmt.Println(msg) flag.Usage() os.Exit(2) } }