forgejo-federation/models/access.go

105 lines
2.5 KiB
Go
Raw Normal View History

2014-02-18 05:08:50 +05:30
// Copyright 2014 The Gogs Authors. All rights reserved.
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file.
2014-02-17 21:27:23 +05:30
package models
import (
"strings"
"time"
2014-04-05 04:25:17 +05:30
2014-04-18 19:05:09 +05:30
"github.com/go-xorm/xorm"
2014-02-17 21:27:23 +05:30
)
2014-06-25 10:14:48 +05:30
type AccessType int
2014-02-17 21:27:23 +05:30
const (
2014-06-25 10:14:48 +05:30
READABLE AccessType = iota + 1
WRITABLE
2014-02-17 21:27:23 +05:30
)
2014-03-27 21:07:33 +05:30
// Access represents the accessibility of user to repository.
2014-02-17 21:27:23 +05:30
type Access struct {
Id int64
2014-08-26 15:41:15 +05:30
UserName string `xorm:"UNIQUE(s)"`
RepoName string `xorm:"UNIQUE(s)"` // <user name>/<repo name>
Mode AccessType `xorm:"UNIQUE(s)"`
Created time.Time `xorm:"CREATED"`
2014-02-17 21:27:23 +05:30
}
// AddAccess adds new access record.
2014-02-17 21:27:23 +05:30
func AddAccess(access *Access) error {
2014-03-31 01:31:50 +05:30
access.UserName = strings.ToLower(access.UserName)
access.RepoName = strings.ToLower(access.RepoName)
2014-06-21 10:21:41 +05:30
_, err := x.Insert(access)
2014-02-17 21:27:23 +05:30
return err
}
2014-04-04 01:20:55 +05:30
// UpdateAccess updates access information.
func UpdateAccess(access *Access) error {
access.UserName = strings.ToLower(access.UserName)
access.RepoName = strings.ToLower(access.RepoName)
2014-06-21 10:21:41 +05:30
_, err := x.Id(access.Id).Update(access)
2014-04-04 01:20:55 +05:30
return err
}
2014-05-01 21:02:12 +05:30
// DeleteAccess deletes access record.
func DeleteAccess(access *Access) error {
2014-06-21 10:21:41 +05:30
_, err := x.Delete(access)
2014-05-01 21:02:12 +05:30
return err
}
2014-04-05 04:25:17 +05:30
// UpdateAccess updates access information with session for rolling back.
func UpdateAccessWithSession(sess *xorm.Session, access *Access) error {
if _, err := sess.Id(access.Id).Update(access); err != nil {
sess.Rollback()
return err
}
return nil
}
2014-03-27 21:07:33 +05:30
// HasAccess returns true if someone can read or write to given repository.
2014-05-08 21:54:11 +05:30
// The repoName should be in format <username>/<reponame>.
2014-06-25 10:14:48 +05:30
func HasAccess(uname, repoName string, mode AccessType) (bool, error) {
if len(repoName) == 0 {
return false, nil
}
2014-04-12 07:17:39 +05:30
access := &Access{
2014-05-08 21:54:11 +05:30
UserName: strings.ToLower(uname),
2014-02-18 05:08:50 +05:30
RepoName: strings.ToLower(repoName),
2014-04-12 07:17:39 +05:30
}
2014-06-21 10:21:41 +05:30
has, err := x.Get(access)
2014-04-12 07:17:39 +05:30
if err != nil {
return false, err
} else if !has {
return false, nil
} else if mode > access.Mode {
return false, nil
}
return true, nil
2014-02-17 21:27:23 +05:30
}
2015-01-23 13:24:16 +05:30
// GetAccessibleRepositories finds all repositories where a user has access to,
// besides his own.
func (u *User) GetAccessibleRepositories() (map[*Repository]AccessType, error) {
accesses := make([]*Access, 0, 10)
if err := x.Find(&accesses, &Access{UserName: u.LowerName}); err != nil {
return nil, err
}
repos := make(map[*Repository]AccessType, len(accesses))
for _, access := range accesses {
repo, err := GetRepositoryByRef(access.RepoName)
if err != nil {
return nil, err
}
err = repo.GetOwner()
if err != nil {
return nil, err
}
2015-01-23 13:24:16 +05:30
repos[repo] = access.Mode
}
return repos, nil
}