mirror of
https://github.com/goharbor/harbor.git
synced 2024-11-25 03:35:21 +01:00
update robot creator database scheme (#20918)
Signed-off-by: wang yan <wangyan@vmware.com>
This commit is contained in:
parent
c5d2672360
commit
438d4c03bb
@ -7846,9 +7846,12 @@ definitions:
|
|||||||
type: array
|
type: array
|
||||||
items:
|
items:
|
||||||
$ref: '#/definitions/RobotPermission'
|
$ref: '#/definitions/RobotPermission'
|
||||||
creator:
|
creator_type:
|
||||||
type: string
|
type: string
|
||||||
description: The creator of the robot
|
description: The type of the robot creator, like local(harbor_user) or robot.
|
||||||
|
creator_ref:
|
||||||
|
type: integer
|
||||||
|
description: The reference of the robot creator, like the id of harbor user.
|
||||||
creation_time:
|
creation_time:
|
||||||
type: string
|
type: string
|
||||||
format: date-time
|
format: date-time
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Add new column creator for robot table to add a new column to record the creator of the robot
|
Add new column creator_ref and creator_type for robot table to record the creator information of the robot
|
||||||
*/
|
*/
|
||||||
ALTER TABLE robot ADD COLUMN IF NOT EXISTS creator varchar(255);
|
ALTER TABLE robot ADD COLUMN IF NOT EXISTS creator_ref integer default 0;
|
||||||
UPDATE robot SET creator = 'unknown' WHERE creator IS NULL;
|
ALTER TABLE robot ADD COLUMN IF NOT EXISTS creator_type varchar(255);
|
||||||
|
@ -133,7 +133,8 @@ func (d *controller) Create(ctx context.Context, r *Robot) (int64, string, error
|
|||||||
Duration: r.Duration,
|
Duration: r.Duration,
|
||||||
Salt: salt,
|
Salt: salt,
|
||||||
Visible: r.Visible,
|
Visible: r.Visible,
|
||||||
Creator: r.Creator,
|
CreatorRef: r.CreatorRef,
|
||||||
|
CreatorType: r.CreatorType,
|
||||||
}
|
}
|
||||||
robotID, err := d.robotMgr.Create(ctx, rCreate)
|
robotID, err := d.robotMgr.Create(ctx, rCreate)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -864,7 +864,8 @@ func (bc *basicController) makeRobotAccount(ctx context.Context, projectID int64
|
|||||||
Description: "for scan",
|
Description: "for scan",
|
||||||
ProjectID: projectID,
|
ProjectID: projectID,
|
||||||
Duration: -1,
|
Duration: -1,
|
||||||
Creator: "harbor-core-for-scan-all",
|
CreatorType: "local",
|
||||||
|
CreatorRef: int64(0),
|
||||||
},
|
},
|
||||||
Level: robot.LEVELPROJECT,
|
Level: robot.LEVELPROJECT,
|
||||||
Permissions: []*robot.Permission{
|
Permissions: []*robot.Permission{
|
||||||
|
@ -235,7 +235,8 @@ func (suite *ControllerTestSuite) SetupSuite() {
|
|||||||
Description: "for scan",
|
Description: "for scan",
|
||||||
ProjectID: suite.artifact.ProjectID,
|
ProjectID: suite.artifact.ProjectID,
|
||||||
Duration: -1,
|
Duration: -1,
|
||||||
Creator: "harbor-core-for-scan-all",
|
CreatorType: "local",
|
||||||
|
CreatorRef: int64(0),
|
||||||
},
|
},
|
||||||
Level: robot.LEVELPROJECT,
|
Level: robot.LEVELPROJECT,
|
||||||
Permissions: []*robot.Permission{
|
Permissions: []*robot.Permission{
|
||||||
@ -267,7 +268,8 @@ func (suite *ControllerTestSuite) SetupSuite() {
|
|||||||
Description: "for scan",
|
Description: "for scan",
|
||||||
ProjectID: suite.artifact.ProjectID,
|
ProjectID: suite.artifact.ProjectID,
|
||||||
Duration: -1,
|
Duration: -1,
|
||||||
Creator: "harbor-core-for-scan-all",
|
CreatorType: "local",
|
||||||
|
CreatorRef: int64(0),
|
||||||
},
|
},
|
||||||
Level: "project",
|
Level: "project",
|
||||||
}, nil)
|
}, nil)
|
||||||
|
@ -52,7 +52,8 @@ func (suite *DaoTestSuite) robots() {
|
|||||||
Description: "test3 description",
|
Description: "test3 description",
|
||||||
ProjectID: 1,
|
ProjectID: 1,
|
||||||
Secret: suite.RandString(10),
|
Secret: suite.RandString(10),
|
||||||
Creator: "tester",
|
CreatorType: "local",
|
||||||
|
CreatorRef: int64(1),
|
||||||
})
|
})
|
||||||
suite.Nil(err)
|
suite.Nil(err)
|
||||||
|
|
||||||
@ -121,7 +122,7 @@ func (suite *DaoTestSuite) TestGet() {
|
|||||||
r, err := suite.dao.Get(orm.Context(), suite.robotID3)
|
r, err := suite.dao.Get(orm.Context(), suite.robotID3)
|
||||||
suite.Nil(err)
|
suite.Nil(err)
|
||||||
suite.Equal("test3", r.Name)
|
suite.Equal("test3", r.Name)
|
||||||
suite.Equal("tester", r.Creator)
|
suite.Equal("local", r.CreatorType)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (suite *DaoTestSuite) TestCount() {
|
func (suite *DaoTestSuite) TestCount() {
|
||||||
|
@ -39,7 +39,8 @@ type Robot struct {
|
|||||||
ExpiresAt int64 `orm:"column(expiresat)" json:"expires_at"`
|
ExpiresAt int64 `orm:"column(expiresat)" json:"expires_at"`
|
||||||
Disabled bool `orm:"column(disabled)" json:"disabled"`
|
Disabled bool `orm:"column(disabled)" json:"disabled"`
|
||||||
Visible bool `orm:"column(visible)" json:"-"`
|
Visible bool `orm:"column(visible)" json:"-"`
|
||||||
Creator string `orm:"column(creator)" json:"creator"`
|
CreatorRef int64 `orm:"column(creator_ref)" json:"creator_ref"`
|
||||||
|
CreatorType string `orm:"column(creator_type)" json:"creator_type"`
|
||||||
CreationTime time.Time `orm:"column(creation_time);auto_now_add" json:"creation_time"`
|
CreationTime time.Time `orm:"column(creation_time);auto_now_add" json:"creation_time"`
|
||||||
UpdateTime time.Time `orm:"column(update_time);auto_now" json:"update_time"`
|
UpdateTime time.Time `orm:"column(update_time);auto_now" json:"update_time"`
|
||||||
}
|
}
|
||||||
|
@ -48,7 +48,8 @@ func (r *Robot) ToSwagger() *models.Robot {
|
|||||||
Level: r.Level,
|
Level: r.Level,
|
||||||
Disable: r.Disabled,
|
Disable: r.Disabled,
|
||||||
Editable: r.Editable,
|
Editable: r.Editable,
|
||||||
Creator: r.Creator,
|
CreatorType: r.CreatorType,
|
||||||
|
CreatorRef: r.CreatorRef,
|
||||||
CreationTime: strfmt.DateTime(r.CreationTime),
|
CreationTime: strfmt.DateTime(r.CreationTime),
|
||||||
UpdateTime: strfmt.DateTime(r.UpdateTime),
|
UpdateTime: strfmt.DateTime(r.UpdateTime),
|
||||||
Permissions: perms,
|
Permissions: perms,
|
||||||
|
@ -26,6 +26,8 @@ import (
|
|||||||
"github.com/go-openapi/strfmt"
|
"github.com/go-openapi/strfmt"
|
||||||
|
|
||||||
"github.com/goharbor/harbor/src/common/rbac"
|
"github.com/goharbor/harbor/src/common/rbac"
|
||||||
|
"github.com/goharbor/harbor/src/common/security/local"
|
||||||
|
robotSc "github.com/goharbor/harbor/src/common/security/robot"
|
||||||
"github.com/goharbor/harbor/src/common/utils"
|
"github.com/goharbor/harbor/src/common/utils"
|
||||||
"github.com/goharbor/harbor/src/controller/robot"
|
"github.com/goharbor/harbor/src/controller/robot"
|
||||||
"github.com/goharbor/harbor/src/lib"
|
"github.com/goharbor/harbor/src/lib"
|
||||||
@ -67,13 +69,24 @@ func (rAPI *robotAPI) CreateRobot(ctx context.Context, params operation.CreateRo
|
|||||||
return rAPI.SendError(ctx, err)
|
return rAPI.SendError(ctx, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var creatorRef int64
|
||||||
|
switch s := sc.(type) {
|
||||||
|
case *local.SecurityContext:
|
||||||
|
creatorRef = int64(s.User().UserID)
|
||||||
|
case *robotSc.SecurityContext:
|
||||||
|
creatorRef = s.User().ID
|
||||||
|
default:
|
||||||
|
return rAPI.SendError(ctx, errors.New(nil).WithMessage("invalid security context"))
|
||||||
|
}
|
||||||
|
|
||||||
r := &robot.Robot{
|
r := &robot.Robot{
|
||||||
Robot: pkg.Robot{
|
Robot: pkg.Robot{
|
||||||
Name: params.Robot.Name,
|
Name: params.Robot.Name,
|
||||||
Description: params.Robot.Description,
|
Description: params.Robot.Description,
|
||||||
Duration: params.Robot.Duration,
|
Duration: params.Robot.Duration,
|
||||||
Visible: true,
|
Visible: true,
|
||||||
Creator: sc.GetUsername(),
|
CreatorRef: creatorRef,
|
||||||
|
CreatorType: sc.Name(),
|
||||||
},
|
},
|
||||||
Level: params.Robot.Level,
|
Level: params.Robot.Level,
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user