mirror of
https://github.com/NotAShelf/catApi.git
synced 2024-11-22 15:40:42 +00:00
use /api/random endpoint for fetching images
This commit is contained in:
parent
05642cb93b
commit
493e3972a2
1 changed files with 64 additions and 71 deletions
119
main.go
119
main.go
|
@ -9,7 +9,6 @@ import (
|
|||
"math/rand"
|
||||
"net/http"
|
||||
"os"
|
||||
"path/filepath"
|
||||
"strconv"
|
||||
"time"
|
||||
|
||||
|
@ -33,32 +32,63 @@ func init() {
|
|||
}
|
||||
|
||||
func main() {
|
||||
flag.StringVar(&port, "port", "3000", "Port to run the server on")
|
||||
flag.Parse()
|
||||
|
||||
// Initialize Viper for configuration management
|
||||
viper.SetConfigName("config")
|
||||
viper.SetConfigType("yaml")
|
||||
viper.AddConfigPath(".")
|
||||
viper.AutomaticEnv() // Allow environment variables to override config settings
|
||||
|
||||
// Read the configuration file (config.yaml in this example)
|
||||
viper.SetConfigName("config") // name of config file (without extension)
|
||||
viper.SetConfigType("yaml") // REQUIRED if the config file does not have the extension in the name
|
||||
viper.AddConfigPath(".") // path to look for the config file in
|
||||
if err := viper.ReadInConfig(); err != nil {
|
||||
log.Fatalf("Error reading configuration file: %v", err)
|
||||
}
|
||||
|
||||
http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
|
||||
images := getImages(r) // Call getImages with the request parameter
|
||||
port := viper.GetString("server.port")
|
||||
flag.Parse()
|
||||
|
||||
if err := viper.ReadInConfig(); err != nil {
|
||||
log.Fatalf("Error reading configuration file: %v", err)
|
||||
}
|
||||
|
||||
images = getImages()
|
||||
|
||||
http.HandleFunc("/", homeHandler)
|
||||
http.HandleFunc("/api/id", idHandler)
|
||||
http.HandleFunc("/api/list", listHandler)
|
||||
http.HandleFunc("/api/random", randomHandler)
|
||||
|
||||
http.HandleFunc("/api/", func(w http.ResponseWriter, r *http.Request) {
|
||||
http.Error(w, "Invalid API path", http.StatusNotFound)
|
||||
})
|
||||
|
||||
log.Println("Server started at port", port)
|
||||
log.Fatal(http.ListenAndServe(":"+port, nil))
|
||||
}
|
||||
|
||||
func getImages() []string {
|
||||
files, err := os.ReadDir("images/")
|
||||
if err != nil {
|
||||
logger.WithError(err).Fatal("Error reading images directory")
|
||||
}
|
||||
var images []string
|
||||
for _, file := range files {
|
||||
images = append(images, file.Name())
|
||||
logger.Info("Loaded image:", file.Name())
|
||||
}
|
||||
return images
|
||||
}
|
||||
|
||||
func sanitizeInput(input string) string {
|
||||
return template.HTMLEscapeString(input)
|
||||
}
|
||||
|
||||
func homeHandler(w http.ResponseWriter, r *http.Request) {
|
||||
io.WriteString(w, "<html><body><div style=\"display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); grid-gap: 10px;\">")
|
||||
for i, image := range images {
|
||||
for i := range images {
|
||||
io.WriteString(w, `<a href="/api/id?id=`+strconv.Itoa(i)+`">`)
|
||||
io.WriteString(w, `<img src="`+filepath.Base(image)+`" style="width: 100%; height: auto;"/>`)
|
||||
io.WriteString(w, `<img src="/api/id?id=`+strconv.Itoa(i)+`" style="width: 100%; height: auto;"/>`)
|
||||
io.WriteString(w, `</a>`)
|
||||
}
|
||||
io.WriteString(w, "</div></body></html>")
|
||||
})
|
||||
}
|
||||
|
||||
http.HandleFunc("/api/id", func(w http.ResponseWriter, r *http.Request) {
|
||||
func idHandler(w http.ResponseWriter, r *http.Request) {
|
||||
id := sanitizeInput(r.URL.Query().Get("id"))
|
||||
if id == "" {
|
||||
http.Error(w, "Missing id", http.StatusBadRequest)
|
||||
|
@ -69,66 +99,29 @@ func main() {
|
|||
http.Error(w, "Invalid id", http.StatusBadRequest)
|
||||
return
|
||||
}
|
||||
http.ServeFile(w, r, images[i])
|
||||
})
|
||||
http.ServeFile(w, r, "images/"+images[i])
|
||||
}
|
||||
|
||||
http.HandleFunc("/api/list", func(w http.ResponseWriter, r *http.Request) {
|
||||
// Create a slice to store image information
|
||||
func listHandler(w http.ResponseWriter, r *http.Request) {
|
||||
imageList := []map[string]string{}
|
||||
|
||||
for _, image := range images {
|
||||
for i := range images {
|
||||
imageInfo := map[string]string{
|
||||
"image": image,
|
||||
"url": "/" + filepath.Base(image),
|
||||
"id": strconv.Itoa(i),
|
||||
"url": "/api/id?id=" + strconv.Itoa(i),
|
||||
}
|
||||
imageList = append(imageList, imageInfo)
|
||||
}
|
||||
|
||||
// Convert the slice to JSON
|
||||
jsonData, err := json.Marshal(imageList)
|
||||
if err != nil {
|
||||
http.Error(w, "Internal Server Error", http.StatusInternalServerError)
|
||||
return
|
||||
}
|
||||
|
||||
// Set the content type to JSON
|
||||
w.Header().Set("Content-Type", "application/json")
|
||||
|
||||
// Write the JSON response
|
||||
w.Write(jsonData)
|
||||
})
|
||||
}
|
||||
|
||||
http.HandleFunc("/api/random", func(w http.ResponseWriter, r *http.Request) {
|
||||
// Reseed the random number generator to make it truly random on each request
|
||||
func randomHandler(w http.ResponseWriter, r *http.Request) {
|
||||
rand.Seed(time.Now().UnixNano())
|
||||
|
||||
i := rand.Intn(len(images))
|
||||
http.ServeFile(w, r, images[i])
|
||||
})
|
||||
|
||||
http.HandleFunc("/api/", func(w http.ResponseWriter, r *http.Request) {
|
||||
http.Error(w, "Invalid API path", http.StatusNotFound)
|
||||
})
|
||||
|
||||
log.Println("Server started at port", port)
|
||||
log.Fatal(http.ListenAndServe(":"+port, nil))
|
||||
}
|
||||
|
||||
func getImages(r *http.Request) []string {
|
||||
files, err := os.ReadDir("images/")
|
||||
if err != nil {
|
||||
logger.WithError(err).Fatal("Error reading images directory")
|
||||
}
|
||||
var images []string
|
||||
serverAddress := r.Host // Get the server address from the request
|
||||
for _, file := range files {
|
||||
imagePath := "http://" + serverAddress + "/images/" + file.Name()
|
||||
images = append(images, imagePath)
|
||||
logger.Info("Loaded image:", imagePath)
|
||||
}
|
||||
return images
|
||||
}
|
||||
|
||||
func sanitizeInput(input string) string {
|
||||
return template.HTMLEscapeString(input)
|
||||
http.Redirect(w, r, "/api/id?id="+strconv.Itoa(i), http.StatusSeeOther)
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue