| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202 | 
							- package transport
 
- import (
 
- 	"context"
 
- 	"encoding/json"
 
- 	"errors"
 
- 	"fmt"
 
- 	"github.com/go-kit/kit/log"
 
- 	"github.com/go-kit/kit/transport"
 
- 	kithttp "github.com/go-kit/kit/transport/http"
 
- 	"github.com/gorilla/mux"
 
- 	"github.com/longjoy/micro-go-course/section19/cargo/endpoint"
 
- 	"io/ioutil"
 
- 	"net/http"
 
- 	"os"
 
- )
 
- var (
 
- 	ErrorBadRequest = errors.New("invalid request parameter")
 
- )
 
- // MakeHttpHandler make http handler use mux
 
- func MakeHttpHandler(ctx context.Context, endpoints *endpoint.CargoEndpoints) http.Handler {
 
- 	r := mux.NewRouter()
 
- 	kitLog := log.NewLogfmtLogger(os.Stderr)
 
- 	kitLog = log.With(kitLog, "ts", log.DefaultTimestampUTC)
 
- 	kitLog = log.With(kitLog, "caller", log.DefaultCaller)
 
- 	options := []kithttp.ServerOption{
 
- 		kithttp.ServerErrorHandler(transport.NewLogErrorHandler(kitLog)),
 
- 		kithttp.ServerErrorEncoder(encodeError),
 
- 	}
 
- 	r.Methods("GET").Path("/locations").Handler(kithttp.NewServer(
 
- 		endpoints.LocationsEndpoint,
 
- 		decodeLocationsRequest,
 
- 		encodeJSONResponse,
 
- 		options...,
 
- 	))
 
- 	r.Methods("POST").Path("/incidents").Handler(kithttp.NewServer(
 
- 		endpoints.RegisterHandlingEventEndpoint,
 
- 		decodeRegisterHandlingEventRequest,
 
- 		encodeJSONResponse,
 
- 		options...,
 
- 	))
 
- 	r.Methods("POST").PathPrefix("/cargos").Path("/").Handler(kithttp.NewServer(
 
- 		endpoints.LoadCargoEndpoint,
 
- 		decodeLoadCargoRequest,
 
- 		encodeJSONResponse,
 
- 		options...,
 
- 	))
 
- 	r.Methods("POST").PathPrefix("/cargos").Path("/change_destination").Handler(kithttp.NewServer(
 
- 		endpoints.ChangeDestinationEndpoint,
 
- 		decodeChangeDestinationRequest,
 
- 		encodeJSONResponse,
 
- 		options...,
 
- 	))
 
- 	r.Methods("POST").PathPrefix("/cargos").Path("/").Handler(kithttp.NewServer(
 
- 		endpoints.AssignCargoToRouteEndpoint,
 
- 		decodeAssignCargoToRouteRequest,
 
- 		encodeJSONResponse,
 
- 		options...,
 
- 	))
 
- 	r.Methods("POST").PathPrefix("/cargos").Path("/assign_to_route").Handler(kithttp.NewServer(
 
- 		endpoints.BookCargoEndpoint,
 
- 		decodeBookCargoRequest,
 
- 		encodeJSONResponse,
 
- 		options...,
 
- 	))
 
- 	return r
 
- }
 
- // decodeHealthCheckRequest decode request
 
- func decodeLocationsRequest(ctx context.Context, r *http.Request) (interface{}, error) {
 
- 	return endpoint.LocationsRequest{}, nil
 
- }
 
- func decodeBookCargoRequest(_ context.Context, r *http.Request) (interface{}, error) {
 
- 	body, err := ioutil.ReadAll(r.Body)
 
- 	if err != nil {
 
- 		fmt.Printf("read body err, %v\n", err)
 
- 		return nil, err
 
- 	}
 
- 	println("json:", string(body))
 
- 	var bcr endpoint.BookCargoRequest
 
- 	if err = json.Unmarshal(body, &bcr); err != nil {
 
- 		fmt.Printf("Unmarshal err, %v\n", err)
 
- 		return nil, err
 
- 	}
 
- 	fmt.Printf("%+v", bcr)
 
- 	return &endpoint.BookCargoRequest{
 
- 		Origin:      bcr.Origin,
 
- 		Destination: bcr.Destination,
 
- 		Deadline:    bcr.Deadline,
 
- 	}, nil
 
- }
 
- func decodeAssignCargoToRouteRequest(_ context.Context, r *http.Request) (interface{}, error) {
 
- 	body, err := ioutil.ReadAll(r.Body)
 
- 	if err != nil {
 
- 		fmt.Printf("read body err, %v\n", err)
 
- 		return nil, err
 
- 	}
 
- 	println("json:", string(body))
 
- 	var acr endpoint.AssignCargoToRouteRequest
 
- 	if err = json.Unmarshal(body, &acr); err != nil {
 
- 		fmt.Printf("Unmarshal err, %v\n", err)
 
- 		return nil, err
 
- 	}
 
- 	fmt.Printf("%+v", acr)
 
- 	return &endpoint.AssignCargoToRouteRequest{
 
- 		Id:        acr.Id,
 
- 		Itinerary: acr.Itinerary,
 
- 	}, nil
 
- }
 
- func decodeLoadCargoRequest(_ context.Context, r *http.Request) (interface{}, error) {
 
- 	body, err := ioutil.ReadAll(r.Body)
 
- 	if err != nil {
 
- 		fmt.Printf("read body err, %v\n", err)
 
- 		return nil, err
 
- 	}
 
- 	println("json:", string(body))
 
- 	var lcr endpoint.LoadCargoRequest
 
- 	if err = json.Unmarshal(body, &lcr); err != nil {
 
- 		fmt.Printf("Unmarshal err, %v\n", err)
 
- 		return nil, err
 
- 	}
 
- 	fmt.Printf("%+v", lcr)
 
- 	return &endpoint.LoadCargoRequest{
 
- 		Id: lcr.Id,
 
- 	}, nil
 
- }
 
- func decodeChangeDestinationRequest(_ context.Context, r *http.Request) (interface{}, error) {
 
- 	body, err := ioutil.ReadAll(r.Body)
 
- 	if err != nil {
 
- 		fmt.Printf("read body err, %v\n", err)
 
- 		return nil, err
 
- 	}
 
- 	println("json:", string(body))
 
- 	var cdr endpoint.ChangeDestinationRequest
 
- 	if err = json.Unmarshal(body, &cdr); err != nil {
 
- 		fmt.Printf("Unmarshal err, %v\n", err)
 
- 		return nil, err
 
- 	}
 
- 	fmt.Printf("%+v", cdr)
 
- 	return &endpoint.ChangeDestinationRequest{
 
- 		Id:          cdr.Id,
 
- 		Destination: cdr.Destination,
 
- 	}, nil
 
- }
 
- func decodeRegisterHandlingEventRequest(_ context.Context, r *http.Request) (interface{}, error) {
 
- 	body, err := ioutil.ReadAll(r.Body)
 
- 	if err != nil {
 
- 		fmt.Printf("read body err, %v\n", err)
 
- 		return nil, err
 
- 	}
 
- 	println("json:", string(body))
 
- 	var rhe endpoint.RegisterHandlingEventRequest
 
- 	if err = json.Unmarshal(body, &rhe); err != nil {
 
- 		fmt.Printf("Unmarshal err, %v\n", err)
 
- 		return nil, err
 
- 	}
 
- 	fmt.Printf("%+v", rhe)
 
- 	return &endpoint.RegisterHandlingEventRequest{
 
- 		Id:           rhe.Id,
 
- 		Completed:    rhe.Completed,
 
- 		VoyageNumber: rhe.VoyageNumber,
 
- 		UnLocode:     rhe.UnLocode,
 
- 		EventType:    rhe.EventType,
 
- 	}, nil
 
- }
 
- func encodeJSONResponse(ctx context.Context, w http.ResponseWriter, response interface{}) error {
 
- 	w.Header().Set("Content-Type", "application/json;charset=utf-8")
 
- 	return json.NewEncoder(w).Encode(response)
 
- }
 
- func encodeError(_ context.Context, err error, w http.ResponseWriter) {
 
- 	w.Header().Set("Content-Type", "application/json; charset=utf-8")
 
- 	switch err {
 
- 	default:
 
- 		w.WriteHeader(http.StatusInternalServerError)
 
- 	}
 
- 	json.NewEncoder(w).Encode(map[string]interface{}{
 
- 		"error": err.Error(),
 
- 	})
 
- }
 
 
  |