2022-02-13 23:39:27 +08:00
|
|
|
// Copyright 2021 The Casdoor Authors. All Rights Reserved.
|
2021-12-18 01:08:03 +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-01-17 21:16:32 +08:00
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"time"
|
|
|
|
)
|
2021-12-18 01:08:03 +08:00
|
|
|
|
|
|
|
func (syncer *Syncer) syncUsers() {
|
|
|
|
fmt.Printf("Running syncUsers()..\n")
|
|
|
|
|
2022-07-30 22:24:23 +08:00
|
|
|
users, userMap, userNameMap := syncer.getUserMap()
|
2022-01-17 21:16:32 +08:00
|
|
|
oUsers, oUserMap, err := syncer.getOriginalUserMap()
|
|
|
|
if err != nil {
|
|
|
|
fmt.Printf(err.Error())
|
|
|
|
|
|
|
|
timestamp := time.Now().Format("2006-01-02 15:04:05")
|
|
|
|
line := fmt.Sprintf("[%s] %s\n", timestamp, err.Error())
|
|
|
|
updateSyncerErrorText(syncer, line)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2021-12-18 01:08:03 +08:00
|
|
|
fmt.Printf("Users: %d, oUsers: %d\n", len(users), len(oUsers))
|
|
|
|
|
2021-12-22 21:09:13 +08:00
|
|
|
var affiliationMap map[int]string
|
|
|
|
if syncer.AffiliationTable != "" {
|
2023-05-30 15:49:39 +08:00
|
|
|
_, affiliationMap, err = syncer.getAffiliationMap()
|
2021-12-22 21:09:13 +08:00
|
|
|
}
|
2021-12-18 01:08:03 +08:00
|
|
|
|
|
|
|
newUsers := []*User{}
|
|
|
|
for _, oUser := range oUsers {
|
2021-12-19 22:30:54 +08:00
|
|
|
id := oUser.Id
|
2021-12-18 01:08:03 +08:00
|
|
|
if _, ok := userMap[id]; !ok {
|
2022-07-30 22:24:23 +08:00
|
|
|
if _, ok := userNameMap[oUser.Name]; !ok {
|
|
|
|
newUser := syncer.createUserFromOriginalUser(oUser, affiliationMap)
|
|
|
|
fmt.Printf("New user: %v\n", newUser)
|
|
|
|
newUsers = append(newUsers, newUser)
|
|
|
|
}
|
2021-12-18 01:08:03 +08:00
|
|
|
} else {
|
|
|
|
user := userMap[id]
|
|
|
|
oHash := syncer.calculateHash(oUser)
|
|
|
|
|
|
|
|
if user.Hash == user.PreHash {
|
|
|
|
if user.Hash != oHash {
|
|
|
|
updatedUser := syncer.createUserFromOriginalUser(oUser, affiliationMap)
|
|
|
|
updatedUser.Hash = oHash
|
|
|
|
updatedUser.PreHash = oHash
|
2021-12-20 00:26:46 +08:00
|
|
|
syncer.updateUserForOriginalFields(updatedUser)
|
2021-12-18 01:08:03 +08:00
|
|
|
fmt.Printf("Update from oUser to user: %v\n", updatedUser)
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if user.PreHash == oHash {
|
|
|
|
updatedOUser := syncer.createOriginalUserFromUser(user)
|
|
|
|
syncer.updateUser(updatedOUser)
|
|
|
|
fmt.Printf("Update from user to oUser: %v\n", updatedOUser)
|
|
|
|
|
|
|
|
// update preHash
|
|
|
|
user.PreHash = user.Hash
|
|
|
|
SetUserField(user, "pre_hash", user.PreHash)
|
|
|
|
} else {
|
|
|
|
if user.Hash == oHash {
|
|
|
|
// update preHash
|
|
|
|
user.PreHash = user.Hash
|
|
|
|
SetUserField(user, "pre_hash", user.PreHash)
|
|
|
|
} else {
|
|
|
|
updatedUser := syncer.createUserFromOriginalUser(oUser, affiliationMap)
|
|
|
|
updatedUser.Hash = oHash
|
|
|
|
updatedUser.PreHash = oHash
|
2021-12-20 00:26:46 +08:00
|
|
|
syncer.updateUserForOriginalFields(updatedUser)
|
2021-12-18 01:08:03 +08:00
|
|
|
fmt.Printf("Update from oUser to user (2nd condition): %v\n", updatedUser)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-05-30 15:49:39 +08:00
|
|
|
_, err = AddUsersInBatch(newUsers)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2021-12-18 01:08:03 +08:00
|
|
|
|
|
|
|
for _, user := range users {
|
|
|
|
id := user.Id
|
|
|
|
if _, ok := oUserMap[id]; !ok {
|
2021-12-25 00:05:54 +08:00
|
|
|
newOUser := syncer.createOriginalUserFromUser(user)
|
2023-05-30 15:49:39 +08:00
|
|
|
_, err = syncer.addUser(newOUser)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2021-12-25 00:05:54 +08:00
|
|
|
fmt.Printf("New oUser: %v\n", newOUser)
|
2021-12-18 01:08:03 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|