Serve seconds

This commit is contained in:
Eden Kirin
2023-03-20 23:25:53 +01:00
parent 1876158d9d
commit 3776bdca24
21 changed files with 1373 additions and 44 deletions

View File

@ -5,12 +5,17 @@ import (
"fmt"
"log"
"net"
"time"
pb "serve_hours/stubs"
pb_get_currenttime "serve_hours/stubs/serve_currenttime"
pb_serve_hours "serve_hours/stubs/serve_hours"
"google.golang.org/grpc"
"google.golang.org/grpc/credentials/insecure"
)
const SERVE_CURRENTTIME_HOST = "localhost"
const SERVE_CURRENTTIME_PORT = 50000
const SERVE_HOURS_HOST = "localhost"
const SERVE_HOURS_PORT = 50001
const SERVE_MINUTES_HOST = "localhost"
@ -21,12 +26,53 @@ const SERVE_MILLISECONDS_HOST = "localhost"
const SERVE_MILLISECONDS_PORT = 50004
type grpc_server struct {
pb.UnimplementedServeHoursServer
pb_serve_hours.UnimplementedServeHoursServer
}
func (s *grpc_server) GetHours(ctx context.Context, in *pb.GetHoursRequest) (*pb.GetHoursResponse, error) {
log.Printf("Received timezone: %v", in.GetTimezone())
return &pb.GetHoursResponse{Hours: 123}, nil
type currentTimeResponse struct {
hours uint32
minutes uint32
seconds uint32
milliseconds uint32
formatted_time string
}
func GetCurrentTime(timezone string) currentTimeResponse {
conn, err := grpc.Dial(
fmt.Sprintf("%s:%d", SERVE_CURRENTTIME_HOST, SERVE_CURRENTTIME_PORT),
grpc.WithTransportCredentials(insecure.NewCredentials()),
)
if err != nil {
log.Fatalf("did not connect: %v", err)
}
defer conn.Close()
c := pb_get_currenttime.NewServeCurrentTimeServiceClient(conn)
// Contact the server and print out its response.
ctx, cancel := context.WithTimeout(context.Background(), time.Second)
defer cancel()
r, err := c.GetCurrentTime(
ctx,
&pb_get_currenttime.GetCurrentTimeRequest{Timezone: timezone},
)
if err != nil {
log.Fatalf("could not greet: %v", err)
}
result := currentTimeResponse{
hours: r.Hours,
minutes: r.Minutes,
seconds: r.Seconds,
milliseconds: r.Milliseconds,
formatted_time: r.FormattedTime,
}
return result
}
func (s *grpc_server) GetHours(ctx context.Context, in *pb_serve_hours.GetHoursRequest) (*pb_serve_hours.GetHoursResponse, error) {
timezone := in.GetTimezone()
current_time := GetCurrentTime(timezone)
return &pb_serve_hours.GetHoursResponse{Hours: current_time.hours}, nil
}
func serve() {
@ -34,10 +80,11 @@ func serve() {
if err != nil {
log.Fatalf("failed to listen: %v", err)
}
s := grpc.NewServer()
pb.RegisterServeHoursServer(s, &grpc_server{})
server := grpc.NewServer()
pb_serve_hours.RegisterServeHoursServer(server, &grpc_server{})
log.Printf("server listening at %v", lis.Addr())
if err := s.Serve(lis); err != nil {
if err := server.Serve(lis); err != nil {
log.Fatalf("failed to serve: %v", err)
}
}