This repository was archived by the owner on Feb 21, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 4
Expand file tree
/
Copy pathmain.go
More file actions
127 lines (95 loc) · 2.63 KB
/
main.go
File metadata and controls
127 lines (95 loc) · 2.63 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
package main
import (
"fmt"
"net"
"bufio"
"strings"
"os"
"time"
_ "github.com/lib/pq"
"database/sql"
"log"
"strconv"
)
func main() {
// postgres
db, err := sql.Open("postgres", "host=adsb1090 user=adsb1090 password=adsb1090 dbname=adsb1090") // todo env variables
if err != nil {
log.Fatal("Error: The data source arguments are not valid")
os.Exit(1)
}
err = db.Ping()
if err != nil {
log.Fatal("Error: Could not establish a connection with the database")
os.Exit(1)
}
// connect to mutability-dump1090
conn, err := net.Dial("tcp", "127.0.0.1:30003") // todo env variables
if err != nil {
fmt.Printf("connection error: %s\n", err)
os.Exit(1)
}
reader := bufio.NewReader(conn)
for {
output, err := reader.ReadString('\n')
if err != nil {
fmt.Printf("error: %s\n", err)
os.Exit(1)
}
if len(strings.TrimSpace(output)) != 0 {
//fmt.Print(output)
values := strings.Split(output, ",")
hex := values[4]
timestamp := parseTimestamp(values[6], values[7])
flight := sqlString(values[10]) // flight "name"
altitude := sqlInt(values[11]) // feet
speed := sqlInt(values[12]) // mph
heading := sqlInt(values[13]) // degrees
lat := sqlDouble(values[14])
lon := sqlDouble(values[15])
src := strings.TrimSpace(output)
addBeacon(db, hex, timestamp, flight, altitude, speed, heading, lat, lon, src);
checkErr(err)
}
}
}
func parseTimestamp(date_part string, time_part string) int64 {
form := "2006/01/02 15:04:05.999"
timestamp, err := time.Parse(form, date_part + " " + time_part)
checkErr(err)
return timestamp.Unix()
}
func addBeacon(db *sql.DB, hex string, timestamp int64, flight sql.NullString, altitude sql.NullInt64, speed sql.NullInt64, heading sql.NullInt64, lat sql.NullFloat64, lon sql.NullFloat64, src string) {
_, err := db.Exec("INSERT INTO beacons (hex, timestamp, flight, altitude, speed, heading, lat, lon, src) VALUES ($1, $2, $3, $4, $5, $6, $7, $8, $9)", hex, timestamp, flight, altitude, speed, heading, lat, lon, src)
checkErr(err)
}
func sqlInt(value string) sql.NullInt64 {
if len(value) == 0 {
return sql.NullInt64{}
}
s, err := strconv.ParseInt(value, 10, 64)
checkErr(err)
return sql.NullInt64{Int64: s, Valid: true}
}
func sqlDouble(value string) sql.NullFloat64 {
if len(value) == 0 {
return sql.NullFloat64{}
}
s, err := strconv.ParseFloat(value, 64)
checkErr(err)
return sql.NullFloat64{Float64: s, Valid: true}
}
func sqlString(s string) sql.NullString {
if len(s) == 0 {
return sql.NullString{}
}
return sql.NullString{
String: s,
Valid: true,
}
}
func checkErr(err error) {
if err != nil {
fmt.Printf("error: %s\n", err)
}
}