From 9574c2d0bcc7936660ffa261b85d61c5590f1c15 Mon Sep 17 00:00:00 2001 From: Tueem Date: Tue, 3 Feb 2026 00:29:08 +0100 Subject: [PATCH] feat(upload): add first prototype of File storage, svg database and svg processing. Also added --help command --- cmd/svg-templater/main.go | 39 ++------------- internal/command/commandline.go | 37 ++++++++++++++ .../tokencommands.go | 2 +- internal/database/svgdb.go | 28 +++++++++++ internal/routes/upload.go | 49 ++++++++++++++++++ internal/server/http.go | 32 ++++++++++++ pkg/svg/actions/upload.go | 50 +++++++++++++++++++ pkg/svg/storage.go | 50 +++++++++++++++++++ pkg/svg/templates.go | 8 +++ 9 files changed, 258 insertions(+), 37 deletions(-) create mode 100644 internal/command/commandline.go rename internal/{svg-templater => command}/tokencommands.go (96%) create mode 100644 internal/database/svgdb.go create mode 100644 internal/routes/upload.go create mode 100644 internal/server/http.go create mode 100644 pkg/svg/actions/upload.go create mode 100644 pkg/svg/storage.go create mode 100644 pkg/svg/templates.go diff --git a/cmd/svg-templater/main.go b/cmd/svg-templater/main.go index d5dcb82..b6de69e 100644 --- a/cmd/svg-templater/main.go +++ b/cmd/svg-templater/main.go @@ -1,19 +1,10 @@ package main import ( - "flag" - "fmt" "log" - "net/http" + "tomatentum.net/svg-templater/internal/command" "tomatentum.net/svg-templater/internal/database" - svgtemplater "tomatentum.net/svg-templater/internal/svg-templater" - "tomatentum.net/svg-templater/pkg/auth" -) - -var ( - generateTokenFlag bool - deleteTokenFlag bool ) func main() { @@ -23,30 +14,6 @@ func main() { } defer database.Close() database.InitDB() - prepareCommandLine() - prepareHTTP() - handleCommandline() -} - -func prepareCommandLine() { - flag.BoolVar(&generateTokenFlag, "tokengen", false, "svg-templater --tokengen : Generate token with name") - flag.BoolVar(&deleteTokenFlag, "tokendel", false, "svg-templater --tokendel : Delete token with name") -} - -func prepareHTTP() { - http.HandleFunc("/", auth.AuthMiddleware(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { - fmt.Fprintln(w, "You are authorized!") - }))) -} - -func handleCommandline() { - flag.Parse() - if generateTokenFlag { - svgtemplater.GenerateTokenCommand() - } else if deleteTokenFlag { - svgtemplater.DeleteTokenCommand() - } else { - log.Println("Starting http server on :3000") - http.ListenAndServe(":3000", nil) - } + command.PrepareCommandLine() + command.HandleCommandline() } diff --git a/internal/command/commandline.go b/internal/command/commandline.go new file mode 100644 index 0000000..32b528b --- /dev/null +++ b/internal/command/commandline.go @@ -0,0 +1,37 @@ +package command + +import ( + "flag" + + "tomatentum.net/svg-templater/internal/server" + "tomatentum.net/svg-templater/pkg/svg" +) + +var ( + help bool + generateTokenFlag bool + deleteTokenFlag bool + datapath string +) + +func PrepareCommandLine() { + flag.BoolVar(&help, "help", false, "Displays the help String") + flag.BoolVar(&generateTokenFlag, "tokengen", false, "Generate token with name") + flag.BoolVar(&deleteTokenFlag, "tokendel", false, "Delete token with name") + flag.StringVar(&datapath, "data", "/var/lib/svg-templater", "Override data directory") +} + +func HandleCommandline() { + flag.Parse() + if generateTokenFlag { + GenerateTokenCommand() + } else if deleteTokenFlag { + DeleteTokenCommand() + } else if help { + flag.PrintDefaults() + } else { + svg.Storage = svg.NewFileStorage(datapath) + server.PrepareHTTP() + server.Start() + } +} diff --git a/internal/svg-templater/tokencommands.go b/internal/command/tokencommands.go similarity index 96% rename from internal/svg-templater/tokencommands.go rename to internal/command/tokencommands.go index 73b096d..44e0aaf 100644 --- a/internal/svg-templater/tokencommands.go +++ b/internal/command/tokencommands.go @@ -1,4 +1,4 @@ -package svgtemplater +package command import ( "flag" diff --git a/internal/database/svgdb.go b/internal/database/svgdb.go new file mode 100644 index 0000000..d91f2ee --- /dev/null +++ b/internal/database/svgdb.go @@ -0,0 +1,28 @@ +package database + +import ( + "encoding/json" + + "tomatentum.net/svg-templater/pkg/svg" +) + +const SVGTABLECREATE string = ` + CREATE TABLE IF NOT EXISTS svg ( + name varchar(16) PRIMARY KEY NOT NULL, + templatekeys longtext NOT NULL + );` + +const INSERTSVGSQL string = "INSERT INTO svg VALUES (?, ?);" + +func InsertSVG(data *svg.TemplateData) error { + json, err := json.Marshal(data.TemplateKeys) + if err != nil { + return err + } + + if _, err := database.Exec(INSERTSVGSQL, data.Id, string(json)); err != nil { + return err + } + + return nil +} diff --git a/internal/routes/upload.go b/internal/routes/upload.go new file mode 100644 index 0000000..b3fbb92 --- /dev/null +++ b/internal/routes/upload.go @@ -0,0 +1,49 @@ +package routes + +import ( + "bytes" + "encoding/json" + "io" + "log" + "net/http" + + "tomatentum.net/svg-templater/pkg/svg/actions" +) + +func CreateSVG(writer http.ResponseWriter, r http.Request) { + + contentType := r.Header.Get("Content-Type") + if contentType != "image/svg+xml" { + http.Error(writer, "Incorrect Content-Type. Needs image/svg+xml.", http.StatusUnsupportedMediaType) + return + } + + readsvg, err := io.ReadAll(r.Body) + if err != nil { + http.Error(writer, err.Error(), http.StatusInternalServerError) + log.Println("Error while reading Body\n", err) + return + } + + if ok, err := validateSVG(readsvg); err != nil || !ok { + http.Error(writer, err.Error(), http.StatusUnsupportedMediaType) + log.Println("Wrong Media Type was uploaded\n", err) + return + } + + data, err := actions.Create(readsvg) + + if err != nil { + http.Error(writer, err.Error(), http.StatusInternalServerError) + log.Println("Failed creating SVG template\n", err) + return + } + + writer.Header().Add("Content-Type", "application/json") + json.NewEncoder(writer).Encode(data) + log.Println("Created SVG Template " + data.Id) +} + +func validateSVG(svgbuf []byte) (bool, error) { + return bytes.Contains(svgbuf[:512], []byte("