diff options
-rw-r--r-- | handlers.go | 38 | ||||
-rw-r--r-- | main.go | 14 | ||||
-rw-r--r-- | types.go | 17 |
3 files changed, 69 insertions, 0 deletions
diff --git a/handlers.go b/handlers.go new file mode 100644 index 0000000..ce33716 --- /dev/null +++ b/handlers.go @@ -0,0 +1,38 @@ +package main + +import ( + "crypto/sha256" + "fmt" + "log" + "net/http" + "time" +) + +const textutf8 = "text/plain; charset=utf8" + +func validRequest(fn func(http.ResponseWriter, *http.Request, string)) http.HandlerFunc { + return func(w http.ResponseWriter, r *http.Request) { + m := confObj.validPath.FindStringSubmatch(r.URL.Path) + if m == nil { + log.Printf("Invalid API request: %v", r.URL.Path) + http.Error(w, fmt.Errorf(r.URL.Path).Error(), http.StatusNotFound) + return + } + fn(w, r, m[2]) + } +} + +func apiHandler(w http.ResponseWriter, r *http.Request) { + timerfc3339, err := time.Now().MarshalText() + if err != nil { + log.Printf("Couldn't format time as RFC3339: %v\n", err) + } + etag := fmt.Sprintf("%x", sha256.Sum256(timerfc3339)) + w.Header().Set("ETag", etag) + w.Header().Set("Content-Type", textutf8) + timerfc3339 = append(timerfc3339, byte('\n')) + n, err := w.Write(timerfc3339) + if err != nil || n == 0 { + log.Printf("Error writing to HTTP stream: %v\n", err) + } +} diff --git a/main.go b/main.go new file mode 100644 index 0000000..7477055 --- /dev/null +++ b/main.go @@ -0,0 +1,14 @@ +package main + +import ( + "log" + "net/http" +) + +func main() { + log.Printf("getwtxt v0.1\n") + + http.HandleFunc("/api", apiHandler) + + log.Fatalln(http.ListenAndServe(":666", nil)) +} diff --git a/types.go b/types.go new file mode 100644 index 0000000..a8f027a --- /dev/null +++ b/types.go @@ -0,0 +1,17 @@ +package main + +import "regexp" + +type configuration struct { + port string + validPath *regexp.Regexp + quietLogging bool + fileLogging bool + logFile string +} + +var confObj = &configuration{} + +func initConfig() { + confObj.validPath = regexp.MustCompile("^/(api)/(plain)/(tweets|users|tags|mentions)") +} |