// 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. package models import ( "time" ) // Project holds the details of a project. // TODO remove useless attrs type Project struct { 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"` CreationTimeStr string `orm:"-" json:"creation_time_str"` Deleted int `orm:"column(deleted)" json:"deleted"` //UserID int `json:"UserId"` OwnerName string `orm:"-" json:"owner_name"` Public int `orm:"column(public)" json:"public"` //This field does not have correspondent column in DB, this is just for UI to disable button Togglable bool `orm:"-"` UpdateTime time.Time `orm:"update_time" json:"update_time"` Role int `orm:"-" json:"current_user_role_id"` RepoCount int `orm:"-" json:"repo_count"` } // ProjectSorter holds an array of projects type ProjectSorter struct { Projects []*Project } // 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] } // ProjectQueryParam can be used to set query parameters when listing projects. // 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}} type ProjectQueryParam struct { 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 *Member // the member of project Pagination *Pagination // pagination information } // Member fitler by member's username and role type Member struct { 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 }