6 "github.com/go-kit/kit/metrics"
8 "github.com/go-kit/kit/examples/shipping/cargo"
9 "github.com/go-kit/kit/examples/shipping/location"
12 type instrumentingService struct {
13 requestCount metrics.Counter
14 requestLatency metrics.Histogram
18 // NewInstrumentingService returns an instance of an instrumenting Service.
19 func NewInstrumentingService(counter metrics.Counter, latency metrics.Histogram, s Service) Service {
20 return &instrumentingService{
21 requestCount: counter,
22 requestLatency: latency,
27 func (s *instrumentingService) BookNewCargo(origin, destination location.UNLocode, deadline time.Time) (cargo.TrackingID, error) {
28 defer func(begin time.Time) {
29 s.requestCount.With("method", "book").Add(1)
30 s.requestLatency.With("method", "book").Observe(time.Since(begin).Seconds())
33 return s.Service.BookNewCargo(origin, destination, deadline)
36 func (s *instrumentingService) LoadCargo(id cargo.TrackingID) (c Cargo, err error) {
37 defer func(begin time.Time) {
38 s.requestCount.With("method", "load").Add(1)
39 s.requestLatency.With("method", "load").Observe(time.Since(begin).Seconds())
42 return s.Service.LoadCargo(id)
45 func (s *instrumentingService) RequestPossibleRoutesForCargo(id cargo.TrackingID) []cargo.Itinerary {
46 defer func(begin time.Time) {
47 s.requestCount.With("method", "request_routes").Add(1)
48 s.requestLatency.With("method", "request_routes").Observe(time.Since(begin).Seconds())
51 return s.Service.RequestPossibleRoutesForCargo(id)
54 func (s *instrumentingService) AssignCargoToRoute(id cargo.TrackingID, itinerary cargo.Itinerary) (err error) {
55 defer func(begin time.Time) {
56 s.requestCount.With("method", "assign_to_route").Add(1)
57 s.requestLatency.With("method", "assign_to_route").Observe(time.Since(begin).Seconds())
60 return s.Service.AssignCargoToRoute(id, itinerary)
63 func (s *instrumentingService) ChangeDestination(id cargo.TrackingID, l location.UNLocode) (err error) {
64 defer func(begin time.Time) {
65 s.requestCount.With("method", "change_destination").Add(1)
66 s.requestLatency.With("method", "change_destination").Observe(time.Since(begin).Seconds())
69 return s.Service.ChangeDestination(id, l)
72 func (s *instrumentingService) Cargos() []Cargo {
73 defer func(begin time.Time) {
74 s.requestCount.With("method", "list_cargos").Add(1)
75 s.requestLatency.With("method", "list_cargos").Observe(time.Since(begin).Seconds())
78 return s.Service.Cargos()
81 func (s *instrumentingService) Locations() []Location {
82 defer func(begin time.Time) {
83 s.requestCount.With("method", "list_locations").Add(1)
84 s.requestLatency.With("method", "list_locations").Observe(time.Since(begin).Seconds())
87 return s.Service.Locations()