aboutsummaryrefslogblamecommitdiffstats
path: root/identity/common.go
blob: 00feaa2d95b0a0ebaba7fd4a4d0e7549b5032056 (plain) (tree)
























                                                                                                     
                              
 




                                                                  





















                                                                       
package identity

import (
	"encoding/json"
	"errors"
	"fmt"
	"strings"
)

var ErrIdentityNotExist = errors.New("identity doesn't exist")

type ErrMultipleMatch struct {
	Matching []string
}

func (e ErrMultipleMatch) Error() string {
	return fmt.Sprintf("Multiple matching identities found:\n%s", strings.Join(e.Matching, "\n"))
}

// 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) {
	aux := &IdentityStub{}

	// First try to decode and load as a normal Identity
	err := json.Unmarshal(raw, &aux)
	if err == nil && aux.Id() != "" {
		return aux, nil
		// return identityResolver.ResolveIdentity(aux.Id)
	}

	// 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
	var b Bare

	err = json.Unmarshal(raw, &b)
	if err == nil && (b.name != "" || b.login != "") {
		return &b, nil
	}

	// 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")
}