mirror of
https://github.com/ProtonMail/proton-bridge.git
synced 2025-12-18 08:06:59 +00:00
Other: better keychain logging
This commit is contained in:
@ -18,6 +18,7 @@
|
|||||||
package credentials
|
package credentials
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"sort"
|
"sort"
|
||||||
"sync"
|
"sync"
|
||||||
@ -228,21 +229,28 @@ func (s *Store) Get(userID string) (creds *Credentials, err error) {
|
|||||||
return s.get(userID)
|
return s.get(userID)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Store) get(userID string) (creds *Credentials, err error) {
|
func (s *Store) get(userID string) (*Credentials, error) {
|
||||||
log := log.WithField("user", userID)
|
log := log.WithField("user", userID)
|
||||||
|
|
||||||
_, secret, err := s.secrets.Get(userID)
|
_, secret, err := s.secrets.Get(userID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.WithError(err).Warn("Could not get credentials from native keychain")
|
return nil, err
|
||||||
return
|
}
|
||||||
|
|
||||||
|
if secret == "" {
|
||||||
|
return nil, errors.New("secret is empty")
|
||||||
}
|
}
|
||||||
|
|
||||||
credentials := &Credentials{UserID: userID}
|
credentials := &Credentials{UserID: userID}
|
||||||
if err = credentials.Unmarshal(secret); err != nil {
|
|
||||||
err = fmt.Errorf("backend/credentials: malformed secret: %v", err)
|
if err := credentials.Unmarshal(secret); err != nil {
|
||||||
_ = s.secrets.Delete(userID)
|
log.WithError(fmt.Errorf("malformed secret: %w", err)).Error("Could not unmarshal secret")
|
||||||
log.WithError(err).Error("Could not unmarshal secret")
|
|
||||||
return
|
if err := s.secrets.Delete(userID); err != nil {
|
||||||
|
log.WithError(err).Error("Failed to remove malformed secret")
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
return credentials, nil
|
return credentials, nil
|
||||||
|
|||||||
Reference in New Issue
Block a user