mirror of
https://github.com/netbirdio/netbird.git
synced 2024-11-29 11:33:48 +01:00
fix peer fields updated after save
Signed-off-by: bcmmbaga <bethuelmbaga12@gmail.com>
This commit is contained in:
parent
a2fb274b86
commit
a2a49bdd47
@ -213,7 +213,10 @@ func (am *DefaultAccountManager) UpdatePeer(ctx context.Context, accountID, user
|
|||||||
var settings *Settings
|
var settings *Settings
|
||||||
var peerGroupList []string
|
var peerGroupList []string
|
||||||
var requiresPeerUpdates bool
|
var requiresPeerUpdates bool
|
||||||
var newLabel string
|
var peerLabelChanged bool
|
||||||
|
var sshChanged bool
|
||||||
|
var loginExpirationChanged bool
|
||||||
|
var inactivityExpirationChanged bool
|
||||||
|
|
||||||
err = am.Store.ExecuteInTransaction(ctx, func(transaction Store) error {
|
err = am.Store.ExecuteInTransaction(ctx, func(transaction Store) error {
|
||||||
peer, err = transaction.GetPeerByID(ctx, LockingStrengthUpdate, accountID, update.ID)
|
peer, err = transaction.GetPeerByID(ctx, LockingStrengthUpdate, accountID, update.ID)
|
||||||
@ -226,7 +229,7 @@ func (am *DefaultAccountManager) UpdatePeer(ctx context.Context, accountID, user
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
peerGroupList, err = getPeerGroupIDs(ctx, am.Store, accountID, update.ID)
|
peerGroupList, err = getPeerGroupIDs(ctx, transaction, accountID, update.ID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -242,12 +245,35 @@ func (am *DefaultAccountManager) UpdatePeer(ctx context.Context, accountID, user
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
newLabel, err = getPeerHostLabel(update.Name, existingLabels)
|
newLabel, err := getPeerHostLabel(update.Name, existingLabels)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
peer.Name = update.Name
|
||||||
peer.DNSLabel = newLabel
|
peer.DNSLabel = newLabel
|
||||||
|
peerLabelChanged = true
|
||||||
|
}
|
||||||
|
|
||||||
|
if peer.SSHEnabled != update.SSHEnabled {
|
||||||
|
peer.SSHEnabled = update.SSHEnabled
|
||||||
|
sshChanged = true
|
||||||
|
}
|
||||||
|
|
||||||
|
if peer.LoginExpirationEnabled != update.LoginExpirationEnabled {
|
||||||
|
if !peer.AddedWithSSOLogin() {
|
||||||
|
return status.Errorf(status.PreconditionFailed, "this peer hasn't been added with the SSO login, therefore the login expiration can't be updated")
|
||||||
|
}
|
||||||
|
peer.LoginExpirationEnabled = update.LoginExpirationEnabled
|
||||||
|
loginExpirationChanged = true
|
||||||
|
}
|
||||||
|
|
||||||
|
if peer.InactivityExpirationEnabled != update.InactivityExpirationEnabled {
|
||||||
|
if !peer.AddedWithSSOLogin() {
|
||||||
|
return status.Errorf(status.PreconditionFailed, "this peer hasn't been added with the SSO login, therefore the inactivity expiration can't be updated")
|
||||||
|
}
|
||||||
|
peer.InactivityExpirationEnabled = update.InactivityExpirationEnabled
|
||||||
|
inactivityExpirationChanged = true
|
||||||
}
|
}
|
||||||
|
|
||||||
return transaction.SavePeer(ctx, LockingStrengthUpdate, accountID, peer)
|
return transaction.SavePeer(ctx, LockingStrengthUpdate, accountID, peer)
|
||||||
@ -256,34 +282,6 @@ func (am *DefaultAccountManager) UpdatePeer(ctx context.Context, accountID, user
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var sshChanged, peerLabelChanged, loginExpirationChanged, inactivityExpirationChanged bool
|
|
||||||
|
|
||||||
if peer.SSHEnabled != update.SSHEnabled {
|
|
||||||
peer.SSHEnabled = update.SSHEnabled
|
|
||||||
sshChanged = true
|
|
||||||
}
|
|
||||||
|
|
||||||
if peer.Name != update.Name {
|
|
||||||
peer.Name = update.Name
|
|
||||||
peerLabelChanged = true
|
|
||||||
}
|
|
||||||
|
|
||||||
if peer.LoginExpirationEnabled != update.LoginExpirationEnabled {
|
|
||||||
if !peer.AddedWithSSOLogin() {
|
|
||||||
return nil, status.Errorf(status.PreconditionFailed, "this peer hasn't been added with the SSO login, therefore the login expiration can't be updated")
|
|
||||||
}
|
|
||||||
peer.LoginExpirationEnabled = update.LoginExpirationEnabled
|
|
||||||
loginExpirationChanged = true
|
|
||||||
}
|
|
||||||
|
|
||||||
if peer.InactivityExpirationEnabled != update.InactivityExpirationEnabled {
|
|
||||||
if !peer.AddedWithSSOLogin() {
|
|
||||||
return nil, status.Errorf(status.PreconditionFailed, "this peer hasn't been added with the SSO login, therefore the inactivity expiration can't be updated")
|
|
||||||
}
|
|
||||||
peer.InactivityExpirationEnabled = update.InactivityExpirationEnabled
|
|
||||||
inactivityExpirationChanged = true
|
|
||||||
}
|
|
||||||
|
|
||||||
if sshChanged {
|
if sshChanged {
|
||||||
event := activity.PeerSSHEnabled
|
event := activity.PeerSSHEnabled
|
||||||
if !peer.SSHEnabled {
|
if !peer.SSHEnabled {
|
||||||
@ -783,7 +781,7 @@ func (am *DefaultAccountManager) LoginPeer(ctx context.Context, login PeerLogin)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
peerGroupIDs, err := getPeerGroupIDs(ctx, am.Store, accountID, peer.ID)
|
peerGroupIDs, err := getPeerGroupIDs(ctx, transaction, accountID, peer.ID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user