diff options
author | 2018-01-02 22:04:48 -0800 | |
---|---|---|
committer | 2018-01-02 22:04:48 -0800 | |
commit | 320d1b016747ba4501da9417d9ce5f99368a5768 (patch) | |
tree | 1054d96afde6022951b76cc4a09b78e1e3f05058 /ui/form/user.go | |
parent | c39f2e1a8d2de6d412bcc673d29eb0f7a2d1f5f7 (diff) | |
download | v2-320d1b016747ba4501da9417d9ce5f99368a5768.tar.gz v2-320d1b016747ba4501da9417d9ce5f99368a5768.tar.zst v2-320d1b016747ba4501da9417d9ce5f99368a5768.zip |
Refactor packages to have more idiomatic code base
Diffstat (limited to 'ui/form/user.go')
-rw-r--r-- | ui/form/user.go | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/ui/form/user.go b/ui/form/user.go new file mode 100644 index 00000000..8b8346ea --- /dev/null +++ b/ui/form/user.go @@ -0,0 +1,87 @@ +// Copyright 2017 Frédéric Guillot. All rights reserved. +// Use of this source code is governed by the Apache 2.0 +// license that can be found in the LICENSE file. + +package form + +import ( + "net/http" + + "github.com/miniflux/miniflux/errors" + "github.com/miniflux/miniflux/model" +) + +// UserForm represents the user form. +type UserForm struct { + Username string + Password string + Confirmation string + IsAdmin bool +} + +// ValidateCreation validates user creation. +func (u UserForm) ValidateCreation() error { + if u.Username == "" || u.Password == "" || u.Confirmation == "" { + return errors.NewLocalizedError("All fields are mandatory.") + } + + if u.Password != u.Confirmation { + return errors.NewLocalizedError("Passwords are not the same.") + } + + if len(u.Password) < 6 { + return errors.NewLocalizedError("You must use at least 6 characters.") + } + + return nil +} + +// ValidateModification validates user modification. +func (u UserForm) ValidateModification() error { + if u.Username == "" { + return errors.NewLocalizedError("The username is mandatory.") + } + + if u.Password != "" { + if u.Password != u.Confirmation { + return errors.NewLocalizedError("Passwords are not the same.") + } + + if len(u.Password) < 6 { + return errors.NewLocalizedError("You must use at least 6 characters.") + } + } + + return nil +} + +// ToUser returns a User from the form values. +func (u UserForm) ToUser() *model.User { + return &model.User{ + Username: u.Username, + Password: u.Password, + IsAdmin: u.IsAdmin, + } +} + +// Merge updates the fields of the given user. +func (u UserForm) Merge(user *model.User) *model.User { + user.Username = u.Username + user.IsAdmin = u.IsAdmin + + if u.Password != "" { + user.Password = u.Password + } + + return user +} + +// NewUserForm returns a new UserForm. +func NewUserForm(r *http.Request) *UserForm { + return &UserForm{ + Username: r.FormValue("username"), + Password: r.FormValue("password"), + Confirmation: r.FormValue("confirmation"), + IsAdmin: r.FormValue("is_admin") == "1", + } +} |