2017-11-17 22:49:01 +00:00
|
|
|
package rpc
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"google.golang.org/grpc"
|
|
|
|
"google.golang.org/grpc/codes"
|
2021-09-24 14:29:26 +00:00
|
|
|
"google.golang.org/grpc/status"
|
2021-10-12 07:25:13 +00:00
|
|
|
|
|
|
|
"github.com/woodpecker-ci/woodpecker/pipeline/rpc/proto"
|
2017-11-17 22:49:01 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// generate protobuffs
|
|
|
|
// protoc --go_out=plugins=grpc,import_path=proto:. *.proto
|
|
|
|
|
|
|
|
type healthClient struct {
|
|
|
|
client proto.HealthClient
|
|
|
|
conn *grpc.ClientConn
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewGrpcHealthClient returns a new grpc Client.
|
|
|
|
func NewGrpcHealthClient(conn *grpc.ClientConn) Health {
|
|
|
|
client := new(healthClient)
|
|
|
|
client.client = proto.NewHealthClient(conn)
|
|
|
|
client.conn = conn
|
|
|
|
return client
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *healthClient) Close() error {
|
|
|
|
return c.conn.Close()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *healthClient) Check(ctx context.Context) (bool, error) {
|
|
|
|
var res *proto.HealthCheckResponse
|
|
|
|
var err error
|
|
|
|
req := new(proto.HealthCheckRequest)
|
|
|
|
|
|
|
|
for {
|
|
|
|
res, err = c.client.Check(ctx, req)
|
|
|
|
if err == nil {
|
|
|
|
if res.GetStatus() == proto.HealthCheckResponse_SERVING {
|
|
|
|
return true, nil
|
|
|
|
}
|
|
|
|
return false, nil
|
|
|
|
}
|
2021-09-24 14:29:26 +00:00
|
|
|
switch status.Code(err) {
|
2017-11-17 22:49:01 +00:00
|
|
|
case
|
|
|
|
codes.Aborted,
|
|
|
|
codes.DataLoss,
|
|
|
|
codes.DeadlineExceeded,
|
|
|
|
codes.Internal,
|
|
|
|
codes.Unavailable:
|
|
|
|
// non-fatal errors
|
|
|
|
default:
|
|
|
|
return false, err
|
|
|
|
}
|
|
|
|
<-time.After(backoff)
|
|
|
|
}
|
|
|
|
}
|