fix: 2.6-stable - fixes
This commit is contained in:
parent
b05c444a0a
commit
5751f1d0c7
@ -1,4 +1,4 @@
|
||||
# HMAC File Server 2.6-Stable
|
||||
# HMAC File Server 2.5-Stable
|
||||
|
||||
## Overview
|
||||
The **HMAC File Server** ensures secure file uploads and downloads using HMAC authentication. It incorporates rate limiting, CORS support, retries, file versioning, and Unix socket support for enhanced flexibility. Redis integration provides efficient caching and session management. Prometheus metrics and a graceful shutdown mechanism ensure reliable and efficient file handling.
|
||||
@ -202,4 +202,4 @@ in the Software without restriction, including without limitation the rights to
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
@ -514,6 +514,7 @@ func main() {
|
||||
log.Fatalf("Insufficient free space: %v", err)
|
||||
}
|
||||
|
||||
initializeWorkerSettings(&conf.Server, &conf.Workers, &conf.ClamAV)
|
||||
log.Info("Prometheus metrics initialized.")
|
||||
|
||||
networkEvents = make(chan NetworkEvent, 100)
|
||||
@ -1789,9 +1790,25 @@ func handleUpload(w http.ResponseWriter, r *http.Request, absFilename, fileStore
|
||||
}
|
||||
|
||||
// Determine the final filename based on the FileNaming configuration
|
||||
finalFilename := getFinalFilename(absFilename)
|
||||
finalFilename := absFilename
|
||||
switch conf.Server.FileNaming {
|
||||
case "HMAC":
|
||||
// Use hashed/HMAC name
|
||||
tempFilename := ""
|
||||
hashVal, err := computeSHA256(context.Background(), tempFilename)
|
||||
if err != nil {
|
||||
// ...existing code...
|
||||
}
|
||||
finalFilename = filepath.Join(filepath.Dir(absFilename), hashVal)
|
||||
case "None":
|
||||
// Preserve the original filename
|
||||
finalFilename = absFilename
|
||||
default:
|
||||
// ...existing code...
|
||||
}
|
||||
|
||||
// Create temp file and write the uploaded data
|
||||
tempFilename := getTempFilename(finalFilename)
|
||||
tempFilename := finalFilename + ".tmp"
|
||||
err = createFile(tempFilename, r)
|
||||
if err != nil {
|
||||
log.WithFields(logrus.Fields{
|
||||
@ -2741,13 +2758,4 @@ func setupRouter() *http.ServeMux {
|
||||
router := http.NewServeMux()
|
||||
router.HandleFunc("/", handleRequest)
|
||||
return router
|
||||
}
|
||||
|
||||
func getFinalFilename(absFilename string) string {
|
||||
// Use config if needed, or just return absFilename for now
|
||||
return absFilename
|
||||
}
|
||||
|
||||
func getTempFilename(filename string) string {
|
||||
return filename + ".tmp"
|
||||
}
|
@ -41,7 +41,7 @@ containerfile = "/mnt/iso/container.iso"
|
||||
[timeouts]
|
||||
readtimeout = "4800s"
|
||||
writetimeout = "4800s"
|
||||
idletimeout = "65s"
|
||||
idletimeout = "4800s"
|
||||
|
||||
[security]
|
||||
secret = "changeme"
|
||||
@ -55,14 +55,12 @@ resumableuploadsenabled = true
|
||||
chunkeduploadsenabled = true
|
||||
chunksize = "8192"
|
||||
allowedextensions = [".txt", ".pdf", ".png", ".jpg", ".jpeg", ".gif", ".bmp", ".tiff", ".svg", ".webp"]
|
||||
max_upload_size = "2GB" # New setting for maximum upload size
|
||||
|
||||
[downloads]
|
||||
resumabledownloadsenabled = true
|
||||
chunkeddownloadsenabled = true
|
||||
chunksize = "8192"
|
||||
allowedextensions = [".txt", ".pdf", ".png", ".jpg", ".jpeg", ".gif", ".bmp", ".tiff", ".svg", ".webp"]
|
||||
max_download_size = "2GB" # New setting for maximum download size
|
||||
|
||||
[clamav]
|
||||
clamavenabled = true
|
||||
|
Loading…
x
Reference in New Issue
Block a user