From b73447b7fa932a1d6e1c4ccc8577c45465cc98ba Mon Sep 17 00:00:00 2001 From: Unbewohnte Date: Tue, 5 Nov 2024 11:14:41 +0300 Subject: [PATCH] Feature: Set maximum login and password lengths --- src/server/validation.go | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/src/server/validation.go b/src/server/validation.go index cb423e1..5c79b9e 100644 --- a/src/server/validation.go +++ b/src/server/validation.go @@ -20,14 +20,16 @@ package server import ( "Unbewohnte/dela/db" + "fmt" "net/http" "strings" ) const ( MinimalLoginLength uint = 3 - MinimalUsernameLength uint = 3 MinimalPasswordLength uint = 5 + MaxLoginLength uint = 60 + MaxPasswordLength uint = 250 ) // Check if user is valid. Returns false and a reason-string if not @@ -35,6 +37,9 @@ func IsUserValid(user db.User) (bool, string) { if uint(len(user.Login)) < MinimalLoginLength { return false, "Login is too small" } + if uint(len(user.Login)) > MaxLoginLength { + return false, fmt.Sprintf("Login is too big; Login should be up to %d characters", MaxLoginLength) + } for _, char := range user.Login { if char < 0x21 || char > 0x7E { // Not printable ASCII char! @@ -45,6 +50,9 @@ func IsUserValid(user db.User) (bool, string) { if uint(len(user.Password)) < MinimalPasswordLength { return false, "Password is too small" } + if uint(len(user.Password)) > MaxPasswordLength { + return false, fmt.Sprintf("Password is too big; Password should be up to %d characters", MaxPasswordLength) + } for _, char := range user.Password { if char < 0x21 || char > 0x7E { // Not printable ASCII char!