mirror of
https://github.com/aunefyren/wrapperr
synced 2024-12-12 20:32:27 +00:00
266c51556e
Rewrote file write/read process Frontend and backend now respects the root setting Fixed some form bugs
132 lines
3.8 KiB
Go
132 lines
3.8 KiB
Go
package main
|
|
|
|
import (
|
|
"aunefyren/wrapperr/files"
|
|
"aunefyren/wrapperr/routes"
|
|
"aunefyren/wrapperr/utilities"
|
|
"flag"
|
|
"fmt"
|
|
"log"
|
|
"net/http"
|
|
"os"
|
|
"strconv"
|
|
"time"
|
|
|
|
"github.com/gorilla/mux"
|
|
|
|
_ "time/tzdata"
|
|
)
|
|
|
|
func main() {
|
|
|
|
utilities.PrintASCII()
|
|
|
|
// Create and define file for logging
|
|
file, err := os.OpenFile("config/wrapperr.log", os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0666)
|
|
if err != nil {
|
|
log.Println("Failed to load configuration file. Error: ")
|
|
log.Println(err)
|
|
|
|
fmt.Println("Failed to load configuration file. Error: ")
|
|
fmt.Println(err)
|
|
|
|
os.Exit(1)
|
|
}
|
|
|
|
config, err := files.GetConfig()
|
|
if err != nil {
|
|
log.Println("Failed to load configuration file. Error: ")
|
|
log.Println(err)
|
|
|
|
fmt.Println("Failed to load configuration file. Error: ")
|
|
fmt.Println(err)
|
|
|
|
os.Exit(1)
|
|
}
|
|
|
|
// Set time zone from config if it is not empty
|
|
if config.Timezone != "" {
|
|
loc, err := time.LoadLocation(config.Timezone)
|
|
if err != nil {
|
|
fmt.Println("Failed to set time zone from config. Error: ")
|
|
fmt.Println(err)
|
|
fmt.Println("Removing value...")
|
|
|
|
log.Println("Failed to set time zone from config. Error: ")
|
|
log.Println(err)
|
|
log.Println("Removing value...")
|
|
|
|
config.Timezone = ""
|
|
err = files.SaveConfig(config)
|
|
if err != nil {
|
|
log.Println("Failed to set new time zone in the config. Error: ")
|
|
log.Println(err)
|
|
log.Println("Exiting...")
|
|
os.Exit(1)
|
|
}
|
|
|
|
} else {
|
|
time.Local = loc
|
|
}
|
|
}
|
|
|
|
// Set log file is logging is enabled
|
|
if config.UseLogs {
|
|
log.SetOutput(file)
|
|
}
|
|
|
|
// Define port variable with the port from the config file as default
|
|
var port int
|
|
flag.IntVar(&port, "port", config.WrapperrPort, "The port Wrapperr is listening on.")
|
|
|
|
// Parse the flags from input
|
|
flag.Parse()
|
|
|
|
// Alert what port is in use
|
|
log.Println("Starting Wrapperr on port: " + strconv.Itoa(port) + ".")
|
|
fmt.Println("Starting Wrapperr on port: " + strconv.Itoa(port) + ".")
|
|
|
|
// Assign routes
|
|
router := mux.NewRouter().StrictSlash(true)
|
|
|
|
var root string
|
|
if config.WrapperrRoot != "" {
|
|
root = "/" + config.WrapperrRoot
|
|
} else {
|
|
root = ""
|
|
}
|
|
|
|
// Admin auth routes
|
|
router.HandleFunc(root+"/api/validate/admin", routes.ApiValidateAdmin)
|
|
router.HandleFunc(root+"/api/get/config", routes.ApiGetConfig)
|
|
router.HandleFunc(root+"/api/get/log", routes.ApiGetLog)
|
|
router.HandleFunc(root+"/api/set/config", routes.ApiSetConfig)
|
|
router.HandleFunc(root+"/api/update/admin", routes.ApiUpdateAdmin)
|
|
|
|
// No-auth routes
|
|
router.HandleFunc(root+"/api/get/config-state", routes.ApiWrapperrConfigured)
|
|
router.HandleFunc(root+"/api/login/admin", routes.ApiLogInAdmin)
|
|
router.HandleFunc(root+"/api/get/wrapperr-version", routes.ApiGetWrapperrVersion)
|
|
router.HandleFunc(root+"/api/get/admin-state", routes.ApiGetAdminState)
|
|
router.HandleFunc(root+"/api/get/functions", routes.ApiGetFunctions)
|
|
router.HandleFunc(root+"/api/create/admin", routes.ApiCreateAdmin)
|
|
router.HandleFunc(root+"/api/get/tautulli-connection", routes.ApiGetTautulliConncection)
|
|
router.HandleFunc(root+"/api/get/share-link", routes.ApiGetShareLink)
|
|
|
|
// User auth routes
|
|
router.HandleFunc(root+"/api/get/login-url", routes.ApiGetLoginURL)
|
|
router.HandleFunc(root+"/api/login/plex-auth", routes.ApiLoginPlexAuth)
|
|
router.HandleFunc(root+"/api/validate/plex-auth", routes.ApiValidatePlexAuth)
|
|
router.HandleFunc(root+"/api/create/share-link", routes.ApiCreateShareLink)
|
|
router.HandleFunc(root+"/api/get/user-share-link", routes.ApiGetUserShareLink)
|
|
router.HandleFunc(root+"/api/delete/user-share-link", routes.ApiDeleteUserShareLink)
|
|
|
|
// Get stats route
|
|
router.HandleFunc(root+"/api/get/statistics", routes.ApiWrapperGetStatistics)
|
|
|
|
// Static routes
|
|
router.PathPrefix(root).Handler(http.StripPrefix(root, http.FileServer(http.Dir("./web/"))))
|
|
|
|
// Start web-server
|
|
log.Fatal(http.ListenAndServe(":"+strconv.Itoa(port), router))
|
|
}
|