mirror of
https://github.com/casdoor/casdoor.git
synced 2025-05-23 02:35:49 +08:00
154 lines
3.9 KiB
Go
154 lines
3.9 KiB
Go
// Copyright 2021 The Casdoor Authors. All Rights Reserved.
|
|
//
|
|
// 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
|
|
|
|
import (
|
|
"fmt"
|
|
"time"
|
|
)
|
|
|
|
func (syncer *Syncer) syncUsers() error {
|
|
if len(syncer.TableColumns) == 0 {
|
|
return fmt.Errorf("The syncer table columns should not be empty")
|
|
}
|
|
|
|
fmt.Printf("Running syncUsers()..\n")
|
|
|
|
users, _, _ := syncer.getUserMap()
|
|
oUsers, _, 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())
|
|
_, err = updateSyncerErrorText(syncer, line)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
fmt.Printf("Users: %d, oUsers: %d\n", len(users), len(oUsers))
|
|
|
|
var affiliationMap map[int]string
|
|
if syncer.AffiliationTable != "" {
|
|
_, affiliationMap, err = syncer.getAffiliationMap()
|
|
}
|
|
|
|
key := syncer.getKey()
|
|
|
|
myUsers := map[string]*User{}
|
|
for _, m := range users {
|
|
myUsers[syncer.getUserValue(m, key)] = m
|
|
}
|
|
|
|
myOUsers := map[string]*User{}
|
|
for _, m := range oUsers {
|
|
myOUsers[syncer.getUserValue(m, key)] = m
|
|
}
|
|
|
|
newUsers := []*User{}
|
|
for _, oUser := range oUsers {
|
|
primary := syncer.getUserValue(oUser, key)
|
|
|
|
if _, ok := myUsers[primary]; !ok {
|
|
newUser := syncer.createUserFromOriginalUser(oUser, affiliationMap)
|
|
fmt.Printf("New user: %v\n", newUser)
|
|
newUsers = append(newUsers, newUser)
|
|
} else {
|
|
user := myUsers[primary]
|
|
oHash := syncer.calculateHash(oUser)
|
|
if user.Hash == user.PreHash {
|
|
if user.Hash != oHash {
|
|
updatedUser := syncer.createUserFromOriginalUser(oUser, affiliationMap)
|
|
updatedUser.Hash = oHash
|
|
updatedUser.PreHash = oHash
|
|
|
|
fmt.Printf("Update from oUser to user: %v\n", updatedUser)
|
|
_, err = syncer.updateUserForOriginalByFields(updatedUser, key)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
} else {
|
|
if user.PreHash == oHash {
|
|
if !syncer.IsReadOnly {
|
|
updatedOUser := syncer.createOriginalUserFromUser(user)
|
|
|
|
fmt.Printf("Update from user to oUser: %v\n", updatedOUser)
|
|
_, err = syncer.updateUser(updatedOUser)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
// update preHash
|
|
user.PreHash = user.Hash
|
|
_, err = SetUserField(user, "pre_hash", user.PreHash)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
} else {
|
|
if user.Hash == oHash {
|
|
// update preHash
|
|
user.PreHash = user.Hash
|
|
_, err = SetUserField(user, "pre_hash", user.PreHash)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
} else {
|
|
updatedUser := syncer.createUserFromOriginalUser(oUser, affiliationMap)
|
|
updatedUser.Hash = oHash
|
|
updatedUser.PreHash = oHash
|
|
|
|
fmt.Printf("Update from oUser to user (2nd condition): %v\n", updatedUser)
|
|
_, err = syncer.updateUserForOriginalByFields(updatedUser, key)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
_, err = AddUsersInBatch(newUsers)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if !syncer.IsReadOnly {
|
|
for _, user := range users {
|
|
primary := syncer.getUserValue(user, key)
|
|
if _, ok := myOUsers[primary]; !ok {
|
|
newOUser := syncer.createOriginalUserFromUser(user)
|
|
|
|
fmt.Printf("New oUser: %v\n", newOUser)
|
|
_, err = syncer.addUser(newOUser)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (syncer *Syncer) syncUsersNoError() {
|
|
err := syncer.syncUsers()
|
|
if err != nil {
|
|
fmt.Printf("syncUsersNoError() error: %s\n", err.Error())
|
|
}
|
|
}
|