2021-03-13 23:06:03 +08:00
|
|
|
// Copyright 2021 The casbin Authors. All Rights Reserved.
|
2021-03-06 16:39:17 +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.
|
|
|
|
|
2021-02-11 22:56:08 +08:00
|
|
|
package object
|
|
|
|
|
2021-05-01 16:50:47 +08:00
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"regexp"
|
2021-05-01 17:45:01 +08:00
|
|
|
|
|
|
|
"github.com/casdoor/casdoor/util"
|
2021-05-01 16:50:47 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
var reWhiteSpace *regexp.Regexp
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
reWhiteSpace, _ = regexp.Compile("\\s")
|
|
|
|
}
|
2021-02-14 01:04:51 +08:00
|
|
|
|
2021-05-01 18:39:40 +08:00
|
|
|
func CheckUserSignup(organization string, username string, password string, displayName string, email string, phonePrefix string, phone string, affiliation string) string {
|
|
|
|
if len(username) == 0 {
|
|
|
|
return "username cannot be blank"
|
|
|
|
} else if len(password) == 0 {
|
|
|
|
return "password cannot be blank"
|
|
|
|
} else if getOrganization("admin", organization) == nil {
|
|
|
|
return "organization does not exist"
|
|
|
|
} else if reWhiteSpace.MatchString(username) {
|
2021-05-01 16:50:47 +08:00
|
|
|
return "username cannot contain white spaces"
|
2021-05-01 18:39:40 +08:00
|
|
|
} else if HasUserByField(organization, "name", username) {
|
2021-02-11 22:56:08 +08:00
|
|
|
return "username already exists"
|
2021-05-01 18:39:40 +08:00
|
|
|
} else if HasUserByField(organization, "email", email) {
|
|
|
|
return "email already exists"
|
|
|
|
} else if HasUserByField(organization, "phone", phone) {
|
|
|
|
return "phone already exists"
|
2021-05-01 17:45:01 +08:00
|
|
|
} else if displayName == "" {
|
|
|
|
return "displayName cannot be blank"
|
|
|
|
} else if affiliation == "" {
|
|
|
|
return "affiliation cannot be blank"
|
|
|
|
} else if !util.IsEmailValid(email) {
|
|
|
|
return "email is invalid"
|
|
|
|
} else if phonePrefix == "86" && !util.IsPhoneCnValid(phone) {
|
|
|
|
return "phone number is invalid"
|
2021-02-11 22:56:08 +08:00
|
|
|
} else {
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-01 19:45:40 +08:00
|
|
|
func CheckUserLogin(organization string, username string, password string) (*User, string) {
|
|
|
|
user := GetUserByField(organization, "name", username)
|
|
|
|
if user == nil {
|
|
|
|
return nil, "username does not exist, please sign up first"
|
2021-02-11 22:56:08 +08:00
|
|
|
}
|
|
|
|
|
2021-05-01 19:45:40 +08:00
|
|
|
if user.Password != password {
|
|
|
|
return nil, "password incorrect"
|
2021-02-11 22:56:08 +08:00
|
|
|
}
|
|
|
|
|
2021-05-01 19:45:40 +08:00
|
|
|
return user, ""
|
2021-02-11 22:56:08 +08:00
|
|
|
}
|
2021-02-14 00:22:24 +08:00
|
|
|
|
2021-05-01 19:45:40 +08:00
|
|
|
func (user *User) GetId() string {
|
2021-02-14 01:04:51 +08:00
|
|
|
return fmt.Sprintf("%s/%s", user.Owner, user.Name)
|
|
|
|
}
|