68 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
| package http
 | |
| 
 | |
| import (
 | |
| 	"net/http"
 | |
| 	"strings"
 | |
| 
 | |
| 	"github.com/filebrowser/filebrowser/v2/files"
 | |
| )
 | |
| 
 | |
| var withHashFile = func(fn handleFunc) handleFunc {
 | |
| 	return func(w http.ResponseWriter, r *http.Request, d *data) (int, error) {
 | |
| 		link, err := d.store.Share.GetByHash(r.URL.Path)
 | |
| 		if err != nil {
 | |
| 			link, err = d.store.Share.GetByHash(ifPathWithName(r))
 | |
| 			if err != nil {
 | |
| 				return errToStatus(err), err
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		user, err := d.store.Users.Get(d.server.Root, link.UserID)
 | |
| 		if err != nil {
 | |
| 			return errToStatus(err), err
 | |
| 		}
 | |
| 
 | |
| 		d.user = user
 | |
| 
 | |
| 		file, err := files.NewFileInfo(files.FileOptions{
 | |
| 			Fs:      d.user.Fs,
 | |
| 			Path:    link.Path,
 | |
| 			Modify:  d.user.Perm.Modify,
 | |
| 			Expand:  false,
 | |
| 			Checker: d,
 | |
| 		})
 | |
| 		if err != nil {
 | |
| 			return errToStatus(err), err
 | |
| 		}
 | |
| 
 | |
| 		d.raw = file
 | |
| 		return fn(w, r, d)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // ref to https://github.com/filebrowser/filebrowser/pull/727
 | |
| // `/api/public/dl/MEEuZK-v/file-name.txt` for old browsers to save file with correct name
 | |
| func ifPathWithName(r *http.Request) string {
 | |
| 	pathElements := strings.Split(r.URL.Path, "/")
 | |
| 	// prevent maliciously constructed parameters like `/api/public/dl/XZzCDnK2_not_exists_hash_name`
 | |
| 	// len(pathElements) will be 1, and golang will panic `runtime error: index out of range`
 | |
| 	if len(pathElements) < 2 { //nolint: mnd
 | |
| 		return r.URL.Path
 | |
| 	}
 | |
| 	id := pathElements[len(pathElements)-2]
 | |
| 	return id
 | |
| }
 | |
| 
 | |
| var publicShareHandler = withHashFile(func(w http.ResponseWriter, r *http.Request, d *data) (int, error) {
 | |
| 	return renderJSON(w, r, d.raw)
 | |
| })
 | |
| 
 | |
| var publicDlHandler = withHashFile(func(w http.ResponseWriter, r *http.Request, d *data) (int, error) {
 | |
| 	file := d.raw.(*files.FileInfo)
 | |
| 	if !file.IsDir {
 | |
| 		return rawFileHandler(w, r, file)
 | |
| 	}
 | |
| 
 | |
| 	return rawDirHandler(w, r, d, file)
 | |
| })
 |