mirror of
https://github.com/go-gitea/gitea.git
synced 2025-07-22 21:35:21 +02:00
chore(runner): register new runner
Signed-off-by: Bo-Yi.Wu <appleboy.tw@gmail.com>
This commit is contained in:
parent
e21c07cc55
commit
ade88b3a7b
@ -43,7 +43,7 @@ type Runner struct {
|
|||||||
Description string `xorm:"TEXT"`
|
Description string `xorm:"TEXT"`
|
||||||
Base int // 0 native 1 docker 2 virtual machine
|
Base int // 0 native 1 docker 2 virtual machine
|
||||||
RepoRange string // glob match which repositories could use this runner
|
RepoRange string // glob match which repositories could use this runner
|
||||||
Token string
|
Token string `xorm:"CHAR(36) UNIQUE"`
|
||||||
|
|
||||||
// instance status (idle)
|
// instance status (idle)
|
||||||
Status core.RunnerStatus
|
Status core.RunnerStatus
|
||||||
@ -148,7 +148,7 @@ func GetRunnerByToken(token string) (*Runner, error) {
|
|||||||
return nil, err
|
return nil, err
|
||||||
} else if !has {
|
} else if !has {
|
||||||
return nil, ErrRunnerNotExist{
|
return nil, ErrRunnerNotExist{
|
||||||
UUID: "",
|
Token: token,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return &runner, nil
|
return &runner, nil
|
||||||
@ -177,3 +177,9 @@ func FindRunnersByRepoID(repoID int64) ([]*Runner, error) {
|
|||||||
err = db.GetEngine(db.DefaultContext).Join("INNER", "repository", "repository.owner_id = bot_runner.owner_id").Find(&runners)
|
err = db.GetEngine(db.DefaultContext).Join("INNER", "repository", "repository.owner_id = bot_runner.owner_id").Find(&runners)
|
||||||
return runners, err
|
return runners, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// NewRunner creates new runner.
|
||||||
|
func NewRunner(ctx context.Context, t *Runner) error {
|
||||||
|
_, err := db.GetEngine(ctx).Insert(t)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
@ -5,6 +5,9 @@
|
|||||||
package bots
|
package bots
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
|
"fmt"
|
||||||
|
|
||||||
"code.gitea.io/gitea/models/db"
|
"code.gitea.io/gitea/models/db"
|
||||||
repo_model "code.gitea.io/gitea/models/repo"
|
repo_model "code.gitea.io/gitea/models/repo"
|
||||||
user_model "code.gitea.io/gitea/models/user"
|
user_model "code.gitea.io/gitea/models/user"
|
||||||
@ -14,14 +17,24 @@ import (
|
|||||||
gouuid "github.com/google/uuid"
|
gouuid "github.com/google/uuid"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// ErrRunnerNotExist represents an error for bot runner not exist
|
||||||
|
type ErrRunnerTokenNotExist struct {
|
||||||
|
Token string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (err ErrRunnerTokenNotExist) Error() string {
|
||||||
|
return fmt.Sprintf("runner token [%s] is not exist", err.Token)
|
||||||
|
}
|
||||||
|
|
||||||
// RunnerToken represents runner tokens
|
// RunnerToken represents runner tokens
|
||||||
type RunnerToken struct {
|
type RunnerToken struct {
|
||||||
ID int64
|
ID int64
|
||||||
Token string `xorm:"CHAR(36) UNIQUE"`
|
Token string `xorm:"CHAR(36) UNIQUE"`
|
||||||
OwnerID int64 `xorm:"index"` // org level runner, 0 means system
|
OwnerID int64 `xorm:"index"` // org level runner, 0 means system
|
||||||
Owner *user_model.User `xorm:"-"`
|
Owner *user_model.User `xorm:"-"`
|
||||||
RepoID int64 `xorm:"index"` // repo level runner, if orgid also is zero, then it's a global
|
RepoID int64 `xorm:"index"` // repo level runner, if orgid also is zero, then it's a global
|
||||||
Repo *repo_model.Repository `xorm:"-"`
|
Repo *repo_model.Repository `xorm:"-"`
|
||||||
|
IsActive bool
|
||||||
|
|
||||||
CreatedUnix timeutil.TimeStamp `xorm:"INDEX created"`
|
CreatedUnix timeutil.TimeStamp `xorm:"INDEX created"`
|
||||||
UpdatedUnix timeutil.TimeStamp `xorm:"INDEX updated"`
|
UpdatedUnix timeutil.TimeStamp `xorm:"INDEX updated"`
|
||||||
@ -35,9 +48,35 @@ func init() {
|
|||||||
db.RegisterModel(new(RunnerToken))
|
db.RegisterModel(new(RunnerToken))
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewAccessToken creates new access token.
|
// NewRunnerToken creates new runner token.
|
||||||
func NewRunnerToken(t *RunnerToken) error {
|
func NewRunnerToken(t *RunnerToken) error {
|
||||||
t.Token = base.EncodeSha1(gouuid.New().String())
|
t.Token = base.EncodeSha1(gouuid.New().String())
|
||||||
_, err := db.GetEngine(db.DefaultContext).Insert(t)
|
_, err := db.GetEngine(db.DefaultContext).Insert(t)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetRunnerByToken returns a bot runner via token
|
||||||
|
func GetRunnerToken(token string) (*RunnerToken, error) {
|
||||||
|
var runnerToken RunnerToken
|
||||||
|
has, err := db.GetEngine(db.DefaultContext).Where("token=?", token).Get(&runnerToken)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
} else if !has {
|
||||||
|
return nil, ErrRunnerTokenNotExist{
|
||||||
|
Token: token,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return &runnerToken, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// UpdateRunnerToken updates runner token information.
|
||||||
|
func UpdateRunnerToken(ctx context.Context, r *RunnerToken, cols ...string) (err error) {
|
||||||
|
e := db.GetEngine(ctx)
|
||||||
|
|
||||||
|
if len(cols) == 0 {
|
||||||
|
_, err = e.ID(r.ID).AllCols().Update(r)
|
||||||
|
} else {
|
||||||
|
_, err = e.ID(r.ID).Cols(cols...).Update(r)
|
||||||
|
}
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
@ -15,6 +15,7 @@ import (
|
|||||||
"gitea.com/gitea/proto-go/runner/v1/runnerv1connect"
|
"gitea.com/gitea/proto-go/runner/v1/runnerv1connect"
|
||||||
|
|
||||||
"github.com/bufbuild/connect-go"
|
"github.com/bufbuild/connect-go"
|
||||||
|
gouuid "github.com/google/uuid"
|
||||||
)
|
)
|
||||||
|
|
||||||
var _ runnerv1connect.RunnerServiceClient = (*Service)(nil)
|
var _ runnerv1connect.RunnerServiceClient = (*Service)(nil)
|
||||||
@ -30,33 +31,49 @@ func (s *Service) Register(
|
|||||||
ctx context.Context,
|
ctx context.Context,
|
||||||
req *connect.Request[runnerv1.RegisterRequest],
|
req *connect.Request[runnerv1.RegisterRequest],
|
||||||
) (*connect.Response[runnerv1.RegisterResponse], error) {
|
) (*connect.Response[runnerv1.RegisterResponse], error) {
|
||||||
log.Info("Request headers: %v", req.Header())
|
if req.Msg.Token == "" || req.Msg.Name == "" {
|
||||||
|
return nil, errors.New("missing runner token or name")
|
||||||
token := req.Header().Get("X-Runner-Token")
|
|
||||||
log.Info("token: %v", token)
|
|
||||||
|
|
||||||
if token == "" {
|
|
||||||
return nil, errors.New("missing runner token")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: Get token data from runner_token table
|
runnerToken, err := bots_model.GetRunnerToken(req.Msg.Token)
|
||||||
runner, err := bots_model.GetRunnerByToken(token)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, errors.New("runner not found")
|
return nil, errors.New("runner token not found")
|
||||||
}
|
}
|
||||||
|
|
||||||
// update runner information
|
if runnerToken.IsActive {
|
||||||
runner.AgentLabels = req.Msg.AgentLabels
|
return nil, errors.New("runner token has already activated")
|
||||||
runner.CustomLabels = req.Msg.CustomLabels
|
}
|
||||||
runner.Name = req.Msg.Name
|
|
||||||
if err := bots_model.UpdateRunner(ctx, runner, []string{"name", "agent_labels", "custom_labels"}...); err != nil {
|
// create new runner
|
||||||
return nil, errors.New("can't update runner")
|
runner := &bots_model.Runner{
|
||||||
|
UUID: gouuid.New().String(),
|
||||||
|
Name: req.Msg.Name,
|
||||||
|
OwnerID: runnerToken.OwnerID,
|
||||||
|
RepoID: runnerToken.RepoID,
|
||||||
|
Token: req.Msg.Token,
|
||||||
|
Status: core.StatusOffline,
|
||||||
|
AgentLabels: req.Msg.AgentLabels,
|
||||||
|
CustomLabels: req.Msg.CustomLabels,
|
||||||
|
}
|
||||||
|
|
||||||
|
// create new runner
|
||||||
|
if err := bots_model.NewRunner(ctx, runner); err != nil {
|
||||||
|
return nil, errors.New("can't create new runner")
|
||||||
|
}
|
||||||
|
|
||||||
|
// update token status
|
||||||
|
runnerToken.IsActive = true
|
||||||
|
if err := bots_model.UpdateRunnerToken(ctx, runnerToken, "is_active"); err != nil {
|
||||||
|
return nil, errors.New("can't update runner token status")
|
||||||
}
|
}
|
||||||
|
|
||||||
res := connect.NewResponse(&runnerv1.RegisterResponse{
|
res := connect.NewResponse(&runnerv1.RegisterResponse{
|
||||||
Runner: &runnerv1.Runner{
|
Runner: &runnerv1.Runner{
|
||||||
Uuid: runner.UUID,
|
Uuid: runner.UUID,
|
||||||
Token: runner.Token,
|
Token: runner.Token,
|
||||||
|
Name: runner.Name,
|
||||||
|
AgentLabels: runner.AgentLabels,
|
||||||
|
CustomLabels: runner.CustomLabels,
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user