Finish new reset password, etc.

release/v1.15
Unknwon 2014-08-09 21:02:00 -07:00
parent 5605af973b
commit 7af7584d25
16 changed files with 625 additions and 602 deletions

1
.gitignore vendored
View File

@ -38,3 +38,4 @@ __pycache__
*.pem *.pem
output* output*
config.codekit config.codekit
.brackets.json

View File

@ -52,9 +52,23 @@ create_new_account = Create New Account
register_hepler_msg = Already have an account? Sign in now! register_hepler_msg = Already have an account? Sign in now!
social_register_hepler_msg = Already have an account? Bind now! social_register_hepler_msg = Already have an account? Bind now!
disable_register_prompt = Sorry, registration has been disabled. Please contact the site administrator. disable_register_prompt = Sorry, registration has been disabled. Please contact the site administrator.
disable_register_mail = Sorry, Register Mail Confirmation has been disabled.
remember_me = Remember Me remember_me = Remember Me
forgot_password= Fotgot Password
forget_password = Fotget password? forget_password = Fotget password?
sign_up_now = Need an account? Sign up now. sign_up_now = Need an account? Sign up now.
confirmation_mail_sent_prompt = A new confirmation e-mail has been sent to <b>%s</b>, please check your inbox within the next %d hours to complete your registration.
sign_in_email = Sign in to your e-mail
active_your_account = Activate Your Account
resent_limit_prompt = Sorry, you are sending an activation e-mail too frequently. Please wait 3 minutes.
has_unconfirmed_mail = Hi %s, you have an unconfirmed email address(<b>%s</b>). If you haven't received a confirmation e-mail or need to resend a new one, please click on the button below.
resend_mail = Click here to resend your activation e-mail
email_not_associate = This e-mail address does not associate to any account.
send_reset_mail = Click here to (re)send your passowrd reset e-mail
reset_password = Reset Your Password
invalid_code = Sorry, your confirmation code has exipired or not valid.
reset_password_helper = Click here to reset your password
password_too_short = Password length cannot be less then 6.
[form] [form]
UserName = Username UserName = Username

View File

@ -52,9 +52,23 @@ create_new_account = 创建帐户
register_hepler_msg = 已经注册?立即登录! register_hepler_msg = 已经注册?立即登录!
social_register_hepler_msg = 已经注册?立即绑定! social_register_hepler_msg = 已经注册?立即绑定!
disable_register_prompt = 对不起,注册功能已被关闭。请联系网站管理员。 disable_register_prompt = 对不起,注册功能已被关闭。请联系网站管理员。
disable_register_mail = 对不起,注册邮箱确认功能已被关闭。
remember_me = 记住登录 remember_me = 记住登录
forgot_password = 忘记密码
forget_password = 忘记密码? forget_password = 忘记密码?
sign_up_now = 还没帐户?马上注册。 sign_up_now = 还没帐户?马上注册。
confirmation_mail_sent_prompt = 一封新的确认邮件已经被发送至 <b>%s</b>,请检查您的收件箱并在 %d 小时内完成确认注册操作。
sign_in_email = 登录到您的邮箱
active_your_account = 激活您的帐户
resent_limit_prompt = 对不起,您请求发送激活邮件过于频繁,请等待 3 分钟后再试!
has_unconfirmed_mail = %s 您好,系统检测到您有一封发送至 <b>%s</b> 但未被确认的邮件。如果您未收到激活邮件,或需要重新发送,请单击下方的按钮。
resend_mail = 单击此处重新发送确认邮件
email_not_associate = 您输入的邮箱地址未被关联到任何帐号!
send_reset_mail = 单击此处(重新)发送您的密码重置邮件
reset_password = 重置密码
invalid_code = 对不起,您的确认代码已过期或已失效。
reset_password_helper = 单击此处重置密码
password_too_short = 密码长度不能少于 6 位!
[form] [form]
UserName = 用户名 UserName = 用户名

View File

@ -5,6 +5,7 @@
package middleware package middleware
import ( import (
"fmt"
"net/url" "net/url"
"strings" "strings"
@ -43,6 +44,7 @@ func Toggle(options *ToggleOptions) macaron.Handler {
} }
if options.SignInRequire { if options.SignInRequire {
fmt.Println(ctx.User.IsActive, setting.Service.RegisterEmailConfirm)
if !ctx.IsSigned { if !ctx.IsSigned {
// Ignore watch repository operation. // Ignore watch repository operation.
if strings.HasSuffix(ctx.Req.RequestURI, "watch") { if strings.HasSuffix(ctx.Req.RequestURI, "watch") {
@ -52,7 +54,7 @@ func Toggle(options *ToggleOptions) macaron.Handler {
ctx.Redirect("/user/login") ctx.Redirect("/user/login")
return return
} else if !ctx.User.IsActive && setting.Service.RegisterEmailConfirm { } else if !ctx.User.IsActive && setting.Service.RegisterEmailConfirm {
// ctx.Data["Title"] = "Activate Your Account" ctx.Data["Title"] = ctx.Tr("auth.active_your_account")
ctx.HTML(200, "user/activate") ctx.HTML(200, "user/activate")
return return
} }

View File

@ -435,6 +435,7 @@ dt {
} }
.btn-link { .btn-link {
overflow: visible; overflow: visible;
color: white;
padding: .6em 1.2em; padding: .6em 1.2em;
} }
.btn-radius { .btn-radius {

View File

@ -1,476 +1,458 @@
@import "../ui/var"; @import "../ui/var";
@repoHeaderBorderColor: #D6D6D6; @repoHeaderBorderColor: #D6D6D6;
@repoHeaderBgColor: #FFF; @repoHeaderBgColor: #FFF;
@repoHeaderNameColor: #888; @repoHeaderNameColor: #888;
/* repository main */ /* repository main */
#repo-wrapper { #repo-wrapper {
padding-bottom: 100px; padding-bottom: 100px;
} }
#repo-header { #repo-header {
height: 69px; height: 69px;
border-bottom: 1px solid @repoHeaderBorderColor; border-bottom: 1px solid@repoHeaderBorderColor;
background-color: @repoHeaderBgColor;
background-color: @repoHeaderBgColor;
} }
#repo-header-name { #repo-header-name {
line-height: 66px; line-height: 66px;
color: @repoHeaderNameColor; color: @repoHeaderNameColor;
font-size: 1.6em;
font-weight: normal;
margin-bottom: 0;
i {
margin-right: 12px;
vertical-align: middle;
}
.divider {
margin: 0 4px;
}
}
font-size: 1.6em;
font-weight: normal;
margin-bottom: 0;
i {
margin-right: 12px;
vertical-align: middle;
}
.divider {
margin: 0 4px;
}
}
#repo-header-meta { #repo-header-meta {
line-height: 66px; line-height: 66px;
li { li {
> a { > a {
padding: 0; padding: 0;
&:hover { &:hover {
background-color: transparent; background-color: transparent;
} }
} }
} }
a > .btn { a > .btn {
font-size: 1.05em; font-size: 1.05em;
margin-left: 16px; margin-left: 16px;
i { i {
margin-right: 6px; margin-right: 6px;
} }
line-height: 16px; line-height:16px;
.num { .num {
margin-left: 6px; margin-left: 6px;
} }
} }
} }
#repo-header-download-btn { #repo-header-download-btn {
> .btn > i { > .btn > i {
margin-right: 0 !important; margin-right: 0 !important;
} }
&:hover { &:hover {
&:after, &:after, .btn {
.btn { background-color: @btnHoverBlackColor;
background-color: @btnHoverBlackColor;
color: #FFF;
}
}
&:after {
background-color: @btnBlackColor;
padding: 9px 16px 8px 0;
margin-left: -8px !important;
color: #FFF;
border-top: 1px solid @btnBlackColor;
border-bottom: 1px solid @btnBlackColor;
border-top-right-radius: .25em;
border-bottom-right-radius: .25em;
}
}
color: #FFF;
}
}
&:after {
background-color: @btnBlackColor;
padding: 9px 16px 8px 0;
margin-left: -8px !important;
color: #FFF;
border-top: 1px solid@btnBlackColor;
border-bottom: 1px solid@btnBlackColor;
border-top-right-radius: .25em;
border-bottom-right-radius: .25em;
}
}
#repo-header-download-drop { #repo-header-download-drop {
line-height: 24px; line-height: 24px;
width: 440px; width: 440px;
top: 50px; top: 50px;
left: -354px; left: -354px;
padding: 20px; padding: 20px;
box-sizing: border-box; box-sizing: border-box;
.btn > i { .btn > i {
margin-right: 6px; margin-right: 6px;
} }
} }
#repo-content { #repo-content {
padding: 18px 0; padding: 18px 0;
} }
#repo-clone-url { #repo-clone-url {
border-right: none; border-right: none;
width: 196px; width: 196px;
border-left: none; border-left: none;
} }
#repo-clone-help { #repo-clone-help {
line-height: 48px; line-height: 48px;
} }
#repo-clone-zip { #repo-clone-zip {
line-height: 48px; line-height: 48px;
a { a {
cursor: pointer; cursor: pointer;
color: white; color: white;
overflow: visible; overflow: visible;
padding: .6em 1.2em; padding: .6em 1.2em;
} }
.btn { .btn {
margin: 0 6px; margin: 0 6px;
} }
} }
#repo-desc { #repo-desc {
font-size: 1.2em; font-size: 1.2em;
} }
#repo-sidebar-nav { #repo-sidebar-nav {
.label { .label {
font-size: 12px; font-size: 12px;
line-height: 1.4em; line-height: 1.4em;
margin-top: 2px; margin-top: 2px;
} }
i { i {
margin-right: 6px; margin-right: 6px;
} }
} }
#repo-file-nav { #repo-file-nav {
padding: .6em 0 1em 0; padding: .6em 0 1em 0;
> li > a { > li > a {
padding-left: 0; padding-left: 0;
&:hover { &:hover {
background-color: transparent; background-color: transparent;
} }
} }
li.repo-jump > a { li.repo-jump > a {
padding-right: 0; padding-right: 0;
.btn { .btn {
margin-left: -1px; margin-left: -1px;
} }
} }
} }
#repo-branch-switch { #repo-branch-switch {
> a { > a {
.btn { .btn {
padding-right: 30px; padding-right: 30px;
} }
&:after { &:after {
position: absolute; position: absolute;
top: 12px; top: 12px;
right: 30px; right: 30px;
margin-left: 0; margin-left: 0;
color: @baseFontColor; color: @baseFontColor;
}
}
> .drop-down {
top: 40px;
left: 0;
}
}
}
}
> .drop-down {
top: 40px;
left: 0;
}
}
#repo-branch-filter-ipt { #repo-branch-filter-ipt {
width: 100%; width: 100%;
border-left: none; border-left: none;
border-right: none; border-right: none;
box-sizing: border-box; box-sizing: border-box;
} }
#repo-branch-tag { #repo-branch-tag {
.tab-nav { .tab-nav {
border-bottom: 1px solid #EAEAEA; border-bottom: 1px solid #EAEAEA;
a { a {
padding: .3em .8em; padding: .3em .8em;
} }
.js-tab-nav-show { .js-tab-nav-show {
background-color: #EEE; background-color: #EEE;
font-weight: bold; font-weight: bold;
} }
} }
} }
#repo-branch-list, #repo-branch-list,
#repo-tag-list { #repo-tag-list {
li { li {
i { i {
margin-right: 12px; margin-right: 12px;
opacity: 0; opacity: 0;
} }
} }
li.checked { li.checked {
i { i {
opacity: 1; opacity: 1;
} }
} }
} }
#repo-tag-list { #repo-tag-list {
display: none; display: none;
} }
#repo-bread { #repo-bread {
.bread { .bread {
padding-right: 0; padding-right: 0;
font-size: 16px; font-size: 16px;
font-weight: bold; font-weight: bold;
} }
} }
#repo-main { #repo-main {
padding-right: 40px; padding-right: 40px;
box-sizing: border-box; box-sizing: border-box;
} }
#repo-files-table { #repo-files-table {
margin-bottom: 20px; margin-bottom: 20px;
th, th, td {
td { text-align: left;
text-align: left; line-height: 32px;
line-height: 32px; }
} td.icon {
td.icon { width: 16px;
width: 16px; padding-right: .1em;
padding-right: .1em; padding-left: 1em;
padding-left: 1em; }
} td.name {
td.name { max-width: 120px;
max-width: 120px; .text-truncate {
.text-truncate { max-width: 100%;
max-width: 100%; }
} }
} td.age {
td.age { max-width: 120px;
max-width: 120px; text-align: right;
text-align: right; }
} td.msg {
td.msg { max-width: 440px;
max-width: 440px; .text-truncate {
.text-truncate { max-width: 100%;
max-width: 100%; }
} }
} td.age,
td.age, td.size,
td.size, td.msg a {
td.msg a { color: #888;
color: #888; }
} td.msg a:hover {
td.msg a:hover { color: #428BCA;
color: #428BCA; text-decoration: underline;
text-decoration: underline; }
} tbody {
tbody { background-color: #FFF;
background-color: #FFF; tr:hover {
tr:hover { background-color: #ffffEE;
background-color: #ffffEE; }
} }
} thead {
thead { background-color: #F0F0F0;
background-color: #F0F0F0; .author {
.author { a {
a { margin: 0 .4em;
margin: 0 .4em; }
} }
} .last-commit {
.last-commit { strong {
strong { color: #444;
color: #444; }
} .text-truncate {
.text-truncate { margin-left: .4em;
margin-left: .4em; }
} }
} .last-commit .text-truncate,
.last-commit .text-truncate, .age {
.age { font-weight: normal;
font-weight: normal; color: #888;
color: #888; }
} }
}
} }
#repo-readme { #repo-readme {
margin-bottom: 80px; margin-bottom: 80px;
} }
#repo-bare-start { #repo-bare-start {
margin-bottom: 100px; margin-bottom: 100px;
.panel-content { .panel-content {
background-color: #FFF; background-color: #FFF;
} }
pre { pre {
margin: 0 40px; margin: 0 40px;
padding: 6px 10px; padding: 6px 10px;
border: 1px solid #ddd; border: 1px solid #ddd;
background: #f8f8f8; background: #f8f8f8;
} }
} }
.repo-bare { .repo-bare {
#repo-bare-start { #repo-bare-start {
h2 { h2 {
margin-top: 30px; margin-top: 30px;
margin-bottom: 24px; margin-bottom: 24px;
} }
} }
#repo-header-meta { #repo-header-meta {
display: none; display: none;
} }
#repo-clone-ssh { #repo-clone-ssh {
margin-left: 200px; margin-left: 200px;
} }
#repo-clone-copy { #repo-clone-copy {
margin-right: 200px; margin-right: 200px;
} }
#repo-clone-help { #repo-clone-help {
clear: both; clear: both;
width: 100%; width: 100%;
} }
#repo-clone-url { #repo-clone-url {
width: 520px; width: 520px;
} }
} }
/* repository create */ /* repository create */
#repo-migrate-form, #repo-migrate-form,
#repo-create-form { #repo-create-form {
width: 800px; width: 800px;
margin: 60px auto auto auto; margin: 60px auto auto auto;
background: white; background: white;
h2 { h2 {
margin: .5em 1em; margin: .5em 1em;
} }
.field { .field {
margin: 1.2em 0 2em 0; margin: 1.2em 0 2em 0;
} }
.ipt { .ipt {
width: 540px; width: 540px;
} }
textarea { textarea {
height: 120px; height: 120px;
} }
.avatar { .avatar {
vertical-align: middle; vertical-align: middle;
margin-right: .6em; margin-right: .6em;
width: 28px; width: 28px;
height: 28px; height: 28px;
} }
&:hover { &:hover {
box-shadow: 0px 0px 6px #CCC; box-shadow: 0px 0px 6px #CCC;
} }
} }
#repo-create-cancel { #repo-create-cancel {
margin-left: 4em; margin-left: 4em;
} }
#repo-create-owner-list { #repo-create-owner-list {
top: 30px; top: 30px;
left: 0; left: 0;
width: auto; width: auto;
max-width: 300px; max-width: 300px;
.octicon { .octicon {
margin-right: 12px; margin-right: 12px;
opacity: 0; opacity: 0;
} }
.avatar { .avatar {
width: 20px; width: 20px;
height: 20px; height: 20px;
} }
li { li {
white-space: nowrap; white-space: nowrap;
&.checked { &.checked {
.octicon { .octicon {
opacity: 1; opacity: 1;
} }
} }
a { a {
text-overflow: ellipsis; text-overflow: ellipsis;
-o-text-overflow: ellipsis; -o-text-overflow: ellipsis;
overflow: hidden; overflow: hidden;
} }
} }
} }
.file-name { .file-name {
margin-left: 1em; margin-left: 1em;
} }
.file-size { .file-size {
font-size: 13px; font-size: 13px;
color: #888; color: #888;
margin-left: 1em; margin-left: 1em;
} }
.code-view { .code-view {
overflow: auto; overflow: auto;
overflow-x: auto; overflow-x: auto;
overflow-y: hidden; overflow-y: hidden;
background: white; background: white;
.view-raw { .view-raw {
min-height: 40px; min-height: 40px;
text-align: center; text-align: center;
padding-top: 20px; padding-top: 20px;
.btn { .btn {
font-size: 1.05em; font-size: 1.05em;
line-height: 16px; line-height: 16px;
padding: 6px 8px; padding: 6px 8px;
} }
} }
table { table {
width: 100%; width: 100%;
td { td {
padding: 0; padding: 0;
} }
} }
.lines-num { .lines-num {
text-align: right; text-align: right;
color: #999; color: #999;
background: #f5f5f5; background: #f5f5f5;
width: 1%; width: 1%;
span { span {
font-family: Monaco, Menlo, Consolas, "Courier New", monospace; font-family: Monaco, Menlo, Consolas, "Courier New", monospace;
line-height: 18px; line-height: 18px;
padding: 0 8px 0 10px; padding: 0 8px 0 10px;
cursor: pointer; cursor: pointer;
display: block; display: block;
margin-top: 2px; margin-top: 2px;
font-size: 12px; font-size: 12px;
} }
} }
.lines-code > pre { .lines-code > pre {
border: none; border: none;
border-left: 1px solid #ddd; border-left: 1px solid #ddd;
> ol.linenums > li { > ol.linenums > li {
padding: 0 10px; padding: 0 10px;
&.active { &.active {
background: #ffffdd; background: #ffffdd;
} }
} }
} }
} }
.repo-setting-zone { .repo-setting-zone {
padding: 30px; padding: 30px;
} }
#repo-collab-list { #repo-collab-list {
list-style: none; list-style: none;
padding: 10px 0 5px 0; padding: 10px 0 5px 0;
li.collab { li.collab {
clear: both; clear: both;
height: 50px; height: 50px;
padding: 0 15px 0 15px; padding: 0 15px 0 15px;
} }
a.member { a.member {
color: #444; color: #444;
height: 50px; height: 50px;
line-height: 50px; line-height: 50px;
&:hover { &:hover {
color: #4183C4; color: #4183C4;
} }
} }
.avatar { .avatar {
margin-right: 1em; margin-right: 1em;
width: 40px; width: 40px;
} }
.remove-collab { .remove-collab {
color: #DD4B39; color: #DD4B39;
} }
} }
.repo-user-list-block { .repo-user-list-block {
position: relative; position: relative;
top: 5px; top: 5px;
} }
.setting-list { .setting-list {
width: 100%; width: 100%;
list-style: none; list-style: none;
} }

View File

@ -81,6 +81,7 @@
} }
.btn-link { .btn-link {
overflow: visible; overflow: visible;
color: white;
padding: .6em 1.2em; padding: .6em 1.2em;
} }
.btn-radius { .btn-radius {

View File

@ -17,7 +17,12 @@ const (
func Home(ctx *middleware.Context) { func Home(ctx *middleware.Context) {
if ctx.IsSigned { if ctx.IsSigned {
user.Dashboard(ctx) if !ctx.User.IsActive && setting.Service.RegisterEmailConfirm {
ctx.Data["Title"] = ctx.Tr("auth.active_your_account")
ctx.HTML(200, user.ACTIVATE)
} else {
user.Dashboard(ctx)
}
return return
} }

View File

@ -106,10 +106,9 @@ func SignInPost(ctx *middleware.Context, form auth.SignInForm) {
if err != nil { if err != nil {
if err == models.ErrUserNotExist { if err == models.ErrUserNotExist {
ctx.RenderWithErr(ctx.Tr("form.username_password_incorrect"), SIGNIN, &form) ctx.RenderWithErr(ctx.Tr("form.username_password_incorrect"), SIGNIN, &form)
return } else {
ctx.Handle(500, "UserSignIn", err)
} }
ctx.Handle(500, "UserSignIn", err)
return return
} }
@ -294,55 +293,59 @@ func SignUpPost(ctx *middleware.Context, cpt *captcha.Captcha, form auth.Registe
} }
func Activate(ctx *middleware.Context) { func Activate(ctx *middleware.Context) {
// code := ctx.Query("code") code := ctx.Query("code")
// if len(code) == 0 { if len(code) == 0 {
// ctx.Data["IsActivatePage"] = true ctx.Data["IsActivatePage"] = true
// if ctx.User.IsActive { if ctx.User.IsActive {
// ctx.Handle(404, "user.Activate", nil) ctx.Error(404)
// return return
// } }
// // Resend confirmation e-mail. // Resend confirmation e-mail.
// if setting.Service.RegisterEmailConfirm { if setting.Service.RegisterEmailConfirm {
// if ctx.Cache.IsExist("MailResendLimit_" + ctx.User.LowerName) { if ctx.Cache.IsExist("MailResendLimit_" + ctx.User.LowerName) {
// ctx.Data["ResendLimited"] = true ctx.Data["ResendLimited"] = true
// } else { } else {
// ctx.Data["Hours"] = setting.Service.ActiveCodeLives / 60 ctx.Data["Hours"] = setting.Service.ActiveCodeLives / 60
// mailer.SendActiveMail(ctx.Render, ctx.User) mailer.SendActiveMail(ctx.Render, ctx.User)
// if err := ctx.Cache.Put("MailResendLimit_"+ctx.User.LowerName, ctx.User.LowerName, 180); err != nil { if err := ctx.Cache.Put("MailResendLimit_"+ctx.User.LowerName, ctx.User.LowerName, 180); err != nil {
// log.Error("Set cache(MailResendLimit) fail: %v", err) log.Error(4, "Set cache(MailResendLimit) fail: %v", err)
// } }
// } }
// } else { } else {
// ctx.Data["ServiceNotEnabled"] = true ctx.Data["ServiceNotEnabled"] = true
// } }
// ctx.HTML(200, ACTIVATE) ctx.HTML(200, ACTIVATE)
// return return
// } }
// // Verify code. // Verify code.
// if user := models.VerifyUserActiveCode(code); user != nil { if user := models.VerifyUserActiveCode(code); user != nil {
// user.IsActive = true user.IsActive = true
// user.Rands = models.GetUserSalt() user.Rands = models.GetUserSalt()
// if err := models.UpdateUser(user); err != nil { if err := models.UpdateUser(user); err != nil {
// ctx.Handle(404, "user.Activate", err) if err == models.ErrUserNotExist {
// return ctx.Error(404)
// } } else {
ctx.Handle(500, "UpdateUser", err)
}
return
}
// log.Trace("%s User activated: %s", ctx.Req.RequestURI, user.Name) log.Trace("User activated: %s", user.Name)
// ctx.Session.Set("userId", user.Id) ctx.Session.Set("uid", user.Id)
// ctx.Session.Set("userName", user.Name) ctx.Session.Set("uname", user.Name)
// ctx.Redirect("/") ctx.Redirect("/")
// return return
// } }
// ctx.Data["IsActivateFailed"] = true ctx.Data["IsActivateFailed"] = true
// ctx.HTML(200, ACTIVATE) ctx.HTML(200, ACTIVATE)
} }
func ForgotPasswd(ctx *middleware.Context) { func ForgotPasswd(ctx *middleware.Context) {
ctx.Data["Title"] = "Forgot Password" ctx.Data["Title"] = ctx.Tr("auth.forgot_password")
if setting.MailService == nil { if setting.MailService == nil {
ctx.Data["IsResetDisable"] = true ctx.Data["IsResetDisable"] = true
@ -355,44 +358,45 @@ func ForgotPasswd(ctx *middleware.Context) {
} }
func ForgotPasswdPost(ctx *middleware.Context) { func ForgotPasswdPost(ctx *middleware.Context) {
// ctx.Data["Title"] = "Forgot Password" ctx.Data["Title"] = ctx.Tr("auth.forgot_password")
// if setting.MailService == nil { if setting.MailService == nil {
// ctx.Handle(403, "user.ForgotPasswdPost", nil) ctx.Handle(403, "user.ForgotPasswdPost", nil)
// return return
// } }
// ctx.Data["IsResetRequest"] = true ctx.Data["IsResetRequest"] = true
// email := ctx.Query("email") email := ctx.Query("email")
// u, err := models.GetUserByEmail(email) u, err := models.GetUserByEmail(email)
// if err != nil { if err != nil {
// if err == models.ErrUserNotExist { if err == models.ErrUserNotExist {
// ctx.RenderWithErr("This e-mail address does not associate to any account.", "user/forgot_passwd", nil) ctx.Data["Err_Email"] = true
// } else { ctx.RenderWithErr(ctx.Tr("auth.email_not_associate"), FORGOT_PASSWORD, nil)
// ctx.Handle(500, "user.ResetPasswd(check existence)", err) } else {
// } ctx.Handle(500, "user.ResetPasswd(check existence)", err)
// return }
// } return
}
// if ctx.Cache.IsExist("MailResendLimit_" + u.LowerName) { if ctx.Cache.IsExist("MailResendLimit_" + u.LowerName) {
// ctx.Data["ResendLimited"] = true ctx.Data["ResendLimited"] = true
// ctx.HTML(200, FORGOT_PASSWORD) ctx.HTML(200, FORGOT_PASSWORD)
// return return
// } }
// mailer.SendResetPasswdMail(ctx.Render, u) mailer.SendResetPasswdMail(ctx.Render, u)
// if err = ctx.Cache.Put("MailResendLimit_"+u.LowerName, u.LowerName, 180); err != nil { if err = ctx.Cache.Put("MailResendLimit_"+u.LowerName, u.LowerName, 180); err != nil {
// log.Error("Set cache(MailResendLimit) fail: %v", err) log.Error(4, "Set cache(MailResendLimit) fail: %v", err)
// } }
// ctx.Data["Email"] = email ctx.Data["Email"] = email
// ctx.Data["Hours"] = setting.Service.ActiveCodeLives / 60 ctx.Data["Hours"] = setting.Service.ActiveCodeLives / 60
// ctx.Data["IsResetSent"] = true ctx.Data["IsResetSent"] = true
// ctx.HTML(200, FORGOT_PASSWORD) ctx.HTML(200, FORGOT_PASSWORD)
} }
func ResetPasswd(ctx *middleware.Context) { func ResetPasswd(ctx *middleware.Context) {
ctx.Data["Title"] = "Reset Password" ctx.Data["Title"] = ctx.Tr("auth.reset_password")
code := ctx.Query("code") code := ctx.Query("code")
if len(code) == 0 { if len(code) == 0 {
@ -405,38 +409,39 @@ func ResetPasswd(ctx *middleware.Context) {
} }
func ResetPasswdPost(ctx *middleware.Context) { func ResetPasswdPost(ctx *middleware.Context) {
// ctx.Data["Title"] = "Reset Password" ctx.Data["Title"] = ctx.Tr("auth.reset_password")
// code := ctx.Query("code") code := ctx.Query("code")
// if len(code) == 0 { if len(code) == 0 {
// ctx.Error(404) ctx.Error(404)
// return return
// } }
// ctx.Data["Code"] = code ctx.Data["Code"] = code
// if u := models.VerifyUserActiveCode(code); u != nil { if u := models.VerifyUserActiveCode(code); u != nil {
// // Validate password length. // Validate password length.
// passwd := ctx.Query("passwd") passwd := ctx.Query("password")
// if len(passwd) < 6 || len(passwd) > 30 { if len(passwd) < 6 {
// ctx.Data["IsResetForm"] = true ctx.Data["IsResetForm"] = true
// ctx.RenderWithErr("Password length should be in 6 and 30.", "user/reset_passwd", nil) ctx.Data["Err_Password"] = true
// return ctx.RenderWithErr(ctx.Tr("auth.password_too_short"), RESET_PASSWORD, nil)
// } return
}
// u.Passwd = passwd u.Passwd = passwd
// u.Rands = models.GetUserSalt() u.Rands = models.GetUserSalt()
// u.Salt = models.GetUserSalt() u.Salt = models.GetUserSalt()
// u.EncodePasswd() u.EncodePasswd()
// if err := models.UpdateUser(u); err != nil { if err := models.UpdateUser(u); err != nil {
// ctx.Handle(500, "user.ResetPasswd(UpdateUser)", err) ctx.Handle(500, "UpdateUser", err)
// return return
// } }
// log.Trace("%s User password reset: %s", ctx.Req.RequestURI, u.Name) log.Trace("User password reset: %s", u.Name)
// ctx.Redirect("/user/login") ctx.Redirect("/user/login")
// return return
// } }
// ctx.Data["IsResetFailed"] = true ctx.Data["IsResetFailed"] = true
// ctx.HTML(200, RESET_PASSWORD) ctx.HTML(200, RESET_PASSWORD)
} }

View File

@ -1,5 +0,0 @@
{
"language.fileExtensions": {
"tmpl": "html"
}
}

View File

@ -1,4 +1,5 @@
{{template "ng/base/head" .}} {{template "ng/base/header" .}} {{template "ng/base/head" .}}
{{template "ng/base/header" .}}
<div id="promo-wrapper"> <div id="promo-wrapper">
<div class="container clear"> <div class="container clear">
<div id="promo-logo" class="left"> <div id="promo-logo" class="left">

View File

@ -1,36 +1,39 @@
{{template "base/head" .}} {{template "ng/base/head" .}}
{{template "base/navbar" .}} {{template "ng/base/header" .}}
<div id="body" class="container"> <div id="sign-wrapper">
<form action="/user/activate" method="post" class="form-horizontal card" id="login-card"> <form class="form-align form panel sign-panel sign-form container panel-radius" id="sign-up-form" action="/user/activate" method="post">
{{.CsrfTokenHtml}} {{.CsrfTokenHtml}}
<h3>Activate Your Account</h3> <div class="panel-header">
<h2>{{.i18n.Tr "auth.active_your_account"}}</h2>
</div>
<div class="panel-content">
{{if .IsActivatePage}} {{if .IsActivatePage}}
{{if .ServiceNotEnabled}} {{if .ServiceNotEnabled}}
<p>Sorry, Register Mail Confirmation has been disabled.</p> <p>{{.i18n.Tr "auth.disable_register_mail"}}</p>
{{else if .ResendLimited}} {{else if .ResendLimited}}
<p>Sorry, you are sending an activation e-mail too frequently. Please wait 3 minutes.</p> <p>{{.i18n.Tr "auth.resent_limit_prompt"}}</p>
{{else}} {{else}}
<p>A new confirmation e-mail has been sent to <b>{{.SignedUser.Email}}</b>, please check your inbox within the next {{.Hours}} hours to complete your registration.</p> <p>{{.i18n.Tr "auth.confirmation_mail_sent_prompt" .SignedUser.Email .Hours | Str2html}}</p>
<hr/> <hr/>
<a href="http://{{Mail2Domain .SignedUser.Email}}" class="btn btn-lg btn-success">Sign in to your e-mail</a> <label></label>
<a class="btn btn-green btn-large btn-link btn-radius" href="http://{{Mail2Domain .SignedUser.Email}}">{{.i18n.Tr "auth.sign_in_email"}}</a>
{{end}} {{end}}
{{else}} {{else}}
{{if .IsSendRegisterMail}} {{if .IsSendRegisterMail}}
<p>A confirmation e-mail has been sent to <b>{{.Email}}</b>, please check your inbox within the next {{.Hours}} hours to complete your registration.</p> <p>{{.i18n.Tr "auth.confirmation_mail_sent_prompt" .Email .Hours | Str2html}}</p>
<hr/> <hr/>
<a href="http://{{Mail2Domain .Email}}" class="btn btn-lg btn-success">Sign in to your e-mail</a> <label></label>
<a class="btn btn-green btn-large btn-link btn-radius" href="http://{{Mail2Domain .Email}}">{{.i18n.Tr "auth.sign_in_email"}}</a>
{{else if .IsActivateFailed}} {{else if .IsActivateFailed}}
<p>Sorry, your confirmation code has exipired or not valid.</p> <p>{{.i18n.Tr "auth.invalid_code"}}</p>
{{else}} {{else}}
<p>Hi, {{.SignedUser.Name}}, you have an unconfirmed email address(<b>{{.SignedUser.Email}}</b>). If you haven't received a confirmation e-mail or need to resend a new one, please click on the button below.</p> <p>{{.i18n.Tr "auth.has_unconfirmed_mail" .SignedUser.Name .SignedUser.Email | Str2html}}</p>
<hr/> <hr/>
<div class="form-group"> <label></label>
<div class="col-md-offset-4 col-md-6"> <button class="btn btn-blue btn-large btn-radius">{{.i18n.Tr "auth.resend_mail"}}</button>
<button type="submit" class="btn btn-lg btn-primary">Click here to resend your activation e-mail</button>
</div>
</div>
{{end}} {{end}}
{{end}} {{end}}
</div>
</form> </form>
</div> </div>
{{template "base/footer" .}} {{template "ng/base/footer" .}}

View File

@ -1,32 +1,32 @@
{{template "base/head" .}} {{template "ng/base/head" .}}
{{template "base/navbar" .}} {{template "ng/base/header" .}}
<div id="body" class="container"> <div id="sign-wrapper">
<form action="/user/forget_password" method="post" class="form-horizontal card" id="login-card"> <form class="form-align form panel sign-panel sign-form container panel-radius" id="sign-up-form" action="/user/forget_password" method="post">
{{.CsrfTokenHtml}} {{.CsrfTokenHtml}}
<h3>Reset Your Password</h3> <div class="panel-header">
{{template "base/alert" .}} <h2>{{.i18n.Tr "auth.forgot_password"}}</h2>
{{if .IsResetSent}}
<p>A confirmation e-mail has been sent to <b>{{.Email}}</b>, please check your inbox within {{.Hours}} hours.</p>
<hr/>
<a href="http://{{Mail2Domain .Email}}" class="btn btn-lg btn-success">Sign in to your e-mail</a>
{{else if .IsResetRequest}}
<div class="form-group {{if .Err_Email}}has-error has-feedback{{end}}">
<label class="col-md-3 control-label">Email: </label>
<div class="col-md-7">
<input name="email" class="form-control" placeholder="Type your e-mail address" required="required">
</div>
</div> </div>
<hr/> <div class="panel-content">
<div class="form-group"> {{template "ng/base/alert" .}}
<div class="col-md-offset-4 col-md-6"> {{if .IsResetSent}}
<button type="submit" class="btn btn-lg btn-primary">Click here to send resend confirmation e-mail</button> <p>{{.i18n.Tr "auth.confirmation_mail_sent_prompt" .Email .Hours | Str2html}}</p>
<hr/>
<label></label>
<a class="btn btn-green btn-large btn-link btn-radius" href="http://{{Mail2Domain .Email}}">{{.i18n.Tr "auth.sign_in_email"}}</a>
{{else if .IsResetRequest}}
<div class="field">
<label class="req" for="email">{{.i18n.Tr "email"}}</label>
<input class="ipt ipt-large ipt-radius {{if .Err_Email}}ipt-error{{end}}" id="email" name="email" type="email" value="{{.email}}"required/>
</div> </div>
<hr/>
<label></label>
<button class="btn btn-blue btn-large btn-radius">{{.i18n.Tr "auth.send_reset_mail"}}</button>
{{else if .IsResetDisable}}
<p>{{.i18n.Tr "auth.disable_register_mail"}}</p>
{{else if .ResendLimited}}
<p>{{.i18n.Tr "auth.resent_limit_prompt"}}</p>
{{end}}
</div> </div>
{{else if .IsResetDisable}}
<p>Sorry, mail service is not enabled.</p>
{{else if .ResendLimited}}
<p>Sorry, you are sending an e-mail too frequently, please wait another 3 minutes and try again.</p>
{{end}}
</form> </form>
</div> </div>
{{template "base/footer" .}} {{template "ng/base/footer" .}}

View File

@ -1,26 +1,25 @@
{{template "base/head" .}} {{template "ng/base/head" .}}
{{template "base/navbar" .}} {{template "ng/base/header" .}}
<div id="body" class="container"> <div id="sign-wrapper">
<form action="/user/reset_password?code={{.Code}}" method="post" class="form-horizontal card" id="login-card"> <form class="form-align form panel sign-panel sign-form container panel-radius" id="sign-up-form" action="/user/reset_password?code={{.Code}}" method="post">
{{.CsrfTokenHtml}} {{.CsrfTokenHtml}}
<h3>Reset Your Pasword</h3> <div class="panel-header">
{{template "base/alert" .}} <h2>{{.i18n.Tr "auth.reset_password"}}</h2>
{{if .IsResetForm}}
<div class="form-group">
<label class="col-md-4 control-label">Password: </label>
<div class="col-md-6">
<input name="passwd" type="password" class="form-control" placeholder="Type your password" required="required">
</div>
</div> </div>
<hr/> <div class="panel-content">
<div class="form-group"> {{template "ng/base/alert" .}}
<div class="col-md-offset-4 col-md-6"> {{if .IsResetForm}}
<button type="submit" class="btn btn-lg btn-primary">Click here to reset your password</button> <div class="field">
<label class="req" for="password">{{.i18n.Tr "password"}}</label>
<input class="ipt ipt-large ipt-radius {{if .Err_Password}}ipt-error{{end}}" id="password" name="password" type="password" value="{{.password}}" required/>
</div> </div>
<hr/>
<label></label>
<button class="btn btn-blue btn-large btn-radius">{{.i18n.Tr "auth.reset_password_helper"}}</button>
{{else}}
<p>{{.i18n.Tr "auth.invalid_code"}}</p>
{{end}}
</div> </div>
{{else}}
<p>Sorry, your confirmation code has expired or is not valid.</p>
{{end}}
</form> </form>
</div> </div>
{{template "base/footer" .}} {{template "ng/base/footer" .}}

View File

@ -7,30 +7,30 @@
</div> </div>
<div class="panel-content"> <div class="panel-content">
{{template "ng/base/alert" .}} {{template "ng/base/alert" .}}
<p class="field"> <div class="field">
<label class="req" for="username">{{.i18n.Tr "home.uname_holder"}}</label> <label class="req" for="username">{{.i18n.Tr "home.uname_holder"}}</label>
<input class="ipt ipt-large ipt-radius {{if .Err_UserName}}ipt-error{{end}}" id="username" name="uname" type="text" value="{{.uname}}" required/> <input class="ipt ipt-large ipt-radius {{if .Err_UserName}}ipt-error{{end}}" id="username" name="uname" type="text" value="{{.uname}}" required/>
</p> </div>
<p class="field"> <div class="field">
<label class="req" for="password">{{.i18n.Tr "password"}}</label> <label class="req" for="password">{{.i18n.Tr "password"}}</label>
<input class="ipt ipt-large ipt-radius {{if .Err_Password}}ipt-error{{end}}" id="password" name="password" type="password" required/> <input class="ipt ipt-large ipt-radius {{if .Err_Password}}ipt-error{{end}}" id="password" name="password" type="password" required/>
</p> </div>
{{if not .IsSocialLogin}} {{if not .IsSocialLogin}}
<p class="field"> <div class="field">
<span class="form-label"></span> <span class="form-label"></span>
<input class="ipt-chk" id="remember" name="remember" type="checkbox"/>&nbsp;&nbsp;&nbsp;&nbsp;<strong>{{.i18n.Tr "auth.remember_me"}}</strong> <input class="ipt-chk" id="remember" name="remember" type="checkbox"/>&nbsp;&nbsp;&nbsp;&nbsp;<strong>{{.i18n.Tr "auth.remember_me"}}</strong>
</p> </div>
{{end}} {{end}}
<p class="field"> <div class="field">
<span class="form-label"></span> <span class="form-label"></span>
<button class="btn btn-green btn-large btn-radius">{{.i18n.Tr "sign_in"}}</button>&nbsp;&nbsp;&nbsp;&nbsp; <button class="btn btn-green btn-large btn-radius">{{.i18n.Tr "sign_in"}}</button>&nbsp;&nbsp;&nbsp;&nbsp;
{{if not .IsSocialLogin}}<a href="/user/forget_password">{{.i18n.Tr "auth.forget_password"}}</a>{{end}} {{if not .IsSocialLogin}}<a href="/user/forget_password">{{.i18n.Tr "auth.forget_password"}}</a>{{end}}
</p> </div>
{{if not .IsSocialLogin}} {{if not .IsSocialLogin}}
<p class="field"> <div class="field">
<span class="form-label"></span> <label></label>
<a href="/user/sign_up">{{.i18n.Tr "auth.sign_up_now" | Str2html}}</a> <a href="/user/sign_up">{{.i18n.Tr "auth.sign_up_now" | Str2html}}</a>
</p> </div>
{{if .OauthEnabled}} {{if .OauthEnabled}}
<hr/> <hr/>
<div id="sign-social" class="text-center social-buttons"> <div id="sign-social" class="text-center social-buttons">

View File

@ -10,38 +10,38 @@
{{if .DisableRegistration}} {{if .DisableRegistration}}
<p>{{.i18n.Tr "auth.disable_register_prompt"}}</p> <p>{{.i18n.Tr "auth.disable_register_prompt"}}</p>
{{else}} {{else}}
<p class="field"> <div class="field">
<label class="req" for="username">{{.i18n.Tr "username"}}</label> <label class="req" for="username">{{.i18n.Tr "username"}}</label>
<input class="ipt ipt-large ipt-radius {{if .Err_UserName}}ipt-error{{end}}" id="username" name="uname" type="text" value="{{.uname}}" required/> <input class="ipt ipt-large ipt-radius {{if .Err_UserName}}ipt-error{{end}}" id="username" name="uname" type="text" value="{{.uname}}" required/>
</p> </div>
<p class="field"> <div class="field">
<label class="req" for="email">{{.i18n.Tr "email"}}</label> <label class="req" for="email">{{.i18n.Tr "email"}}</label>
<input class="ipt ipt-large ipt-radius {{if .Err_Email}}ipt-error{{end}}" id="email" name="email" type="email" value="{{.email}}"required/> <input class="ipt ipt-large ipt-radius {{if .Err_Email}}ipt-error{{end}}" id="email" name="email" type="email" value="{{.email}}"required/>
</p> </div>
<p class="field"> <div class="field">
<label class="req" for="password">{{.i18n.Tr "password"}}</label> <label class="req" for="password">{{.i18n.Tr "password"}}</label>
<input class="ipt ipt-large ipt-radius {{if .Err_Password}}ipt-error{{end}}" id="password" name="password" type="password" value="{{.password}}" required/> <input class="ipt ipt-large ipt-radius {{if .Err_Password}}ipt-error{{end}}" id="password" name="password" type="password" value="{{.password}}" required/>
</p> </div>
<p class="field"> <div class="field">
<label class="req" for="re-type">{{.i18n.Tr "re_type"}}</label> <label class="req" for="re-type">{{.i18n.Tr "re_type"}}</label>
<input class="ipt ipt-large ipt-radius {{if .Err_Password}}ipt-error{{end}}" id="re-type" name="retype" type="password" required/> <input class="ipt ipt-large ipt-radius {{if .Err_Password}}ipt-error{{end}}" id="re-type" name="retype" type="password" required/>
</p> </div>
<p class="field"> <div class="field">
<label></label> <label></label>
{{.Captcha.CreateHtml}} {{.Captcha.CreateHtml}}
</p> </div>
<p class="field"> <div class="field">
<label class="req" for="captcha">{{.i18n.Tr "captcha"}}</label> <label class="req" for="captcha">{{.i18n.Tr "captcha"}}</label>
<input class="ipt ipt-large ipt-radius {{if .Err_Captcha}}ipt-error{{end}}" id="captcha" name="captcha" type="text" required/> <input class="ipt ipt-large ipt-radius {{if .Err_Captcha}}ipt-error{{end}}" id="captcha" name="captcha" type="text" required/>
</p> </div>
<p class="field"> <div class="field">
<span class="form-label"></span> <span class="form-label"></span>
<button class="btn btn-blue btn-large btn-radius">{{.i18n.Tr "auth.create_new_account"}}</button> <button class="btn btn-blue btn-large btn-radius">{{.i18n.Tr "auth.create_new_account"}}</button>
</p> </div>
<p class="field"> <div class="field">
<span class="form-label"></span> <span class="form-label"></span>
<a href="/user/login">{{if .IsSocialLogin}}{{.i18n.Tr "auth.social_register_hepler_msg"}}{{else}}{{.i18n.Tr "auth.register_hepler_msg"}}{{end}}</a> <a href="/user/login">{{if .IsSocialLogin}}{{.i18n.Tr "auth.social_register_hepler_msg"}}{{else}}{{.i18n.Tr "auth.register_hepler_msg"}}{{end}}</a>
</p> </div>
{{end}} {{end}}
</div> </div>
</form> </form>