This commit is contained in:
Emile Vauge
2016-06-30 10:51:39 +02:00
parent 4a4db8d195
commit 1362371fa1

28
app.go
View File

@ -2,8 +2,10 @@ package main
import ( import (
"encoding/json" "encoding/json"
"flag"
"fmt" "fmt"
"github.com/gorilla/websocket" "github.com/gorilla/websocket"
// "github.com/pkg/profile"
"log" "log"
"net" "net"
"net/http" "net/http"
@ -12,27 +14,41 @@ import (
"time" "time"
) )
var port string
func init() {
flag.StringVar(&port, "port", "80", "give me a port number")
}
var upgrader = websocket.Upgrader{ var upgrader = websocket.Upgrader{
ReadBufferSize: 1024, ReadBufferSize: 1024,
WriteBufferSize: 1024, WriteBufferSize: 1024,
} }
func main() { func main() {
// defer profile.Start().Stop()
flag.Parse()
http.HandleFunc("/echo", echoHandler) http.HandleFunc("/echo", echoHandler)
http.HandleFunc("/bench", benchHandler)
http.HandleFunc("/", whoamI) http.HandleFunc("/", whoamI)
http.HandleFunc("/api", api) http.HandleFunc("/api", api)
fmt.Println("Starting up on 80") fmt.Println("Starting up on port " + port)
log.Fatal(http.ListenAndServe(":80", nil)) log.Fatal(http.ListenAndServe(":"+port, nil))
} }
func print_binary(s []byte) { func printBinary(s []byte) {
fmt.Printf("Received b:") fmt.Printf("Received b:")
for n := 0; n < len(s); n++ { for n := 0; n < len(s); n++ {
fmt.Printf("%d,", s[n]) fmt.Printf("%d,", s[n])
} }
fmt.Printf("\n") fmt.Printf("\n")
} }
func benchHandler(w http.ResponseWriter, r *http.Request) {
// body := "Hello World\n"
w.Header().Set("Connection", "keep-alive")
w.Header().Set("Content-Type", "text/plain")
// fmt.Fprint(w, body)
}
func echoHandler(w http.ResponseWriter, r *http.Request) { func echoHandler(w http.ResponseWriter, r *http.Request) {
conn, err := upgrader.Upgrade(w, r, nil) conn, err := upgrader.Upgrade(w, r, nil)
if err != nil { if err != nil {
@ -44,7 +60,7 @@ func echoHandler(w http.ResponseWriter, r *http.Request) {
if err != nil { if err != nil {
return return
} }
print_binary(p) printBinary(p)
err = conn.WriteMessage(messageType, p) err = conn.WriteMessage(messageType, p)
if err != nil { if err != nil {
return return
@ -87,9 +103,11 @@ func api(w http.ResponseWriter, req *http.Request) {
data := struct { data := struct {
Hostname string `json:"hostname,omitempty"` Hostname string `json:"hostname,omitempty"`
IP []string `json:"ip,omitempty"` IP []string `json:"ip,omitempty"`
Headers http.Header `json:"headers,omitempty"`
}{ }{
hostname, hostname,
[]string{}, []string{},
req.Header,
} }
ifaces, _ := net.Interfaces() ifaces, _ := net.Interfaces()