1
0
mirror of https://github.com/go-gitea/gitea.git synced 2024-12-04 14:46:57 -05:00
gitea/models/access.go

80 lines
1.9 KiB
Go
Raw Normal View History

2014-02-17 18:38:50 -05:00
// 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 10:57:23 -05:00
package models
import (
"strings"
"time"
2014-04-04 18:55:17 -04:00
2014-04-18 09:35:09 -04:00
"github.com/go-xorm/xorm"
2014-02-17 10:57:23 -05:00
)
// Access types.
2014-02-17 10:57:23 -05:00
const (
2014-02-17 18:38:50 -05:00
AU_READABLE = iota + 1
AU_WRITABLE
2014-02-17 10:57:23 -05:00
)
2014-03-27 11:37:33 -04:00
// Access represents the accessibility of user to repository.
2014-02-17 10:57:23 -05:00
type Access struct {
Id int64
UserName string `xorm:"unique(s)"`
2014-04-12 20:35:35 -04:00
RepoName string `xorm:"unique(s)"` // <user name>/<repo name>
2014-02-17 10:57:23 -05:00
Mode int `xorm:"unique(s)"`
Created time.Time `xorm:"created"`
}
// AddAccess adds new access record.
2014-02-17 10:57:23 -05:00
func AddAccess(access *Access) error {
2014-03-30 16:01:50 -04:00
access.UserName = strings.ToLower(access.UserName)
access.RepoName = strings.ToLower(access.RepoName)
2014-02-17 10:57:23 -05:00
_, err := orm.Insert(access)
return err
}
2014-04-03 15:50:55 -04:00
// UpdateAccess updates access information.
func UpdateAccess(access *Access) error {
access.UserName = strings.ToLower(access.UserName)
access.RepoName = strings.ToLower(access.RepoName)
_, err := orm.Id(access.Id).Update(access)
return err
}
2014-05-01 11:32:12 -04:00
// DeleteAccess deletes access record.
func DeleteAccess(access *Access) error {
_, err := orm.Delete(access)
return err
}
2014-04-04 18:55:17 -04:00
// 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 11:37:33 -04:00
// HasAccess returns true if someone can read or write to given repository.
2014-05-08 12:24:11 -04:00
// The repoName should be in format <username>/<reponame>.
func HasAccess(uname, repoName string, mode int) (bool, error) {
if len(repoName) == 0 {
return false, nil
}
2014-04-11 21:47:39 -04:00
access := &Access{
2014-05-08 12:24:11 -04:00
UserName: strings.ToLower(uname),
2014-02-17 18:38:50 -05:00
RepoName: strings.ToLower(repoName),
2014-04-11 21:47:39 -04:00
}
has, err := orm.Get(access)
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 10:57:23 -05:00
}