本文整理匯總了Golang中OnlineJudge/models.User.GetUserInfo方法的典型用法代碼示例。如果您正苦於以下問題:Golang User.GetUserInfo方法的具體用法?Golang User.GetUserInfo怎麽用?Golang User.GetUserInfo使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類OnlineJudge/models.User
的用法示例。
在下文中一共展示了User.GetUserInfo方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: ProblemById
// Serves the Problem Page
// To-do: Show recently solved users and their language on sidebar
// To-do: Later, add least execution time log on sidebar
func (this *ProblemController) ProblemById() {
pid := this.Ctx.Input.Param(":id")
id, err := strconv.Atoi(pid)
if err != nil {
// Redirect to 404
this.Abort("404")
}
p := models.Problem{Pid: id}
p.GetById()
if strings.Contains(p.Type, "contest") {
this.Redirect("/", 302)
return
}
log := models.Problemlogs{Pid: id}
logs, count := log.GetRecentByPid()
users := make(map[int]models.User)
if count == 0 {
this.Data["recentlySolvedUsersExist"] = false
} else {
this.Data["recentlySolvedUsersExist"] = true
for index, element := range logs {
u := models.User{Uid: element.Uid}
u.GetUserInfo()
users[index] = u
}
}
//Author added
user := models.User{}
user.Uid = p.Uid
user.GetUserInfo()
this.Data["title"] = p.Statement
this.Data["problem"] = p
this.Data["Author"] = user.Username
this.Data["recentlySolvedUsers"] = users
// Handle problem log of a user
if this.isLoggedIn() {
problemLog := models.Problemlogs{}
problemLog.Pid = p.Pid
problemLog.Uid = p.Uid
if problemLog.GetByPidUid() {
this.Data["userScore"] = problemLog.Points
this.Data["solvedCount"] = problemLog.Solved
}
}
this.Layout = "layout.tpl"
this.TplNames = "problem/show.tpl"
this.LayoutSections = make(map[string]string)
this.LayoutSections["HtmlHead"] = "problem/submit_head.tpl"
this.LayoutSections["Sidebar"] = "sidebar/recently_solved_by.tpl"
}
示例2: GetProblem
// /contest/:name/:pid
func (this *ContestController) GetProblem() {
pid := this.Ctx.Input.Param(":id")
contestName := this.Ctx.Input.Param(":name")
id, err := strconv.Atoi(pid)
if err != nil {
// Redirect to 404
this.Abort("404")
}
p := models.Problem{Pid: id}
p.GetById()
check := strings.Contains(p.Type, contestName)
if !check {
this.Redirect("/contest/"+contestName, 302)
return
}
log := models.Problemlogs{Pid: id}
logs, count := log.GetRecentByPid()
users := make(map[int]models.User)
if count == 0 {
this.Data["recentlySolvedUsersExist"] = false
} else {
this.Data["recentlySolvedUsersExist"] = true
for index, element := range logs {
u := models.User{Uid: element.Uid}
u.GetUserInfo()
users[index] = u
}
}
this.Data["title"] = p.Statement
this.Data["problem"] = p
this.Data["Author"] = contestName
this.Data["recentlySolvedUsers"] = users
// Handle problem log of a user
if this.isLoggedIn() {
problemLog := models.Problemlogs{}
problemLog.Pid = p.Pid
problemLog.Uid = p.Uid
if problemLog.GetByPidUid() {
this.Data["userScore"] = problemLog.Points
this.Data["solvedCount"] = problemLog.Solved
}
}
}
示例3: Login
func (this *UserController) Login() {
uid := this.GetSession("Uid")
if uid != nil {
this.Redirect("/", 302)
}
if this.Ctx.Input.Param("0") == "submit" {
user := models.User{
Username: this.GetString("username"),
Password: this.GetString("password"),
}
// Handle the flash messages
err := user.LoginVerify()
if err != nil {
flash := beego.NewFlash()
flash.Error(err.Error())
flash.Store(&this.Controller)
}
if user.Login() == true {
this.SetSession("Uid", this.GetString("username"))
user.GetUserInfo()
this.SetSession("id", user.Uid)
// store the user ID in the session
this.Redirect("/", 302)
}
//If login failed, flash a relevent message
}
this.Data["title"] = "Login"
this.Layout = "layout.tpl"
this.TplNames = "user/login.tpl"
this.LayoutSections = make(map[string]string)
this.LayoutSections["HtmlHead"] = ""
this.LayoutSections["Sidebar"] = ""
this.LayoutSections["ErrorHead"] = "errorHead.tpl"
}