43 lines
774 B
Go
43 lines
774 B
Go
package main
|
|
|
|
import (
|
|
"log"
|
|
"ti1/data"
|
|
"ti1/database"
|
|
"ti1/export"
|
|
"time"
|
|
)
|
|
|
|
func main() {
|
|
log.Println("ti1 v1.1.0")
|
|
log.Println("Starting...")
|
|
|
|
// Setup the database
|
|
err := database.SetupDB()
|
|
if err != nil {
|
|
log.Fatalf("Database setup failed: %v", err)
|
|
}
|
|
|
|
// Get the current timestamp
|
|
starttimestamp := time.Now().Format("20060102T150405")
|
|
log.Printf("Starting timestamp: %s", starttimestamp)
|
|
|
|
for {
|
|
start := time.Now()
|
|
|
|
data, err := data.FetchData(starttimestamp)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
|
|
export.DBData(data)
|
|
|
|
log.Println("finished in", time.Since(start))
|
|
elapsed := time.Since(start)
|
|
if elapsed < 20*time.Second {
|
|
log.Printf("starting again in %v", 20*time.Second-elapsed)
|
|
time.Sleep(20*time.Second - elapsed)
|
|
}
|
|
}
|
|
}
|