models

package
v0.7.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 8, 2015 License: MIT Imports: 54 Imported by: 0

Documentation

Index

Constants

View Source
const (
	DIFF_LINE_PLAIN = iota + 1
	DIFF_LINE_ADD
	DIFF_LINE_DEL
	DIFF_LINE_SECTION
)

Diff line types.

View Source
const (
	DIFF_FILE_ADD = iota + 1
	DIFF_FILE_CHANGE
	DIFF_FILE_DEL
	DIFF_FILE_RENAME
)
View Source
const (
	IS_OPEN = iota + 1
	IS_CLOSE
)
View Source
const (
	FM_ALL = iota
	FM_ASSIGN
	FM_CREATE
	FM_MENTION
)

Filter modes.

View Source
const (
	SMTP_PLAIN = "PLAIN"
	SMTP_LOGIN = "LOGIN"
)
View Source
const (
	KEY_TYPE_USER = iota + 1
	KEY_TYPE_DEPLOY
)
View Source
const (
	HOOK_STATUS_NONE = iota
	HOOK_STATUS_SUCCEED
	HOOK_STATUS_FAILED
)
View Source
const DIFF_HEAD = "diff --git "
View Source
const OWNER_TEAM = "Owners"

Variables

View Source
var (
	// Same as Github. See https://help.github.com/articles/closing-issues-via-commit-messages
	IssueCloseKeywords  = []string{"close", "closes", "closed", "fix", "fixes", "fixed", "resolve", "resolves", "resolved"}
	IssueReopenKeywords = []string{"reopen", "reopens", "reopened"}

	IssueCloseKeywordsPat, IssueReopenKeywordsPat *regexp.Regexp
	IssueReferenceKeywordsPat                     *regexp.Regexp
)
View Source
var (
	ErrWrongIssueCounter   = errors.New("Invalid number of issues for this milestone")
	ErrAttachmentNotLinked = errors.New("Attachment does not belong to this issue")
	ErrMissingIssueNumber  = errors.New("No issue number specified")
)
View Source
var (
	ErrAuthenticationAlreadyExist = errors.New("Authentication already exist")
	ErrAuthenticationNotExist     = errors.New("Authentication does not exist")
	ErrAuthenticationUserUsed     = errors.New("Authentication has been used by some users")
)
View Source
var (
	HasEngine bool

	DbCfg struct {
		Type, Host, Name, User, Passwd, Path, SSLMode string
	}

	EnableSQLite3 bool
	EnableTidb    bool
)
View Source
var (
	ErrOrgNotExist      = errors.New("Organization does not exist")
	ErrTeamAlreadyExist = errors.New("Team already exist")
	ErrTeamNotExist     = errors.New("Team does not exist")
	ErrTeamNameIllegal  = errors.New("Team name contains illegal characters")
)
View Source
var (
	ErrReleaseAlreadyExist = errors.New("Release already exist")
	ErrReleaseNotExist     = errors.New("Release does not exist")
)
View Source
var (
	ErrRepoFileNotExist  = errors.New("Repository file does not exist")
	ErrRepoFileNotLoaded = errors.New("Repository file not loaded")
	ErrMirrorNotExist    = errors.New("Mirror does not exist")
	ErrInvalidReference  = errors.New("Invalid reference specified")
	ErrNameEmpty         = errors.New("Name is empty")
)
View Source
var (
	Gitignores, Licenses, Readmes []string

	// Maximum items per page in forks, watchers and stars of a repo
	ItemsPerPage = 54
)
View Source
var (
	ErrUserNotKeyOwner       = errors.New("User does not the owner of public key")
	ErrEmailNotExist         = errors.New("E-mail does not exist")
	ErrEmailNotActivated     = errors.New("E-mail address has not been activated")
	ErrUserNameIllegal       = errors.New("User name contains illegal characters")
	ErrLoginSourceNotExist   = errors.New("Login source does not exist")
	ErrLoginSourceNotActived = errors.New("Login source is not actived")
	ErrUnsupportedLoginType  = errors.New("Login source is unknown")
)
View Source
var (
	DescPattern = regexp.MustCompile(`https?://\S+`)
)
View Source
var (
	ErrKeyUnableVerify = errors.New("Unable to verify public key")
)
View Source
var (
	ErrNotImplemented = errors.New("Not implemented yet")
)
View Source
var HookQueue = NewUniqueQueue(setting.Webhook.QueueLength)
View Source
var LoginNames = map[LoginType]string{
	LDAP:  "LDAP (via BindDN)",
	DLDAP: "LDAP (simple auth)",
	SMTP:  "SMTP",
	PAM:   "PAM",
}
View Source
var PullRequestQueue = NewUniqueQueue(setting.Repository.PullRequestQueueLength)
View Source
var SMTPAuths = []string{SMTP_PLAIN, SMTP_LOGIN}
View Source
var (
	SSHPath string // SSH directory.

)

Functions

func AddDeployKey added in v0.6.5

func AddDeployKey(repoID int64, name, content string) (err error)

AddDeployKey add new deploy key to database and authorized_keys file.

func AddEmailAddress added in v0.5.11

func AddEmailAddress(email *EmailAddress) error

func AddOrgUser added in v0.5.0

func AddOrgUser(orgId, uid int64) error

AddOrgUser adds new user to given organization.

func AddPublicKey

func AddPublicKey(ownerID int64, name, content string) (err error)

AddPublicKey adds new public key to database and authorized_keys file.

func AddTeamMember added in v0.5.0

func AddTeamMember(orgId, teamId, uid int64) error

AddTeamMember adds new member to given team of given organization.

func AddTeamRepo added in v0.6.0

func AddTeamRepo(orgID, teamID, repoID int64) error

AddTeamRepo adds new repository relation to team.

func AddTestPullRequestTask added in v0.7.0

func AddTestPullRequestTask(repoID int64, branch string)

AddTestPullRequestTask adds new test tasks by given head/base repository and head/base branch, and generate new patch for testing as needed.

func AddUpdateTask added in v0.5.0

func AddUpdateTask(task *UpdateTask) error

func AttachmentLocalPath added in v0.6.5

func AttachmentLocalPath(uuid string) string

AttachmentLocalPath returns where attachment is stored in local file system based on given UUID.

func ChangeMilestoneAssign added in v0.4.0

func ChangeMilestoneAssign(oldMid int64, issue *Issue) (err error)

ChangeMilestoneAssign changes assignment of milestone for issue.

func ChangeMilestoneIssueStats added in v0.5.0

func ChangeMilestoneIssueStats(issue *Issue) (err error)

ChangeMilestoneIssueStats updates the open/closed issues counter and progress for the milestone associated witht the given issue.

func ChangeMilestoneStatus added in v0.4.0

func ChangeMilestoneStatus(m *Milestone, isClosed bool) (err error)

ChangeMilestoneStatus changes the milestone open/closed status.

func ChangeOrgUserStatus added in v0.5.0

func ChangeOrgUserStatus(orgId, uid int64, public bool) error

ChangeOrgUserStatus changes public or private membership status.

func ChangeRepositoryName added in v0.3.0

func ChangeRepositoryName(u *User, oldRepoName, newRepoName string) (err error)

ChangeRepositoryName changes all corresponding setting from old repository name to new one.

func ChangeUserName added in v0.3.0

func ChangeUserName(u *User, newUserName string) (err error)

ChangeUserName changes all corresponding setting from old user name to new one.

func CheckPublicKeyString added in v0.5.0

func CheckPublicKeyString(content string) (_ string, err error)

CheckPublicKeyString checks if the given public key string is recognized by SSH.

func CheckRepoStats added in v0.6.3

func CheckRepoStats()

func CommitRepoAction

func CommitRepoAction(
	userID, repoUserID int64,
	userName, actEmail string,
	repoID int64,
	repoUserName, repoName string,
	refFullName string,
	commit *base.PushCommits,
	oldCommitID string, newCommitID string) error

CommitRepoAction adds new action for committing repository.

func CountLoginSources added in v0.6.15

func CountLoginSources() int64

CountLoginSources returns number of login sources.

func CountNotices added in v0.5.5

func CountNotices() int64

CountNotices returns number of notices.

func CountOrganizations added in v0.5.0

func CountOrganizations() int64

CountOrganizations returns number of organizations.

func CountPublicRepositories added in v0.6.9

func CountPublicRepositories() int64

CountPublicRepositories returns number of public repositories.

func CountRepoClosedMilestones added in v0.6.5

func CountRepoClosedMilestones(repoID int64) int64

CountRepoClosedMilestones returns number of closed milestones in given repository.

func CountRepoMilestones added in v0.6.5

func CountRepoMilestones(repoID int64) int64

CountRepoMilestones returns number of milestones in given repository.

func CountRepositories added in v0.5.0

func CountRepositories() int64

CountRepositories returns number of repositories.

func CountUsers added in v0.5.0

func CountUsers() int64

CountUsers returns number of users.

func CreateHookTask added in v0.5.0

func CreateHookTask(t *HookTask) error

CreateHookTask creates a new hook task, it handles conversion from Payload to PayloadContent.

func CreateNotice added in v0.5.5

func CreateNotice(tp NoticeType, desc string) error

CreateNotice creates new system notice.

func CreateOrganization added in v0.5.0

func CreateOrganization(org, owner *User) (err error)

CreateOrganization creates record of a new organization.

func CreateRefComment added in v0.6.15

func CreateRefComment(doer *User, repo *Repository, issue *Issue, content, commitSHA string) error

CreateRefComment creates a commit reference comment to issue.

func CreateRelease added in v0.3.0

func CreateRelease(gitRepo *git.Repository, rel *Release) error

CreateRelease creates a new release of repository.

func CreateRepositoryNotice added in v0.5.5

func CreateRepositoryNotice(desc string) error

CreateRepositoryNotice creates new system notice with type NOTICE_REPOSITORY.

func CreateSource added in v0.5.0

func CreateSource(source *LoginSource) error

func CreateUser added in v0.5.0

func CreateUser(u *User) (err error)

CreateUser creates record of a new user.

func CreateWebhook added in v0.4.0

func CreateWebhook(w *Webhook) error

CreateWebhook creates a new web hook.

func DeleteAccessTokenByID added in v0.6.9

func DeleteAccessTokenByID(id int64) error

DeleteAccessTokenByID deletes access token by given ID.

func DeleteAttachment added in v0.5.0

func DeleteAttachment(a *Attachment, remove bool) error

DeleteAttachment deletes the given attachment and optionally the associated file.

func DeleteAttachments added in v0.5.0

func DeleteAttachments(attachments []*Attachment, remove bool) (int, error)

DeleteAttachments deletes the given attachments and optionally the associated files.

func DeleteAttachmentsByComment added in v0.5.0

func DeleteAttachmentsByComment(commentId int64, remove bool) (int, error)

DeleteAttachmentsByComment deletes all attachments associated with the given comment.

func DeleteAttachmentsByIssue added in v0.5.0

func DeleteAttachmentsByIssue(issueId int64, remove bool) (int, error)

DeleteAttachmentsByIssue deletes all attachments associated with the given issue.

func DeleteDeployKey added in v0.6.5

func DeleteDeployKey(id int64) error

DeleteDeployKey deletes deploy key from its repository authorized_keys file if needed.

func DeleteEmailAddress added in v0.5.11

func DeleteEmailAddress(email *EmailAddress) error

func DeleteInactivateUsers added in v0.5.0

func DeleteInactivateUsers() (err error)

DeleteInactivateUsers deletes all inactivate users and email addresses.

func DeleteIssueLabel added in v0.6.5

func DeleteIssueLabel(issue *Issue, label *Label) (err error)

DeleteIssueLabel deletes issue-label relation.

func DeleteLabel added in v0.4.0

func DeleteLabel(repoID, labelID int64) error

DeleteLabel delete a label of given repository.

func DeleteMilestoneByID added in v0.6.5

func DeleteMilestoneByID(mid int64) error

DeleteMilestoneByID deletes a milestone by given ID.

func DeleteNotice added in v0.5.5

func DeleteNotice(id int64) error

DeleteNotice deletes a system notice by given ID.

func DeleteOrganization added in v0.5.0

func DeleteOrganization(org *User) (err error)

DeleteOrganization completely and permanently deletes everything of organization.

func DeletePublicKey

func DeletePublicKey(id int64) (err error)

DeletePublicKey deletes SSH key information both in database and authorized_keys file.

func DeleteRepository

func DeleteRepository(uid, repoID int64) error

DeleteRepository deletes a repository for a user or organization.

func DeleteRepositoryArchives added in v0.5.8

func DeleteRepositoryArchives() error

DeleteRepositoryArchives deletes all repositories' archives.

func DeleteSource added in v0.6.15

func DeleteSource(source *LoginSource) error

func DeleteTeam added in v0.5.0

func DeleteTeam(t *Team) error

DeleteTeam deletes given team. It's caller's responsibility to assign organization ID.

func DeleteUpdateTaskByUUID added in v0.7.0

func DeleteUpdateTaskByUUID(uuid string) error

func DeleteUser

func DeleteUser(u *User) (err error)

DeleteUser completely and permanently deletes everything of a user, but issues/comments/pulls will be kept and shown as someone has been deleted.

func DeleteWebhook added in v0.4.0

func DeleteWebhook(id int64) (err error)

DeleteWebhook deletes webhook of repository.

func DeliverHooks added in v0.5.0

func DeliverHooks()

DeliverHooks checks and delivers undelivered hooks. TODO: shoot more hooks at same time.

func DumpDatabase added in v0.4.0

func DumpDatabase(filePath string) error

DumpDatabase dumps all data from database to file system.

func FollowUser

func FollowUser(userId int64, followId int64) (err error)

FollowUser marks someone be another's follower.

func GetIssueCountByPoster added in v0.4.0

func GetIssueCountByPoster(uid, rid int64, isClosed bool) int64

GetIssueCountByPoster returns number of issues of repository by poster.

func GetRepoIssueStats added in v0.6.9

func GetRepoIssueStats(repoID, uid int64, filterMode int, isPull bool) (numOpen int64, numClosed int64)

GetRepoIssueStats returns number of open and closed repository issues by given filter mode.

func GetRepositoryCount

func GetRepositoryCount(u *User) (int64, error)

GetRepositoryCount returns the total number of repositories of user.

func GetUserEmailsByNames added in v0.3.0

func GetUserEmailsByNames(names []string) []string

GetUserEmailsByNames returns a list of e-mails corresponds to names.

func GetUserIdsByNames added in v0.4.0

func GetUserIdsByNames(names []string) []int64

GetUserIdsByNames returns a slice of ids corresponds to names.

func GetUserSalt

func GetUserSalt() string

GetUserSalt returns a ramdom user salt token.

func GitFsck added in v0.5.9

func GitFsck()

GitFsck calls 'git fsck' to check repository health.

func GitGcRepos added in v0.5.9

func GitGcRepos() error

func HasAccess

func HasAccess(u *User, repo *Repository, testMode AccessMode) (bool, error)

HasAccess returns true if someone has the request access level. User can be nil!

func HasDeployKey added in v0.6.5

func HasDeployKey(keyID, repoID int64) bool

HasDeployKey returns true if public key is a deploy key of given repository.

func HasIssueLabel added in v0.6.5

func HasIssueLabel(issueID, labelID int64) bool

HasIssueLabel returns true if issue has been labeled.

func HasTeamRepo added in v0.6.0

func HasTeamRepo(orgID, teamID, repoID int64) bool

HasTeamRepo returns true if given repository belongs to team.

func InitDeliverHooks added in v0.6.3

func InitDeliverHooks()

func InitTestPullRequests added in v0.7.0

func InitTestPullRequests()

func IsEmailUsed

func IsEmailUsed(email string) (bool, error)

IsEmailUsed returns true if the e-mail has been used.

func IsErrAccessTokenNotExist added in v0.6.9

func IsErrAccessTokenNotExist(err error) bool

func IsErrAttachmentNotExist added in v0.6.5

func IsErrAttachmentNotExist(err error) bool

func IsErrCommentNotExist added in v0.6.9

func IsErrCommentNotExist(err error) bool

func IsErrDeployKeyAlreadyExist added in v0.6.5

func IsErrDeployKeyAlreadyExist(err error) bool

func IsErrDeployKeyNameAlreadyUsed added in v0.6.5

func IsErrDeployKeyNameAlreadyUsed(err error) bool

func IsErrEmailAlreadyUsed added in v0.6.3

func IsErrEmailAlreadyUsed(err error) bool

func IsErrInvalidCloneAddr added in v0.7.0

func IsErrInvalidCloneAddr(err error) bool

func IsErrIssueNotExist added in v0.6.5

func IsErrIssueNotExist(err error) bool

func IsErrKeyAlreadyExist added in v0.6.5

func IsErrKeyAlreadyExist(err error) bool

func IsErrKeyNameAlreadyUsed added in v0.6.5

func IsErrKeyNameAlreadyUsed(err error) bool

func IsErrKeyNotExist added in v0.6.5

func IsErrKeyNotExist(err error) bool

func IsErrLabelNotExist added in v0.6.5

func IsErrLabelNotExist(err error) bool

func IsErrLastOrgOwner added in v0.6.0

func IsErrLastOrgOwner(err error) bool

func IsErrMilestoneNotExist added in v0.6.5

func IsErrMilestoneNotExist(err error) bool

func IsErrNamePatternNotAllowed added in v0.6.3

func IsErrNamePatternNotAllowed(err error) bool

func IsErrNameReserved added in v0.6.3

func IsErrNameReserved(err error) bool

func IsErrPullRequestNotExist added in v0.6.9

func IsErrPullRequestNotExist(err error) bool

func IsErrRepoAlreadyExist added in v0.6.5

func IsErrRepoAlreadyExist(err error) bool

func IsErrRepoNotExist added in v0.6.0

func IsErrRepoNotExist(err error) bool

func IsErrUpdateTaskNotExist added in v0.7.0

func IsErrUpdateTaskNotExist(err error) bool

func IsErrUserAlreadyExist added in v0.6.3

func IsErrUserAlreadyExist(err error) bool

func IsErrUserHasOrgs added in v0.6.0

func IsErrUserHasOrgs(err error) bool

func IsErrUserNotExist added in v0.6.5

func IsErrUserNotExist(err error) bool

func IsErrUserOwnRepos added in v0.6.0

func IsErrUserOwnRepos(err error) bool

func IsErrWebhookNotExist added in v0.6.9

func IsErrWebhookNotExist(err error) bool

func IsOrganizationMember added in v0.5.0

func IsOrganizationMember(orgId, uid int64) bool

IsOrganizationMember returns true if given user is member of organization.

func IsOrganizationOwner added in v0.5.0

func IsOrganizationOwner(orgId, uid int64) bool

IsOrganizationOwner returns true if given user is in the owner team.

func IsPublicMembership added in v0.5.0

func IsPublicMembership(orgId, uid int64) bool

IsPublicMembership returns true if given user public his/her membership.

func IsReleaseExist added in v0.3.0

func IsReleaseExist(repoId int64, tagName string) (bool, error)

IsReleaseExist returns true if release with given tag name already exists.

func IsRepositoryExist

func IsRepositoryExist(u *User, repoName string) (bool, error)

IsRepositoryExist returns true if the repository with given name under user has already existed.

func IsStaring added in v0.5.0

func IsStaring(uid, repoId int64) bool

IsStaring checks if user has starred given repository.

func IsTeamMember added in v0.5.0

func IsTeamMember(orgID, teamID, uid int64) bool

IsTeamMember returns true if given user is a member of team.

func IsUsableName added in v0.6.3

func IsUsableName(name string) error

IsUsableName checks if name is reserved or pattern of name is not allowed.

func IsUserExist

func IsUserExist(uid int64, name string) (bool, error)

IsUserExist checks if given user name exist, the user name should be noncased unique. If uid is presented, then check will rule out that one, it is used when update a user name in settings page.

func IsValidHookContentType added in v0.5.8

func IsValidHookContentType(name string) bool

IsValidHookContentType returns true if given name is a valid hook content type.

func IsValidHookTaskType added in v0.5.8

func IsValidHookTaskType(name string) bool

IsValidHookTaskType returns true if given name is a valid hook task type.

func IsWatching

func IsWatching(uid, repoId int64) bool

IsWatching checks if user has watched given repository.

func LoadConfigs added in v0.6.15

func LoadConfigs()

func LoadRepoConfig

func LoadRepoConfig()

func LoginAuth added in v0.4.0

func LoginAuth(username, password string) smtp.Auth

func MakeEmailPrimary added in v0.5.11

func MakeEmailPrimary(email *EmailAddress) error

func MergePullRequestAction added in v0.6.9

func MergePullRequestAction(actUser *User, repo *Repository, pull *Issue) error

MergePullRequestAction adds new action for merging pull request.

func MilestoneStats added in v0.6.5

func MilestoneStats(repoID int64) (open int64, closed int64)

MilestoneStats returns number of open and closed milestones of given repository.

func MirrorRepository added in v0.3.0

func MirrorRepository(repoId int64, userName, repoName, repoPath, url string) error

MirrorRepository creates a mirror repository from source.

func MirrorUpdate added in v0.3.0

func MirrorUpdate()

MirrorUpdate checks and updates mirror repositories.

func NewAccessToken added in v0.5.8

func NewAccessToken(t *AccessToken) error

NewAccessToken creates new access token.

func NewEngine

func NewEngine() (err error)

func NewIssue added in v0.4.0

func NewIssue(repo *Repository, issue *Issue, labelIDs []int64, uuids []string) (err error)

NewIssue creates new issue with labels for repository.

func NewIssueLabel added in v0.6.5

func NewIssueLabel(issue *Issue, label *Label) (err error)

NewIssueLabel creates a new issue-label relation.

func NewIssueUsers added in v0.6.5

func NewIssueUsers(repo *Repository, issue *Issue) (err error)

NewIssueUsers adds new issue-user relations for new issue of repository.

func NewLabel added in v0.4.0

func NewLabel(l *Label) error

NewLabel creates new label of repository.

func NewMilestone added in v0.4.0

func NewMilestone(m *Milestone) (err error)

NewMilestone creates new milestone of repository.

func NewPullRequest added in v0.6.9

func NewPullRequest(repo *Repository, pull *Issue, labelIDs []int64, uuids []string, pr *PullRequest, patch []byte) (err error)

NewPullRequest creates new pull request with labels for repository.

func NewRepoAction

func NewRepoAction(u *User, repo *Repository) (err error)

NewRepoAction adds new action for creating repository.

func NewRepoContext

func NewRepoContext()

func NewTeam added in v0.5.0

func NewTeam(t *Team) (err error)

NewTeam creates a record of new team. It's caller's responsibility to assign organization ID.

func NewTestEngine

func NewTestEngine(x *xorm.Engine) (err error)

func NotifyWatchers

func NotifyWatchers(act *Action) error

NotifyWatchers creates batch of actions for every watcher.

func PairsContains added in v0.4.0

func PairsContains(ius []*IssueUser, issueId, uid int64) int

PairsContains returns true when pairs list contains given issue.

func Ping added in v0.5.0

func Ping() error

func PrepareWebhooks added in v0.6.9

func PrepareWebhooks(repo *Repository, event HookEventType, p api.Payloader) error

PrepareWebhooks adds new webhooks to task queue for given payload.

func RemoveOrgRepo added in v0.6.0

func RemoveOrgRepo(orgID, repoID int64) error

RemoveOrgRepo removes all team-repository relations of given organization.

func RemoveOrgUser added in v0.5.0

func RemoveOrgUser(orgId, uid int64) error

RemoveOrgUser removes user from given organization.

func RemoveTeamMember added in v0.5.0

func RemoveTeamMember(orgId, teamId, uid int64) error

RemoveTeamMember removes member from given team of given organization.

func RemoveTeamRepo added in v0.6.0

func RemoveTeamRepo(teamID, repoID int64) error

RemoveTeamRepo deletes repository relation to team.

func RenameRepoAction added in v0.6.9

func RenameRepoAction(actUser *User, oldRepoName string, repo *Repository) error

RenameRepoAction adds new action for renaming a repository.

func RepoPath

func RepoPath(userName, repoName string) string

RepoPath returns repository path by given user and repository name.

func RewriteAllPublicKeys added in v0.5.13

func RewriteAllPublicKeys() error

RewriteAllPublicKeys removes any authorized key and rewrite all keys from database again.

func RewriteRepositoryUpdateHook added in v0.5.13

func RewriteRepositoryUpdateHook() error

RewriteRepositoryUpdateHook rewrites all repositories' update hook.

func SMTPAuth added in v0.6.9

func SMTPAuth(a smtp.Auth, cfg *SMTPConfig) error

func SetEngine

func SetEngine() (err error)

func SlackLinkFormatter added in v0.5.0

func SlackLinkFormatter(url string, text string) string

func SlackTextFormatter added in v0.5.0

func SlackTextFormatter(s string) string

see: https://api.slack.com/docs/formatting

func SortReleases added in v0.5.0

func SortReleases(rels []*Release)

SortReleases sorts releases by number of commits and created time.

func StarRepo added in v0.5.0

func StarRepo(uid, repoId int64, star bool) (err error)

Star or unstar repository.

func TestPullRequests added in v0.7.0

func TestPullRequests()

TestPullRequests checks and tests untested patches of pull requests. TODO: test more pull requests at same time.

func TransferOwnership added in v0.3.0

func TransferOwnership(u *User, newOwnerName string, repo *Repository) error

TransferOwnership transfers all corresponding setting from old user to new one.

func TransferRepoAction added in v0.3.0

func TransferRepoAction(actUser, oldOwner, newOwner *User, repo *Repository) error

TransferRepoAction adds new action for transferring repository.

func UnFollowUser

func UnFollowUser(userId int64, unFollowId int64) (err error)

UnFollowUser unmarks someone be another's follower.

func Update added in v0.3.0

func Update(refName, oldCommitID, newCommitID, userName, repoUserName, repoName string, userID int64) error

func UpdateAccessToekn added in v0.6.9

func UpdateAccessToekn(t *AccessToken) error

UpdateAccessToekn updates information of access token.

func UpdateComment added in v0.6.9

func UpdateComment(c *Comment) error

UpdateComment updates information of comment.

func UpdateDeployKey added in v0.6.5

func UpdateDeployKey(key *DeployKey) error

UpdateDeployKey updates deploy key information.

func UpdateHookTask added in v0.5.0

func UpdateHookTask(t *HookTask) error

UpdateHookTask updates information of hook task.

func UpdateIssue

func UpdateIssue(issue *Issue) error

UpdateIssue updates all fields of given issue.

func UpdateIssueUserByAssignee added in v0.6.5

func UpdateIssueUserByAssignee(issue *Issue) (err error)

UpdateIssueUserByAssignee updates issue-user relation for assignee.

func UpdateIssueUserByRead added in v0.6.5

func UpdateIssueUserByRead(uid, issueID int64) error

UpdateIssueUserByRead updates issue-user relation for reading.

func UpdateIssueUsersByMentions added in v0.6.5

func UpdateIssueUsersByMentions(uids []int64, iid int64) error

UpdateIssueUsersByMentions updates issue-user pairs by mentioning.

func UpdateIssueUsersByStatus added in v0.6.5

func UpdateIssueUsersByStatus(issueID int64, isClosed bool) error

UpdateIssueUsersByStatus updates issue-user relations by issue status.

func UpdateLabel added in v0.4.0

func UpdateLabel(l *Label) error

UpdateLabel updates label information.

func UpdateMentions added in v0.5.0

func UpdateMentions(userNames []string, issueId int64) error

func UpdateMilestone added in v0.4.0

func UpdateMilestone(m *Milestone) error

UpdateMilestone updates information of given milestone.

func UpdateMirror added in v0.3.0

func UpdateMirror(m *Mirror) error

func UpdatePublicKey added in v0.5.0

func UpdatePublicKey(key *PublicKey) error

UpdatePublicKey updates given public key.

func UpdateRelease added in v0.5.0

func UpdateRelease(gitRepo *git.Repository, rel *Release) (err error)

UpdateRelease updates information of a release.

func UpdateRepository

func UpdateRepository(repo *Repository, visibilityChanged bool) (err error)

func UpdateSource added in v0.4.0

func UpdateSource(source *LoginSource) error

func UpdateTeam added in v0.5.0

func UpdateTeam(t *Team, authChanged bool) (err error)

UpdateTeam updates information of team.

func UpdateUser

func UpdateUser(u *User) error

UpdateUser updates user's information.

func UpdateWebhook added in v0.4.0

func UpdateWebhook(w *Webhook) error

UpdateWebhook updates information of webhook.

func UserPath

func UserPath(userName string) string

UserPath returns the path absolute path of user repositories.

func ValidateCommitsWithEmails added in v0.5.5

func ValidateCommitsWithEmails(oldCommits *list.List) *list.List

ValidateCommitsWithEmails checks if authors' e-mails of commits are corresponding to users.

func WatchRepo

func WatchRepo(uid, repoId int64, watch bool) (err error)

Watch or unwatch repository.

Types

type Access

type Access struct {
	ID     int64 `xorm:"pk autoincr"`
	UserID int64 `xorm:"UNIQUE(s)"`
	RepoID int64 `xorm:"UNIQUE(s)"`
	Mode   AccessMode
}

Access represents the highest access level of a user to the repository. The only access type that is not in this table is the real owner of a repository. In case of an organization repository, the members of the owners team are in this table.

type AccessMode added in v0.6.0

type AccessMode int
const (
	ACCESS_MODE_NONE AccessMode = iota
	ACCESS_MODE_READ
	ACCESS_MODE_WRITE
	ACCESS_MODE_ADMIN
	ACCESS_MODE_OWNER
)

func AccessLevel added in v0.6.0

func AccessLevel(u *User, repo *Repository) (AccessMode, error)

AccessLevel returns the Access a user has to a repository. Will return NoneAccess if the user does not have access. User can be nil!

type AccessToken added in v0.5.8

type AccessToken struct {
	ID                int64 `xorm:"pk autoincr"`
	UID               int64 `xorm:"INDEX"`
	Name              string
	Sha1              string    `xorm:"UNIQUE VARCHAR(40)"`
	Created           time.Time `xorm:"CREATED"`
	Updated           time.Time
	HasRecentActivity bool `xorm:"-"`
	HasUsed           bool `xorm:"-"`
}

AccessToken represents a personal access token.

func GetAccessTokenBySHA added in v0.6.9

func GetAccessTokenBySHA(sha string) (*AccessToken, error)

GetAccessTokenBySHA returns access token by given sha1.

func ListAccessTokens added in v0.5.8

func ListAccessTokens(uid int64) ([]*AccessToken, error)

ListAccessTokens returns a list of access tokens belongs to given user.

type Action

type Action struct {
	ID           int64 `xorm:"pk autoincr"`
	UserID       int64 // Receiver user id.
	OpType       ActionType
	ActUserID    int64  // Action user id.
	ActUserName  string // Action user name.
	ActEmail     string
	ActAvatar    string `xorm:"-"`
	RepoID       int64
	RepoUserName string
	RepoName     string
	RefName      string
	IsPrivate    bool      `xorm:"NOT NULL DEFAULT false"`
	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 GetFeeds

func GetFeeds(uid, offset int64, isProfile bool) ([]*Action, error)

GetFeeds returns action list of given user in given context.

func (*Action) AfterSet added in v0.6.9

func (a *Action) AfterSet(colName string, _ xorm.Cell)

func (Action) GetActEmail

func (a Action) GetActEmail() string

func (Action) GetActUserName

func (a Action) GetActUserName() string

func (Action) GetBranch

func (a Action) GetBranch() string

func (Action) GetContent

func (a Action) GetContent() string

func (Action) GetCreate added in v0.5.0

func (a Action) GetCreate() time.Time

func (Action) GetIssueInfos added in v0.5.0

func (a Action) GetIssueInfos() []string

func (Action) GetOpType

func (a Action) GetOpType() int
func (a Action) GetRepoLink() string

func (Action) GetRepoName

func (a Action) GetRepoName() string

func (Action) GetRepoPath added in v0.6.0

func (a Action) GetRepoPath() string

func (Action) GetRepoUserName added in v0.4.0

func (a Action) GetRepoUserName() string

type ActionType added in v0.5.0

type ActionType int
const (
	CREATE_REPO         ActionType = iota + 1 // 1
	RENAME_REPO                               // 2
	STAR_REPO                                 // 3
	FOLLOW_REPO                               // 4
	COMMIT_REPO                               // 5
	CREATE_ISSUE                              // 6
	CREATE_PULL_REQUEST                       // 7
	TRANSFER_REPO                             // 8
	PUSH_TAG                                  // 9
	COMMENT_ISSUE                             // 10
	MERGE_PULL_REQUEST                        // 11
)

type Attachment added in v0.5.0

type Attachment struct {
	ID        int64  `xorm:"pk autoincr"`
	UUID      string `xorm:"uuid UNIQUE"`
	IssueID   int64  `xorm:"INDEX"`
	CommentID int64
	ReleaseID int64 `xorm:"INDEX"`
	Name      string
	Created   time.Time `xorm:"CREATED"`
}

Attachment represent a attachment of issue/comment/release.

func GetAttachmentByUUID added in v0.6.5

func GetAttachmentByUUID(uuid string) (*Attachment, error)

GetAttachmentByUUID returns attachment by given UUID.

func GetAttachmentsByCommentID added in v0.6.5

func GetAttachmentsByCommentID(commentID int64) ([]*Attachment, error)

GetAttachmentsByCommentID returns all attachments if comment by given ID.

func GetAttachmentsByIssueID added in v0.6.5

func GetAttachmentsByIssueID(issueID int64) ([]*Attachment, error)

GetAttachmentsByIssueID returns all attachments for given issue by ID.

func NewAttachment added in v0.6.5

func NewAttachment(name string, buf []byte, file multipart.File) (_ *Attachment, err error)

NewAttachment creates a new attachment object.

func (*Attachment) LocalPath added in v0.6.5

func (attach *Attachment) LocalPath() string

LocalPath returns where attachment is stored in local file system.

type CloneLink struct {
	SSH   string
	HTTPS string
	Git   string
}

CloneLink represents different types of clone URLs of repository.

type Collaboration added in v0.6.0

type Collaboration struct {
	ID      int64     `xorm:"pk autoincr"`
	RepoID  int64     `xorm:"UNIQUE(s) INDEX NOT NULL"`
	UserID  int64     `xorm:"UNIQUE(s) INDEX NOT NULL"`
	Created time.Time `xorm:"CREATED"`
}

A Collaboration is a relation between an individual and a repository

type Comment

type Comment struct {
	ID              int64 `xorm:"pk autoincr"`
	Type            CommentType
	PosterID        int64
	Poster          *User `xorm:"-"`
	IssueID         int64 `xorm:"INDEX"`
	CommitID        int64
	Line            int64
	Content         string    `xorm:"TEXT"`
	RenderedContent string    `xorm:"-"`
	Created         time.Time `xorm:"CREATED"`

	// Reference issue in commit message
	CommitSHA string `xorm:"VARCHAR(40)"`

	Attachments []*Attachment `xorm:"-"`

	// For view issue page.
	ShowTag CommentTag `xorm:"-"`
}

Comment represents a comment in commit and issue page.

func CreateComment

func CreateComment(doer *User, repo *Repository, issue *Issue, commitID, line int64, cmtType CommentType, content, commitSHA string, attachments []string) (comment *Comment, err error)

CreateComment creates comment of issue or commit.

func CreateIssueComment added in v0.6.5

func CreateIssueComment(doer *User, repo *Repository, issue *Issue, content string, attachments []string) (*Comment, error)

CreateIssueComment creates a plain issue comment.

func GetCommentByID added in v0.6.9

func GetCommentByID(id int64) (*Comment, error)

GetCommentByID returns the comment by given ID.

func GetCommentsByIssueID added in v0.6.5

func GetCommentsByIssueID(issueID int64) ([]*Comment, error)

GetCommentsByIssueID returns all comments of issue by given ID.

func (*Comment) AfterDelete added in v0.5.0

func (c *Comment) AfterDelete()

func (*Comment) AfterSet added in v0.6.5

func (c *Comment) AfterSet(colName string, _ xorm.Cell)

func (*Comment) EventTag added in v0.6.5

func (c *Comment) EventTag() string

EventTag returns unique event hash tag for comment.

func (*Comment) HashTag added in v0.6.5

func (c *Comment) HashTag() string

HashTag returns unique hash tag for comment.

type CommentTag added in v0.6.5

type CommentTag int
const (
	COMMENT_TAG_NONE CommentTag = iota
	COMMENT_TAG_POSTER
	COMMENT_TAG_ADMIN
	COMMENT_TAG_OWNER
)

type CommentType added in v0.5.0

type CommentType int

CommentType defines whether a comment is just a simple comment, an action (like close) or a reference.

const (
	// Plain comment, can be associated with a commit (CommitId > 0) and a line (Line > 0)
	COMMENT_TYPE_COMMENT CommentType = iota
	COMMENT_TYPE_REOPEN
	COMMENT_TYPE_CLOSE

	// References.
	COMMENT_TYPE_ISSUE_REF
	// Reference from a commit (not part of a pull request)
	COMMENT_TYPE_COMMIT_REF
	// Reference from a comment
	COMMENT_TYPE_COMMENT_REF
	// Reference from a pull request
	COMMENT_TYPE_PULL_REF
)

type CreateRepoOptions added in v0.6.9

type CreateRepoOptions struct {
	Name        string
	Description string
	Gitignores  string
	License     string
	Readme      string
	IsPrivate   bool
	IsMirror    bool
	AutoInit    bool
}

type DeployKey added in v0.6.5

type DeployKey struct {
	ID                int64 `xorm:"pk autoincr"`
	KeyID             int64 `xorm:"UNIQUE(s) INDEX"`
	RepoID            int64 `xorm:"UNIQUE(s) INDEX"`
	Name              string
	Fingerprint       string
	Created           time.Time `xorm:"CREATED"`
	Updated           time.Time // Note: Updated must below Created for AfterSet.
	HasRecentActivity bool      `xorm:"-"`
	HasUsed           bool      `xorm:"-"`
}

DeployKey represents deploy key information and its relation with repository.

func GetDeployKeyByRepo added in v0.6.5

func GetDeployKeyByRepo(keyID, repoID int64) (*DeployKey, error)

GetDeployKeyByRepo returns deploy key by given public key ID and repository ID.

func ListDeployKeys added in v0.6.5

func ListDeployKeys(repoID int64) ([]*DeployKey, error)

ListDeployKeys returns all deploy keys by given repository ID.

func (*DeployKey) AfterSet added in v0.6.5

func (k *DeployKey) AfterSet(colName string, _ xorm.Cell)

type Diff

type Diff struct {
	TotalAddition, TotalDeletion int
	Files                        []*DiffFile
}

func GetDiffCommit added in v0.5.0

func GetDiffCommit(repoPath, commitId string, maxlines int) (*Diff, error)

func GetDiffRange added in v0.5.0

func GetDiffRange(repoPath, beforeCommitId string, afterCommitId string, maxlines int) (*Diff, error)

func ParsePatch

func ParsePatch(pid int64, maxlines int, cmd *exec.Cmd, reader io.Reader) (*Diff, error)

func (*Diff) NumFiles

func (diff *Diff) NumFiles() int

type DiffFile

type DiffFile struct {
	Name               string
	OldName            string
	Index              int
	Addition, Deletion int
	Type               int
	IsCreated          bool
	IsDeleted          bool
	IsBin              bool
	IsRenamed          bool
	Sections           []*DiffSection
}

type DiffLine

type DiffLine struct {
	LeftIdx  int
	RightIdx int
	Type     int
	Content  string
}

func (DiffLine) GetType

func (d DiffLine) GetType() int

type DiffSection

type DiffSection struct {
	Name  string
	Lines []*DiffLine
}

type EmailAddress added in v0.5.11

type EmailAddress struct {
	ID          int64  `xorm:"pk autoincr"`
	UID         int64  `xorm:"INDEX NOT NULL"`
	Email       string `xorm:"UNIQUE NOT NULL"`
	IsActivated bool
	IsPrimary   bool `xorm:"-"`
}

EmailAdresses is the list of all email addresses of a user. Can contain the primary email address, but is not obligatory

func GetEmailAddresses added in v0.5.11

func GetEmailAddresses(uid int64) ([]*EmailAddress, error)

GetEmailAddresses returns all e-mail addresses belongs to given user.

func VerifyActiveEmailCode added in v0.5.11

func VerifyActiveEmailCode(code, email string) *EmailAddress

verify active code when active account

func (*EmailAddress) Activate added in v0.5.11

func (email *EmailAddress) Activate() error

type Engine added in v0.5.8

type Engine interface {
	Delete(interface{}) (int64, error)
	Exec(string, ...interface{}) (sql.Result, error)
	Find(interface{}, ...interface{}) error
	Get(interface{}) (bool, error)
	Insert(...interface{}) (int64, error)
	InsertOne(interface{}) (int64, error)
	Id(interface{}) *xorm.Session
	Sql(string, ...interface{}) *xorm.Session
	Where(string, ...interface{}) *xorm.Session
}

Engine represents a xorm engine or session.

type ErrAccessTokenNotExist added in v0.5.8

type ErrAccessTokenNotExist struct {
	SHA string
}

func (ErrAccessTokenNotExist) Error added in v0.6.9

func (err ErrAccessTokenNotExist) Error() string

type ErrAttachmentNotExist added in v0.5.0

type ErrAttachmentNotExist struct {
	ID   int64
	UUID string
}

func (ErrAttachmentNotExist) Error added in v0.6.5

func (err ErrAttachmentNotExist) Error() string

type ErrCommentNotExist added in v0.6.9

type ErrCommentNotExist struct {
	ID int64
}

func (ErrCommentNotExist) Error added in v0.6.9

func (err ErrCommentNotExist) Error() string

type ErrDeployKeyAlreadyExist added in v0.6.5

type ErrDeployKeyAlreadyExist struct {
	KeyID  int64
	RepoID int64
}

func (ErrDeployKeyAlreadyExist) Error added in v0.6.5

func (err ErrDeployKeyAlreadyExist) Error() string

type ErrDeployKeyNameAlreadyUsed added in v0.6.5

type ErrDeployKeyNameAlreadyUsed struct {
	RepoID int64
	Name   string
}

func (ErrDeployKeyNameAlreadyUsed) Error added in v0.6.5

func (err ErrDeployKeyNameAlreadyUsed) Error() string

type ErrEmailAlreadyUsed

type ErrEmailAlreadyUsed struct {
	Email string
}

func (ErrEmailAlreadyUsed) Error added in v0.6.3

func (err ErrEmailAlreadyUsed) Error() string

type ErrInvalidCloneAddr added in v0.7.0

type ErrInvalidCloneAddr struct {
	IsURLError         bool
	IsInvalidPath      bool
	IsPermissionDenied bool
}

func (ErrInvalidCloneAddr) Error added in v0.7.0

func (err ErrInvalidCloneAddr) Error() string

type ErrIssueNotExist

type ErrIssueNotExist struct {
	ID     int64
	RepoID int64
	Index  int64
}

func (ErrIssueNotExist) Error added in v0.6.5

func (err ErrIssueNotExist) Error() string

type ErrKeyAlreadyExist

type ErrKeyAlreadyExist struct {
	OwnerID int64
	Content string
}

func (ErrKeyAlreadyExist) Error added in v0.6.5

func (err ErrKeyAlreadyExist) Error() string

type ErrKeyNameAlreadyUsed added in v0.6.5

type ErrKeyNameAlreadyUsed struct {
	OwnerID int64
	Name    string
}

func (ErrKeyNameAlreadyUsed) Error added in v0.6.5

func (err ErrKeyNameAlreadyUsed) Error() string

type ErrKeyNotExist

type ErrKeyNotExist struct {
	ID int64
}

func (ErrKeyNotExist) Error added in v0.6.5

func (err ErrKeyNotExist) Error() string

type ErrLabelNotExist added in v0.4.0

type ErrLabelNotExist struct {
	ID int64
}

func (ErrLabelNotExist) Error added in v0.6.5

func (err ErrLabelNotExist) Error() string

type ErrLastOrgOwner added in v0.5.0

type ErrLastOrgOwner struct {
	UID int64
}

func (ErrLastOrgOwner) Error added in v0.6.0

func (err ErrLastOrgOwner) Error() string

type ErrMilestoneNotExist added in v0.4.0

type ErrMilestoneNotExist struct {
	ID     int64
	RepoID int64
}

func (ErrMilestoneNotExist) Error added in v0.6.5

func (err ErrMilestoneNotExist) Error() string

type ErrNamePatternNotAllowed added in v0.6.3

type ErrNamePatternNotAllowed struct {
	Pattern string
}

func (ErrNamePatternNotAllowed) Error added in v0.6.3

func (err ErrNamePatternNotAllowed) Error() string

type ErrNameReserved added in v0.6.3

type ErrNameReserved struct {
	Name string
}

func (ErrNameReserved) Error added in v0.6.3

func (err ErrNameReserved) Error() string

type ErrPullRequestNotExist added in v0.6.9

type ErrPullRequestNotExist struct {
	ID         int64
	IssueID    int64
	HeadRepoID int64
	BaseRepoID int64
	HeadBarcnh string
	BaseBranch string
}

func (ErrPullRequestNotExist) Error added in v0.6.9

func (err ErrPullRequestNotExist) Error() string

type ErrRepoAlreadyExist

type ErrRepoAlreadyExist struct {
	Uname string
	Name  string
}

func (ErrRepoAlreadyExist) Error added in v0.6.5

func (err ErrRepoAlreadyExist) Error() string

type ErrRepoNotExist

type ErrRepoNotExist struct {
	ID   int64
	UID  int64
	Name string
}

func (ErrRepoNotExist) Error added in v0.6.0

func (err ErrRepoNotExist) Error() string

type ErrUpdateTaskNotExist added in v0.7.0

type ErrUpdateTaskNotExist struct {
	UUID string
}

func (ErrUpdateTaskNotExist) Error added in v0.7.0

func (err ErrUpdateTaskNotExist) Error() string

type ErrUserAlreadyExist

type ErrUserAlreadyExist struct {
	Name string
}

func (ErrUserAlreadyExist) Error added in v0.6.3

func (err ErrUserAlreadyExist) Error() string

type ErrUserHasOrgs added in v0.5.0

type ErrUserHasOrgs struct {
	UID int64
}

func (ErrUserHasOrgs) Error added in v0.6.0

func (err ErrUserHasOrgs) Error() string

type ErrUserNotExist

type ErrUserNotExist struct {
	UID  int64
	Name string
}

func (ErrUserNotExist) Error added in v0.6.5

func (err ErrUserNotExist) Error() string

type ErrUserOwnRepos

type ErrUserOwnRepos struct {
	UID int64
}

func (ErrUserOwnRepos) Error added in v0.6.0

func (err ErrUserOwnRepos) Error() string

type ErrWebhookNotExist added in v0.4.0

type ErrWebhookNotExist struct {
	ID int64
}

func (ErrWebhookNotExist) Error added in v0.6.9

func (err ErrWebhookNotExist) Error() string

type Follow

type Follow struct {
	ID       int64 `xorm:"pk autoincr"`
	UserID   int64 `xorm:"UNIQUE(follow)"`
	FollowID int64 `xorm:"UNIQUE(follow)"`
}

Follow is connection request for receiving user notification.

type HookContentType added in v0.5.0

type HookContentType int
const (
	JSON HookContentType = iota + 1
	FORM
)

func ToHookContentType added in v0.5.8

func ToHookContentType(name string) HookContentType

ToHookContentType returns HookContentType by given name.

func (HookContentType) Name added in v0.5.8

func (t HookContentType) Name() string

type HookEvent added in v0.4.0

type HookEvent struct {
	PushOnly       bool `json:"push_only"`
	SendEverything bool `json:"send_everything"`
	ChooseEvents   bool `json:"choose_events"`

	HookEvents `json:"events"`
}

HookEvent represents events that will delivery hook.

type HookEventType added in v0.5.0

type HookEventType string
const (
	HOOK_EVENT_CREATE HookEventType = "create"
	HOOK_EVENT_PUSH   HookEventType = "push"
)

type HookEvents added in v0.6.9

type HookEvents struct {
	Create bool `json:"create"`
	Push   bool `json:"push"`
}

type HookRequest added in v0.6.9

type HookRequest struct {
	Headers map[string]string `json:"headers"`
}

HookRequest represents hook task request information.

type HookResponse added in v0.6.9

type HookResponse struct {
	Status  int               `json:"status"`
	Headers map[string]string `json:"headers"`
	Body    string            `json:"body"`
}

HookResponse represents hook task response information.

type HookStatus added in v0.6.9

type HookStatus int

type HookTask added in v0.5.0

type HookTask struct {
	ID              int64 `xorm:"pk autoincr"`
	RepoID          int64 `xorm:"INDEX"`
	HookID          int64
	UUID            string
	Type            HookTaskType
	URL             string
	api.Payloader   `xorm:"-"`
	PayloadContent  string `xorm:"TEXT"`
	ContentType     HookContentType
	EventType       HookEventType
	IsSSL           bool
	IsDelivered     bool
	Delivered       int64
	DeliveredString string `xorm:"-"`

	// History info.
	IsSucceed       bool
	RequestContent  string        `xorm:"TEXT"`
	RequestInfo     *HookRequest  `xorm:"-"`
	ResponseContent string        `xorm:"TEXT"`
	ResponseInfo    *HookResponse `xorm:"-"`
}

HookTask represents a hook task.

func HookTasks added in v0.6.9

func HookTasks(hookID int64, page int) ([]*HookTask, error)

HookTasks returns a list of hook tasks by given conditions.

func (*HookTask) AfterSet added in v0.6.9

func (t *HookTask) AfterSet(colName string, _ xorm.Cell)

func (*HookTask) BeforeUpdate added in v0.6.9

func (t *HookTask) BeforeUpdate()

func (*HookTask) MarshalJSON added in v0.6.9

func (t *HookTask) MarshalJSON(v interface{}) string

type HookTaskType added in v0.5.0

type HookTaskType int
const (
	GOGS HookTaskType = iota + 1
	SLACK
)

func ToHookTaskType added in v0.5.8

func ToHookTaskType(name string) HookTaskType

ToHookTaskType returns HookTaskType by given name.

func (HookTaskType) Name added in v0.5.8

func (t HookTaskType) Name() string

type Issue

type Issue struct {
	ID              int64 `xorm:"pk autoincr"`
	RepoID          int64 `xorm:"INDEX"`
	Index           int64 // Index in one repository.
	Name            string
	Repo            *Repository `xorm:"-"`
	PosterID        int64
	Poster          *User    `xorm:"-"`
	Labels          []*Label `xorm:"-"`
	MilestoneID     int64
	Milestone       *Milestone `xorm:"-"`
	AssigneeID      int64
	Assignee        *User `xorm:"-"`
	IsRead          bool  `xorm:"-"`
	IsPull          bool  // Indicates whether is a pull request or not.
	*PullRequest    `xorm:"-"`
	IsClosed        bool
	Content         string `xorm:"TEXT"`
	RenderedContent string `xorm:"-"`
	Priority        int
	NumComments     int
	Deadline        time.Time
	Created         time.Time `xorm:"CREATED"`
	Updated         time.Time `xorm:"UPDATED"`

	Attachments []*Attachment `xorm:"-"`
	Comments    []*Comment    `xorm:"-"`
}

Issue represents an issue or pull request of repository.

func GetIssueByID added in v0.6.5

func GetIssueByID(id int64) (*Issue, error)

GetIssueByID returns an issue by given ID.

func GetIssueByIndex

func GetIssueByIndex(repoID, index int64) (*Issue, error)

GetIssueByIndex returns issue by given index in repository.

func GetIssueByRef added in v0.5.0

func GetIssueByRef(ref string) (*Issue, error)

GetIssueByRef returns an Issue specified by a GFM reference. See https://help.github.com/articles/writing-on-github#references for more information on the syntax.

func Issues added in v0.6.5

func Issues(opts *IssuesOptions) ([]*Issue, error)

Issues returns a list of issues by given conditions.

func (*Issue) AddLabel added in v0.6.5

func (i *Issue) AddLabel(label *Label) (err error)

AddLabel adds new label to issue by given ID.

func (*Issue) AfterSet added in v0.6.5

func (i *Issue) AfterSet(colName string, _ xorm.Cell)

func (*Issue) ChangeStatus added in v0.6.5

func (i *Issue) ChangeStatus(doer *User, isClosed bool) (err error)

ChangeStatus changes issue status to open/closed.

func (*Issue) ClearLabels added in v0.6.5

func (i *Issue) ClearLabels() (err error)

func (*Issue) GetAssignee added in v0.4.0

func (i *Issue) GetAssignee() (err error)

func (*Issue) GetLabels added in v0.4.0

func (i *Issue) GetLabels() error

GetLabels retrieves all labels of issue and assign to corresponding field.

func (*Issue) GetPoster added in v0.4.0

func (i *Issue) GetPoster() (err error)

func (*Issue) GetPullRequest added in v0.7.0

func (i *Issue) GetPullRequest() (err error)

func (*Issue) HasLabel added in v0.6.5

func (i *Issue) HasLabel(labelID int64) bool

HasLabel returns true if issue has been labeled by given ID.

func (*Issue) HashTag added in v0.6.5

func (i *Issue) HashTag() string

HashTag returns unique hash tag for issue.

func (*Issue) IsPoster added in v0.6.5

func (i *Issue) IsPoster(uid int64) bool

IsPoster returns true if given user by ID is the poster.

func (*Issue) ReadBy added in v0.6.5

func (i *Issue) ReadBy(uid int64) error

ReadBy sets issue to be read by given user.

func (*Issue) RemoveLabel added in v0.6.5

func (i *Issue) RemoveLabel(label *Label) (err error)

RemoveLabel removes a label from issue by given ID.

type IssueLabel added in v0.6.5

type IssueLabel struct {
	ID      int64 `xorm:"pk autoincr"`
	IssueID int64 `xorm:"UNIQUE(s)"`
	LabelID int64 `xorm:"UNIQUE(s)"`
}

IssueLabel represetns an issue-lable relation.

func GetIssueLabels added in v0.6.5

func GetIssueLabels(issueID int64) ([]*IssueLabel, error)

GetIssueLabels returns all issue-label relations of given issue by ID.

type IssueStats added in v0.4.0

type IssueStats struct {
	OpenCount, ClosedCount int64
	AllCount               int64
	AssignCount            int64
	CreateCount            int64
	MentionCount           int64
}

IssueStats represents issue statistic information.

func GetIssueStats added in v0.4.0

func GetIssueStats(opts *IssueStatsOptions) *IssueStats

GetIssueStats returns issue statistic information by given conditions.

func GetUserIssueStats added in v0.4.0

func GetUserIssueStats(repoID, uid int64, repoIDs []int64, filterMode int, isPull bool) *IssueStats

GetUserIssueStats returns issue statistic information for dashboard by given conditions.

type IssueStatsOptions added in v0.6.9

type IssueStatsOptions struct {
	RepoID      int64
	UserID      int64
	LabelID     int64
	MilestoneID int64
	AssigneeID  int64
	FilterMode  int
	IsPull      bool
}

type IssueStatus added in v0.4.0

type IssueStatus int

type IssueUser added in v0.4.0

type IssueUser struct {
	ID          int64 `xorm:"pk autoincr"`
	UID         int64 `xorm:"INDEX"` // User ID.
	IssueID     int64
	RepoID      int64 `xorm:"INDEX"`
	MilestoneID int64
	IsRead      bool
	IsAssigned  bool
	IsMentioned bool
	IsPoster    bool
	IsClosed    bool
}

IssueUser represents an issue-user relation.

func GetIssueUserPairsByMode added in v0.4.0

func GetIssueUserPairsByMode(uid, rid int64, isClosed bool, page, filterMode int) ([]*IssueUser, error)

GetIssueUserPairsByMode returns issue-user pairs by given repository and user.

func GetIssueUserPairsByRepoIds added in v0.4.0

func GetIssueUserPairsByRepoIds(rids []int64, isClosed bool, page int) ([]*IssueUser, error)

GetIssueUserPairsByRepoIds returns issue-user pairs by given repository IDs.

func GetIssueUsers added in v0.6.5

func GetIssueUsers(rid, uid int64, isClosed bool) ([]*IssueUser, error)

GetIssueUsers returns issue-user pairs by given repository and user.

type IssuesOptions added in v0.6.9

type IssuesOptions struct {
	UserID      int64
	AssigneeID  int64
	RepoID      int64
	PosterID    int64
	MilestoneID int64
	RepoIDs     []int64
	Page        int
	IsClosed    bool
	IsMention   bool
	IsPull      bool
	Labels      string
	SortType    string
}

type KeyType added in v0.6.5

type KeyType int

type LDAPConfig added in v0.4.0

type LDAPConfig struct {
	*ldap.Source
}

func (*LDAPConfig) FromDB added in v0.4.0

func (cfg *LDAPConfig) FromDB(bs []byte) error

func (*LDAPConfig) ToDB added in v0.4.0

func (cfg *LDAPConfig) ToDB() ([]byte, error)

type Label

type Label struct {
	ID              int64 `xorm:"pk autoincr"`
	RepoID          int64 `xorm:"INDEX"`
	Name            string
	Color           string `xorm:"VARCHAR(7)"`
	NumIssues       int
	NumClosedIssues int
	NumOpenIssues   int  `xorm:"-"`
	IsChecked       bool `xorm:"-"`
}

Label represents a label of repository for issues.

func GetLabelByID added in v0.6.5

func GetLabelByID(id int64) (*Label, error)

GetLabelByID returns a label by given ID.

func GetLabelsByIssueID added in v0.6.5

func GetLabelsByIssueID(issueID int64) ([]*Label, error)

GetLabelsByIssueID returns all labels that belong to given issue by ID.

func GetLabelsByRepoID added in v0.6.5

func GetLabelsByRepoID(repoID int64) ([]*Label, error)

GetLabelsByRepoID returns all labels that belong to given repository by ID.

func (*Label) CalOpenIssues added in v0.4.0

func (m *Label) CalOpenIssues()

CalOpenIssues calculates the open issues of label.

type LoginSource added in v0.4.0

type LoginSource struct {
	ID        int64 `xorm:"pk autoincr"`
	Type      LoginType
	Name      string          `xorm:"UNIQUE"`
	IsActived bool            `xorm:"NOT NULL DEFAULT false"`
	Cfg       core.Conversion `xorm:"TEXT"`
	Created   time.Time       `xorm:"CREATED"`
	Updated   time.Time       `xorm:"UPDATED"`
}

func GetLoginSourceByID added in v0.6.9

func GetLoginSourceByID(id int64) (*LoginSource, error)

func LoginSources added in v0.6.15

func LoginSources() ([]*LoginSource, error)

func (*LoginSource) BeforeSet added in v0.4.0

func (source *LoginSource) BeforeSet(colName string, val xorm.Cell)

func (*LoginSource) IsDLDAP added in v0.6.15

func (source *LoginSource) IsDLDAP() bool

func (*LoginSource) IsLDAP added in v0.6.15

func (source *LoginSource) IsLDAP() bool

func (*LoginSource) IsPAM added in v0.6.15

func (source *LoginSource) IsPAM() bool

func (*LoginSource) IsSMTP added in v0.6.15

func (source *LoginSource) IsSMTP() bool

func (*LoginSource) LDAP added in v0.4.0

func (source *LoginSource) LDAP() *LDAPConfig

func (*LoginSource) PAM added in v0.6.3

func (source *LoginSource) PAM() *PAMConfig

func (*LoginSource) SMTP added in v0.4.0

func (source *LoginSource) SMTP() *SMTPConfig

func (*LoginSource) SkipVerify added in v0.6.15

func (source *LoginSource) SkipVerify() bool

func (*LoginSource) TypeName added in v0.6.15

func (source *LoginSource) TypeName() string

func (*LoginSource) UseTLS added in v0.6.15

func (source *LoginSource) UseTLS() bool

type LoginType added in v0.5.0

type LoginType int
const (
	NOTYPE LoginType = iota
	PLAIN
	LDAP
	SMTP
	PAM
	DLDAP
)

Note: new type must be added at the end of list to maintain compatibility.

type MigrateRepoOptions added in v0.7.0

type MigrateRepoOptions struct {
	Name        string
	Description string
	IsPrivate   bool
	IsMirror    bool
	RemoteAddr  string
}

type Milestone

type Milestone struct {
	ID              int64 `xorm:"pk autoincr"`
	RepoID          int64 `xorm:"INDEX"`
	Name            string
	Content         string `xorm:"TEXT"`
	RenderedContent string `xorm:"-"`
	IsClosed        bool
	NumIssues       int
	NumClosedIssues int
	NumOpenIssues   int `xorm:"-"`
	Completeness    int // Percentage(1-100).
	Deadline        time.Time
	DeadlineString  string `xorm:"-"`
	IsOverDue       bool   `xorm:"-"`
	ClosedDate      time.Time
}

Milestone represents a milestone of repository.

func GetAllRepoMilestones added in v0.6.5

func GetAllRepoMilestones(repoID int64) ([]*Milestone, error)

GetAllRepoMilestones returns all milestones of given repository.

func GetMilestoneByID added in v0.6.5

func GetMilestoneByID(id int64) (*Milestone, error)

GetMilestoneByID returns the milestone of given ID.

func GetMilestones added in v0.4.0

func GetMilestones(repoID int64, page int, isClosed bool) ([]*Milestone, error)

GetMilestones returns a list of milestones of given repository and status.

func GetRepoMilestoneByID added in v0.6.5

func GetRepoMilestoneByID(repoID, milestoneID int64) (*Milestone, error)

GetRepoMilestoneByID returns the milestone of given ID and repository.

func (*Milestone) AfterSet added in v0.6.5

func (m *Milestone) AfterSet(colName string, _ xorm.Cell)

func (*Milestone) BeforeUpdate added in v0.6.5

func (m *Milestone) BeforeUpdate()

func (*Milestone) CalOpenIssues added in v0.4.0

func (m *Milestone) CalOpenIssues()

CalOpenIssues calculates the open issues of milestone.

type Mirror added in v0.3.0

type Mirror struct {
	ID         int64 `xorm:"pk autoincr"`
	RepoID     int64
	Repo       *Repository `xorm:"-"`
	Interval   int         // Hour.
	Updated    time.Time   `xorm:"UPDATED"`
	NextUpdate time.Time
}

Mirror represents a mirror information of repository.

func GetMirror added in v0.3.0

func GetMirror(repoId int64) (*Mirror, error)

GetMirror returns mirror object by given repository ID.

func (*Mirror) AfterSet added in v0.6.9

func (m *Mirror) AfterSet(colName string, _ xorm.Cell)

type Notice added in v0.5.5

type Notice struct {
	Id          int64
	Type        NoticeType
	Description string    `xorm:"TEXT"`
	Created     time.Time `xorm:"CREATED"`
}

Notice represents a system notice for admin.

func Notices added in v0.6.15

func Notices(page, pageSize int) ([]*Notice, error)

Notices returns number of notices in given page.

func (*Notice) TrStr added in v0.5.5

func (n *Notice) TrStr() string

TrStr returns a translation format string.

type NoticeType added in v0.5.5

type NoticeType int
const (
	NOTICE_REPOSITORY NoticeType = iota + 1
)

type OrgUser added in v0.5.0

type OrgUser struct {
	ID       int64 `xorm:"pk autoincr"`
	Uid      int64 `xorm:"INDEX UNIQUE(s)"`
	OrgID    int64 `xorm:"INDEX UNIQUE(s)"`
	IsPublic bool
	IsOwner  bool
	NumTeams int
}

OrgUser represents an organization-user relation.

func GetOrgUsersByOrgId added in v0.5.0

func GetOrgUsersByOrgId(orgId int64) ([]*OrgUser, error)

GetOrgUsersByOrgId returns all organization-user relations by organization ID.

func GetOrgUsersByUserId added in v0.5.0

func GetOrgUsersByUserId(uid int64) ([]*OrgUser, error)

GetOrgUsersByUserId returns all organization-user relations by user ID.

type PAMConfig added in v0.6.3

type PAMConfig struct {
	ServiceName string // pam service (e.g. system-auth)
}

func (*PAMConfig) FromDB added in v0.6.3

func (cfg *PAMConfig) FromDB(bs []byte) error

func (*PAMConfig) ToDB added in v0.6.3

func (cfg *PAMConfig) ToDB() ([]byte, error)

type PublicKey

type PublicKey struct {
	ID                int64      `xorm:"pk autoincr"`
	OwnerID           int64      `xorm:"INDEX NOT NULL"`
	Name              string     `xorm:"NOT NULL"`
	Fingerprint       string     `xorm:"NOT NULL"`
	Content           string     `xorm:"TEXT NOT NULL"`
	Mode              AccessMode `xorm:"NOT NULL DEFAULT 2"`
	Type              KeyType    `xorm:"NOT NULL DEFAULT 1"`
	Created           time.Time  `xorm:"CREATED"`
	Updated           time.Time  // Note: Updated must below Created for AfterSet.
	HasRecentActivity bool       `xorm:"-"`
	HasUsed           bool       `xorm:"-"`
}

PublicKey represents a SSH or deploy key.

func GetPublicKeyByID added in v0.6.5

func GetPublicKeyByID(keyID int64) (*PublicKey, error)

GetPublicKeyByID returns public key by given ID.

func ListPublicKeys added in v0.5.8

func ListPublicKeys(uid int64) ([]*PublicKey, error)

ListPublicKeys returns a list of public keys belongs to given user.

func (*PublicKey) AfterSet added in v0.6.5

func (k *PublicKey) AfterSet(colName string, _ xorm.Cell)

func (*PublicKey) GetAuthorizedString added in v0.4.0

func (key *PublicKey) GetAuthorizedString() string

GetAuthorizedString generates and returns formatted public key string for authorized_keys file.

func (*PublicKey) OmitEmail added in v0.5.9

func (k *PublicKey) OmitEmail() string

OmitEmail returns content of public key but without e-mail address.

type PullRequest added in v0.6.9

type PullRequest struct {
	ID     int64 `xorm:"pk autoincr"`
	Type   PullRequestType
	Status PullRequestStatus

	IssueID int64  `xorm:"INDEX"`
	Issue   *Issue `xorm:"-"`
	Index   int64

	HeadRepoID   int64
	HeadRepo     *Repository `xorm:"-"`
	BaseRepoID   int64
	BaseRepo     *Repository `xorm:"-"`
	HeadUserName string
	HeadBranch   string
	BaseBranch   string
	MergeBase    string `xorm:"VARCHAR(40)"`

	HasMerged      bool
	MergedCommitID string `xorm:"VARCHAR(40)"`
	Merged         time.Time
	MergerID       int64
	Merger         *User `xorm:"-"`
}

PullRequest represents relation between pull request and repositories.

func GetPullRequestByID added in v0.7.0

func GetPullRequestByID(id int64) (*PullRequest, error)

GetPullRequestByID returns a pull request by given ID.

func GetPullRequestByIssueID added in v0.7.0

func GetPullRequestByIssueID(issueID int64) (*PullRequest, error)

GetPullRequestByIssueID returns pull request by given issue ID.

func GetUnmergedPullRequest added in v0.6.9

func GetUnmergedPullRequest(headRepoID, baseRepoID int64, headBranch, baseBranch string) (*PullRequest, error)

GetUnmergedPullRequest returnss a pull request that is open and has not been merged by given head/base and repo/branch.

func GetUnmergedPullRequestsByBaseInfo added in v0.7.0

func GetUnmergedPullRequestsByBaseInfo(repoID int64, branch string) ([]*PullRequest, error)

GetUnmergedPullRequestsByBaseInfo returnss all pull requests that are open and has not been merged by given base information (repo and branch).

func GetUnmergedPullRequestsByHeadInfo added in v0.7.0

func GetUnmergedPullRequestsByHeadInfo(repoID int64, branch string) ([]*PullRequest, error)

GetUnmergedPullRequestsByHeadInfo returnss all pull requests that are open and has not been merged by given head information (repo and branch).

func (*PullRequest) AddToTaskQueue added in v0.7.0

func (pr *PullRequest) AddToTaskQueue()

AddToTaskQueue adds itself to pull request test task queue.

func (*PullRequest) AfterSet added in v0.6.9

func (pr *PullRequest) AfterSet(colName string, _ xorm.Cell)

Note: don't try to get Pull because will end up recursive querying.

func (*PullRequest) CanAutoMerge added in v0.6.9

func (pr *PullRequest) CanAutoMerge() bool

CanAutoMerge returns true if this pull request can be merged automatically.

func (*PullRequest) GetBaseRepo added in v0.7.0

func (pr *PullRequest) GetBaseRepo() (err error)

func (*PullRequest) GetHeadRepo added in v0.7.0

func (pr *PullRequest) GetHeadRepo() (err error)

func (*PullRequest) GetMerger added in v0.7.0

func (pr *PullRequest) GetMerger() (err error)

func (*PullRequest) IsChecking added in v0.7.0

func (pr *PullRequest) IsChecking() bool

IsChecking returns true if this pull request is still checking conflict.

func (*PullRequest) Merge added in v0.6.9

func (pr *PullRequest) Merge(doer *User, baseGitRepo *git.Repository) (err error)

Merge merges pull request to base repository.

func (*PullRequest) Update added in v0.7.0

func (pr *PullRequest) Update() error

Update updates all fields of pull request.

func (*PullRequest) UpdateCols added in v0.7.0

func (pr *PullRequest) UpdateCols(cols ...string) error

Update updates specific fields of pull request.

func (*PullRequest) UpdatePatch added in v0.7.0

func (pr *PullRequest) UpdatePatch() (err error)

UpdatePatch generates and saves a new patch.

type PullRequestStatus added in v0.7.0

type PullRequestStatus int
const (
	PULL_REQUEST_STATUS_CONFLICT PullRequestStatus = iota
	PULL_REQUEST_STATUS_CHECKING
	PULL_REQUEST_STATUS_MERGEABLE
)

type PullRequestType added in v0.6.9

type PullRequestType int
const (
	PULL_REQUEST_GOGS PullRequestType = iota
	PLLL_ERQUEST_GIT
)

type Release added in v0.3.0

type Release struct {
	Id               int64
	RepoId           int64
	PublisherId      int64
	Publisher        *User `xorm:"-"`
	TagName          string
	LowerTagName     string
	Target           string
	Title            string
	Sha1             string `xorm:"VARCHAR(40)"`
	NumCommits       int
	NumCommitsBehind int    `xorm:"-"`
	Note             string `xorm:"TEXT"`
	IsDraft          bool   `xorm:"NOT NULL DEFAULT false"`
	IsPrerelease     bool
	Created          time.Time `xorm:"CREATED"`
}

Release represents a release of repository.

func GetRelease added in v0.5.0

func GetRelease(repoId int64, tagName string) (*Release, error)

GetRelease returns release by given ID.

func GetReleasesByRepoId added in v0.3.0

func GetReleasesByRepoId(repoId int64) (rels []*Release, err error)

GetReleasesByRepoId returns a list of releases of repository.

func (*Release) AfterSet added in v0.6.9

func (r *Release) AfterSet(colName string, _ xorm.Cell)

type ReleaseSorter added in v0.5.0

type ReleaseSorter struct {
	// contains filtered or unexported fields
}

func (*ReleaseSorter) Len added in v0.5.0

func (rs *ReleaseSorter) Len() int

func (*ReleaseSorter) Less added in v0.5.0

func (rs *ReleaseSorter) Less(i, j int) bool

func (*ReleaseSorter) Swap added in v0.5.0

func (rs *ReleaseSorter) Swap(i, j int)

type Repository

type Repository struct {
	ID            int64  `xorm:"pk autoincr"`
	OwnerID       int64  `xorm:"UNIQUE(s)"`
	Owner         *User  `xorm:"-"`
	LowerName     string `xorm:"UNIQUE(s) INDEX NOT NULL"`
	Name          string `xorm:"INDEX NOT NULL"`
	Description   string
	Website       string
	DefaultBranch string

	NumWatches          int
	NumStars            int
	NumForks            int
	NumIssues           int
	NumClosedIssues     int
	NumOpenIssues       int `xorm:"-"`
	NumPulls            int
	NumClosedPulls      int
	NumOpenPulls        int `xorm:"-"`
	NumMilestones       int `xorm:"NOT NULL DEFAULT 0"`
	NumClosedMilestones int `xorm:"NOT NULL DEFAULT 0"`
	NumOpenMilestones   int `xorm:"-"`
	NumTags             int `xorm:"-"`

	IsPrivate bool
	IsBare    bool

	IsMirror bool
	*Mirror  `xorm:"-"`

	IsFork   bool `xorm:"NOT NULL DEFAULT false"`
	ForkID   int64
	BaseRepo *Repository `xorm:"-"`

	Created time.Time `xorm:"CREATED"`
	Updated time.Time `xorm:"UPDATED"`
}

Repository represents a git repository.

func CreateRepository

func CreateRepository(u *User, opts CreateRepoOptions) (_ *Repository, err error)

CreateRepository creates a repository for given user or organization.

func ForkRepository

func ForkRepository(u *User, oldRepo *Repository, name, desc string) (_ *Repository, err error)

func GetRecentUpdatedRepositories added in v0.3.0

func GetRecentUpdatedRepositories(page int) (repos []*Repository, err error)

GetRecentUpdatedRepositories returns the list of repositories that are recently updated.

func GetRepositories

func GetRepositories(uid int64, private bool) ([]*Repository, error)

GetRepositories returns a list of repositories of given user.

func GetRepositoriesByForkID added in v0.6.9

func GetRepositoriesByForkID(forkID int64) ([]*Repository, error)

GetRepositoriesByForkID returns all repositories with given fork ID.

func GetRepositoryByID added in v0.6.5

func GetRepositoryByID(id int64) (*Repository, error)

GetRepositoryByID returns the repository by given id if exists.

func GetRepositoryByName

func GetRepositoryByName(uid int64, repoName string) (*Repository, error)

GetRepositoryByName returns the repository by given name under user if exists.

func GetRepositoryByRef added in v0.5.0

func GetRepositoryByRef(ref string) (*Repository, error)

GetRepositoryByRef returns a Repository specified by a GFM reference. See https://help.github.com/articles/writing-on-github#references for more information on the syntax.

func HasForkedRepo added in v0.6.5

func HasForkedRepo(ownerID, repoID int64) (*Repository, bool)

HasForkedRepo checks if given user has already forked a repository with given ID.

func MigrateRepository added in v0.3.0

func MigrateRepository(u *User, opts MigrateRepoOptions) (*Repository, error)

MigrateRepository migrates a existing repository from other project hosting.

func RepositoriesWithUsers added in v0.6.15

func RepositoriesWithUsers(page, pageSize int) (_ []*Repository, err error)

RepositoriesWithUsers returns number of repos in given page.

func SearchRepositoryByName added in v0.5.0

func SearchRepositoryByName(opt SearchOption) (repos []*Repository, err error)

SearchRepositoryByName returns given number of repositories whose name contains keyword.

func (*Repository) AddCollaborator added in v0.6.0

func (repo *Repository) AddCollaborator(u *User) error

Add collaborator and accompanying access

func (*Repository) AfterSet added in v0.6.9

func (repo *Repository) AfterSet(colName string, _ xorm.Cell)

func (*Repository) CanBeForked added in v0.6.15

func (repo *Repository) CanBeForked() bool

CanBeForked returns true if repository meets the requirements of being forked.

func (repo *Repository) CloneLink() (cl CloneLink, err error)

CloneLink returns clone URLs of repository.

func (*Repository) DeleteCollaborator added in v0.6.0

func (repo *Repository) DeleteCollaborator(u *User) (err error)

Delete collaborator and accompanying access

func (*Repository) DescriptionHtml added in v0.5.0

func (repo *Repository) DescriptionHtml() template.HTML

DescriptionHtml does special handles to description and return HTML string.

func (*Repository) GetAssigneeByID added in v0.6.5

func (repo *Repository) GetAssigneeByID(userID int64) (*User, error)

GetAssigneeByID returns the user that has write access of repository by given ID.

func (*Repository) GetAssignees added in v0.6.5

func (repo *Repository) GetAssignees() (_ []*User, err error)

GetAssignees returns all users that have write access of repository.

func (*Repository) GetBaseRepo added in v0.6.5

func (repo *Repository) GetBaseRepo() (err error)

func (*Repository) GetCollaborators added in v0.6.0

func (repo *Repository) GetCollaborators() ([]*User, error)

GetCollaborators returns the collaborators for a repository

func (*Repository) GetForks added in v0.7.0

func (repo *Repository) GetForks() ([]*Repository, error)

func (*Repository) GetMilestoneByID added in v0.6.5

func (repo *Repository) GetMilestoneByID(milestoneID int64) (*Milestone, error)

GetMilestoneByID returns the milestone belongs to repository by given ID.

func (*Repository) GetMirror added in v0.5.0

func (repo *Repository) GetMirror() (err error)

func (*Repository) GetOwner added in v0.4.0

func (repo *Repository) GetOwner() error

func (*Repository) GetStars added in v0.7.0

func (repo *Repository) GetStars(offset int) ([]*User, error)

func (*Repository) GetWatchers added in v0.7.0

func (repo *Repository) GetWatchers(offset int) ([]*User, error)

Repository.GetWatchers returns all users watching given repository.

func (*Repository) HasAccess added in v0.5.5

func (repo *Repository) HasAccess(u *User) bool

func (*Repository) IsOwnedBy added in v0.5.8

func (repo *Repository) IsOwnedBy(userID int64) bool

func (*Repository) IssueStats added in v0.6.9

func (repo *Repository) IssueStats(uid int64, filterMode int, isPull bool) (int64, int64)

IssueStats returns number of open and closed repository issues by given filter mode.

func (*Repository) LocalCopyPath added in v0.7.0

func (repo *Repository) LocalCopyPath() string

func (*Repository) NextIssueIndex added in v0.6.9

func (repo *Repository) NextIssueIndex() int64

func (*Repository) PatchPath added in v0.7.0

func (repo *Repository) PatchPath(index int64) (string, error)

PatchPath returns corresponding patch file path of repository by given issue ID.

func (*Repository) RecalculateAccesses added in v0.6.0

func (r *Repository) RecalculateAccesses() error

RecalculateAccesses recalculates all accesses for repository.

func (repo *Repository) RepoLink() (string, error)

func (*Repository) RepoPath added in v0.5.8

func (repo *Repository) RepoPath() (string, error)

func (*Repository) SavePatch added in v0.7.0

func (repo *Repository) SavePatch(index int64, patch []byte) error

SavePatch saves patch data to corresponding location by given issue ID.

func (*Repository) UpdateLocalCopy added in v0.7.0

func (repo *Repository) UpdateLocalCopy() error

UpdateLocalCopy makes sure the local copy of repository is up-to-date.

type SMTPConfig added in v0.4.0

type SMTPConfig struct {
	Auth           string
	Host           string
	Port           int
	AllowedDomains string `xorm:"TEXT"`
	TLS            bool
	SkipVerify     bool
}

func (*SMTPConfig) FromDB added in v0.4.0

func (cfg *SMTPConfig) FromDB(bs []byte) error

func (*SMTPConfig) ToDB added in v0.4.0

func (cfg *SMTPConfig) ToDB() ([]byte, error)

type SearchOption added in v0.5.0

type SearchOption struct {
	Keyword string
	Uid     int64
	Limit   int
	Private bool
}

type SlackAttachment added in v0.5.0

type SlackAttachment struct {
	Color string `json:"color"`
	Text  string `json:"text"`
}

type SlackMeta added in v0.6.9

type SlackMeta struct {
	Channel  string `json:"channel"`
	Username string `json:"username"`
	IconURL  string `json:"icon_url"`
	Color    string `json:"color"`
}

type SlackPayload added in v0.5.0

type SlackPayload struct {
	Channel     string            `json:"channel"`
	Text        string            `json:"text"`
	Username    string            `json:"username"`
	IconURL     string            `json:"icon_url"`
	UnfurlLinks int               `json:"unfurl_links"`
	LinkNames   int               `json:"link_names"`
	Attachments []SlackAttachment `json:"attachments"`
}

func GetSlackPayload added in v0.5.0

func GetSlackPayload(p api.Payloader, event HookEventType, meta string) (*SlackPayload, error)

func (*SlackPayload) JSONPayload added in v0.6.9

func (p *SlackPayload) JSONPayload() ([]byte, error)

func (*SlackPayload) SetSecret added in v0.6.9

func (p *SlackPayload) SetSecret(_ string)

type Star added in v0.5.0

type Star struct {
	ID     int64 `xorm:"pk autoincr"`
	UID    int64 `xorm:"UNIQUE(s)"`
	RepoID int64 `xorm:"UNIQUE(s)"`
}

type Statistic

type Statistic struct {
	Counter struct {
		User, Org, PublicKey,
		Repo, Watch, Star, Action, Access,
		Issue, Comment, Oauth, Follow,
		Mirror, Release, LoginSource, Webhook,
		Milestone, Label, HookTask,
		Team, UpdateTask, Attachment int64
	}
}

func GetStatistic

func GetStatistic() (stats Statistic)

type Team added in v0.5.0

type Team struct {
	ID          int64 `xorm:"pk autoincr"`
	OrgID       int64 `xorm:"INDEX"`
	LowerName   string
	Name        string
	Description string
	Authorize   AccessMode
	Repos       []*Repository `xorm:"-"`
	Members     []*User       `xorm:"-"`
	NumRepos    int
	NumMembers  int
}

Team represents a organization team.

func GetTeam added in v0.5.0

func GetTeam(orgId int64, name string) (*Team, error)

GetTeam returns team by given team name and organization.

func GetTeamById added in v0.5.0

func GetTeamById(teamId int64) (*Team, error)

GetTeamById returns team by given ID.

func GetUserTeams added in v0.5.0

func GetUserTeams(orgId, uid int64) ([]*Team, error)

GetUserTeams returns all teams that user belongs to in given organization.

func (*Team) AddMember added in v0.5.0

func (t *Team) AddMember(uid int64) error

AddMember adds new member to team of organization.

func (*Team) AddRepository added in v0.5.0

func (t *Team) AddRepository(repo *Repository) (err error)

AddRepository adds new repository to team of organization.

func (*Team) GetMembers added in v0.5.0

func (t *Team) GetMembers() (err error)

GetMembers returns all members in team of organization.

func (*Team) GetRepositories added in v0.5.0

func (t *Team) GetRepositories() error

GetRepositories returns all repositories in team of organization.

func (*Team) HasRepository added in v0.6.0

func (t *Team) HasRepository(repoID int64) bool

HasRepository returns true if given repository belong to team.

func (*Team) IsMember added in v0.5.0

func (t *Team) IsMember(uid int64) bool

IsTeamMember returns true if given user is a member of team.

func (*Team) IsOwnerTeam added in v0.5.0

func (t *Team) IsOwnerTeam() bool

IsOwnerTeam returns true if team is owner team.

func (*Team) RemoveMember added in v0.5.0

func (t *Team) RemoveMember(uid int64) error

RemoveMember removes member from team of organization.

func (*Team) RemoveRepository added in v0.5.0

func (t *Team) RemoveRepository(repoID int64) error

RemoveRepository removes repository from team of organization.

type TeamRepo added in v0.6.0

type TeamRepo struct {
	ID     int64 `xorm:"pk autoincr"`
	OrgID  int64 `xorm:"INDEX"`
	TeamID int64 `xorm:"UNIQUE(s)"`
	RepoID int64 `xorm:"UNIQUE(s)"`
}

TeamRepo represents an team-repository relation.

type TeamUser added in v0.5.0

type TeamUser struct {
	ID     int64 `xorm:"pk autoincr"`
	OrgID  int64 `xorm:"INDEX"`
	TeamID int64 `xorm:"UNIQUE(s)"`
	Uid    int64 `xorm:"UNIQUE(s)"`
}

TeamUser represents an team-user relation.

type UniqueQueue added in v0.7.0

type UniqueQueue struct {
	// contains filtered or unexported fields
}

UniqueQueue represents a queue that guarantees only one instance of same ID is in the line.

func NewUniqueQueue added in v0.7.0

func NewUniqueQueue(queueLength int) *UniqueQueue

func (*UniqueQueue) Add added in v0.7.0

func (q *UniqueQueue) Add(id interface{})

func (*UniqueQueue) AddFunc added in v0.7.0

func (q *UniqueQueue) AddFunc(id interface{}, fn func())

func (*UniqueQueue) Exist added in v0.7.0

func (q *UniqueQueue) Exist(id interface{}) bool

func (*UniqueQueue) Queue added in v0.7.0

func (q *UniqueQueue) Queue() <-chan string

func (*UniqueQueue) Remove added in v0.7.0

func (q *UniqueQueue) Remove(id interface{})

type UpdateTask added in v0.5.0

type UpdateTask struct {
	ID          int64  `xorm:"pk autoincr"`
	UUID        string `xorm:"index"`
	RefName     string
	OldCommitID string
	NewCommitID string
}

func GetUpdateTaskByUUID added in v0.7.0

func GetUpdateTaskByUUID(uuid string) (*UpdateTask, error)

GetUpdateTaskByUUID returns update task by given UUID.

type User

type User struct {
	Id        int64
	LowerName string `xorm:"UNIQUE NOT NULL"`
	Name      string `xorm:"UNIQUE NOT NULL"`
	FullName  string
	// Email is the primary email address (to be used for communication).
	Email       string `xorm:"NOT NULL"`
	Passwd      string `xorm:"NOT NULL"`
	LoginType   LoginType
	LoginSource int64 `xorm:"NOT NULL DEFAULT 0"`
	LoginName   string
	Type        UserType
	OwnedOrgs   []*User       `xorm:"-"`
	Orgs        []*User       `xorm:"-"`
	Repos       []*Repository `xorm:"-"`
	Location    string
	Website     string
	Rands       string    `xorm:"VARCHAR(10)"`
	Salt        string    `xorm:"VARCHAR(10)"`
	Created     time.Time `xorm:"CREATED"`
	Updated     time.Time `xorm:"UPDATED"`

	// Remember visibility choice for convenience, true for private
	LastRepoVisibility bool

	// Permissions.
	IsActive         bool
	IsAdmin          bool
	AllowGitHook     bool
	AllowImportLocal bool // Allow migrate repository by local path

	// Avatar.
	Avatar          string `xorm:"VARCHAR(2048) NOT NULL"`
	AvatarEmail     string `xorm:"NOT NULL"`
	UseCustomAvatar bool

	// Counters.
	NumFollowers  int
	NumFollowings int
	NumStars      int
	NumRepos      int

	// For organization.
	Description string
	NumTeams    int
	NumMembers  int
	Teams       []*Team `xorm:"-"`
	Members     []*User `xorm:"-"`
}

User represents the object of individual and member of organization.

func ExternalUserLogin added in v0.6.15

func ExternalUserLogin(u *User, name, passwd string, source *LoginSource, autoRegister bool) (*User, error)

func GetAssigneeByID added in v0.6.5

func GetAssigneeByID(repo *Repository, userID int64) (*User, error)

GetAssigneeByID returns the user with write access of repository by given ID.

func GetOrgByName added in v0.5.9

func GetOrgByName(name string) (*User, error)

GetOrgByName returns organization by given name.

func GetOwnedOrgsByUserID added in v0.6.15

func GetOwnedOrgsByUserID(userID int64) ([]*User, error)

GetOwnedOrgsByUserID returns a list of organizations are owned by given user ID.

func GetOwnedOrgsByUserIDDesc added in v0.6.15

func GetOwnedOrgsByUserIDDesc(userID int64, desc string) ([]*User, error)

GetOwnedOrganizationsByUserIDDesc returns a list of organizations are owned by given user ID and descring order by given condition.

func GetTeamMembers added in v0.5.0

func GetTeamMembers(teamID int64) ([]*User, error)

GetTeamMembers returns all members in given team of organization.

func GetUserByEmail added in v0.3.0

func GetUserByEmail(email string) (*User, error)

GetUserByEmail returns the user object by given e-mail if exists.

func GetUserByID added in v0.6.5

func GetUserByID(id int64) (*User, error)

GetUserByID returns the user object by given ID if exists.

func GetUserByKeyID added in v0.7.0

func GetUserByKeyID(keyID int64) (*User, error)

func GetUserByName

func GetUserByName(name string) (*User, error)

GetUserByName returns user by given name.

func LoginUserLDAPSource added in v0.6.15

func LoginUserLDAPSource(u *User, name, passwd string, source *LoginSource, autoRegister bool) (*User, error)

Query if name/passwd can login against the LDAP directory pool Create a local user if success Return the same LoginUserPlain semantic FIXME: https://github.com/gogits/gogs/issues/672

func LoginUserPAMSource added in v0.6.3

func LoginUserPAMSource(u *User, name, passwd string, sourceId int64, cfg *PAMConfig, autoRegister bool) (*User, error)

Query if name/passwd can login against PAM Create a local user if success Return the same LoginUserPlain semantic

func LoginUserSMTPSource added in v0.4.0

func LoginUserSMTPSource(u *User, name, passwd string, sourceId int64, cfg *SMTPConfig, autoRegister bool) (*User, error)

Query if name/passwd can login against the LDAP directory pool Create a local user if success Return the same LoginUserPlain semantic

func NewFakeUser added in v0.6.5

func NewFakeUser() *User

NewFakeUser creates and returns a fake user for someone has deleted his/her account.

func Organizations added in v0.6.15

func Organizations(page, pageSize int) ([]*User, error)

Organizations returns number of organizations in given page.

func SearchUserByName added in v0.4.0

func SearchUserByName(opt SearchOption) (us []*User, err error)

SearchUserByName returns given number of users whose name contains keyword.

func UserSignIn added in v0.4.2

func UserSignIn(uname, passwd string) (*User, error)

UserSignIn validates user name and password.

func Users added in v0.6.15

func Users(page, pageSize int) ([]*User, error)

Users returns number of users in given page.

func ValidateCommitWithEmail added in v0.5.5

func ValidateCommitWithEmail(c *git.Commit) *User

ValidateCommitWithEmail chceck if author's e-mail of commit is corresponsind to a user.

func VerifyUserActiveCode

func VerifyUserActiveCode(code string) (user *User)

verify active code when active account

func (*User) AddMember added in v0.5.0

func (org *User) AddMember(uid int64) error

AddMember adds new member to organization.

func (*User) AfterSet added in v0.6.9

func (u *User) AfterSet(colName string, _ xorm.Cell)
func (u *User) AvatarLink() string

AvatarLink returns user gravatar link.

func (*User) CanEditGitHook added in v0.7.0

func (u *User) CanEditGitHook() bool

CanEditGitHook returns true if user can edit Git hooks.

func (*User) CanImportLocal added in v0.7.0

func (u *User) CanImportLocal() bool

CanImportLocal returns true if user can migrate repository by local path.

func (*User) CustomAvatarPath added in v0.5.9

func (u *User) CustomAvatarPath() string

CustomAvatarPath returns user custom avatar file path.

func (u *User) DashboardLink() string

DashboardLink returns the user dashboard page link.

func (*User) DisplayName added in v0.6.9

func (u *User) DisplayName() string

DisplayName returns full name if it's not empty, returns username otherwise.

func (*User) EncodePasswd

func (u *User) EncodePasswd()

EncodePasswd encodes password to safe format.

func (*User) GenerateActivateCode added in v0.6.15

func (u *User) GenerateActivateCode() string

GenerateActivateCode generates an activate code based on user information.

func (*User) GenerateEmailActivateCode added in v0.6.15

func (u *User) GenerateEmailActivateCode(email string) string

GenerateEmailActivateCode generates an activate code based on user information and given e-mail.

func (*User) GenerateRandomAvatar added in v0.6.15

func (u *User) GenerateRandomAvatar() error

GenerateRandomAvatar generates a random avatar for user.

func (*User) GetAccessibleRepositories added in v0.6.0

func (u *User) GetAccessibleRepositories() (map[*Repository]AccessMode, error)

GetAccessibleRepositories finds all repositories where a user has access to, besides he/she owns.

func (*User) GetMembers added in v0.5.0

func (org *User) GetMembers() error

GetMembers returns all members of organization.

func (*User) GetOrganizationCount added in v0.5.0

func (u *User) GetOrganizationCount() (int64, error)

GetOrganizationCount returns count of membership of organization of user.

func (*User) GetOrganizations added in v0.5.0

func (u *User) GetOrganizations() error

GetOrganizations returns all organizations that user belongs to.

func (*User) GetOwnedOrganizations added in v0.6.15

func (u *User) GetOwnedOrganizations() (err error)

GetOwnedOrganizations returns all organizations that user owns.

func (*User) GetOwnerTeam added in v0.5.0

func (org *User) GetOwnerTeam() (*Team, error)

GetOwnerTeam returns owner team of organization.

func (*User) GetRepositories added in v0.5.0

func (u *User) GetRepositories() (err error)

GetRepositories returns all repositories that user owns, including private repositories.

func (*User) GetTeam added in v0.5.0

func (org *User) GetTeam(name string) (*Team, error)

GetTeam returns named team of organization.

func (*User) GetTeams added in v0.5.0

func (org *User) GetTeams() error

GetTeams returns all teams that belong to organization.

func (u *User) HomeLink() string

HomeLink returns the user or organization home page link.

func (*User) IsAdminOfRepo added in v0.6.5

func (u *User) IsAdminOfRepo(repo *Repository) bool

IsAdminOfRepo returns true if user has admin or higher access of repository.

func (*User) IsOrgMember added in v0.5.0

func (org *User) IsOrgMember(uid int64) bool

IsOrgMember returns true if given user is member of organization.

func (*User) IsOrganization added in v0.5.0

func (u *User) IsOrganization() bool

IsOrganization returns true if user is actually a organization.

func (*User) IsOwnedBy added in v0.5.9

func (org *User) IsOwnedBy(uid int64) bool

IsOwnedBy returns true if given user is in the owner team.

func (*User) IsPublicMember added in v0.5.0

func (u *User) IsPublicMember(orgId int64) bool

IsPublicMember returns true if user public his/her membership in give organization.

func (*User) IsUserOrgOwner added in v0.5.0

func (u *User) IsUserOrgOwner(orgId int64) bool

IsUserOrgOwner returns true if user is in the owner team of given organization.

func (*User) NewGitSig

func (u *User) NewGitSig() *git.Signature

NewGitSig generates and returns the signature of given user.

func (u *User) RelAvatarLink() string

func (*User) RemoveMember added in v0.5.0

func (org *User) RemoveMember(uid int64) error

RemoveMember removes member from organization.

func (*User) RemoveOrgRepo added in v0.6.0

func (org *User) RemoveOrgRepo(repoID int64) error

RemoveOrgRepo removes all team-repository relations of organization.

func (*User) UploadAvatar added in v0.5.9

func (u *User) UploadAvatar(data []byte) error

UploadAvatar saves custom avatar for user. FIXME: split uploads to different subdirs in case we have massive users.

func (*User) ValidatePassword added in v0.6.3

func (u *User) ValidatePassword(passwd string) bool

ValidatePassword checks if given password matches the one belongs to the user.

type UserCommit added in v0.5.5

type UserCommit struct {
	User *User
	*git.Commit
}

UserCommit represents a commit with validation of user.

type UserType added in v0.5.0

type UserType int
const (
	INDIVIDUAL UserType = iota // Historic reason to make it starts at 0.
	ORGANIZATION
)

type Watch

type Watch struct {
	ID     int64 `xorm:"pk autoincr"`
	UserID int64 `xorm:"UNIQUE(watch)"`
	RepoID int64 `xorm:"UNIQUE(watch)"`
}

Watch is connection request for receiving repository notification.

func GetWatchers added in v0.4.0

func GetWatchers(rid int64) ([]*Watch, error)

GetWatchers returns all watchers of given repository.

type Webhook added in v0.4.0

type Webhook struct {
	ID           int64 `xorm:"pk autoincr"`
	RepoID       int64
	OrgID        int64
	URL          string `xorm:"url TEXT"`
	ContentType  HookContentType
	Secret       string `xorm:"TEXT"`
	Events       string `xorm:"TEXT"`
	*HookEvent   `xorm:"-"`
	IsSSL        bool `xorm:"is_ssl"`
	IsActive     bool
	HookTaskType HookTaskType
	Meta         string     `xorm:"TEXT"` // store hook-specific attributes
	LastStatus   HookStatus // Last delivery status
	Created      time.Time  `xorm:"CREATED"`
	Updated      time.Time  `xorm:"UPDATED"`
}

Webhook represents a web hook object.

func GetActiveWebhooksByOrgID added in v0.6.9

func GetActiveWebhooksByOrgID(orgID int64) (ws []*Webhook, err error)

GetActiveWebhooksByOrgID returns all active webhooks for an organization.

func GetActiveWebhooksByRepoID added in v0.6.9

func GetActiveWebhooksByRepoID(repoID int64) (ws []*Webhook, err error)

GetActiveWebhooksByRepoID returns all active webhooks of repository.

func GetWebhookByID added in v0.6.9

func GetWebhookByID(id int64) (*Webhook, error)

GetWebhookByID returns webhook by given ID.

func GetWebhooksByOrgId added in v0.5.0

func GetWebhooksByOrgId(orgID int64) (ws []*Webhook, err error)

GetWebhooksByOrgId returns all webhooks for an organization.

func GetWebhooksByRepoId added in v0.4.0

func GetWebhooksByRepoId(repoID int64) (ws []*Webhook, err error)

GetWebhooksByRepoId returns all webhooks of repository.

func (*Webhook) AfterSet added in v0.6.9

func (w *Webhook) AfterSet(colName string, _ xorm.Cell)

func (*Webhook) EventsArray added in v0.6.9

func (w *Webhook) EventsArray() []string

func (*Webhook) GetSlackHook added in v0.5.0

func (w *Webhook) GetSlackHook() *SlackMeta

func (*Webhook) HasCreateEvent added in v0.6.9

func (w *Webhook) HasCreateEvent() bool

HasCreateEvent returns true if hook enabled create event.

func (*Webhook) HasPushEvent added in v0.4.0

func (w *Webhook) HasPushEvent() bool

HasPushEvent returns true if hook enabled push event.

func (*Webhook) History added in v0.6.9

func (w *Webhook) History(page int) ([]*HookTask, error)

History returns history of webhook by given conditions.

func (*Webhook) UpdateEvent added in v0.5.0

func (w *Webhook) UpdateEvent() error

UpdateEvent handles conversion from HookEvent to Events.

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL