You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

auth.go 6.1 kB

11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. // Copyright 2014 The Gogs Authors. All rights reserved.
  2. // Use of this source code is governed by a MIT-style
  3. // license that can be found in the LICENSE file.
  4. package auth
  5. import (
  6. "net/http"
  7. "reflect"
  8. "strings"
  9. "github.com/go-martini/martini"
  10. "github.com/gogits/gogs/modules/base"
  11. "github.com/gogits/gogs/modules/log"
  12. )
  13. // Web form interface.
  14. type Form interface {
  15. Name(field string) string
  16. }
  17. type RegisterForm struct {
  18. UserName string `form:"username" binding:"Required;AlphaDashDot;MaxSize(30)"`
  19. Email string `form:"email" binding:"Required;Email;MaxSize(50)"`
  20. Password string `form:"passwd" binding:"Required;MinSize(6);MaxSize(30)"`
  21. RetypePasswd string `form:"retypepasswd"`
  22. }
  23. func (f *RegisterForm) Name(field string) string {
  24. names := map[string]string{
  25. "UserName": "Username",
  26. "Email": "E-mail address",
  27. "Password": "Password",
  28. "RetypePasswd": "Re-type password",
  29. }
  30. return names[field]
  31. }
  32. func (f *RegisterForm) Validate(errors *base.BindingErrors, req *http.Request, context martini.Context) {
  33. if req.Method == "GET" || errors.Count() == 0 {
  34. return
  35. }
  36. data := context.Get(reflect.TypeOf(base.TmplData{})).Interface().(base.TmplData)
  37. data["HasError"] = true
  38. AssignForm(f, data)
  39. if len(errors.Overall) > 0 {
  40. for _, err := range errors.Overall {
  41. log.Error("RegisterForm.Validate: %v", err)
  42. }
  43. return
  44. }
  45. validate(errors, data, f)
  46. }
  47. type LogInForm struct {
  48. UserName string `form:"username" binding:"Required;MaxSize(35)"`
  49. Password string `form:"passwd" binding:"Required;MinSize(6);MaxSize(30)"`
  50. Remember string `form:"remember"`
  51. }
  52. func (f *LogInForm) Name(field string) string {
  53. names := map[string]string{
  54. "UserName": "Username",
  55. "Password": "Password",
  56. }
  57. return names[field]
  58. }
  59. func (f *LogInForm) Validate(errors *base.BindingErrors, req *http.Request, context martini.Context) {
  60. if req.Method == "GET" || errors.Count() == 0 {
  61. return
  62. }
  63. data := context.Get(reflect.TypeOf(base.TmplData{})).Interface().(base.TmplData)
  64. data["HasError"] = true
  65. AssignForm(f, data)
  66. if len(errors.Overall) > 0 {
  67. for _, err := range errors.Overall {
  68. log.Error("LogInForm.Validate: %v", err)
  69. }
  70. return
  71. }
  72. validate(errors, data, f)
  73. }
  74. func getMinMaxSize(field reflect.StructField) string {
  75. for _, rule := range strings.Split(field.Tag.Get("binding"), ";") {
  76. if strings.HasPrefix(rule, "MinSize(") || strings.HasPrefix(rule, "MaxSize(") {
  77. return rule[8 : len(rule)-1]
  78. }
  79. }
  80. return ""
  81. }
  82. func validate(errors *base.BindingErrors, data base.TmplData, form Form) {
  83. typ := reflect.TypeOf(form)
  84. val := reflect.ValueOf(form)
  85. if typ.Kind() == reflect.Ptr {
  86. typ = typ.Elem()
  87. val = val.Elem()
  88. }
  89. for i := 0; i < typ.NumField(); i++ {
  90. field := typ.Field(i)
  91. fieldName := field.Tag.Get("form")
  92. // Allow ignored fields in the struct
  93. if fieldName == "-" {
  94. continue
  95. }
  96. if err, ok := errors.Fields[field.Name]; ok {
  97. data["Err_"+field.Name] = true
  98. switch err {
  99. case base.BindingRequireError:
  100. data["ErrorMsg"] = form.Name(field.Name) + " cannot be empty"
  101. case base.BindingAlphaDashError:
  102. data["ErrorMsg"] = form.Name(field.Name) + " must be valid alpha or numeric or dash(-_) characters"
  103. case base.BindingAlphaDashDotError:
  104. data["ErrorMsg"] = form.Name(field.Name) + " must be valid alpha or numeric or dash(-_) or dot characters"
  105. case base.BindingMinSizeError:
  106. data["ErrorMsg"] = form.Name(field.Name) + " must contain at least " + getMinMaxSize(field) + " characters"
  107. case base.BindingMaxSizeError:
  108. data["ErrorMsg"] = form.Name(field.Name) + " must contain at most " + getMinMaxSize(field) + " characters"
  109. case base.BindingEmailError:
  110. data["ErrorMsg"] = form.Name(field.Name) + " is not a valid e-mail address"
  111. case base.BindingUrlError:
  112. data["ErrorMsg"] = form.Name(field.Name) + " is not a valid URL"
  113. default:
  114. data["ErrorMsg"] = "Unknown error: " + err
  115. }
  116. return
  117. }
  118. }
  119. }
  120. // AssignForm assign form values back to the template data.
  121. func AssignForm(form interface{}, data base.TmplData) {
  122. typ := reflect.TypeOf(form)
  123. val := reflect.ValueOf(form)
  124. if typ.Kind() == reflect.Ptr {
  125. typ = typ.Elem()
  126. val = val.Elem()
  127. }
  128. for i := 0; i < typ.NumField(); i++ {
  129. field := typ.Field(i)
  130. fieldName := field.Tag.Get("form")
  131. // Allow ignored fields in the struct
  132. if fieldName == "-" {
  133. continue
  134. }
  135. data[fieldName] = val.Field(i).Interface()
  136. }
  137. }
  138. type InstallForm struct {
  139. Database string `form:"database" binding:"Required"`
  140. Host string `form:"host"`
  141. User string `form:"user"`
  142. Passwd string `form:"passwd"`
  143. DatabaseName string `form:"database_name"`
  144. SslMode string `form:"ssl_mode"`
  145. DatabasePath string `form:"database_path"`
  146. RepoRootPath string `form:"repo_path"`
  147. RunUser string `form:"run_user"`
  148. Domain string `form:"domain"`
  149. AppUrl string `form:"app_url"`
  150. AdminName string `form:"admin_name" binding:"Required;AlphaDashDot;MaxSize(30)"`
  151. AdminPasswd string `form:"admin_pwd" binding:"Required;MinSize(6);MaxSize(30)"`
  152. AdminEmail string `form:"admin_email" binding:"Required;Email;MaxSize(50)"`
  153. SmtpHost string `form:"smtp_host"`
  154. SmtpEmail string `form:"mailer_user"`
  155. SmtpPasswd string `form:"mailer_pwd"`
  156. RegisterConfirm string `form:"register_confirm"`
  157. MailNotify string `form:"mail_notify"`
  158. }
  159. func (f *InstallForm) Name(field string) string {
  160. names := map[string]string{
  161. "Database": "Database name",
  162. "AdminName": "Admin user name",
  163. "AdminPasswd": "Admin password",
  164. "AdminEmail": "Admin e-maill address",
  165. }
  166. return names[field]
  167. }
  168. func (f *InstallForm) Validate(errors *base.BindingErrors, req *http.Request, context martini.Context) {
  169. if req.Method == "GET" || errors.Count() == 0 {
  170. return
  171. }
  172. data := context.Get(reflect.TypeOf(base.TmplData{})).Interface().(base.TmplData)
  173. data["HasError"] = true
  174. AssignForm(f, data)
  175. if len(errors.Overall) > 0 {
  176. for _, err := range errors.Overall {
  177. log.Error("InstallForm.Validate: %v", err)
  178. }
  179. return
  180. }
  181. validate(errors, data, f)
  182. }