spongy/spongy.cgi/spongy.cgi.go

108 lines
2.2 KiB
Go
Raw Normal View History

2014-07-14 19:30:47 -06:00
package main
import (
"fmt"
"log"
"strings"
2014-07-14 19:30:47 -06:00
"net/http"
"net/http/cgi"
2015-02-22 19:45:41 -07:00
"os"
2014-08-05 15:53:03 -06:00
"path"
2014-07-14 19:30:47 -06:00
)
type Handler struct {
cgi.Handler
}
2015-02-20 16:48:52 -07:00
func (h Handler) handleCommand(cfg *Config, w http.ResponseWriter, r *http.Request) {
network := r.FormValue("network")
text := r.FormValue("text")
target := r.FormValue("target")
2014-10-24 22:21:53 -06:00
2015-02-20 16:48:52 -07:00
nw := NewNetwork(path.Join(cfg.BaseDir, network))
2014-08-05 15:53:03 -06:00
2015-02-20 16:48:52 -07:00
var out string
2014-08-05 15:53:03 -06:00
switch {
case strings.HasPrefix(text, "/quote "):
2015-02-20 16:48:52 -07:00
out = text[7:]
2014-08-05 15:53:03 -06:00
case strings.HasPrefix(text, "/me "):
2015-02-20 16:48:52 -07:00
out = fmt.Sprintf("PRIVMSG %s :\001ACTION %s\001", target, text[4:])
2014-08-05 15:53:03 -06:00
default:
2015-02-20 16:48:52 -07:00
out = fmt.Sprintf("PRIVMSG %s :%s", target, text)
2014-08-05 15:53:03 -06:00
}
2015-02-20 16:48:52 -07:00
nw.Write([]byte(out))
2014-07-14 19:30:47 -06:00
fmt.Fprintln(w, "OK")
}
2014-08-12 23:21:19 -06:00
2015-02-20 16:48:52 -07:00
func (h Handler) handleTail(cfg *Config, w http.ResponseWriter, r *http.Request) {
2015-02-21 21:45:56 -07:00
w.Header().Set("Content-Type", "text/event-stream")
2015-02-20 16:48:52 -07:00
nws := Networks(cfg.BaseDir)
2014-10-24 22:21:53 -06:00
2015-02-22 16:06:22 -07:00
lastEventId := r.FormValue("HTTP_LAST_EVENT_ID")
2015-02-21 21:45:56 -07:00
updates := make(chan []string, 100)
2014-07-14 19:30:47 -06:00
2015-02-20 16:48:52 -07:00
for _, nw := range nws {
2015-02-22 16:06:22 -07:00
nw.ReadLastEventId(lastEventId)
2015-02-21 21:45:56 -07:00
go nw.Tail(updates)
defer nw.Close()
2014-08-12 22:59:18 -06:00
}
2014-08-05 16:35:51 -06:00
2015-02-21 21:45:56 -07:00
for lines := range updates {
for _, line := range lines {
fmt.Fprintf(w, "data: %s\n", line)
2014-08-05 16:35:51 -06:00
}
2014-10-24 22:21:53 -06:00
2015-02-21 21:45:56 -07:00
ids := make([]string, 0)
for _, nw := range nws {
ids = append(ids, nw.LastEventId())
2014-08-05 16:35:51 -06:00
}
2015-02-21 21:45:56 -07:00
idstring := strings.Join(ids, " ")
_, err := fmt.Fprintf(w, "id: %s\n\n", idstring)
2014-08-05 16:35:51 -06:00
if err != nil {
2015-02-21 21:45:56 -07:00
// Can't write anymore, guess they hung up.
return
2014-08-05 16:35:51 -06:00
}
w.(http.Flusher).Flush()
2014-07-14 19:30:47 -06:00
}
}
func (h Handler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
2015-02-20 16:48:52 -07:00
cfg, err := ReadConfig(h.Dir)
2014-07-14 19:30:47 -06:00
if err != nil {
2015-02-20 16:48:52 -07:00
http.Error(w, err.Error(), 500)
2014-07-14 19:30:47 -06:00
return
}
2014-08-05 15:53:03 -06:00
2015-02-20 16:48:52 -07:00
// Validate authtok
authtok, err := cfg.Get("authtok")
if err != nil {
http.Error(w, err.Error(), 500)
2015-02-21 17:37:00 -07:00
return
2014-08-12 21:41:54 -06:00
}
if r.FormValue("auth") != authtok {
w.Header().Set("Content-Type", "text/plain")
2014-10-24 23:24:49 -06:00
fmt.Fprintln(w, "NO: Invalid authtok")
return
}
2015-02-20 16:48:52 -07:00
// Switch based on type
2014-07-14 19:30:47 -06:00
switch r.FormValue("type") {
case "command":
2015-02-20 16:48:52 -07:00
h.handleCommand(cfg, w, r)
2014-07-14 19:30:47 -06:00
default:
2015-02-20 16:48:52 -07:00
h.handleTail(cfg, w, r)
2014-07-14 19:30:47 -06:00
}
}
func main() {
2015-02-22 19:44:09 -07:00
log.SetOutput(os.Stdout)
log.SetFlags(0)
log.SetPrefix("Status: 500 CGI Go Boom\nContent-type: text/plain\n\nERROR: ")
2014-07-14 19:30:47 -06:00
h := Handler{}
if err := cgi.Serve(h); err != nil {
log.Fatal(err)
}
}