2020-08-12 21:56:41 -07:00
|
|
|
package controllers
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"net/http"
|
2021-07-12 00:34:56 +02:00
|
|
|
"os"
|
2020-08-12 21:56:41 -07:00
|
|
|
"path"
|
|
|
|
"path/filepath"
|
|
|
|
"strings"
|
2021-07-12 00:34:56 +02:00
|
|
|
"time"
|
2020-08-12 21:56:41 -07:00
|
|
|
|
2020-10-06 01:07:09 +08:00
|
|
|
"github.com/owncast/owncast/config"
|
|
|
|
"github.com/owncast/owncast/models"
|
2020-08-12 21:56:41 -07:00
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
)
|
|
|
|
|
2022-05-26 18:59:16 -07:00
|
|
|
var (
|
|
|
|
emojiCache = make([]models.CustomEmoji, 0)
|
|
|
|
emojiCacheTimestamp time.Time
|
|
|
|
)
|
2020-08-12 21:56:41 -07:00
|
|
|
|
2021-07-12 00:34:56 +02:00
|
|
|
// getCustomEmojiList returns a list of custom emoji either from the cache or from the emoji directory.
|
|
|
|
func getCustomEmojiList() []models.CustomEmoji {
|
2021-08-14 21:48:04 +02:00
|
|
|
fullPath := filepath.Join(config.WebRoot, config.EmojiDir)
|
2021-07-12 00:34:56 +02:00
|
|
|
emojiDirInfo, err := os.Stat(fullPath)
|
2020-08-12 21:56:41 -07:00
|
|
|
if err != nil {
|
|
|
|
log.Errorln(err)
|
2021-07-12 00:34:56 +02:00
|
|
|
}
|
|
|
|
if emojiDirInfo.ModTime() != emojiCacheTimestamp {
|
|
|
|
log.Traceln("Emoji cache invalid")
|
|
|
|
emojiCache = make([]models.CustomEmoji, 0)
|
2020-08-12 21:56:41 -07:00
|
|
|
}
|
|
|
|
|
2021-07-12 00:34:56 +02:00
|
|
|
if len(emojiCache) == 0 {
|
2021-11-20 14:42:50 +08:00
|
|
|
files, err := os.ReadDir(fullPath)
|
2021-07-12 00:34:56 +02:00
|
|
|
if err != nil {
|
|
|
|
log.Errorln(err)
|
|
|
|
return emojiCache
|
|
|
|
}
|
|
|
|
for _, f := range files {
|
|
|
|
name := strings.TrimSuffix(f.Name(), path.Ext(f.Name()))
|
2021-08-14 21:48:04 +02:00
|
|
|
emojiPath := filepath.Join(config.EmojiDir, f.Name())
|
2022-05-26 18:59:16 -07:00
|
|
|
singleEmoji := models.CustomEmoji{Name: name, URL: emojiPath}
|
2021-07-12 00:34:56 +02:00
|
|
|
emojiCache = append(emojiCache, singleEmoji)
|
|
|
|
}
|
|
|
|
|
|
|
|
emojiCacheTimestamp = emojiDirInfo.ModTime()
|
2020-08-12 21:56:41 -07:00
|
|
|
}
|
|
|
|
|
2021-07-12 00:34:56 +02:00
|
|
|
return emojiCache
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetCustomEmoji returns a list of custom emoji via the API.
|
|
|
|
func GetCustomEmoji(w http.ResponseWriter, r *http.Request) {
|
|
|
|
emojiList := getCustomEmojiList()
|
|
|
|
|
2020-11-14 18:39:53 -08:00
|
|
|
if err := json.NewEncoder(w).Encode(emojiList); err != nil {
|
2021-02-18 23:05:52 -08:00
|
|
|
InternalErrorHandler(w, err)
|
2020-11-14 18:39:53 -08:00
|
|
|
}
|
2020-08-12 21:56:41 -07:00
|
|
|
}
|