本文整理匯總了Golang中github.com/playaer/myFirstGoProject/di.DI類的典型用法代碼示例。如果您正苦於以下問題:Golang DI類的具體用法?Golang DI怎麽用?Golang DI使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了DI類的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: ProcessRegister
// Process register: check form, create new inactive user and send activation email
func (self *RegisterController) ProcessRegister(params martini.Params, req *http.Request, r render.Render, di *di.DI) {
userManager := di.UserManager()
user := userManager.NewUser()
// need validate
user.Email = req.FormValue("Email")
rawPassword := req.FormValue("Password")
user.Password = userManager.CryptPassword(rawPassword)
user.FullName = req.FormValue("FullName")
user.Address = req.FormValue("Address")
user.Phone = req.FormValue("Phone")
user.IsActive = false
user.Hash = userManager.GenerateHash(user.Email + user.FullName)
userManager.Create(user)
// send email
mailer := di.Mailer()
go mailer.Send(mailer.BuildRegistrationMail(user))
// message: "Activation link was sent to your email."
r.Redirect("/users/")
}
示例2: ProcessLogin
// Process login action
func (self *AuthController) ProcessLogin(w http.ResponseWriter, req *http.Request, r render.Render, di *di.DI) {
email := req.FormValue("Email")
user := di.UserManager().FindActiveByEmail(email)
if user == nil {
// not authenticated
// message: Invalid credentials
r.Redirect("/auth/")
return
}
password := req.FormValue("Password")
if di.UserManager().CheckPassword(user, password) {
// message: Hello, {userName}
authManager := di.AuthManager()
token := authManager.GenerateToken(user)
// set cookie
cookie := http.Cookie{Name: "gousertoken", Value: token, Path: "/"}
http.SetCookie(w, &cookie)
r.Redirect("/users/")
} else {
// not authorized
// message: Invalid credentials
r.Redirect("/auth/")
}
}
示例3: List
// Show login template
func (self *UpdateLogController) List(params martini.Params, r render.Render, di *di.DI, templateVars utils.TemplateVars) {
authManager := di.AuthManager()
if !authManager.IsAuthenticated() {
r.HTML(403, "error/403", templateVars)
return
}
currentUser := authManager.CurrentUser()
userId := currentUser.Id
logs := di.UpdateLogManager().FindAll(userId)
templateVars.SetData(logs)
r.HTML(200, "updateLog/list", templateVars)
}
示例4: Login
// Show login template
func (self *AuthController) Login(r render.Render, di *di.DI, templateVars utils.TemplateVars) {
authManager := di.AuthManager()
if authManager.IsAuthenticated() {
r.HTML(403, "error/403", templateVars)
return
}
r.HTML(200, "auth/login", templateVars)
}
示例5: Register
// Register Action, show register template form
func (self *RegisterController) Register(params martini.Params, r render.Render, di *di.DI, templateVars utils.TemplateVars) {
authManager := di.AuthManager()
if authManager.IsAuthenticated() {
r.HTML(403, "error/403", templateVars)
return
}
r.HTML(200, "register/register", templateVars)
}
示例6: Edit
/**
* Show edit template
* Route /users/edit/profile/
*/
func (u *UserController) Edit(r render.Render, di *di.DI, templateVars utils.TemplateVars) {
authManager := di.AuthManager()
if !authManager.IsAuthenticated() {
r.HTML(403, "error/403", templateVars)
return
}
currentUser := authManager.CurrentUser()
templateVars.SetData(currentUser)
r.HTML(200, "user/edit", templateVars)
}
示例7: LogOut
// Show login template
func (self *AuthController) LogOut(w http.ResponseWriter, params martini.Params, r render.Render, di *di.DI, templateVars utils.TemplateVars) {
authManager := di.AuthManager()
if !authManager.IsAuthenticated() {
r.HTML(403, "error/403", templateVars)
return
}
authManager.Logout()
cookie := http.Cookie{Name: "gousertoken", Value: "", Path: "/", MaxAge: -1}
http.SetCookie(w, &cookie)
r.Redirect("/users/")
}
示例8: View
/**
* Route /users/:id/view/
*/
func (u *UserController) View(params martini.Params, r render.Render, di *di.DI, templateVars utils.TemplateVars) {
userManager := di.UserManager()
id := params["id"]
user := userManager.FindById(id)
if user == nil {
r.HTML(404, "error/404", templateVars)
} else {
templateVars.SetData(user)
r.HTML(200, "user/view", templateVars)
}
}
示例9: Save
/**
* Save user
* Route /users/save/profile/
*/
func (u *UserController) Save(req *http.Request, r render.Render, di *di.DI, templateVars utils.TemplateVars) {
authManager := di.AuthManager()
if !authManager.IsAuthenticated() {
r.HTML(403, "error/403", templateVars)
return
}
userManager := di.UserManager()
currentUser := authManager.CurrentUser()
// clone user
newUser := *currentUser
newUser.FullName = req.FormValue("FullName")
newUser.Address = req.FormValue("Address")
newUser.Phone = req.FormValue("Phone")
userManager.Update(&newUser)
// store user updates to log
di.UpdateLogManager().StoreChanges(currentUser, &newUser)
// redirect
strId := strconv.FormatInt(currentUser.Id, 10)
r.Redirect("/users/" + strId + "/view/")
}
示例10: ProcessActivate
// Check activation link and activate user
func (self *RegisterController) ProcessActivate(params martini.Params, req *http.Request, r render.Render, di *di.DI, templateVars utils.TemplateVars) {
userManager := di.UserManager()
user := userManager.FindInActiveByHash(params["hash"])
if user == nil {
r.HTML(404, "error/404", templateVars)
return
}
user.IsActive = true
user.Hash = ""
userManager.Update(user)
// message "Activation complete. How you can enter on site."
r.Redirect("/auth/")
}
示例11: List
/**
* Routes '/', '/users/'
*/
func (u *UserController) List(r render.Render, di *di.DI, templateVars utils.TemplateVars) {
userManager := di.UserManager()
all := userManager.FindAll()
templateVars.SetData(all)
r.HTML(200, "user/list", templateVars)
}