 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
  
    Index ¶
- Constants
- Variables
- func AddAccess(access *Access) error
- func AddPublicKey(key *PublicKey) (err error)
- func CommitRepoAction(userId int64, userName, actEmail string, repoId int64, repoName string, ...) error
- func CreateComment(userId, repoId, issueId, commitId, line int64, cmtType int, content string) error
- func DeletePublicKey(key *PublicKey) (err error)
- func DeleteRepository(userId, repoId int64, userName string) (err error)
- func DeleteUser(user *User) error
- func FollowUser(userId int64, followId int64) (err error)
- func ForkRepository(reposName string, userId int64)
- func GenAuthorizedKey(keyId int64, key string) string
- func GetBranches(userName, repoName string) ([]string, error)
- func GetCommit(userName, repoName, commitId string) (*git.Commit, error)
- func GetCommitsByBranch(userName, repoName, branchName string) (*list.List, error)
- func GetCommitsByCommitId(userName, repoName, commitId string) (*list.List, error)
- func GetRepositoryCount(user *User) (int64, error)
- func GetUserIssueCount(userId, repoId int64) int64
- func GetUserSalt() string
- func HasAccess(userName, repoName string, mode int) (bool, error)
- func IsBranchExist(userName, repoName, branchName string) bool
- func IsEmailUsed(email string) (bool, error)
- func IsLegalName(repoName string) bool
- func IsRepositoryExist(user *User, repoName string) (bool, error)
- func IsUserExist(name string) (bool, error)
- func IsWatching(userId, repoId int64) bool
- func LoadModelsConfig()
- func LoadRepoConfig()
- func NewEngine() (err error)
- func NewRepoAction(user *User, repo *Repository) (err error)
- func NewRepoContext()
- func NewTestEngine(x *xorm.Engine) (err error)
- func NotifyWatchers(act *Action) error
- func RepoPath(userName, repoName string) string
- func SaveAuthorizedKeyFile(key *PublicKey) error
- func SetEngine() (err error)
- func UnFollowUser(userId int64, unFollowId int64) (err error)
- func UpdateIssue(issue *Issue) error
- func UpdateRepository(repo *Repository) error
- func UpdateUser(user *User) (err error)
- func UserPath(userName string) string
- func WatchRepo(userId, repoId int64, watch bool) (err error)
- type Access
- type Action
- type Comment
- type Diff
- type DiffFile
- type DiffLine
- type DiffSection
- type Follow
- type Issue
- type Label
- type Member
- type Milestone
- type PublicKey
- type RepoFile
- type Repository
- func CreateRepository(user *User, repoName, desc, repoLang, license string, private bool, ...) (*Repository, error)
- func GetRepositories(user *User) ([]Repository, error)
- func GetRepositoryById(id int64) (*Repository, error)
- func GetRepositoryByName(userId int64, repoName string) (*Repository, error)
 
- type Statistic
- type User
- func GetUserById(id int64) (*User, error)
- func GetUserByKeyId(keyId int64) (*User, error)
- func GetUserByName(name string) (*User, error)
- func GetUsers(num, offset int) ([]User, error)
- func LoginUserPlain(name, passwd string) (*User, error)
- func RegisterUser(user *User) (*User, error)
- func VerifyUserActiveCode(code string) (user *User)
 
- type UserRepo
- type Watch
Constants ¶
const ( AU_READABLE = iota + 1 AU_WRITABLE )
Access types.
const ( OP_CREATE_REPO = iota + 1 OP_DELETE_REPO OP_STAR_REPO OP_FOLLOW_REPO OP_COMMIT_REPO OP_CREATE_ISSUE OP_PULL_REQUEST )
Operation types of user action.
const ( DIFF_LINE_PLAIN = iota + 1 DIFF_LINE_ADD DIFF_LINE_DEL DIFF_LINE_SECTION )
Diff line types.
const ( DIFF_FILE_ADD = iota + 1 DIFF_FILE_CHANGE DIFF_FILE_DEL )
const ( IT_PLAIN = iota // Pure comment. IT_REOPEN // Issue reopen status change prompt. IT_CLOSE // Issue close status change prompt. )
Issue types.
const ( UT_INDIVIDUAL = iota + 1 UT_ORGANIZATION )
User types.
const ( LT_PLAIN = iota + 1 LT_LDAP )
Login types.
const DIFF_HEAD = "diff --git "
    const (
	// "### autogenerated by gitgos, DO NOT EDIT\n"
	TPL_PUBLICK_KEY = `command="%s serv key-%d",no-port-forwarding,no-X11-forwarding,no-agent-forwarding,no-pty %s`
)
    Variables ¶
var ( HasEngine bool DbCfg struct { Type, Host, Name, User, Pwd, Path, SslMode string } UseSQLite3 bool )
var ( ErrRepoAlreadyExist = errors.New("Repository already exist") ErrRepoNotExist = errors.New("Repository does not exist") ErrRepoFileNotExist = errors.New("Target Repo file does not exist") ErrRepoNameIllegal = errors.New("Repository name contains illegal characters") ErrRepoFileNotLoaded = fmt.Errorf("repo file not loaded") )
var ( ErrUserOwnRepos = errors.New("User still have ownership of repositories") ErrUserAlreadyExist = errors.New("User already exist") ErrUserNotExist = errors.New("User does not exist") ErrEmailAlreadyUsed = errors.New("E-mail already used") ErrUserNameIllegal = errors.New("User name contains illegal characters") ErrKeyNotExist = errors.New("Public key does not exist") )
var (
	ErrIssueNotExist = errors.New("Issue does not exist")
)
    var (
	ErrKeyAlreadyExist = errors.New("Public key already exist")
)
    var (
	LanguageIgns, Licenses []string
)
    Functions ¶
func AddPublicKey ¶
AddPublicKey adds new public key to database and SSH key file.
func CommitRepoAction ¶
func CommitRepoAction(userId int64, userName, actEmail string, repoId int64, repoName string, refName string, commit *base.PushCommits) error
CommitRepoAction adds new action for committing repository.
func CreateComment ¶
func CreateComment(userId, repoId, issueId, commitId, line int64, cmtType int, content string) error
CreateComment creates comment of issue or commit.
func DeletePublicKey ¶
DeletePublicKey deletes SSH key information both in database and authorized_keys file.
func DeleteRepository ¶
DeleteRepository deletes a repository for a user or orgnaztion.
func DeleteUser ¶
DeleteUser completely deletes everything of the user.
func FollowUser ¶
FollowUser marks someone be another's follower.
func ForkRepository ¶
func GenAuthorizedKey ¶
GenAuthorizedKey returns formatted public key string.
func GetBranches ¶
GetBranches returns all branches of given repository.
func GetCommitsByBranch ¶
GetCommitsByBranch returns all commits of given branch of repository.
func GetCommitsByCommitId ¶
GetCommitsByCommitId returns all commits of given commitId of repository.
func GetRepositoryCount ¶
func GetUserIssueCount ¶
GetUserIssueCount returns the number of issues that were created by given user in repository.
func IsBranchExist ¶
func IsEmailUsed ¶
IsEmailUsed returns true if the e-mail has been used.
func IsLegalName ¶
IsLegalName returns false if name contains illegal characters.
func IsRepositoryExist ¶
IsRepositoryExist returns true if the repository with given name under user has already existed.
func IsUserExist ¶
IsUserExist checks if given user name exist, the user name should be noncased unique.
func IsWatching ¶
IsWatching checks if user has watched given repository.
func LoadModelsConfig ¶
func LoadModelsConfig()
func LoadRepoConfig ¶
func LoadRepoConfig()
func NewRepoAction ¶
func NewRepoAction(user *User, repo *Repository) (err error)
NewRepoAction adds new action for creating repository.
func NewRepoContext ¶
func NewRepoContext()
func NewTestEngine ¶
func NotifyWatchers ¶
NotifyWatchers creates batch of actions for every watcher.
func SaveAuthorizedKeyFile ¶
SaveAuthorizedKeyFile writes SSH key content to SSH key file.
func UnFollowUser ¶
UnFollowUser unmarks someone be another's follower.
func UpdateRepository ¶
func UpdateRepository(repo *Repository) error
Types ¶
type Access ¶
type Access struct {
	Id       int64
	UserName string    `xorm:"unique(s)"`
	RepoName string    `xorm:"unique(s)"`
	Mode     int       `xorm:"unique(s)"`
	Created  time.Time `xorm:"created"`
}
    Access represents the accessibility of user to repository.
type Action ¶
type Action struct {
	Id          int64
	UserId      int64  // Receiver user id.
	OpType      int    // Operations: CREATE DELETE STAR ...
	ActUserId   int64  // Action user id.
	ActUserName string // Action user name.
	ActEmail    string
	RepoId      int64
	RepoName    string
	RefName     string
	Content     string    `xorm:"TEXT"`
	Created     time.Time `xorm:"created"`
}
    Action represents user operation type and other information to repository., it implemented interface base.Actioner so that can be used in template render.
func (Action) GetActEmail ¶
func (Action) GetActUserName ¶
func (Action) GetContent ¶
func (Action) GetRepoName ¶
type Comment ¶
type Comment struct {
	Id       int64
	Type     int
	PosterId int64
	Poster   *User `xorm:"-"`
	IssueId  int64
	CommitId int64
	Line     int64
	Content  string
	Created  time.Time `xorm:"created"`
}
    Comment represents a comment in commit and issue page.
func GetIssueComments ¶
GetIssueComments returns list of comment by given issue id.
type DiffFile ¶
type DiffFile struct {
	Name               string
	Addition, Deletion int
	Type               int
	Sections           []*DiffSection
}
    type DiffSection ¶
type Follow ¶
type Follow struct {
	Id       int64
	UserId   int64 `xorm:"unique(follow)"`
	FollowId int64 `xorm:"unique(follow)"`
}
    Follow is connection request for receiving user notifycation.
type Issue ¶
type Issue struct {
	Id              int64
	Index           int64 // Index in one repository.
	Name            string
	RepoId          int64       `xorm:"index"`
	Repo            *Repository `xorm:"-"`
	PosterId        int64
	Poster          *User `xorm:"-"`
	MilestoneId     int64
	AssigneeId      int64
	IsPull          bool // Indicates whether is a pull request or not.
	IsClosed        bool
	Labels          string `xorm:"TEXT"`
	Mentions        string `xorm:"TEXT"`
	Content         string `xorm:"TEXT"`
	RenderedContent string `xorm:"-"`
	NumComments     int
	Created         time.Time `xorm:"created"`
	Updated         time.Time `xorm:"updated"`
}
    Issue represents an issue or pull request of repository.
func CreateIssue ¶
func CreateIssue(userId, repoId, milestoneId, assigneeId int64, issueCount int, name, labels, content string, isPull bool) (issue *Issue, err error)
CreateIssue creates new issue for repository.
func GetIssueByIndex ¶
GetIssueById returns issue object by given id.
type Member ¶
type Member struct {
	Id     int64
	OrgId  int64 `xorm:"unique(member) index"`
	UserId int64 `xorm:"unique(member)"`
}
    Member represents user is member of organization.
type Milestone ¶
type Milestone struct {
	Id        int64
	Name      string
	RepoId    int64 `xorm:"index"`
	IsClosed  bool
	Content   string
	NumIssues int
	DueDate   time.Time
	Created   time.Time `xorm:"created"`
}
    Milestone represents a milestone of repository.
type PublicKey ¶
type PublicKey struct {
	Id          int64
	OwnerId     int64  `xorm:"index"`
	Name        string `xorm:"unique not null"`
	Fingerprint string
	Content     string    `xorm:"TEXT not null"`
	Created     time.Time `xorm:"created"`
	Updated     time.Time `xorm:"updated"`
}
    PublicKey represents a SSH key of user.
func ListPublicKey ¶
ListPublicKey returns a list of public keys that user has.
type RepoFile ¶
type RepoFile struct {
	*git.TreeEntry
	Path   string
	Size   int64
	Repo   *git.Repository
	Commit *git.Commit
}
    RepoFile represents a file object in git repository.
func GetReposFiles ¶
GetReposFiles returns a list of file object in given directory of repository.
func GetTargetFile ¶
type Repository ¶
type Repository struct {
	Id              int64
	OwnerId         int64 `xorm:"unique(s)"`
	ForkId          int64
	LowerName       string `xorm:"unique(s) index not null"`
	Name            string `xorm:"index not null"`
	Description     string
	Website         string
	NumWatches      int
	NumStars        int
	NumForks        int
	NumIssues       int
	NumClosedIssues int
	NumOpenIssues   int `xorm:"-"`
	IsPrivate       bool
	IsBare          bool
	Created         time.Time `xorm:"created"`
	Updated         time.Time `xorm:"updated"`
}
    Repository represents a git repository.
func CreateRepository ¶
func CreateRepository(user *User, repoName, desc, repoLang, license string, private bool, initReadme bool) (*Repository, error)
CreateRepository creates a repository for given user or orgnaziation.
func GetRepositories ¶
func GetRepositories(user *User) ([]Repository, error)
GetRepositories returns the list of repositories of given user.
func GetRepositoryById ¶
func GetRepositoryById(id int64) (*Repository, error)
GetRepositoryById returns the repository by given id if exists.
func GetRepositoryByName ¶
func GetRepositoryByName(userId int64, repoName string) (*Repository, error)
GetRepositoryByName returns the repository by given name under user if exists.
type Statistic ¶
type Statistic struct {
	Counter struct {
		User, PublicKey, Repo, Watch, Action, Access int64
	}
}
    func GetStatistic ¶
func GetStatistic() (stats Statistic)
type User ¶
type User struct {
	Id            int64
	LowerName     string `xorm:"unique not null"`
	Name          string `xorm:"unique not null"`
	Email         string `xorm:"unique not null"`
	Passwd        string `xorm:"not null"`
	LoginType     int
	Type          int
	NumFollowers  int
	NumFollowings int
	NumStars      int
	NumRepos      int
	Avatar        string `xorm:"varchar(2048) not null"`
	AvatarEmail   string `xorm:"not null"`
	Location      string
	Website       string
	IsActive      bool
	IsAdmin       bool
	Rands         string    `xorm:"VARCHAR(10)"`
	Created       time.Time `xorm:"created"`
	Updated       time.Time `xorm:"updated"`
}
    User represents the object of individual and member of organization.
func GetUserById ¶
GetUserById returns the user object by given id if exists.
func GetUserByKeyId ¶
func GetUserByName ¶
GetUserByName returns the user object by given name if exists.
func LoginUserPlain ¶
LoginUserPlain validates user by raw user name and password.
func RegisterUser ¶
RegisterUser creates record of a new user.
func VerifyUserActiveCode ¶
verify active code when active account
func (*User) AvatarLink ¶
AvatarLink returns the user gravatar link.
func (*User) EncodePasswd ¶
EncodePasswd encodes password to safe format.
type UserRepo ¶
type UserRepo struct {
	*Repository
	UserName string
}
    UserRepo reporesents a repository with user name.