Fixed fileHandler

This commit is contained in:
2025-08-24 01:44:45 +02:00
parent 403b2f878c
commit adbd2dec20

View File

@@ -5,11 +5,8 @@ import (
"net/http" "net/http"
"os" "os"
"path/filepath" "path/filepath"
"strings"
) )
const staticDir = "static"
type FileData struct { type FileData struct {
ImageNames []string ImageNames []string
SpicyImageNames []string SpicyImageNames []string
@@ -21,6 +18,8 @@ type AsciiEntry struct {
FontSize int FontSize int
} }
const staticDir = "static"
// move FileData and AsciiEntry here if you want, or leave in main.go // move FileData and AsciiEntry here if you want, or leave in main.go
func FileHandler(w http.ResponseWriter, r *http.Request) { func FileHandler(w http.ResponseWriter, r *http.Request) {
data := FileData{ data := FileData{
@@ -29,39 +28,29 @@ func FileHandler(w http.ResponseWriter, r *http.Request) {
AsciiFiles: []AsciiEntry{}, AsciiFiles: []AsciiEntry{},
} }
dirs, err := os.ReadDir(staticDir) files, _ := os.ReadDir(filepath.Join(staticDir, "images"))
if err != nil { for _, file := range files {
http.Error(w, err.Error(), http.StatusInternalServerError) fileName := file.Name()
return data.ImageNames = append(data.ImageNames, filepath.Join(staticDir, "images", fileName))
}
files, _ = os.ReadDir(filepath.Join("uploads"))
for _, file := range files {
fileName := file.Name()
data.ImageNames = append(data.ImageNames, filepath.Join("uploads", fileName))
} }
for _, dir := range dirs { files, _ = os.ReadDir(filepath.Join(staticDir, "spicy"))
dirName := dir.Name() for _, file := range files {
fileName := file.Name()
data.SpicyImageNames = append(data.SpicyImageNames, filepath.Join(staticDir, "spicy", fileName))
}
if strings.EqualFold(dirName, "images") { files, _ = os.ReadDir(filepath.Join(staticDir, "ascii_art"))
for _, file := range files {
files, _ := os.ReadDir(filepath.Join(staticDir, dirName)) fileName := file.Name()
for _, file := range files { data.AsciiFiles = append(data.AsciiFiles,
fileName := file.Name() AsciiEntry{Name: filepath.Join(staticDir, "ascii_art", fileName), FontSize: 12},
data.ImageNames = append(data.ImageNames, filepath.Join(staticDir, dirName, fileName)) )
}
} else if strings.EqualFold(dirName, "spicy") {
files, _ := os.ReadDir(filepath.Join(staticDir, dirName))
for _, file := range files {
fileName := file.Name()
data.SpicyImageNames = append(data.SpicyImageNames, filepath.Join(staticDir, dirName, fileName))
}
} else if strings.EqualFold(dirName, "ascii_art") {
files, _ := os.ReadDir(filepath.Join(staticDir, dirName))
for _, file := range files {
fileName := file.Name()
data.AsciiFiles = append(data.AsciiFiles,
AsciiEntry{Name: filepath.Join(staticDir, dirName, fileName), FontSize: 12},
)
}
}
} }
w.Header().Set("Content-Type", "application/json") w.Header().Set("Content-Type", "application/json")