Support listening on unix socket
This commit is contained in:
parent
4e54219efb
commit
fb8fa61546
39
main.go
39
main.go
@ -7,6 +7,7 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"log"
|
"log"
|
||||||
|
"net"
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
"os"
|
||||||
"path"
|
"path"
|
||||||
@ -29,13 +30,19 @@ func main() {
|
|||||||
log.Panicln("CHKBOT_API_TOKEN is empty")
|
log.Panicln("CHKBOT_API_TOKEN is empty")
|
||||||
}
|
}
|
||||||
|
|
||||||
port := func() int {
|
port, unixSocketPath := func() (int, string) {
|
||||||
portStr := os.Getenv("CHKBOT_PORT")
|
portStr := os.Getenv("CHKBOT_PORT")
|
||||||
|
|
||||||
if port, err := strconv.Atoi(portStr); err == nil {
|
defaultPort := 28923
|
||||||
return port
|
|
||||||
|
if strings.HasPrefix(portStr, "unix/") {
|
||||||
|
return defaultPort, strings.TrimPrefix(portStr, "unix/")
|
||||||
}
|
}
|
||||||
return 28923
|
|
||||||
|
if port, err := strconv.Atoi(portStr); err == nil {
|
||||||
|
return port, ""
|
||||||
|
}
|
||||||
|
return defaultPort, ""
|
||||||
}()
|
}()
|
||||||
|
|
||||||
dataPath := func() string {
|
dataPath := func() string {
|
||||||
@ -45,7 +52,7 @@ func main() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if err := os.MkdirAll(dataPath, 0755); err != nil {
|
if err := os.MkdirAll(dataPath, 0755); err != nil {
|
||||||
log.Panicf("Failed to create datapath, path: %s, err: %s\n", dataPath, err)
|
log.Panicf("Failed to create datapath, path: %q, err: %s\n", dataPath, err)
|
||||||
}
|
}
|
||||||
return dataPath
|
return dataPath
|
||||||
}()
|
}()
|
||||||
@ -63,7 +70,14 @@ func main() {
|
|||||||
return "unknown"
|
return "unknown"
|
||||||
}()
|
}()
|
||||||
|
|
||||||
log.Printf("Grocery List bot (%s) starting with datapath:%s, port:%d\n", commit, dataPath, port)
|
listeningOn := func() string {
|
||||||
|
if unixSocketPath != "" {
|
||||||
|
return fmt.Sprintf("socket: %q", unixSocketPath)
|
||||||
|
}
|
||||||
|
return fmt.Sprintf("port: %v", port)
|
||||||
|
}()
|
||||||
|
|
||||||
|
log.Printf("Grocery List bot (%s) starting with datapath: %q, %s\n", commit, dataPath, listeningOn)
|
||||||
|
|
||||||
var chats sync.Map
|
var chats sync.Map
|
||||||
if err := loadData(dataPath, &chats); err != nil {
|
if err := loadData(dataPath, &chats); err != nil {
|
||||||
@ -123,7 +137,7 @@ func main() {
|
|||||||
chatID := update.CallbackQuery.Message.Chat.ID
|
chatID := update.CallbackQuery.Message.Chat.ID
|
||||||
g, ok := chats.Load(chatID)
|
g, ok := chats.Load(chatID)
|
||||||
if !ok {
|
if !ok {
|
||||||
log.Printf("Chat not found: %d\n", chatID)
|
log.Printf("Chat not found: %v\n", chatID)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
gl := g.(*glist.GList)
|
gl := g.(*glist.GList)
|
||||||
@ -131,6 +145,13 @@ func main() {
|
|||||||
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
if unixSocketPath != "" {
|
||||||
|
l, err := net.Listen("unix", unixSocketPath)
|
||||||
|
if err != nil {
|
||||||
|
log.Panicf("Unable to listen to unix socket in path: %q err:%v\n", unixSocketPath, err)
|
||||||
|
}
|
||||||
|
log.Panicln(http.Serve(l, nil))
|
||||||
|
}
|
||||||
log.Panicln(http.ListenAndServe(fmt.Sprintf(":%v", port), nil))
|
log.Panicln(http.ListenAndServe(fmt.Sprintf(":%v", port), nil))
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -276,11 +297,11 @@ func loadData(dataPath string, chats *sync.Map) error {
|
|||||||
var gl glist.GList
|
var gl glist.GList
|
||||||
data, err := os.ReadFile(path.Join(dataPath, name))
|
data, err := os.ReadFile(path.Join(dataPath, name))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("failed read file, name: %s, err:%w", name, err)
|
return fmt.Errorf("failed read file, name: %q, err:%w", name, err)
|
||||||
}
|
}
|
||||||
err = json.Unmarshal(data, &gl)
|
err = json.Unmarshal(data, &gl)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("failed to parse data, data:%s, err:%w", data, err)
|
return fmt.Errorf("failed to parse data, data:%q, err:%w", data, err)
|
||||||
}
|
}
|
||||||
chats.Store(gl.ChatID, &gl)
|
chats.Store(gl.ChatID, &gl)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user