wireguard-ui/main.go

51 lines
1.6 KiB
Go
Raw Normal View History

2020-04-18 11:17:49 +02:00
package main
import (
2020-04-23 13:01:40 +02:00
"fmt"
rice "github.com/GeertJohan/go.rice"
"github.com/labstack/echo/v4"
2020-04-18 11:17:49 +02:00
"github.com/ngoduykhanh/wireguard-ui/handler"
"github.com/ngoduykhanh/wireguard-ui/router"
2020-04-23 13:01:40 +02:00
"github.com/ngoduykhanh/wireguard-ui/util"
"net/http"
2020-04-18 11:17:49 +02:00
)
func main() {
2020-04-23 13:01:40 +02:00
// initialize DB
err := util.InitDB()
if err != nil {
fmt.Print("Cannot init database: ", err)
}
// create rice box for embedded template
tmplBox := rice.MustFindBox("templates")
// rice file server for assets. "assets" is the folder where the files come from.
assetHandler := http.FileServer(rice.MustFindBox("assets").HTTPBox())
2020-04-23 13:01:40 +02:00
// register routes
app := router.New(tmplBox)
2020-04-18 11:17:49 +02:00
app.GET("/", handler.WireGuardClients())
2020-04-24 06:22:50 +02:00
app.GET("/login", handler.LoginPage())
2020-04-24 13:14:54 +02:00
app.POST("/login", handler.Login())
app.GET("/logout", handler.Logout())
2020-04-18 11:17:49 +02:00
app.POST("/new-client", handler.NewClient())
app.POST("/client/set-status", handler.SetClientStatus())
2020-04-18 11:17:49 +02:00
app.POST("/remove-client", handler.RemoveClient())
2020-04-25 11:58:14 +02:00
app.GET("/download", handler.DownloadClient())
app.GET("/wg-server", handler.WireGuardServer())
app.POST("wg-server/interfaces", handler.WireGuardServerInterfaces())
app.POST("wg-server/keypair", handler.WireGuardServerKeyPair())
2020-04-20 04:54:41 +02:00
app.GET("/global-settings", handler.GlobalSettings())
app.POST("/global-settings", handler.GlobalSettingSubmit())
app.GET("/api/machine-ips", handler.MachineIPAddresses())
app.GET("/api/suggest-client-ips", handler.SuggestIPAllocation())
app.GET("/api/apply-wg-config", handler.ApplyServerConfig(tmplBox))
// servers other static files
app.GET("/static/*", echo.WrapHandler(http.StripPrefix("/static/", assetHandler)))
2020-04-24 19:33:22 +02:00
app.Logger.Fatal(app.Start("0.0.0.0:5000"))
2020-04-18 11:17:49 +02:00
}