2017-04-13 12:54:58 +02:00
|
|
|
// Copyright (c) 2017 VMware, Inc. All Rights Reserved.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
2016-02-26 11:54:14 +01:00
|
|
|
|
2016-02-01 12:59:10 +01:00
|
|
|
package models
|
|
|
|
|
|
|
|
import (
|
2017-09-29 10:37:43 +02:00
|
|
|
"strings"
|
2016-02-01 12:59:10 +01:00
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2017-12-21 13:07:23 +01:00
|
|
|
// ProjectTable is the table name for project
|
|
|
|
const ProjectTable = "project"
|
|
|
|
|
2016-02-26 11:13:13 +01:00
|
|
|
// Project holds the details of a project.
|
2016-02-01 12:59:10 +01:00
|
|
|
type Project struct {
|
2017-09-29 10:37:43 +02:00
|
|
|
ProjectID int64 `orm:"pk;auto;column(project_id)" json:"project_id"`
|
|
|
|
OwnerID int `orm:"column(owner_id)" json:"owner_id"`
|
|
|
|
Name string `orm:"column(name)" json:"name"`
|
|
|
|
CreationTime time.Time `orm:"column(creation_time)" json:"creation_time"`
|
2018-02-02 09:17:58 +01:00
|
|
|
UpdateTime time.Time `orm:"column(update_time)" json:"update_time"`
|
2017-09-29 10:37:43 +02:00
|
|
|
Deleted int `orm:"column(deleted)" json:"deleted"`
|
|
|
|
OwnerName string `orm:"-" json:"owner_name"`
|
|
|
|
Togglable bool `orm:"-" json:"togglable"`
|
|
|
|
Role int `orm:"-" json:"current_user_role_id"`
|
2018-03-15 09:56:43 +01:00
|
|
|
RepoCount int64 `orm:"-" json:"repo_count"`
|
2017-09-29 10:37:43 +02:00
|
|
|
Metadata map[string]string `orm:"-" json:"metadata"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetMetadata ...
|
|
|
|
func (p *Project) GetMetadata(key string) (string, bool) {
|
|
|
|
if len(p.Metadata) == 0 {
|
|
|
|
return "", false
|
|
|
|
}
|
|
|
|
value, exist := p.Metadata[key]
|
|
|
|
return value, exist
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetMetadata ...
|
|
|
|
func (p *Project) SetMetadata(key, value string) {
|
|
|
|
if p.Metadata == nil {
|
|
|
|
p.Metadata = map[string]string{}
|
|
|
|
}
|
|
|
|
p.Metadata[key] = value
|
|
|
|
}
|
|
|
|
|
|
|
|
// IsPublic ...
|
|
|
|
func (p *Project) IsPublic() bool {
|
|
|
|
public, exist := p.GetMetadata(ProMetaPublic)
|
|
|
|
if !exist {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
return isTrue(public)
|
|
|
|
}
|
|
|
|
|
|
|
|
// ContentTrustEnabled ...
|
|
|
|
func (p *Project) ContentTrustEnabled() bool {
|
|
|
|
enabled, exist := p.GetMetadata(ProMetaEnableContentTrust)
|
|
|
|
if !exist {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return isTrue(enabled)
|
|
|
|
}
|
|
|
|
|
|
|
|
// VulPrevented ...
|
|
|
|
func (p *Project) VulPrevented() bool {
|
|
|
|
prevent, exist := p.GetMetadata(ProMetaPreventVul)
|
|
|
|
if !exist {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return isTrue(prevent)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Severity ...
|
|
|
|
func (p *Project) Severity() string {
|
|
|
|
severity, exist := p.GetMetadata(ProMetaSeverity)
|
|
|
|
if !exist {
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
return severity
|
|
|
|
}
|
|
|
|
|
|
|
|
// AutoScan ...
|
|
|
|
func (p *Project) AutoScan() bool {
|
|
|
|
auto, exist := p.GetMetadata(ProMetaAutoScan)
|
|
|
|
if !exist {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return isTrue(auto)
|
|
|
|
}
|
|
|
|
|
|
|
|
func isTrue(value string) bool {
|
|
|
|
return strings.ToLower(value) == "true" ||
|
|
|
|
strings.ToLower(value) == "1"
|
2016-02-01 12:59:10 +01:00
|
|
|
}
|
2016-06-27 08:46:06 +02:00
|
|
|
|
|
|
|
// ProjectSorter holds an array of projects
|
|
|
|
type ProjectSorter struct {
|
2017-05-16 07:59:40 +02:00
|
|
|
Projects []*Project
|
2016-06-27 08:46:06 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Len returns the length of array in ProjectSorter
|
|
|
|
func (ps *ProjectSorter) Len() int {
|
|
|
|
return len(ps.Projects)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Less defines the comparison rules of project
|
|
|
|
func (ps *ProjectSorter) Less(i, j int) bool {
|
|
|
|
return ps.Projects[i].Name < ps.Projects[j].Name
|
|
|
|
}
|
|
|
|
|
|
|
|
// Swap swaps the position of i and j
|
|
|
|
func (ps *ProjectSorter) Swap(i, j int) {
|
|
|
|
ps.Projects[i], ps.Projects[j] = ps.Projects[j], ps.Projects[i]
|
|
|
|
}
|
2017-05-19 07:05:44 +02:00
|
|
|
|
2017-05-26 08:58:00 +02:00
|
|
|
// ProjectQueryParam can be used to set query parameters when listing projects.
|
2017-05-19 07:05:44 +02:00
|
|
|
// The query condition will be set in the query if its corresponding field
|
|
|
|
// is not nil. Leave it empty if you don't want to apply this condition.
|
|
|
|
//
|
|
|
|
// e.g.
|
|
|
|
// List all projects: query := nil
|
|
|
|
// List all public projects: query := &QueryParam{Public: true}
|
|
|
|
// List projects the owner of which is user1: query := &QueryParam{Owner:"user1"}
|
|
|
|
// List all public projects the owner of which is user1: query := &QueryParam{Owner:"user1",Public:true}
|
|
|
|
// List projects which user1 is member of: query := &QueryParam{Member:&Member{Name:"user1"}}
|
|
|
|
// List projects which user1 is the project admin : query := &QueryParam{Memeber:&Member{Name:"user1",Role:1}}
|
2017-05-26 08:58:00 +02:00
|
|
|
type ProjectQueryParam struct {
|
2017-06-22 11:22:58 +02:00
|
|
|
Name string // the name of project
|
|
|
|
Owner string // the username of project owner
|
|
|
|
Public *bool // the project is public or not, can be ture, false and nil
|
|
|
|
Member *MemberQuery // the member of project
|
|
|
|
Pagination *Pagination // pagination information
|
2017-09-29 10:37:43 +02:00
|
|
|
ProjectIDs []int64 // project ID list
|
2017-05-19 07:05:44 +02:00
|
|
|
}
|
|
|
|
|
2017-06-22 11:22:58 +02:00
|
|
|
// MemberQuery fitler by member's username and role
|
|
|
|
type MemberQuery struct {
|
2017-05-19 07:05:44 +02:00
|
|
|
Name string // the username of member
|
|
|
|
Role int // the role of the member has to the project
|
|
|
|
}
|
|
|
|
|
|
|
|
// Pagination ...
|
|
|
|
type Pagination struct {
|
|
|
|
Page int64
|
|
|
|
Size int64
|
|
|
|
}
|
2017-06-09 08:11:44 +02:00
|
|
|
|
|
|
|
// BaseProjectCollection contains the query conditions which can be used
|
|
|
|
// to get a project collection. The collection can be used as the base to
|
|
|
|
// do other filter
|
|
|
|
type BaseProjectCollection struct {
|
|
|
|
Public bool
|
|
|
|
Member string
|
|
|
|
}
|
2017-06-23 10:21:19 +02:00
|
|
|
|
|
|
|
// ProjectRequest holds informations that need for creating project API
|
|
|
|
type ProjectRequest struct {
|
2017-09-29 10:37:43 +02:00
|
|
|
Name string `json:"project_name"`
|
|
|
|
Public *int `json:"public"` //deprecated, reserved for project creation in replication
|
|
|
|
Metadata map[string]string `json:"metadata"`
|
2017-06-23 10:21:19 +02:00
|
|
|
}
|
2017-09-26 10:41:08 +02:00
|
|
|
|
|
|
|
// ProjectQueryResult ...
|
|
|
|
type ProjectQueryResult struct {
|
|
|
|
Total int64
|
|
|
|
Projects []*Project
|
|
|
|
}
|
2017-12-21 13:07:23 +01:00
|
|
|
|
|
|
|
//TableName is required by beego orm to map Project to table project
|
|
|
|
func (p *Project) TableName() string {
|
|
|
|
return ProjectTable
|
|
|
|
}
|