1
0
dwelling-radio/internal/http/handlers.go

106 lines
2.8 KiB
Go
Raw Normal View History

package http
2022-03-08 01:17:24 +04:00
import (
"dwelling-radio/internal/radio"
"dwelling-radio/pkg/utils"
"dwelling-radio/web"
2022-03-08 01:17:24 +04:00
"encoding/json"
"log"
2022-03-08 01:17:24 +04:00
"net/http"
"os"
"time"
2022-03-08 01:17:24 +04:00
)
type Handlers struct {
songListLen int
filelistPath string
2023-09-14 17:58:35 +04:00
icecastUrl string
icecastPlaylistPath string
2022-03-08 01:17:24 +04:00
}
func NewHandlers(icecastUrl, icecastPlaylistPath, filelistPath string, songListLen int) *Handlers {
return &Handlers{
songListLen: songListLen,
2023-09-14 17:58:35 +04:00
filelistPath: filelistPath,
icecastUrl: icecastUrl,
icecastPlaylistPath: icecastPlaylistPath}
2022-03-08 01:17:24 +04:00
}
func (h *Handlers) Index(w http.ResponseWriter, r *http.Request) {
status, err := radio.IcecastGetStatus(h.icecastUrl)
2022-03-08 01:17:24 +04:00
if err != nil {
log.Println("failed to get Icecast status:", err)
2022-03-08 01:17:24 +04:00
}
songs, err := radio.IcecastLastSongs(h.icecastPlaylistPath)
2022-03-30 20:20:30 +04:00
if err != nil {
log.Println("cannot retrieve last songs:", err)
} else {
for i := 0; i < len(songs); i++ {
if tim, err := time.Parse(radio.SongTimeFormat, songs[i].Time); err == nil {
songs[i].Time = utils.ToClientTimezone(tim, r).Format("15:04")
}
}
}
web.Index(utils.MainSite(r.Host), h.songListLen, status, &songs, r, w)
2022-03-08 01:17:24 +04:00
}
func (h *Handlers) Status(w http.ResponseWriter, r *http.Request) {
status, err := radio.IcecastGetStatus(h.icecastUrl)
2022-03-08 01:17:24 +04:00
if err != nil {
log.Println("cannot retrieve Icecast status:", err)
http.Error(w, "cannot retrieve Icecast status", http.StatusInternalServerError)
return
2022-03-08 01:17:24 +04:00
}
2022-03-31 02:15:16 +04:00
w.Header().Add("Content-Type", "application/json")
json.NewEncoder(w).Encode(status)
2022-03-08 01:17:24 +04:00
}
func (h *Handlers) LastSong(w http.ResponseWriter, r *http.Request) {
song, err := radio.IcecastLastSong(h.icecastPlaylistPath)
2022-03-30 20:20:30 +04:00
if err != nil {
log.Println("cannot retrieve last songs:", err)
2022-03-30 20:20:30 +04:00
}
if song == nil {
w.WriteHeader(http.StatusNotFound)
return
}
2022-03-31 02:15:16 +04:00
if tim, err := time.Parse(radio.SongTimeFormat, song.Time); err == nil {
song.Time = utils.ToClientTimezone(tim, r).Format("15:04")
}
2022-03-31 02:15:16 +04:00
w.Header().Add("Content-Type", "application/json")
json.NewEncoder(w).Encode(song)
2022-03-08 01:17:24 +04:00
}
func (h *Handlers) Playlist(w http.ResponseWriter, _ *http.Request) {
2023-02-23 17:49:01 +04:00
w.Header().Add("Content-Disposition", "attachment; filename=\"radio.arav.su.m3u\"")
2023-07-22 22:58:42 +04:00
fc, _ := web.AssetsGetFile("playlist.m3u")
w.Write(fc)
2022-03-08 01:17:24 +04:00
}
func (h *Handlers) Filelist(w http.ResponseWriter, _ *http.Request) {
2023-02-19 22:26:25 +04:00
w.Header().Add("Content-Type", "text/html")
data, _ := os.ReadFile(h.filelistPath)
w.Write(data)
}
2023-02-19 21:22:56 +04:00
func RobotsTxt(w http.ResponseWriter, _ *http.Request) {
2023-02-19 21:22:56 +04:00
w.Header().Add("Content-Disposition", "attachment; filename=\"robots.txt\"")
w.Write([]byte("User-agent: *\nDisallow: /assets/\nDisallow: /live/"))
}
2023-05-21 22:35:37 +04:00
func Favicon(w http.ResponseWriter, r *http.Request) {
data, _ := web.AssetsGetFile("img/favicon.svg")
w.Write(data)
}
2023-05-21 22:44:09 +04:00
func SitemapXML(w http.ResponseWriter, r *http.Request) {
data, _ := web.AssetsGetFile("sitemap.xml")
w.Write(data)
}