2022-02-13 23:39:27 +08:00
// Copyright 2021 The Casdoor Authors. All Rights Reserved.
2021-06-17 11:55:06 +08:00
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package object
2022-08-17 01:39:53 +08:00
import (
"fmt"
"regexp"
"time"
2022-12-07 13:13:23 +08:00
"github.com/casdoor/casdoor/i18n"
2022-08-17 01:39:53 +08:00
)
2021-06-17 11:55:06 +08:00
2022-02-27 13:44:44 +08:00
var reRealName * regexp . Regexp
2021-06-17 11:55:06 +08:00
func init ( ) {
var err error
2022-02-27 13:44:44 +08:00
reRealName , err = regexp . Compile ( "^[\u4E00-\u9FA5]{2,3}(?:·[\u4E00-\u9FA5]{2,3})*$" )
2021-06-17 11:55:06 +08:00
if err != nil {
panic ( err )
}
}
2022-02-27 13:44:44 +08:00
func isValidRealName ( s string ) bool {
return reRealName . MatchString ( s )
2021-06-17 11:55:06 +08:00
}
2022-08-17 01:39:53 +08:00
func resetUserSigninErrorTimes ( user * User ) {
// if the password is correct and wrong times is not zero, reset the error times
if user . SigninWrongTimes == 0 {
return
}
user . SigninWrongTimes = 0
UpdateUser ( user . GetId ( ) , user , [ ] string { "signin_wrong_times" , "last_signin_wrong_time" } , user . IsGlobalAdmin )
}
2023-04-22 16:16:25 +08:00
func recordSigninErrorInfo ( user * User , lang string , options ... bool ) string {
enableCaptcha := false
if len ( options ) > 0 {
enableCaptcha = options [ 0 ]
}
2022-08-17 01:39:53 +08:00
// increase failed login count
2023-04-22 16:16:25 +08:00
if user . SigninWrongTimes < SigninWrongTimesLimit {
user . SigninWrongTimes ++
}
2022-08-17 01:39:53 +08:00
if user . SigninWrongTimes >= SigninWrongTimesLimit {
// record the latest failed login time
user . LastSigninWrongTime = time . Now ( ) . UTC ( ) . Format ( time . RFC3339 )
}
// update user
UpdateUser ( user . GetId ( ) , user , [ ] string { "signin_wrong_times" , "last_signin_wrong_time" } , user . IsGlobalAdmin )
leftChances := SigninWrongTimesLimit - user . SigninWrongTimes
2023-04-22 16:16:25 +08:00
if leftChances == 0 && enableCaptcha {
return fmt . Sprint ( i18n . Translate ( lang , "check:password or code is incorrect" ) )
} else if leftChances >= 0 {
2023-01-06 19:49:00 +08:00
return fmt . Sprintf ( i18n . Translate ( lang , "check:password or code is incorrect, you have %d remaining chances" ) , leftChances )
2022-08-17 01:39:53 +08:00
}
// don't show the chance error message if the user has no chance left
2023-01-06 19:49:00 +08:00
return fmt . Sprintf ( i18n . Translate ( lang , "check:You have entered the wrong password or code too many times, please wait for %d minutes and try again" ) , int ( LastSignWrongTimeDuration . Minutes ( ) ) )
2022-08-17 01:39:53 +08:00
}