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 )
}
2022-12-07 13:13:23 +08:00
func recordSigninErrorInfo ( user * User , lang string ) string {
2022-08-17 01:39:53 +08:00
// increase failed login count
user . SigninWrongTimes ++
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
if leftChances > 0 {
2022-12-07 13:13:23 +08:00
return fmt . Sprintf ( i18n . Translate ( lang , "check_util:password 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
2022-12-07 13:13:23 +08:00
return fmt . Sprintf ( i18n . Translate ( lang , "check_util:You have entered the wrong password too many times, please wait for %d minutes and try again" ) , int ( LastSignWrongTimeDuration . Minutes ( ) ) )
2022-08-17 01:39:53 +08:00
}