mirror of
https://github.com/etcd-io/etcd.git
synced 2024-09-27 06:25:44 +00:00
90 lines
1.8 KiB
Go
90 lines
1.8 KiB
Go
package main
|
|
|
|
import (
|
|
"encoding/json"
|
|
"fmt"
|
|
"github.com/coreos/etcd/web"
|
|
"io"
|
|
"log"
|
|
"net/http"
|
|
"os"
|
|
)
|
|
|
|
//--------------------------------------
|
|
// Web Helper
|
|
//--------------------------------------
|
|
var storeMsg chan string
|
|
|
|
// Help to send msg from store to webHub
|
|
func webHelper() {
|
|
storeMsg = make(chan string)
|
|
etcdStore.SetMessager(storeMsg)
|
|
for {
|
|
// transfer the new msg to webHub
|
|
web.Hub().Send(<-storeMsg)
|
|
}
|
|
}
|
|
|
|
//--------------------------------------
|
|
// HTTP Utilities
|
|
//--------------------------------------
|
|
|
|
func decodeJsonRequest(req *http.Request, data interface{}) error {
|
|
decoder := json.NewDecoder(req.Body)
|
|
if err := decoder.Decode(&data); err != nil && err != io.EOF {
|
|
warnf("Malformed json request: %v", err)
|
|
return fmt.Errorf("Malformed json request: %v", err)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func encodeJsonResponse(w http.ResponseWriter, status int, data interface{}) {
|
|
w.Header().Set("Content-Type", "application/json")
|
|
w.WriteHeader(status)
|
|
|
|
if data != nil {
|
|
encoder := json.NewEncoder(w)
|
|
encoder.Encode(data)
|
|
}
|
|
}
|
|
|
|
//--------------------------------------
|
|
// Log
|
|
//--------------------------------------
|
|
|
|
var logger *log.Logger
|
|
|
|
func init() {
|
|
logger = log.New(os.Stdout, "[etcd] ", log.Lmicroseconds)
|
|
}
|
|
|
|
func debugf(msg string, v ...interface{}) {
|
|
if verbose {
|
|
logger.Printf("DEBUG "+msg+"\n", v...)
|
|
}
|
|
}
|
|
|
|
func debug(v ...interface{}) {
|
|
if verbose {
|
|
logger.Println("DEBUG " + fmt.Sprint(v...))
|
|
}
|
|
}
|
|
|
|
func warnf(msg string, v ...interface{}) {
|
|
logger.Printf("WARN "+msg+"\n", v...)
|
|
}
|
|
|
|
func warn(v ...interface{}) {
|
|
logger.Println("WARN " + fmt.Sprint(v...))
|
|
}
|
|
|
|
func fatalf(msg string, v ...interface{}) {
|
|
logger.Printf("FATAL "+msg+"\n", v...)
|
|
os.Exit(1)
|
|
}
|
|
|
|
func fatal(v ...interface{}) {
|
|
logger.Println("FATAL " + fmt.Sprint(v...))
|
|
os.Exit(1)
|
|
}
|