80 lines
3.1 KiB
Go
80 lines
3.1 KiB
Go
package main
|
|
|
|
import (
|
|
"basic-sensor-receiver/app"
|
|
"basic-sensor-receiver/middleware"
|
|
"basic-sensor-receiver/routes"
|
|
"fmt"
|
|
"log"
|
|
|
|
"github.com/gin-gonic/gin"
|
|
"github.com/joho/godotenv"
|
|
_ "github.com/mattn/go-sqlite3"
|
|
)
|
|
|
|
func main() {
|
|
err := godotenv.Load()
|
|
if err != nil {
|
|
log.Println("Error loading .env file")
|
|
}
|
|
|
|
server := app.InitializeServer()
|
|
|
|
gin.SetMode(server.Config.Mode)
|
|
|
|
router := gin.Default()
|
|
|
|
// Front-end resources
|
|
router.StaticFile("/", "client/index.html")
|
|
router.Static("/assets", "client/assets")
|
|
|
|
// Only allow CORS in development mode
|
|
if server.Config.Mode == "debug" {
|
|
router.Use(middleware.CorsMiddleware())
|
|
}
|
|
|
|
// User login route
|
|
router.POST("/api/login", routes.Login(server))
|
|
|
|
// Routes that are only accessible after logging in
|
|
loginProtected := router.Group("/", middleware.LoginAuthMiddleware(server))
|
|
loginProtected.GET("/api/sensors", routes.GetSensors(server))
|
|
loginProtected.POST("/api/sensors", routes.PostSensors(server))
|
|
loginProtected.GET("/api/sensors/:sensor", routes.GetSensor(server))
|
|
loginProtected.PUT("/api/sensors/:sensor", routes.PutSensor(server))
|
|
loginProtected.DELETE("/api/sensors/:sensor", routes.DeleteSensor(server))
|
|
loginProtected.GET("/api/sensors/:sensor/values/latest", routes.GetSensorLatestValue(server))
|
|
loginProtected.GET("/api/sensors/:sensor/values", routes.GetSensorValues(server))
|
|
//loginProtected.GET("/api/sensors/:sensor/config", routes.GetSensorConfig(server))
|
|
//loginProtected.PUT("/api/sensors/:sensor/config/:key", routes.PutSensorConfig(server))
|
|
loginProtected.GET("/api/dashboards", routes.GetDashboards(server))
|
|
loginProtected.POST("/api/dashboards", routes.PostDashboard(server))
|
|
loginProtected.GET("/api/dashboards/:id", routes.GetDashboardById(server))
|
|
loginProtected.PUT("/api/dashboards/:id", routes.PutDashboard(server))
|
|
loginProtected.DELETE("/api/dashboards/:id", routes.DeleteDashboard(server))
|
|
loginProtected.GET("/api/alerts", routes.GetAlerts(server))
|
|
loginProtected.POST("/api/alerts", routes.PostAlerts(server))
|
|
loginProtected.GET("/api/alerts/:alertId", routes.GetAlert(server))
|
|
loginProtected.PUT("/api/alerts/:alertId", routes.PutAlert(server))
|
|
loginProtected.DELETE("/api/alerts/:alertId", routes.DeleteAlert(server))
|
|
loginProtected.GET("/api/contact-points", routes.GetContactPoints(server))
|
|
loginProtected.POST("/api/contact-points", routes.PostContactPoints(server))
|
|
loginProtected.GET("/api/contact-points/:contactPointId", routes.GetContactPoint(server))
|
|
loginProtected.PUT("/api/contact-points/:contactPointId", routes.PutContactPoint(server))
|
|
loginProtected.DELETE("/api/contact-points/:contactPointId", routes.DeleteContactPoint(server))
|
|
loginProtected.POST("/api/logout", routes.Logout(server))
|
|
|
|
// Routes accessible using auth key
|
|
keyProtected := router.Group("/", middleware.KeyAuthMiddleware(server))
|
|
keyProtected.POST("/api/sensors/:sensor/values", routes.PostSensorValues(server))
|
|
|
|
// Starts session cleanup goroutine
|
|
server.StartCleaner()
|
|
|
|
// Starts alerts handling goroutine
|
|
server.StartAlerts()
|
|
|
|
// Run the server
|
|
router.Run(fmt.Sprintf("%s:%d", server.Config.Ip, server.Config.Port))
|
|
}
|