Add router handler
This commit is contained in:
		
							
								
								
									
										180
									
								
								network/router/handler/router.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										180
									
								
								network/router/handler/router.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,180 @@ | ||||
| package handler | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| 	"io" | ||||
| 	"time" | ||||
|  | ||||
| 	"github.com/micro/go-micro/errors" | ||||
| 	"github.com/micro/go-micro/network/router" | ||||
| 	pb "github.com/micro/go-micro/network/router/proto" | ||||
| ) | ||||
|  | ||||
| // Router implements router handler | ||||
| type Router struct { | ||||
| 	Router  router.Router | ||||
| } | ||||
|  | ||||
| // Lookup looks up routes in the routing table and returns them | ||||
| func (r *Router) Lookup(ctx context.Context, req *pb.LookupRequest, resp *pb.LookupResponse) error { | ||||
| 	query := router.NewQuery( | ||||
| 		router.QueryService(req.Query.Service), | ||||
| 	) | ||||
|  | ||||
| 	routes, err := r.Router.Lookup(query) | ||||
| 	if err != nil { | ||||
| 		return errors.InternalServerError("go.micro.router", "failed to lookup routes: %v", err) | ||||
| 	} | ||||
|  | ||||
| 	var respRoutes []*pb.Route | ||||
| 	for _, route := range routes { | ||||
| 		respRoute := &pb.Route{ | ||||
| 			Service: route.Service, | ||||
| 			Address: route.Address, | ||||
| 			Gateway: route.Gateway, | ||||
| 			Network: route.Network, | ||||
| 			Link:    route.Link, | ||||
| 			Metric:  int64(route.Metric), | ||||
| 		} | ||||
| 		respRoutes = append(respRoutes, respRoute) | ||||
| 	} | ||||
|  | ||||
| 	resp.Routes = respRoutes | ||||
|  | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (r *Router) Advertise(ctx context.Context, req *pb.AdvertiseRequest, stream pb.Router_AdvertiseStream) error { | ||||
| 	advertChan, err := r.Router.Advertise() | ||||
| 	if err != nil { | ||||
| 		return errors.InternalServerError("go.micro.router", "failed to get adverts: %v", err) | ||||
| 	} | ||||
|  | ||||
| 	for advert := range advertChan { | ||||
| 		var events []*pb.Event | ||||
| 		for _, event := range advert.Events { | ||||
| 			route := &pb.Route{ | ||||
| 				Service: event.Route.Service, | ||||
| 				Address: event.Route.Address, | ||||
| 				Gateway: event.Route.Gateway, | ||||
| 				Network: event.Route.Network, | ||||
| 				Link:    event.Route.Link, | ||||
| 				Metric:  int64(event.Route.Metric), | ||||
| 			} | ||||
| 			e := &pb.Event{ | ||||
| 				Type:      pb.EventType(event.Type), | ||||
| 				Timestamp: event.Timestamp.UnixNano(), | ||||
| 				Route:     route, | ||||
| 			} | ||||
| 			events = append(events, e) | ||||
| 		} | ||||
|  | ||||
| 		advert := &pb.Advert{ | ||||
| 			Id:        advert.Id, | ||||
| 			Type:      pb.AdvertType(advert.Type), | ||||
| 			Timestamp: advert.Timestamp.UnixNano(), | ||||
| 			Events:    events, | ||||
| 		} | ||||
|  | ||||
| 		// send the advert | ||||
| 		err := stream.Send(advert) | ||||
| 		if err == io.EOF { | ||||
| 			return nil | ||||
| 		} | ||||
| 		if err != nil { | ||||
| 			return errors.InternalServerError("go.micro.router", "error sending message %v", err) | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (r *Router) Process(ctx context.Context, req *pb.Advert, rsp *pb.ProcessResponse) error { | ||||
| 	events := make([]*router.Event, len(req.Events)) | ||||
| 	for i, event := range req.Events { | ||||
| 		route := router.Route{ | ||||
| 			Service: event.Route.Service, | ||||
| 			Address: event.Route.Address, | ||||
| 			Gateway: event.Route.Gateway, | ||||
| 			Network: event.Route.Network, | ||||
| 			Link:    event.Route.Link, | ||||
| 			Metric:  int(event.Route.Metric), | ||||
| 		} | ||||
|  | ||||
| 		events[i] = &router.Event{ | ||||
| 			Type:      router.EventType(event.Type), | ||||
| 			Timestamp: time.Unix(0, event.Timestamp), | ||||
| 			Route:     route, | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	advert := &router.Advert{ | ||||
| 		Id:        req.Id, | ||||
| 		Type:      router.AdvertType(req.Type), | ||||
| 		Timestamp: time.Unix(0, req.Timestamp), | ||||
| 		TTL:       time.Duration(req.Ttl), | ||||
| 		Events:    events, | ||||
| 	} | ||||
|  | ||||
| 	if err := r.Router.Process(advert); err != nil { | ||||
| 		return errors.InternalServerError("go.micro.router", "error publishing advert: %v", err) | ||||
| 	} | ||||
|  | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (r *Router) Status(ctx context.Context, req *pb.Request, rsp *pb.StatusResponse) error { | ||||
| 	status := r.Router.Status() | ||||
|  | ||||
| 	rsp.Status = &pb.Status{ | ||||
| 		Code: status.Code.String(), | ||||
| 	} | ||||
|  | ||||
| 	if status.Error != nil { | ||||
| 		rsp.Status.Error = status.Error.Error() | ||||
| 	} | ||||
|  | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // Watch streans routing table events | ||||
| func (r *Router) Watch(ctx context.Context, req *pb.WatchRequest, stream pb.Router_WatchStream) error { | ||||
| 	watcher, err := r.Router.Watch() | ||||
| 	if err != nil { | ||||
| 		return errors.InternalServerError("go.micro.router", "failed creating event watcher: %v", err) | ||||
| 	} | ||||
|  | ||||
| 	defer stream.Close() | ||||
|  | ||||
| 	for { | ||||
| 		event, err := watcher.Next() | ||||
| 		if err == router.ErrWatcherStopped { | ||||
| 			break | ||||
| 		} | ||||
|  | ||||
| 		if err != nil { | ||||
| 			return errors.InternalServerError("go.micro.router", "error watching events: %v", err) | ||||
| 		} | ||||
|  | ||||
| 		route := &pb.Route{ | ||||
| 			Service: event.Route.Service, | ||||
| 			Address: event.Route.Address, | ||||
| 			Gateway: event.Route.Gateway, | ||||
| 			Network: event.Route.Network, | ||||
| 			Link:    event.Route.Link, | ||||
| 			Metric:  int64(event.Route.Metric), | ||||
| 		} | ||||
|  | ||||
| 		tableEvent := &pb.Event{ | ||||
| 			Type:      pb.EventType(event.Type), | ||||
| 			Timestamp: event.Timestamp.UnixNano(), | ||||
| 			Route:     route, | ||||
| 		} | ||||
|  | ||||
| 		if err := stream.Send(tableEvent); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	return nil | ||||
| } | ||||
							
								
								
									
										114
									
								
								network/router/handler/table.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										114
									
								
								network/router/handler/table.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,114 @@ | ||||
| package handler | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
|  | ||||
| 	"github.com/micro/go-micro/errors" | ||||
| 	"github.com/micro/go-micro/network/router" | ||||
| 	pb "github.com/micro/go-micro/network/router/proto" | ||||
| ) | ||||
|  | ||||
| type Table struct { | ||||
| 	Router router.Router | ||||
| } | ||||
|  | ||||
| func (t *Table) Create(ctx context.Context, route *pb.Route, resp *pb.CreateResponse) error { | ||||
| 	err := t.Router.Table().Create(router.Route{ | ||||
| 		Service: route.Service, | ||||
| 		Address: route.Address, | ||||
| 		Gateway: route.Gateway, | ||||
| 		Network: route.Network, | ||||
| 		Link:    route.Link, | ||||
| 		Metric:  int(route.Metric), | ||||
| 	}) | ||||
| 	if err != nil { | ||||
| 		return errors.InternalServerError("go.micro.router", "failed to create route: %s", err) | ||||
| 	} | ||||
|  | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (t *Table) Update(ctx context.Context, route *pb.Route, resp *pb.UpdateResponse) error { | ||||
| 	err := t.Router.Table().Update(router.Route{ | ||||
| 		Service: route.Service, | ||||
| 		Address: route.Address, | ||||
| 		Gateway: route.Gateway, | ||||
| 		Network: route.Network, | ||||
| 		Link:    route.Link, | ||||
| 		Metric:  int(route.Metric), | ||||
| 	}) | ||||
| 	if err != nil { | ||||
| 		return errors.InternalServerError("go.micro.router", "failed to update route: %s", err) | ||||
| 	} | ||||
|  | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (t *Table) Delete(ctx context.Context, route *pb.Route, resp *pb.DeleteResponse) error { | ||||
| 	err := t.Router.Table().Delete(router.Route{ | ||||
| 		Service: route.Service, | ||||
| 		Address: route.Address, | ||||
| 		Gateway: route.Gateway, | ||||
| 		Network: route.Network, | ||||
| 		Link:    route.Link, | ||||
| 		Metric:  int(route.Metric), | ||||
| 	}) | ||||
| 	if err != nil { | ||||
| 		return errors.InternalServerError("go.micro.router", "failed to delete route: %s", err) | ||||
| 	} | ||||
|  | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // List returns all routes in the routing table | ||||
| func (t *Table) List(ctx context.Context, req *pb.Request, resp *pb.ListResponse) error { | ||||
| 	routes, err := t.Router.Table().List() | ||||
| 	if err != nil { | ||||
| 		return errors.InternalServerError("go.micro.router", "failed to list routes: %s", err) | ||||
| 	} | ||||
|  | ||||
| 	var respRoutes []*pb.Route | ||||
| 	for _, route := range routes { | ||||
| 		respRoute := &pb.Route{ | ||||
| 			Service: route.Service, | ||||
| 			Address: route.Address, | ||||
| 			Gateway: route.Gateway, | ||||
| 			Network: route.Network, | ||||
| 			Link:    route.Link, | ||||
| 			Metric:  int64(route.Metric), | ||||
| 		} | ||||
| 		respRoutes = append(respRoutes, respRoute) | ||||
| 	} | ||||
|  | ||||
| 	resp.Routes = respRoutes | ||||
|  | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (t *Table) Query(ctx context.Context, req *pb.QueryRequest, resp *pb.QueryResponse) error { | ||||
| 	query := router.NewQuery( | ||||
| 		router.QueryService(req.Query.Service), | ||||
| 	) | ||||
|  | ||||
| 	routes, err := t.Router.Table().Query(query) | ||||
| 	if err != nil { | ||||
| 		return errors.InternalServerError("go.micro.router", "failed to lookup routes: %s", err) | ||||
| 	} | ||||
|  | ||||
| 	var respRoutes []*pb.Route | ||||
| 	for _, route := range routes { | ||||
| 		respRoute := &pb.Route{ | ||||
| 			Service: route.Service, | ||||
| 			Address: route.Address, | ||||
| 			Gateway: route.Gateway, | ||||
| 			Network: route.Network, | ||||
| 			Link:    route.Link, | ||||
| 			Metric:  int64(route.Metric), | ||||
| 		} | ||||
| 		respRoutes = append(respRoutes, respRoute) | ||||
| 	} | ||||
|  | ||||
| 	resp.Routes = respRoutes | ||||
|  | ||||
| 	return nil | ||||
| } | ||||
		Reference in New Issue
	
	Block a user