2019-01-19 21:23:31 +03:00
|
|
|
package identity
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"errors"
|
|
|
|
"fmt"
|
2019-08-12 17:12:14 +03:00
|
|
|
|
|
|
|
"github.com/MichaelMure/git-bug/entity"
|
2019-01-19 21:23:31 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
var ErrIdentityNotExist = errors.New("identity doesn't exist")
|
|
|
|
|
2019-08-12 17:12:14 +03:00
|
|
|
func NewErrMultipleMatch(matching []entity.Id) *entity.ErrMultipleMatch {
|
|
|
|
return entity.NewErrMultipleMatch("identity", matching)
|
2019-01-19 21:23:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// Custom unmarshaling function to allow package user to delegate
|
|
|
|
// the decoding of an Identity and distinguish between an Identity
|
|
|
|
// and a Bare.
|
|
|
|
//
|
|
|
|
// If the given message has a "id" field, it's considered being a proper Identity.
|
|
|
|
func UnmarshalJSON(raw json.RawMessage) (Interface, error) {
|
2019-02-01 14:22:00 +03:00
|
|
|
aux := &IdentityStub{}
|
2019-01-19 21:23:31 +03:00
|
|
|
|
2019-02-01 14:22:00 +03:00
|
|
|
// First try to decode and load as a normal Identity
|
|
|
|
err := json.Unmarshal(raw, &aux)
|
|
|
|
if err == nil && aux.Id() != "" {
|
|
|
|
return aux, nil
|
2019-01-19 21:23:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// abort if we have an error other than the wrong type
|
|
|
|
if _, ok := err.(*json.UnmarshalTypeError); err != nil && !ok {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Fallback on a legacy Bare identity
|
2019-08-11 15:08:03 +03:00
|
|
|
b := &Bare{}
|
2019-01-19 21:23:31 +03:00
|
|
|
|
2019-08-11 15:08:03 +03:00
|
|
|
err = json.Unmarshal(raw, b)
|
2019-01-19 21:23:31 +03:00
|
|
|
if err == nil && (b.name != "" || b.login != "") {
|
2019-08-11 15:08:03 +03:00
|
|
|
return b, nil
|
2019-01-19 21:23:31 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// abort if we have an error other than the wrong type
|
|
|
|
if _, ok := err.(*json.UnmarshalTypeError); err != nil && !ok {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil, fmt.Errorf("unknown identity type")
|
|
|
|
}
|