refactor: split helper functions
This commit is contained in:
parent
58c8321a18
commit
f5cb446264
27
handlers.go
27
handlers.go
@ -60,7 +60,7 @@ func (app *Application) fileListingHandler(w http.ResponseWriter, r *http.Reques
|
|||||||
Name: file.Name(),
|
Name: file.Name(),
|
||||||
Path: filepath.Join(r.URL.Path, file.Name()),
|
Path: filepath.Join(r.URL.Path, file.Name()),
|
||||||
Size: info.Size(),
|
Size: info.Size(),
|
||||||
FormattedSize: formatFileSize(info.Size()),
|
FormattedSize: FormatFileSize(info.Size()),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -74,20 +74,9 @@ func (app *Application) fileListingHandler(w http.ResponseWriter, r *http.Reques
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func formatFileSize(size int64) string {
|
|
||||||
if size < 1024 {
|
|
||||||
return fmt.Sprintf("%d B", size)
|
|
||||||
} else if size < 1024*1024 {
|
|
||||||
return fmt.Sprintf("%.2f KB", float64(size)/1024)
|
|
||||||
} else if size < 1024*1024*1024 {
|
|
||||||
return fmt.Sprintf("%.2f MB", float64(size)/(1024*1024))
|
|
||||||
}
|
|
||||||
return fmt.Sprintf("%.2f GB", float64(size)/(1024*1024*1024))
|
|
||||||
}
|
|
||||||
|
|
||||||
func (app *Application) indexHandler(w http.ResponseWriter, r *http.Request) {
|
func (app *Application) indexHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
if r.Method == http.MethodPost {
|
if r.Method == http.MethodPost {
|
||||||
app.uploadHandler(w, r)
|
app.uploadCurlHandler(w, r)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -146,17 +135,21 @@ func (app *Application) lastHandler(w http.ResponseWriter, r *http.Request) {
|
|||||||
http.ServeFile(w, r, app.lastUploadedFile)
|
http.ServeFile(w, r, app.lastUploadedFile)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (app *Application) uploadHandler(w http.ResponseWriter, r *http.Request) {
|
func (app *Application) uploadCurlHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
if r.URL.Path != "/" {
|
if r.URL.Path != "/" {
|
||||||
http.Error(w, "Method not allowed", http.StatusUnauthorized)
|
http.Error(w, "Method not allowed", http.StatusUnauthorized)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if !app.checkAuth(r) {
|
if !CheckAuth(r, app.key) {
|
||||||
http.Error(w, "You're not authorized.", http.StatusBadRequest)
|
http.Error(w, "You're not authorized.", http.StatusBadRequest)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
app.uploadHandler(w, r)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (app *Application) uploadHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
file, handler, err := r.FormFile("file")
|
file, handler, err := r.FormFile("file")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
http.Error(w, "Error retrieving the file", http.StatusBadRequest)
|
http.Error(w, "Error retrieving the file", http.StatusBadRequest)
|
||||||
@ -205,10 +198,6 @@ func (app *Application) uploadHandler(w http.ResponseWriter, r *http.Request) {
|
|||||||
fmt.Fprintf(w, "http://%s/%s\n", app.url, filename)
|
fmt.Fprintf(w, "http://%s/%s\n", app.url, filename)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (app *Application) checkAuth(r *http.Request) bool {
|
|
||||||
return r.Header.Get("X-Auth") == string(app.key)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (app *Application) basicAuth(next http.HandlerFunc) http.HandlerFunc {
|
func (app *Application) basicAuth(next http.HandlerFunc) http.HandlerFunc {
|
||||||
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||||
username, password, ok := r.BasicAuth()
|
username, password, ok := r.BasicAuth()
|
||||||
|
21
helpers.go
Normal file
21
helpers.go
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"net/http"
|
||||||
|
)
|
||||||
|
|
||||||
|
func CheckAuth(r *http.Request, key string) bool {
|
||||||
|
return r.Header.Get("X-Auth") == key
|
||||||
|
}
|
||||||
|
|
||||||
|
func FormatFileSize(size int64) string {
|
||||||
|
if size < 1024 {
|
||||||
|
return fmt.Sprintf("%d B", size)
|
||||||
|
} else if size < 1024*1024 {
|
||||||
|
return fmt.Sprintf("%.2f KB", float64(size)/1024)
|
||||||
|
} else if size < 1024*1024*1024 {
|
||||||
|
return fmt.Sprintf("%.2f MB", float64(size)/(1024*1024))
|
||||||
|
}
|
||||||
|
return fmt.Sprintf("%.2f GB", float64(size)/(1024*1024*1024))
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user