2019-12-29 17:39:08 +00:00
package main
import (
"flag"
"github.com/cyrilix/robocar-base/cli"
"github.com/cyrilix/robocar-display/part"
"log"
"os"
)
const (
2019-12-31 16:22:28 +00:00
DefaultClientId = "robocar-display"
2019-12-29 17:39:08 +00:00
)
func main ( ) {
var mqttBroker , username , password , clientId string
2019-12-31 16:22:28 +00:00
var frameTopic , objectsTopic string
var withObjects bool
2019-12-29 17:39:08 +00:00
mqttQos := cli . InitIntFlag ( "MQTT_QOS" , 0 )
_ , mqttRetain := os . LookupEnv ( "MQTT_RETAIN" )
cli . InitMqttFlags ( DefaultClientId , & mqttBroker , & username , & password , & clientId , & mqttQos , & mqttRetain )
flag . StringVar ( & frameTopic , "mqtt-topic-frame" , os . Getenv ( "MQTT_TOPIC_FRAME" ) , "Mqtt topic that contains frame to display, use MQTT_TOPIC_FRAME if args not set" )
2019-12-31 16:22:28 +00:00
flag . StringVar ( & objectsTopic , "mqtt-topic-objects" , os . Getenv ( "MQTT_TOPIC_OBJECTS" ) , "Mqtt topic that contains detected objects, use MQTT_TOPIC_OBJECTS if args not set" )
flag . BoolVar ( & withObjects , "with-objects" , false , "Display detected objects" )
2019-12-29 17:39:08 +00:00
flag . Parse ( )
if len ( os . Args ) <= 1 {
flag . PrintDefaults ( )
os . Exit ( 1 )
}
client , err := cli . Connect ( mqttBroker , username , password , clientId )
if err != nil {
log . Fatalf ( "unable to connect to mqtt bus: %v" , err )
}
defer client . Disconnect ( 50 )
2019-12-31 16:22:28 +00:00
p := part . NewPart ( client , frameTopic , objectsTopic , withObjects )
2019-12-29 17:39:08 +00:00
defer p . Stop ( )
cli . HandleExit ( p )
err = p . Start ( )
if err != nil {
log . Fatalf ( "unable to start service: %v" , err )
}
}