util.go 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. package main
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "github.com/coreos/etcd/web"
  6. "io"
  7. "log"
  8. "net/http"
  9. "os"
  10. )
  11. //--------------------------------------
  12. // Web Helper
  13. //--------------------------------------
  14. var storeMsg chan string
  15. // Help to send msg from store to webHub
  16. func webHelper() {
  17. storeMsg = make(chan string)
  18. etcdStore.SetMessager(storeMsg)
  19. for {
  20. // transfer the new msg to webHub
  21. web.Hub().Send(<-storeMsg)
  22. }
  23. }
  24. //--------------------------------------
  25. // HTTP Utilities
  26. //--------------------------------------
  27. func decodeJsonRequest(req *http.Request, data interface{}) error {
  28. decoder := json.NewDecoder(req.Body)
  29. if err := decoder.Decode(&data); err != nil && err != io.EOF {
  30. warnf("Malformed json request: %v", err)
  31. return fmt.Errorf("Malformed json request: %v", err)
  32. }
  33. return nil
  34. }
  35. func encodeJsonResponse(w http.ResponseWriter, status int, data interface{}) {
  36. w.Header().Set("Content-Type", "application/json")
  37. w.WriteHeader(status)
  38. if data != nil {
  39. encoder := json.NewEncoder(w)
  40. encoder.Encode(data)
  41. }
  42. }
  43. //--------------------------------------
  44. // Log
  45. //--------------------------------------
  46. var logger *log.Logger
  47. func init() {
  48. logger = log.New(os.Stdout, "[etcd] ", log.Lmicroseconds)
  49. }
  50. func debugf(msg string, v ...interface{}) {
  51. if verbose {
  52. logger.Printf("DEBUG "+msg+"\n", v...)
  53. }
  54. }
  55. func debug(v ...interface{}) {
  56. if verbose {
  57. logger.Println("DEBUG " + fmt.Sprint(v...))
  58. }
  59. }
  60. func warnf(msg string, v ...interface{}) {
  61. logger.Printf("WARN "+msg+"\n", v...)
  62. }
  63. func warn(v ...interface{}) {
  64. logger.Println("WARN " + fmt.Sprint(v...))
  65. }
  66. func fatalf(msg string, v ...interface{}) {
  67. logger.Printf("FATAL "+msg+"\n", v...)
  68. os.Exit(1)
  69. }
  70. func fatal(v ...interface{}) {
  71. logger.Println("FATAL " + fmt.Sprint(v...))
  72. os.Exit(1)
  73. }