mirror of
https://github.com/skidoodle/pastebin
synced 2025-10-14 09:44:48 +02:00
implement running options
This commit is contained in:
9
Makefile
9
Makefile
@@ -1,6 +1,6 @@
|
|||||||
run:
|
dev:
|
||||||
@go tool templ generate
|
@go tool templ generate
|
||||||
@go run .
|
@go run . -addr=":3000" -max-size=32768
|
||||||
|
|
||||||
gen:
|
gen:
|
||||||
@go tool templ generate
|
@go tool templ generate
|
||||||
@@ -8,5 +8,6 @@ gen:
|
|||||||
test:
|
test:
|
||||||
@go test -v ./...
|
@go test -v ./...
|
||||||
|
|
||||||
build:
|
run:
|
||||||
@go build -o bin/main main.go
|
@go build .
|
||||||
|
@./pastebin -addr=0.0.0.0:8080 -max-size=32768
|
||||||
|
|||||||
@@ -10,18 +10,29 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type HttpHandler struct {
|
type HttpHandler struct {
|
||||||
store *store.MemoryStore
|
store *store.MemoryStore
|
||||||
|
maxSize int64
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewHandler(store *store.MemoryStore) *HttpHandler {
|
func NewHandler(store *store.MemoryStore, maxSize int64) *HttpHandler {
|
||||||
return &HttpHandler{
|
return &HttpHandler{
|
||||||
store: store,
|
store,
|
||||||
|
maxSize,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h *HttpHandler) HandleSet(w http.ResponseWriter, r *http.Request) {
|
func (h *HttpHandler) HandleSet(w http.ResponseWriter, r *http.Request) {
|
||||||
|
// form body request looks like:
|
||||||
|
// content=...
|
||||||
|
// so +8 additional bytes must be included
|
||||||
|
r.Body = http.MaxBytesReader(w, r.Body, h.maxSize+8)
|
||||||
|
|
||||||
if err := r.ParseForm(); err != nil {
|
if err := r.ParseForm(); err != nil {
|
||||||
badRequest("invalid bin", err, w, r)
|
if strings.Contains(err.Error(), "request body too large") {
|
||||||
|
badRequest("content too large", nil, w, r)
|
||||||
|
} else {
|
||||||
|
badRequest("invalid form data", err, w, r)
|
||||||
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -31,6 +42,8 @@ func (h *HttpHandler) HandleSet(w http.ResponseWriter, r *http.Request) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//fmt.Println(len(content))
|
||||||
|
|
||||||
id, err := generateId()
|
id, err := generateId()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
internal("could not generate id", err, w, r)
|
internal("could not generate id", err, w, r)
|
||||||
|
|||||||
14
main.go
14
main.go
@@ -1,6 +1,7 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"flag"
|
||||||
"log/slog"
|
"log/slog"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
|
||||||
@@ -8,12 +9,17 @@ import (
|
|||||||
"github.com/csehviktor/pastebin/store"
|
"github.com/csehviktor/pastebin/store"
|
||||||
)
|
)
|
||||||
|
|
||||||
const addr = ":3000"
|
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
addrPtr := flag.String("addr", ":3000", "port to listen on")
|
||||||
|
maxSizePtr := flag.Int("max-size", 32*1024, "maximum size of a paste in bytes")
|
||||||
|
flag.Parse()
|
||||||
|
|
||||||
|
addr := *addrPtr
|
||||||
|
maxSize := int64(*maxSizePtr)
|
||||||
|
|
||||||
mux := http.NewServeMux()
|
mux := http.NewServeMux()
|
||||||
store := store.NewMemoryStore()
|
store := store.NewMemoryStore()
|
||||||
httpHandler := handler.NewHandler(store)
|
httpHandler := handler.NewHandler(store, maxSize)
|
||||||
|
|
||||||
mux.HandleFunc("GET /style.css", func(w http.ResponseWriter, r *http.Request) {
|
mux.HandleFunc("GET /style.css", func(w http.ResponseWriter, r *http.Request) {
|
||||||
http.ServeFile(w, r, "view/style.css")
|
http.ServeFile(w, r, "view/style.css")
|
||||||
@@ -23,7 +29,7 @@ func main() {
|
|||||||
mux.HandleFunc("GET /{id}", httpHandler.HandleGet)
|
mux.HandleFunc("GET /{id}", httpHandler.HandleGet)
|
||||||
mux.HandleFunc("GET /{id}/{theme}", httpHandler.HandleGet)
|
mux.HandleFunc("GET /{id}/{theme}", httpHandler.HandleGet)
|
||||||
|
|
||||||
slog.Info("starting http server on", "addr", addr)
|
slog.Info("starting http server", "addr", addr, "maxSize", maxSize)
|
||||||
err := http.ListenAndServe(addr, mux)
|
err := http.ListenAndServe(addr, mux)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
|
|||||||
Reference in New Issue
Block a user