dispatch.go 972 B

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. package v1
  2. // Dispatch the command to leader.
  3. func dispatchCommand(c Command, w http.ResponseWriter, req *http.Request) error {
  4. return dispatch(c, w, req, nameToEtcdURL)
  5. }
  6. // Dispatches a command to a given URL.
  7. func dispatch(c Command, w http.ResponseWriter, req *http.Request, toURL func(name string) (string, bool)) error {
  8. r := e.raftServer
  9. if r.State() == raft.Leader {
  10. if event, err := r.Do(c); err != nil {
  11. return err
  12. } else {
  13. if event == nil {
  14. return etcdErr.NewError(300, "Empty result from raft", store.UndefIndex, store.UndefTerm)
  15. }
  16. event, _ := event.(*store.Event)
  17. response := eventToResponse(event)
  18. bytes, _ := json.Marshal(response)
  19. w.WriteHeader(http.StatusOK)
  20. w.Write(bytes)
  21. return nil
  22. }
  23. } else {
  24. leader := r.Leader()
  25. // current no leader
  26. if leader == "" {
  27. return etcdErr.NewError(300, "", store.UndefIndex, store.UndefTerm)
  28. }
  29. url, _ := toURL(leader)
  30. redirect(url, w, req)
  31. return nil
  32. }
  33. }