util.go 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  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. "strconv"
  11. "time"
  12. )
  13. //--------------------------------------
  14. // etcd http Helper
  15. //--------------------------------------
  16. // Convert string duration to time format
  17. func durationToExpireTime(strDuration string) (time.Time, error) {
  18. if strDuration != "" {
  19. duration, err := strconv.Atoi(strDuration)
  20. if err != nil {
  21. return time.Unix(0, 0), err
  22. }
  23. return time.Now().Add(time.Second * (time.Duration)(duration)), nil
  24. } else {
  25. return time.Unix(0, 0), nil
  26. }
  27. }
  28. //--------------------------------------
  29. // Web Helper
  30. //--------------------------------------
  31. var storeMsg chan string
  32. // Help to send msg from store to webHub
  33. func webHelper() {
  34. storeMsg = make(chan string)
  35. etcdStore.SetMessager(storeMsg)
  36. for {
  37. // transfer the new msg to webHub
  38. web.Hub().Send(<-storeMsg)
  39. }
  40. }
  41. //--------------------------------------
  42. // HTTP Utilities
  43. //--------------------------------------
  44. func decodeJsonRequest(req *http.Request, data interface{}) error {
  45. decoder := json.NewDecoder(req.Body)
  46. if err := decoder.Decode(&data); err != nil && err != io.EOF {
  47. warnf("Malformed json request: %v", err)
  48. return fmt.Errorf("Malformed json request: %v", err)
  49. }
  50. return nil
  51. }
  52. func encodeJsonResponse(w http.ResponseWriter, status int, data interface{}) {
  53. w.Header().Set("Content-Type", "application/json")
  54. w.WriteHeader(status)
  55. if data != nil {
  56. encoder := json.NewEncoder(w)
  57. encoder.Encode(data)
  58. }
  59. }
  60. //--------------------------------------
  61. // Log
  62. //--------------------------------------
  63. var logger *log.Logger
  64. func init() {
  65. logger = log.New(os.Stdout, "[etcd] ", log.Lmicroseconds)
  66. }
  67. func debugf(msg string, v ...interface{}) {
  68. if verbose {
  69. logger.Printf("DEBUG "+msg+"\n", v...)
  70. }
  71. }
  72. func debug(v ...interface{}) {
  73. if verbose {
  74. logger.Println("DEBUG " + fmt.Sprint(v...))
  75. }
  76. }
  77. func warnf(msg string, v ...interface{}) {
  78. logger.Printf("WARN "+msg+"\n", v...)
  79. }
  80. func warn(v ...interface{}) {
  81. logger.Println("WARN " + fmt.Sprint(v...))
  82. }
  83. func fatalf(msg string, v ...interface{}) {
  84. logger.Printf("FATAL "+msg+"\n", v...)
  85. os.Exit(1)
  86. }
  87. func fatal(v ...interface{}) {
  88. logger.Println("FATAL " + fmt.Sprint(v...))
  89. os.Exit(1)
  90. }