Compare commits

...

4 commits

Author SHA1 Message Date
davrot
5eb09842e8 Dateien nach „routers/web/repo“ hochladen 2025-01-27 20:37:31 +00:00
davrot
17b690673d Dateien nach „routers/web“ hochladen 2025-01-27 20:37:18 +00:00
davrot
4a20a897e4 Dateien nach „services/forms“ hochladen 2025-01-27 20:36:52 +00:00
davrot
e910714237 Dateien nach „services/repository/files“ hochladen 2025-01-27 20:36:28 +00:00
2 changed files with 20 additions and 21 deletions

View file

@ -51,12 +51,12 @@ import (
_ "code.gitea.io/gitea/modules/session" // to registers all internal adapters _ "code.gitea.io/gitea/modules/session" // to registers all internal adapters
"code.forgejo.org/go-chi/binding"
"code.forgejo.org/go-chi/captcha" "code.forgejo.org/go-chi/captcha"
chi_middleware "github.com/go-chi/chi/v5/middleware" chi_middleware "github.com/go-chi/chi/v5/middleware"
"github.com/go-chi/cors" "github.com/go-chi/cors"
"github.com/klauspost/compress/gzhttp" "github.com/klauspost/compress/gzhttp"
"github.com/prometheus/client_golang/prometheus" "github.com/prometheus/client_golang/prometheus"
"code.forgejo.org/go-chi/binding"
) )
var GzipMinSize = gzhttp.DefaultMinSize var GzipMinSize = gzhttp.DefaultMinSize
@ -1674,19 +1674,18 @@ func registerRoutes(m *web.Route) {
} }
func BindUpload(f forms.UploadRepoFileForm) http.HandlerFunc { func BindUpload(f forms.UploadRepoFileForm) http.HandlerFunc {
return func(resp http.ResponseWriter, req *http.Request) { return func(resp http.ResponseWriter, req *http.Request) {
theObj := new(forms.UploadRepoFileForm) // create a new form obj for every request but not use obj directly
theObj := new(forms.UploadRepoFileForm) // create a new form obj for every request but not use obj directly data := middleware.GetContextData(req.Context())
data := middleware.GetContextData(req.Context()) binding.Bind(req, theObj)
binding.Bind(req, theObj) files := theObj.Files
files := theObj.Files var fullpaths []string
var fullpaths []string for _, fileID := range files {
for _, fileID := range files { fullPath := req.Form.Get("files_fullpath[" + fileID + "]")
fullPath := req.Form.Get("files_fullpath[" + fileID + "]") fullpaths = append(fullpaths, fullPath)
fullpaths = append(fullpaths, fullPath) }
} theObj.FullPaths = fullpaths
theObj.FullPaths = fullpaths data.GetData()["__form"] = theObj
data.GetData()["__form"] = theObj middleware.AssignForm(theObj, data)
middleware.AssignForm(theObj, data) }
}
} }

View file

@ -6,11 +6,11 @@ package files
import ( import (
"context" "context"
"fmt" "fmt"
"html"
"os" "os"
"path" "path"
"regexp"
"strings" "strings"
"regexp"
"html"
git_model "code.gitea.io/gitea/models/git" git_model "code.gitea.io/gitea/models/git"
repo_model "code.gitea.io/gitea/models/repo" repo_model "code.gitea.io/gitea/models/repo"
@ -168,12 +168,12 @@ var fileNameSanitizeRegexp = regexp.MustCompile(`(?i)\.\.|[<>:\"\\|?*\x{0000}-\x
// Sanitize user input to valid OS filenames // Sanitize user input to valid OS filenames
// //
// Based on https://github.com/sindresorhus/filename-reserved-regex // Based on https://github.com/sindresorhus/filename-reserved-regex
// Adds ".." to prevent directory traversal // Adds ".." to prevent directory traversal
func fileNameSanitize(s string) string { func fileNameSanitize(s string) string {
// Added this because I am not sure what Windows will deliver us \ or / but we need /. // Added this because I am not sure what Windows will deliver us \ or / but we need /.
s = strings.ReplaceAll(s, "\\", "/") s = strings.ReplaceAll(s, "\\", "/")
return strings.TrimSpace(fileNameSanitizeRegexp.ReplaceAllString(s, "_")) return strings.TrimSpace(fileNameSanitizeRegexp.ReplaceAllString(s, "_"))
} }
func copyUploadedLFSFilesIntoRepository(infos []uploadInfo, t *TemporaryUploadRepository, treePath string) error { func copyUploadedLFSFilesIntoRepository(infos []uploadInfo, t *TemporaryUploadRepository, treePath string) error {