This repository has been archived on 2023-04-11. You can view files and clone it, but cannot push or open issues or pull requests.
openskins/main.go

53 lines
1.1 KiB
Go
Raw Permalink Normal View History

2020-12-26 04:16:14 +01:00
package main
import (
"fmt"
"github.com/josephbmanley/OpenSkins/pluginmanager"
"github.com/josephbmanley/OpenSkins/runtime"
2020-12-26 04:16:14 +01:00
log "github.com/sirupsen/logrus"
"os"
"plugin"
2020-12-26 04:16:14 +01:00
)
var appRuntime = "webserver"
2020-12-26 04:16:14 +01:00
const plugindirectory = "./plugins"
func main() {
pluginFiles, err := pluginmanager.GetPlugins(plugindirectory)
if err != nil {
2021-01-28 13:20:49 +01:00
log.Fatalln(fmt.Sprintf("Failed to read plugins directory: %v", err.Error()))
os.Exit(1)
2020-12-26 04:16:14 +01:00
}
loadedPlugins := []*plugin.Plugin{}
2020-12-26 04:16:14 +01:00
for _, file := range pluginFiles {
log.Infoln(fmt.Sprintf("Loading plugin: %v", file))
plugin, err := plugin.Open(file)
2020-12-26 04:16:14 +01:00
if err != nil {
log.Fatalln(fmt.Sprintf("Failed to load plugin '%v': %v", file, err.Error()))
os.Exit(1)
}
loadedPlugins = append(loadedPlugins, plugin)
2020-12-26 04:16:14 +01:00
}
2020-12-26 04:16:14 +01:00
err = pluginmanager.LoadSkinstores(loadedPlugins)
if err != nil {
log.Fatalln(fmt.Sprintf("Failed to load skinstores '%v'", err.Error()))
os.Exit(1)
2020-12-26 04:16:14 +01:00
}
switch appRuntime {
case "webserver":
2021-01-30 05:19:27 +01:00
runtime.StartWebserver(8080) // Start on port 8080
default:
log.Fatalln("Runtime is currently not implemented!")
os.Exit(1)
}
2020-12-26 04:16:14 +01:00
}