summaryrefslogtreecommitdiffstats
path: root/routers
diff options
context:
space:
mode:
Diffstat (limited to 'routers')
-rw-r--r--routers/admin/auths.go167
1 files changed, 72 insertions, 95 deletions
diff --git a/routers/admin/auths.go b/routers/admin/auths.go
index f62a9e3c2b..5e9d3be140 100644
--- a/routers/admin/auths.go
+++ b/routers/admin/auths.go
@@ -65,6 +65,37 @@ func NewAuthSource(ctx *middleware.Context) {
ctx.HTML(200, AUTH_NEW)
}
+func parseLDAPConfig(form auth.AuthenticationForm) *models.LDAPConfig {
+ return &models.LDAPConfig{
+ Ldapsource: ldap.Ldapsource{
+ Name: form.Name,
+ Host: form.Host,
+ Port: form.Port,
+ UseSSL: form.TLS,
+ BindDN: form.BindDN,
+ UserDN: form.UserDN,
+ BindPassword: form.BindPassword,
+ UserBase: form.UserBase,
+ AttributeName: form.AttributeName,
+ AttributeSurname: form.AttributeSurname,
+ AttributeMail: form.AttributeMail,
+ Filter: form.Filter,
+ AdminFilter: form.AdminFilter,
+ Enabled: true,
+ },
+ }
+}
+
+func parseSMTPConfig(form auth.AuthenticationForm) *models.SMTPConfig {
+ return &models.SMTPConfig{
+ Auth: form.SMTPAuth,
+ Host: form.SMTPHost,
+ Port: form.SMTPPort,
+ TLS: form.TLS,
+ SkipVerify: form.SkipVerify,
+ }
+}
+
func NewAuthSourcePost(ctx *middleware.Context, form auth.AuthenticationForm) {
ctx.Data["Title"] = ctx.Tr("admin.auths.new")
ctx.Data["PageIsAdmin"] = true
@@ -79,37 +110,14 @@ func NewAuthSourcePost(ctx *middleware.Context, form auth.AuthenticationForm) {
return
}
- var u core.Conversion
+ var config core.Conversion
switch models.LoginType(form.Type) {
case models.LDAP, models.DLDAP:
- u = &models.LDAPConfig{
- Ldapsource: ldap.Ldapsource{
- Name: form.Name,
- Host: form.Host,
- Port: form.Port,
- UseSSL: form.UseSSL,
- BindDN: form.BindDN,
- UserDN: form.UserDN,
- BindPassword: form.BindPassword,
- UserBase: form.UserBase,
- AttributeName: form.AttributeName,
- AttributeSurname: form.AttributeSurname,
- AttributeMail: form.AttributeMail,
- Filter: form.Filter,
- AdminFilter: form.AdminFilter,
- Enabled: true,
- },
- }
+ config = parseLDAPConfig(form)
case models.SMTP:
- u = &models.SMTPConfig{
- Auth: form.SMTPAuth,
- Host: form.SMTPHost,
- Port: form.SMTPPort,
- TLS: form.TLS,
- SkipVerify: form.SkipVerify,
- }
+ config = parseSMTPConfig(form)
case models.PAM:
- u = &models.PAMConfig{
+ config = &models.PAMConfig{
ServiceName: form.PAMServiceName,
}
default:
@@ -117,20 +125,20 @@ func NewAuthSourcePost(ctx *middleware.Context, form auth.AuthenticationForm) {
return
}
- var source = &models.LoginSource{
+ if err := models.CreateSource(&models.LoginSource{
Type: models.LoginType(form.Type),
Name: form.Name,
IsActived: form.IsActive,
AllowAutoRegister: form.AllowAutoRegister,
- Cfg: u,
- }
-
- if err := models.CreateSource(source); err != nil {
+ Cfg: config,
+ }); err != nil {
ctx.Handle(500, "CreateSource", err)
return
}
log.Trace("Authentication created by admin(%s): %s", ctx.User.Name, form.Name)
+
+ ctx.Flash.Success(ctx.Tr("admin.auths.new_success", form.Name))
ctx.Redirect(setting.AppSubUrl + "/admin/auths")
}
@@ -138,20 +146,15 @@ func EditAuthSource(ctx *middleware.Context) {
ctx.Data["Title"] = ctx.Tr("admin.auths.edit")
ctx.Data["PageIsAdmin"] = true
ctx.Data["PageIsAdminAuthentications"] = true
- // ctx.Data["LoginTypes"] = models.LoginTypes
+
ctx.Data["SMTPAuths"] = models.SMTPAuths
- id := com.StrTo(ctx.Params(":authid")).MustInt64()
- if id == 0 {
- ctx.Handle(404, "EditAuthSource", nil)
- return
- }
- u, err := models.GetLoginSourceByID(id)
+ source, err := models.GetLoginSourceByID(ctx.ParamsInt64(":authid"))
if err != nil {
- ctx.Handle(500, "GetLoginSourceById", err)
+ ctx.Handle(500, "GetLoginSourceByID", err)
return
}
- ctx.Data["Source"] = u
+ ctx.Data["Source"] = source
ctx.HTML(200, AUTH_EDIT)
}
@@ -159,10 +162,16 @@ func EditAuthSourcePost(ctx *middleware.Context, form auth.AuthenticationForm) {
ctx.Data["Title"] = ctx.Tr("admin.auths.edit")
ctx.Data["PageIsAdmin"] = true
ctx.Data["PageIsAdminAuthentications"] = true
- ctx.Data["PageIsAuths"] = true
- // ctx.Data["LoginTypes"] = models.LoginTypes
+
ctx.Data["SMTPAuths"] = models.SMTPAuths
+ source, err := models.GetLoginSourceByID(ctx.ParamsInt64(":authid"))
+ if err != nil {
+ ctx.Handle(500, "GetLoginSourceByID", err)
+ return
+ }
+ ctx.Data["Source"] = source
+
if ctx.HasError() {
ctx.HTML(200, AUTH_EDIT)
return
@@ -170,35 +179,10 @@ func EditAuthSourcePost(ctx *middleware.Context, form auth.AuthenticationForm) {
var config core.Conversion
switch models.LoginType(form.Type) {
- case models.LDAP:
- fallthrough
- case models.DLDAP:
- config = &models.LDAPConfig{
- Ldapsource: ldap.Ldapsource{
- Name: form.Name,
- Host: form.Host,
- Port: form.Port,
- UseSSL: form.UseSSL,
- BindDN: form.BindDN,
- UserDN: form.UserDN,
- BindPassword: form.BindPassword,
- UserBase: form.UserBase,
- AttributeName: form.AttributeName,
- AttributeSurname: form.AttributeSurname,
- AttributeMail: form.AttributeMail,
- Filter: form.Filter,
- AdminFilter: form.AdminFilter,
- Enabled: true,
- },
- }
+ case models.LDAP, models.DLDAP:
+ config = parseLDAPConfig(form)
case models.SMTP:
- config = &models.SMTPConfig{
- Auth: form.SMTPAuth,
- Host: form.SMTPHost,
- Port: form.SMTPPort,
- TLS: form.TLS,
- SkipVerify: form.SkipVerify,
- }
+ config = parseSMTPConfig(form)
case models.PAM:
config = &models.PAMConfig{
ServiceName: form.PAMServiceName,
@@ -208,48 +192,41 @@ func EditAuthSourcePost(ctx *middleware.Context, form auth.AuthenticationForm) {
return
}
- u := models.LoginSource{
- ID: form.ID,
- Name: form.Name,
- IsActived: form.IsActive,
- Type: models.LoginType(form.Type),
- AllowAutoRegister: form.AllowAutoRegister,
- Cfg: config,
- }
-
- if err := models.UpdateSource(&u); err != nil {
+ source.Name = form.Name
+ source.IsActived = form.IsActive
+ source.AllowAutoRegister = form.AllowAutoRegister
+ source.Cfg = config
+ if err := models.UpdateSource(source); err != nil {
ctx.Handle(500, "UpdateSource", err)
return
}
+ log.Trace("Authentication changed by admin(%s): %s", ctx.User.Name, source.ID)
- log.Trace("Authentication changed by admin(%s): %s", ctx.User.Name, form.Name)
ctx.Flash.Success(ctx.Tr("admin.auths.update_success"))
- ctx.Redirect(setting.AppSubUrl + "/admin/auths/" + ctx.Params(":authid"))
+ ctx.Redirect(setting.AppSubUrl + "/admin/auths/" + com.ToStr(form.ID))
}
func DeleteAuthSource(ctx *middleware.Context) {
- id := com.StrTo(ctx.Params(":authid")).MustInt64()
- if id == 0 {
- ctx.Handle(404, "DeleteAuthSource", nil)
- return
- }
-
- a, err := models.GetLoginSourceByID(id)
+ source, err := models.GetLoginSourceByID(ctx.ParamsInt64(":authid"))
if err != nil {
- ctx.Handle(500, "GetLoginSourceById", err)
+ ctx.Handle(500, "GetLoginSourceByID", err)
return
}
- if err = models.DelLoginSource(a); err != nil {
+ if err = models.DeleteSource(source); err != nil {
switch err {
case models.ErrAuthenticationUserUsed:
ctx.Flash.Error("form.still_own_user")
ctx.Redirect(setting.AppSubUrl + "/admin/auths/" + ctx.Params(":authid"))
default:
- ctx.Handle(500, "DelLoginSource", err)
+ ctx.Handle(500, "DeleteSource", err)
}
return
}
- log.Trace("Authentication deleted by admin(%s): %s", ctx.User.Name, a.Name)
- ctx.Redirect(setting.AppSubUrl + "/admin/auths")
+ log.Trace("Authentication deleted by admin(%s): %d", ctx.User.Name, source.ID)
+
+ ctx.Flash.Success(ctx.Tr("admin.auths.deletion_success"))
+ ctx.JSON(200, map[string]interface{}{
+ "redirect": setting.AppSubUrl + "/admin/auths",
+ })
}