mirror of
https://github.com/selfhst/icons.git
synced 2026-04-30 13:26:18 -04:00
v2.1.0 (Custom icons)
This commit is contained in:
@@ -1,3 +1,9 @@
|
|||||||
|
# v2.1.0
|
||||||
|
|
||||||
|
## What's Changed
|
||||||
|
|
||||||
|
* Added optional volume for custom (non-selfh.st) icons ([#495](https://github.com/selfhst/icons/issues/495))
|
||||||
|
|
||||||
# v2.0.0
|
# v2.0.0
|
||||||
|
|
||||||
## Breaking Changes
|
## Breaking Changes
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
2.0.0
|
2.1.0
|
||||||
@@ -358,6 +358,72 @@ func handleLegacyIcon(w http.ResponseWriter, r *http.Request) {
|
|||||||
handleIcon(w, r)
|
handleIcon(w, r)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func handleCustomIcon(w http.ResponseWriter, r *http.Request) {
|
||||||
|
vars := mux.Vars(r)
|
||||||
|
filename := vars["filename"]
|
||||||
|
|
||||||
|
if filename == "" {
|
||||||
|
http.Error(w, "Filename is required", http.StatusBadRequest)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// Build the path to the custom icon file
|
||||||
|
customPath := filepath.Join("/app/icons/custom", filename)
|
||||||
|
|
||||||
|
// Debug logging
|
||||||
|
log.Printf("[DEBUG] Looking for custom icon at: %s", customPath)
|
||||||
|
|
||||||
|
// Check if file exists
|
||||||
|
if !fileExists(customPath) {
|
||||||
|
// List directory contents for debugging
|
||||||
|
if files, err := os.ReadDir("/app/icons/custom"); err == nil {
|
||||||
|
var fileList []string
|
||||||
|
for _, file := range files {
|
||||||
|
fileList = append(fileList, file.Name())
|
||||||
|
}
|
||||||
|
log.Printf("[DEBUG] Files in /app/icons/custom: %v", fileList)
|
||||||
|
} else {
|
||||||
|
log.Printf("[DEBUG] Failed to read /app/icons/custom directory: %v", err)
|
||||||
|
}
|
||||||
|
log.Printf("[ERROR] Custom icon not found: \"%s\" at path: %s", filename, customPath)
|
||||||
|
http.Error(w, "Custom icon not found", http.StatusNotFound)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// Read the file
|
||||||
|
data, err := os.ReadFile(customPath)
|
||||||
|
if err != nil {
|
||||||
|
log.Printf("[ERROR] Failed to read custom icon \"%s\": %v", filename, err)
|
||||||
|
http.Error(w, "Failed to read custom icon", http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// Determine content type based on file extension
|
||||||
|
ext := strings.ToLower(filepath.Ext(filename))
|
||||||
|
var contentType string
|
||||||
|
switch ext {
|
||||||
|
case ".png":
|
||||||
|
contentType = "image/png"
|
||||||
|
case ".jpg", ".jpeg":
|
||||||
|
contentType = "image/jpeg"
|
||||||
|
case ".gif":
|
||||||
|
contentType = "image/gif"
|
||||||
|
case ".svg":
|
||||||
|
contentType = "image/svg+xml"
|
||||||
|
case ".webp":
|
||||||
|
contentType = "image/webp"
|
||||||
|
case ".ico":
|
||||||
|
contentType = "image/x-icon"
|
||||||
|
default:
|
||||||
|
contentType = "application/octet-stream"
|
||||||
|
}
|
||||||
|
|
||||||
|
log.Printf("[SUCCESS] Serving custom icon: \"%s\" (%s)", filename, contentType)
|
||||||
|
|
||||||
|
w.Header().Set("Content-Type", contentType)
|
||||||
|
w.Write(data)
|
||||||
|
}
|
||||||
|
|
||||||
func handleRoot(w http.ResponseWriter, r *http.Request) {
|
func handleRoot(w http.ResponseWriter, r *http.Request) {
|
||||||
configInfo := map[string]interface{}{
|
configInfo := map[string]interface{}{
|
||||||
"server": "Self-hosted icon server",
|
"server": "Self-hosted icon server",
|
||||||
@@ -390,6 +456,9 @@ func main() {
|
|||||||
|
|
||||||
r := mux.NewRouter()
|
r := mux.NewRouter()
|
||||||
|
|
||||||
|
// Custom icons route: /custom/filename
|
||||||
|
r.HandleFunc("/custom/{filename}", handleCustomIcon).Methods("GET")
|
||||||
|
|
||||||
// Main route: /iconname or /iconname/colorcode
|
// Main route: /iconname or /iconname/colorcode
|
||||||
r.HandleFunc("/{iconname}", handleIcon).Methods("GET")
|
r.HandleFunc("/{iconname}", handleIcon).Methods("GET")
|
||||||
r.HandleFunc("/{iconname}/{colorcode}", handleIcon).Methods("GET")
|
r.HandleFunc("/{iconname}/{colorcode}", handleIcon).Methods("GET")
|
||||||
|
|||||||
Reference in New Issue
Block a user