@ -1402,7 +1402,7 @@ func deleteKeysMarkedForDeletion(keys []string) (bool, error) {
// Delete keys marked for deletion
var sshKeysNeedUpdate bool
for _ , KeyToDelete := range keys {
key , err := SearchPublicKeyByContent ( KeyToDelete )
key , err := searchPublicKeyByContentWithEngine ( sess , KeyToDelete )
if err != nil {
log . Error ( 4 , "SearchPublicKeyByContent: %v" , err )
continue
@ -1421,7 +1421,8 @@ func deleteKeysMarkedForDeletion(keys []string) (bool, error) {
return sshKeysNeedUpdate , nil
}
func addLdapSSHPublicKeys ( s * LoginSource , usr * User , SSHPublicKeys [ ] string ) bool {
// addLdapSSHPublicKeys add a users public keys. Returns true if there are changes.
func addLdapSSHPublicKeys ( usr * User , s * LoginSource , SSHPublicKeys [ ] string ) bool {
var sshKeysNeedUpdate bool
for _ , sshKey := range SSHPublicKeys {
_ , _ , _ , _ , err := ssh . ParseAuthorizedKey ( [ ] byte ( sshKey ) )
@ -1440,7 +1441,8 @@ func addLdapSSHPublicKeys(s *LoginSource, usr *User, SSHPublicKeys []string) boo
return sshKeysNeedUpdate
}
func synchronizeLdapSSHPublicKeys ( s * LoginSource , SSHPublicKeys [ ] string , usr * User ) bool {
// synchronizeLdapSSHPublicKeys updates a users public keys. Returns true if there are changes.
func synchronizeLdapSSHPublicKeys ( usr * User , s * LoginSource , SSHPublicKeys [ ] string ) bool {
var sshKeysNeedUpdate bool
log . Trace ( "synchronizeLdapSSHPublicKeys[%s]: Handling LDAP Public SSH Key synchronization for user %s" , s . Name , usr . Name )
@ -1479,7 +1481,7 @@ func synchronizeLdapSSHPublicKeys(s *LoginSource, SSHPublicKeys []string, usr *U
newLdapSSHKeys = append ( newLdapSSHKeys , LDAPPublicSSHKey )
}
}
if addLdapSSHPublicKeys ( s , u sr , newLdapSSHKeys ) {
if addLdapSSHPublicKeys ( u sr , s , newLdapSSHKeys ) {
sshKeysNeedUpdate = true
}
@ -1581,7 +1583,7 @@ func SyncExternalUsers() {
log . Error ( 4 , "SyncExternalUsers[%s]: Error creating user %s: %v" , s . Name , su . Username , err )
} else if isAttributeSSHPublicKeySet {
log . Trace ( "SyncExternalUsers[%s]: Adding LDAP Public SSH Keys for user %s" , s . Name , usr . Name )
if addLdapSSHPublicKeys ( s , u sr , su . SSHPublicKey ) {
if addLdapSSHPublicKeys ( u sr , s , su . SSHPublicKey ) {
sshKeysNeedUpdate = true
}
}
@ -1589,7 +1591,7 @@ func SyncExternalUsers() {
existingUsers = append ( existingUsers , usr . ID )
// Synchronize SSH Public Key if that attribute is set
if isAttributeSSHPublicKeySet && synchronizeLdapSSHPublicKeys ( s , su . SSHPublicKey , usr ) {
if isAttributeSSHPublicKeySet && synchronizeLdapSSHPublicKeys ( usr , s , su . SSHPublicKey ) {
sshKeysNeedUpdate = true
}