1
0
Fork 0
upl/main.go

57 lines
1.7 KiB
Go
Raw Permalink Normal View History

2021-05-22 13:12:14 +08:00
package main
import (
2021-05-23 00:46:15 +08:00
"log"
2021-05-22 13:12:14 +08:00
"net/http"
"os"
"time"
"github.com/gorilla/mux"
)
var debug = os.Getenv("DEBUG") == "true"
2021-05-22 13:12:14 +08:00
func main() {
listen := os.Getenv("LISTEN")
if listen == "" {
listen = ":8080"
}
setupHandlers()
2021-05-23 00:46:15 +08:00
setupS3()
2021-05-22 13:12:14 +08:00
router := mux.NewRouter()
2021-05-23 00:46:15 +08:00
router.Use(middlewareLogger)
router.Methods(http.MethodGet).Path("/readyz").HandlerFunc(readyz)
2021-05-23 17:00:48 +08:00
router.Methods(http.MethodGet).PathPrefix("/assets").HandlerFunc(handleAssets)
router.Methods(http.MethodGet).Path("/").HandlerFunc(handleCreate)
router.Methods(http.MethodPost).Path("/").HandlerFunc(handleCreateForm)
2021-07-03 20:25:08 +08:00
router.Methods(http.MethodGet).Path("/help").HandlerFunc(handleHelp)
2021-05-22 23:53:00 +08:00
uploadRouter := router.PathPrefix("/{id}").Subrouter()
2021-05-23 00:46:15 +08:00
uploadTemplateRouter := uploadRouter.Path("").Subrouter()
2021-05-22 23:53:00 +08:00
s3Router := uploadRouter.PathPrefix("/s3/multipart").Subrouter()
2021-05-23 00:46:15 +08:00
uploadTemplateRouter.Methods(http.MethodGet).Path("").HandlerFunc(handleUpload)
2021-05-22 23:53:00 +08:00
s3Router.Methods(http.MethodPost).Path("").HandlerFunc(handleCreateMultipartUpload)
s3Router.Methods(http.MethodGet).Path("/{uploadID}").HandlerFunc(handleGetUploadedParts)
s3Router.Methods(http.MethodGet).Path("/{uploadID}/batch").HandlerFunc(handleBatchSignPartsUpload)
2021-05-22 23:53:00 +08:00
s3Router.Methods(http.MethodGet).Path("/{uploadID}/{uploadPart}").HandlerFunc(handleSignPartUpload)
s3Router.Methods(http.MethodPost).Path("/{uploadID}/complete").HandlerFunc(handleCompleteMultipartUpload)
s3Router.Methods(http.MethodDelete).Path("/{uploadID}").HandlerFunc(handleAbortMultipartUpload)
2021-05-22 13:12:14 +08:00
server := &http.Server{
2021-06-29 21:13:14 +08:00
Handler: router,
Addr: listen,
ReadTimeout: 30 * time.Second,
2021-05-22 13:12:14 +08:00
}
log.Printf("listening on %s", listen)
err := server.ListenAndServe()
2021-05-22 13:12:14 +08:00
if err != nil {
panic(err)
}
}