Added Config file #10
@ -1,12 +1,12 @@
|
|||||||
{
|
{
|
||||||
"unms": {
|
"unms": {
|
||||||
"active": "true",
|
"enabled": true,
|
||||||
"unmsAPIUrl": "https://unifi.freifunk-troisdorf.de/v2.1",
|
"unmsAPIUrl": "https://unifi.freifunk-troisdorf.de/v2.1",
|
||||||
"APItoken": "API TOKEN",
|
"APItoken": "API TOKEN",
|
||||||
"devicesURL": "https://git.freifunk-rhein-sieg.net/Freifunk-Troisdorf/ubnt-freifunk-map-api/raw/branch/master/"
|
"devicesURL": "https://git.freifunk-rhein-sieg.net/Freifunk-Troisdorf/ubnt-freifunk-map-api/raw/branch/master/"
|
||||||
},
|
},
|
||||||
"unifi": {
|
"unifi": {
|
||||||
"active": "true",
|
"enabled": true,
|
||||||
"APIUrl": "https://unifi.freifunk-troisdorf.de:8443",
|
"APIUrl": "https://unifi.freifunk-troisdorf.de:8443",
|
||||||
"user": "APIuser",
|
"user": "APIuser",
|
||||||
"password": "PASSWORD",
|
"password": "PASSWORD",
|
||||||
|
32
main.go
32
main.go
@ -25,13 +25,13 @@ const (
|
|||||||
// flags
|
// flags
|
||||||
var configPath = flag.String("configPath", "config.json", "Path to config.json")
|
var configPath = flag.String("configPath", "config.json", "Path to config.json")
|
||||||
var version = "development"
|
var version = "development"
|
||||||
var delay time.Duration = 5 * time.Second
|
var delay time.Duration = 60 * time.Second
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
log.Printf("starting version %s...\n", version)
|
log.Printf("starting version %s...\n", version)
|
||||||
// parse all flags
|
// parse all flags
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
c := loadConfig(*configPath)
|
c := loadconfig(*configPath)
|
||||||
|
|
||||||
// check if flags are set
|
// check if flags are set
|
||||||
if *configPath == "" {
|
if *configPath == "" {
|
||||||
@ -44,8 +44,8 @@ func main() {
|
|||||||
serveJSON()
|
serveJSON()
|
||||||
}
|
}
|
||||||
|
|
||||||
func loadConfig(file string) Config {
|
func loadconfig(file string) config {
|
||||||
var config Config
|
var config config
|
||||||
configFile, err := os.Open(file)
|
configFile, err := os.Open(file)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalln(err)
|
log.Fatalln(err)
|
||||||
@ -64,7 +64,7 @@ func itob(i int) bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//Unifi Controller API processing
|
//Unifi Controller API processing
|
||||||
func processUcAPIs(c Config) ([]node, []link) {
|
func processUcAPIs(c config) ([]node, []link) {
|
||||||
//get list of Unifi devices to display
|
//get list of Unifi devices to display
|
||||||
var nodes []node
|
var nodes []node
|
||||||
var links []link
|
var links []link
|
||||||
@ -148,7 +148,7 @@ func processUcAPIs(c Config) ([]node, []link) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//UNMS API processing (Richtfunk)
|
//UNMS API processing (Richtfunk)
|
||||||
func processUNMSAPI(c Config) ([]node, []link) {
|
func processUNMSAPI(c config) ([]node, []link) {
|
||||||
// Variables for runtime
|
// Variables for runtime
|
||||||
var links []link
|
var links []link
|
||||||
var nodes []node
|
var nodes []node
|
||||||
@ -238,18 +238,22 @@ func processUNMSAPI(c Config) ([]node, []link) {
|
|||||||
return nodes, links
|
return nodes, links
|
||||||
}
|
}
|
||||||
|
|
||||||
func processAPIs(c Config) {
|
func processAPIs(c config) {
|
||||||
tick := time.Tick(delay)
|
tick := time.Tick(delay)
|
||||||
for range tick {
|
for range tick {
|
||||||
var nodes []node
|
var nodes []node
|
||||||
var links []link
|
var links []link
|
||||||
|
|
||||||
unmsNodes, unmsLinks := processUNMSAPI(c)
|
if c.Unms.Enabled == true {
|
||||||
ucNodes, ucLinks := processUcAPIs(c)
|
unmsNodes, unmsLinks := processUNMSAPI(c)
|
||||||
nodes = append(nodes, unmsNodes...)
|
nodes = append(nodes, unmsNodes...)
|
||||||
nodes = append(nodes, ucNodes...)
|
links = append(links, unmsLinks...)
|
||||||
links = append(links, unmsLinks...)
|
}
|
||||||
links = append(links, ucLinks...)
|
if c.Unifi.Enabled == true {
|
||||||
|
ucNodes, ucLinks := processUcAPIs(c)
|
||||||
|
nodes = append(nodes, ucNodes...)
|
||||||
|
links = append(links, ucLinks...)
|
||||||
|
}
|
||||||
|
|
||||||
// assemble final struct
|
// assemble final struct
|
||||||
o := output{
|
o := output{
|
||||||
@ -295,7 +299,7 @@ func getDevices(url string) (devices, error) {
|
|||||||
return d, nil
|
return d, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func callUnifiAPI(c Config, url string, i interface{}) error {
|
func callUnifiAPI(c config, url string, i interface{}) error {
|
||||||
request, err := http.NewRequest(http.MethodGet, c.Unms.UnmsAPIURL+url, nil)
|
request, err := http.NewRequest(http.MethodGet, c.Unms.UnmsAPIURL+url, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return errors.New(fmt.Sprint("can't set request", c.Unms.UnmsAPIURL+url))
|
return errors.New(fmt.Sprint("can't set request", c.Unms.UnmsAPIURL+url))
|
||||||
|
6
types.go
6
types.go
@ -10,15 +10,15 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Config struct {
|
type config struct {
|
||||||
Unms struct {
|
Unms struct {
|
||||||
Active string `json:"active"`
|
Enabled bool `json:"enabled"`
|
||||||
UnmsAPIURL string `json:"unmsAPIUrl"`
|
UnmsAPIURL string `json:"unmsAPIUrl"`
|
||||||
APItoken string `json:"APItoken"`
|
APItoken string `json:"APItoken"`
|
||||||
DevicesURL string `json:"devicesURL"`
|
DevicesURL string `json:"devicesURL"`
|
||||||
} `json:"unms"`
|
} `json:"unms"`
|
||||||
Unifi struct {
|
Unifi struct {
|
||||||
Active string `json:"active"`
|
Enabled bool `json:"enabled"`
|
||||||
APIURL string `json:"APIUrl"`
|
APIURL string `json:"APIUrl"`
|
||||||
User string `json:"user"`
|
User string `json:"user"`
|
||||||
Password string `json:"password"`
|
Password string `json:"password"`
|
||||||
|
Loading…
Reference in New Issue
Block a user