mirror of
https://github.com/goharbor/harbor.git
synced 2025-01-03 14:37:44 +01:00
refined processes of self-registration feature.
This commit is contained in:
parent
0a0ee13d3f
commit
a9352f88df
@ -40,6 +40,8 @@ func (c *CommonController) Render() error {
|
|||||||
type BaseController struct {
|
type BaseController struct {
|
||||||
beego.Controller
|
beego.Controller
|
||||||
i18n.Locale
|
i18n.Locale
|
||||||
|
SelfRegistration bool
|
||||||
|
IsAdminLoginedUser bool
|
||||||
}
|
}
|
||||||
|
|
||||||
type langType struct {
|
type langType struct {
|
||||||
@ -52,8 +54,6 @@ const (
|
|||||||
)
|
)
|
||||||
|
|
||||||
var supportLanguages map[string]langType
|
var supportLanguages map[string]langType
|
||||||
var enableAddUserByAdmin bool
|
|
||||||
var isAdminLoginedUser bool
|
|
||||||
|
|
||||||
// Prepare extracts the language information from request and populate data for rendering templates.
|
// Prepare extracts the language information from request and populate data for rendering templates.
|
||||||
func (b *BaseController) Prepare() {
|
func (b *BaseController) Prepare() {
|
||||||
@ -111,21 +111,21 @@ func (b *BaseController) Prepare() {
|
|||||||
|
|
||||||
selfRegistration := strings.ToLower(os.Getenv("SELF_REGISTRATION"))
|
selfRegistration := strings.ToLower(os.Getenv("SELF_REGISTRATION"))
|
||||||
|
|
||||||
if selfRegistration == "off" {
|
if selfRegistration == "on" {
|
||||||
enableAddUserByAdmin = true
|
b.SelfRegistration = true
|
||||||
}
|
}
|
||||||
|
|
||||||
if sessionUserID != nil {
|
if sessionUserID != nil {
|
||||||
var err error
|
var err error
|
||||||
isAdminLoginedUser, err = dao.IsAdminRole(sessionUserID)
|
b.IsAdminLoginedUser, err = dao.IsAdminRole(sessionUserID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Errorf("Error occurred in IsAdminRole:%v", err)
|
log.Errorf("Error occurred in IsAdminRole:%v", err)
|
||||||
b.CustomAbort(http.StatusInternalServerError, "Internal error.")
|
b.CustomAbort(http.StatusInternalServerError, "Internal error.")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
b.Data["IsAdminLoginedUser"] = isAdminLoginedUser
|
b.Data["IsAdminLoginedUser"] = b.IsAdminLoginedUser
|
||||||
b.Data["EnableAddUserByAdmin"] = enableAddUserByAdmin
|
b.Data["SelfRegistration"] = b.SelfRegistration
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34,25 +34,39 @@ type RegisterController struct {
|
|||||||
// Get renders the Sign In page, it only works if the auth mode is set to db_auth
|
// Get renders the Sign In page, it only works if the auth mode is set to db_auth
|
||||||
func (rc *RegisterController) Get() {
|
func (rc *RegisterController) Get() {
|
||||||
|
|
||||||
if enableAddUserByAdmin && !isAdminLoginedUser {
|
if !rc.BaseController.SelfRegistration {
|
||||||
log.Error("Self registration can only be used by admin user.\n")
|
log.Error("Registration can only be used by admin user when self-registrion is off.\n")
|
||||||
rc.Redirect("/signIn", http.StatusFound)
|
rc.Redirect("/signIn", http.StatusFound)
|
||||||
}
|
}
|
||||||
|
|
||||||
pageTitleKey := "page_title_registration"
|
|
||||||
|
|
||||||
if isAdminLoginedUser {
|
|
||||||
pageTitleKey = "page_title_add_user"
|
|
||||||
}
|
|
||||||
|
|
||||||
authMode := os.Getenv("AUTH_MODE")
|
authMode := os.Getenv("AUTH_MODE")
|
||||||
if authMode == "" || authMode == "db_auth" {
|
if authMode == "" || authMode == "db_auth" {
|
||||||
rc.ForwardTo(pageTitleKey, "register")
|
rc.ForwardTo("page_title_registration", "register")
|
||||||
} else {
|
} else {
|
||||||
rc.Redirect("/signIn", http.StatusFound)
|
rc.Redirect("/signIn", http.StatusFound)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// AddUserController handles request for adding user with an admin role user
|
||||||
|
type AddUserController struct {
|
||||||
|
BaseController
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get renders the Sign In page, it only works if the auth mode is set to db_auth
|
||||||
|
func (ac *AddUserController) Get() {
|
||||||
|
|
||||||
|
if !ac.BaseController.IsAdminLoginedUser {
|
||||||
|
ac.Redirect("/signIn", http.StatusFound)
|
||||||
|
}
|
||||||
|
|
||||||
|
authMode := os.Getenv("AUTH_MODE")
|
||||||
|
if authMode == "" || authMode == "db_auth" {
|
||||||
|
ac.ForwardTo("page_title_add_user", "register")
|
||||||
|
} else {
|
||||||
|
ac.Redirect("/signIn", http.StatusFound)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// SignUp insert data into DB based on data in form.
|
// SignUp insert data into DB based on data in form.
|
||||||
func (rc *CommonController) SignUp() {
|
func (rc *CommonController) SignUp() {
|
||||||
|
|
||||||
@ -61,8 +75,8 @@ func (rc *CommonController) SignUp() {
|
|||||||
rc.CustomAbort(http.StatusForbidden, "")
|
rc.CustomAbort(http.StatusForbidden, "")
|
||||||
}
|
}
|
||||||
|
|
||||||
if enableAddUserByAdmin && !isAdminLoginedUser {
|
if !(rc.BaseController.SelfRegistration || rc.BaseController.IsAdminLoginedUser) {
|
||||||
log.Error("Self registration can only be used by admin user.\n")
|
log.Error("Registration can only be used by admin role user when self-registration is off.\n")
|
||||||
rc.CustomAbort(http.StatusForbidden, "")
|
rc.CustomAbort(http.StatusForbidden, "")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -41,6 +41,7 @@ func init() {
|
|||||||
beego.Router("/", &controllers.IndexController{})
|
beego.Router("/", &controllers.IndexController{})
|
||||||
beego.Router("/signIn", &controllers.SignInController{})
|
beego.Router("/signIn", &controllers.SignInController{})
|
||||||
beego.Router("/register", &controllers.RegisterController{})
|
beego.Router("/register", &controllers.RegisterController{})
|
||||||
|
beego.Router("/addUser", &controllers.AddUserController{})
|
||||||
beego.Router("/forgotPassword", &controllers.ForgotPasswordController{})
|
beego.Router("/forgotPassword", &controllers.ForgotPasswordController{})
|
||||||
beego.Router("/resetPassword", &controllers.ResetPasswordController{})
|
beego.Router("/resetPassword", &controllers.ResetPasswordController{})
|
||||||
beego.Router("/changePassword", &controllers.ChangePasswordController{})
|
beego.Router("/changePassword", &controllers.ChangePasswordController{})
|
||||||
|
@ -55,7 +55,7 @@ jQuery(function(){
|
|||||||
if(isAdminLoginedUser == "true") {
|
if(isAdminLoginedUser == "true") {
|
||||||
document.location = "/registry/project";
|
document.location = "/registry/project";
|
||||||
}else{
|
}else{
|
||||||
document.location = "/signIn";
|
document.location = "/signIn";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -58,7 +58,7 @@
|
|||||||
{{ end }}
|
{{ end }}
|
||||||
{{ if eq .AuthMode "db_auth" }}
|
{{ if eq .AuthMode "db_auth" }}
|
||||||
{{ if eq .IsAdminLoginedUser true }}
|
{{ if eq .IsAdminLoginedUser true }}
|
||||||
<li><a id="aSelfSignUp" href="/register" target="_blank"><span class="glyphicon glyphicon-plus"></span> {{i18n .Lang "add_user"}}</a></li>
|
<li><a id="aAddUser" href="/addUser" target="_blank"><span class="glyphicon glyphicon-plus"></span> {{i18n .Lang "add_user"}}</a></li>
|
||||||
{{ end }}
|
{{ end }}
|
||||||
{{ end}}
|
{{ end}}
|
||||||
<li><a id="aLogout" href="#"><span class="glyphicon glyphicon-log-in"></span> {{i18n .Lang "log_out"}}</a></li>
|
<li><a id="aLogout" href="#"><span class="glyphicon glyphicon-log-in"></span> {{i18n .Lang "log_out"}}</a></li>
|
||||||
@ -69,7 +69,7 @@
|
|||||||
{{ else if eq .AuthMode "db_auth" }}
|
{{ else if eq .AuthMode "db_auth" }}
|
||||||
<div class="input-group">
|
<div class="input-group">
|
||||||
<button type="button" class="btn btn-default" id="btnSignIn">{{i18n .Lang "sign_in"}}</button>
|
<button type="button" class="btn btn-default" id="btnSignIn">{{i18n .Lang "sign_in"}}</button>
|
||||||
{{ if eq .EnableAddUserByAdmin false }}
|
{{ if eq .SelfRegistration true }}
|
||||||
<button type="button" class="btn btn-success" id="btnSignUp">{{i18n .Lang "sign_up"}}</button>
|
<button type="button" class="btn btn-success" id="btnSignUp">{{i18n .Lang "sign_up"}}</button>
|
||||||
{{ end }}
|
{{ end }}
|
||||||
</div>
|
</div>
|
||||||
|
Loading…
Reference in New Issue
Block a user