summaryrefslogtreecommitdiff
path: root/src/Render
diff options
context:
space:
mode:
Diffstat (limited to 'src/Render')
-rw-r--r--src/Render/Render.go41
-rw-r--r--src/Render/Templates.go17
2 files changed, 58 insertions, 0 deletions
diff --git a/src/Render/Render.go b/src/Render/Render.go
new file mode 100644
index 0000000..85061d7
--- /dev/null
+++ b/src/Render/Render.go
@@ -0,0 +1,41 @@
+package render
+
+import (
+ "fmt"
+ "log/slog"
+ "net/http"
+ "strings"
+
+ settings "physick.ru/Settings"
+)
+
+const indexTemplateName string = "index.html"
+
+func RegisterEndpoints() {
+ // http.Handle("static/", http.FileServer(http.FS(os.DirFS(settings.Current.StaticLocation))))
+ http.HandleFunc("/", mux)
+}
+
+func mux(w http.ResponseWriter, r *http.Request) {
+ slog.Info("Request", slog.String("URL", r.URL.String()))
+ if r.URL.String() == "/favicon.ico" {
+ http.ServeFile(w, r, fmt.Sprintf("%s/favicon.ico", settings.Current.StaticLocation))
+ }
+ if strings.HasPrefix(r.URL.String(), "/static") {
+ var filePath = strings.Replace(r.URL.String(), "/static", settings.Current.StaticLocation, 1)
+ http.ServeFile(w, r, filePath)
+ return
+ }
+ render(w, r)
+}
+
+func render(w http.ResponseWriter, r *http.Request) {
+ var indexTempl, readErr = getTemplateString(indexTemplateName)
+ if readErr != nil {
+ slog.Warn("Failed to load template", slog.Any("Error", readErr))
+ w.WriteHeader(http.StatusInternalServerError)
+ return
+ }
+ slog.Info("Requested a template")
+ w.Write([]byte(indexTempl))
+}
diff --git a/src/Render/Templates.go b/src/Render/Templates.go
new file mode 100644
index 0000000..544a2ac
--- /dev/null
+++ b/src/Render/Templates.go
@@ -0,0 +1,17 @@
+package render
+
+import (
+ "fmt"
+ "os"
+
+ settings "physick.ru/Settings"
+)
+
+func getTemplateString(templName string) (string, error) {
+ var fullPath = fmt.Sprintf("%s/%s", settings.Current.TemplatesLocation, templName)
+ var file, fopenerr = os.ReadFile(fullPath)
+ if fopenerr != nil {
+ return "", fopenerr
+ }
+ return string(file), nil
+}