mirror of
				https://github.com/go-gitea/gitea
				synced 2025-09-28 03:28:13 +00:00 
			
		
		
		
	feat(bots): move runner status update function to context
This commit is contained in:
		| @@ -18,7 +18,6 @@ import ( | |||||||
| 	"code.gitea.io/gitea/models/user" | 	"code.gitea.io/gitea/models/user" | ||||||
| 	"code.gitea.io/gitea/modules/json" | 	"code.gitea.io/gitea/modules/json" | ||||||
| 	"code.gitea.io/gitea/modules/log" | 	"code.gitea.io/gitea/modules/log" | ||||||
| 	"code.gitea.io/gitea/modules/timeutil" |  | ||||||
| 	runnerv1 "gitea.com/gitea/proto-go/runner/v1" | 	runnerv1 "gitea.com/gitea/proto-go/runner/v1" | ||||||
| 	"gitea.com/gitea/proto-go/runner/v1/runnerv1connect" | 	"gitea.com/gitea/proto-go/runner/v1/runnerv1connect" | ||||||
|  |  | ||||||
| @@ -129,8 +128,6 @@ func (s *Service) Register( | |||||||
| 	return res, nil | 	return res, nil | ||||||
| } | } | ||||||
|  |  | ||||||
| const runnerOnlineTimeDeltaSecs = 30 |  | ||||||
|  |  | ||||||
| // FetchTask assigns a task to the runner | // FetchTask assigns a task to the runner | ||||||
| func (s *Service) FetchTask( | func (s *Service) FetchTask( | ||||||
| 	ctx context.Context, | 	ctx context.Context, | ||||||
| @@ -138,21 +135,6 @@ func (s *Service) FetchTask( | |||||||
| ) (*connect.Response[runnerv1.FetchTaskResponse], error) { | ) (*connect.Response[runnerv1.FetchTaskResponse], error) { | ||||||
| 	runner := GetRunner(ctx) | 	runner := GetRunner(ctx) | ||||||
|  |  | ||||||
| 	// update runner online status |  | ||||||
| 	if runner.Status == runnerv1.RunnerStatus_RUNNER_STATUS_OFFLINE { |  | ||||||
| 		runner.LastOnline = timeutil.TimeStampNow() |  | ||||||
| 		runner.Status = runnerv1.RunnerStatus_RUNNER_STATUS_ACTIVE |  | ||||||
| 		if err := bots_model.UpdateRunner(ctx, runner, "last_online", "status"); err != nil { |  | ||||||
| 			log.Error("can't update runner status: %v", err) |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 	if timeutil.TimeStampNow()-runner.LastOnline >= runnerOnlineTimeDeltaSecs { |  | ||||||
| 		runner.LastOnline = timeutil.TimeStampNow() |  | ||||||
| 		if err := bots_model.UpdateRunner(ctx, runner, "last_online"); err != nil { |  | ||||||
| 			log.Error("can't update runner last_online: %v", err) |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	var task *runnerv1.Task | 	var task *runnerv1.Task | ||||||
| 	if t, ok, err := s.pickTask(ctx, runner); err != nil { | 	if t, ok, err := s.pickTask(ctx, runner); err != nil { | ||||||
| 		return nil, status.Errorf(codes.Internal, "pick task: %v", err) | 		return nil, status.Errorf(codes.Internal, "pick task: %v", err) | ||||||
|   | |||||||
| @@ -9,12 +9,17 @@ import ( | |||||||
| 	"strings" | 	"strings" | ||||||
|  |  | ||||||
| 	bots_model "code.gitea.io/gitea/models/bots" | 	bots_model "code.gitea.io/gitea/models/bots" | ||||||
|  | 	"code.gitea.io/gitea/modules/log" | ||||||
|  | 	"code.gitea.io/gitea/modules/timeutil" | ||||||
|  | 	runnerv1 "gitea.com/gitea/proto-go/runner/v1" | ||||||
|  |  | ||||||
| 	"github.com/bufbuild/connect-go" | 	"github.com/bufbuild/connect-go" | ||||||
| 	"google.golang.org/grpc/codes" | 	"google.golang.org/grpc/codes" | ||||||
| 	"google.golang.org/grpc/status" | 	"google.golang.org/grpc/status" | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | const runnerOnlineTimeDeltaSecs = 30 | ||||||
|  |  | ||||||
| var WithRunner = connect.WithInterceptors(connect.UnaryInterceptorFunc(func(unaryFunc connect.UnaryFunc) connect.UnaryFunc { | var WithRunner = connect.WithInterceptors(connect.UnaryInterceptorFunc(func(unaryFunc connect.UnaryFunc) connect.UnaryFunc { | ||||||
| 	return func(ctx context.Context, request connect.AnyRequest) (connect.AnyResponse, error) { | 	return func(ctx context.Context, request connect.AnyRequest) (connect.AnyResponse, error) { | ||||||
| 		if methodName(request) == "Register" { | 		if methodName(request) == "Register" { | ||||||
| @@ -28,6 +33,22 @@ var WithRunner = connect.WithInterceptors(connect.UnaryInterceptorFunc(func(unar | |||||||
| 			} | 			} | ||||||
| 			return nil, status.Error(codes.Internal, err.Error()) | 			return nil, status.Error(codes.Internal, err.Error()) | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|  | 		// update runner online status | ||||||
|  | 		if runner.Status == runnerv1.RunnerStatus_RUNNER_STATUS_OFFLINE { | ||||||
|  | 			runner.LastOnline = timeutil.TimeStampNow() | ||||||
|  | 			runner.Status = runnerv1.RunnerStatus_RUNNER_STATUS_ACTIVE | ||||||
|  | 			if err := bots_model.UpdateRunner(ctx, runner, "last_online", "status"); err != nil { | ||||||
|  | 				log.Error("can't update runner status: %v", err) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 		if timeutil.TimeStampNow()-runner.LastOnline >= runnerOnlineTimeDeltaSecs { | ||||||
|  | 			runner.LastOnline = timeutil.TimeStampNow() | ||||||
|  | 			if err := bots_model.UpdateRunner(ctx, runner, "last_online"); err != nil { | ||||||
|  | 				log.Error("can't update runner last_online: %v", err) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		ctx = context.WithValue(ctx, runnerCtxKey{}, runner) | 		ctx = context.WithValue(ctx, runnerCtxKey{}, runner) | ||||||
| 		return unaryFunc(ctx, request) | 		return unaryFunc(ctx, request) | ||||||
| 	} | 	} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user