45 lines
1.1 KiB
Go
45 lines
1.1 KiB
Go
package alias
|
|
|
|
import (
|
|
"crypto/ecdsa"
|
|
"encoding/hex"
|
|
"fmt"
|
|
|
|
"github.com/ethereum/go-ethereum/crypto"
|
|
)
|
|
|
|
const poly uint64 = 0xB8
|
|
|
|
func generate(seed uint64) string {
|
|
generator := newLSFR(poly, seed)
|
|
adjective1Index := generator.next() % uint64(len(adjectives))
|
|
adjective2Index := generator.next() % uint64(len(adjectives))
|
|
animalIndex := generator.next() % uint64(len(animals))
|
|
adjective1 := adjectives[adjective1Index]
|
|
adjective2 := adjectives[adjective2Index]
|
|
animal := animals[animalIndex]
|
|
|
|
return fmt.Sprintf("%s %s %s", adjective1, adjective2, animal)
|
|
}
|
|
|
|
// GenerateFromPublicKey returns the 3 words name given an *ecdsa.PublicKey
|
|
func GenerateFromPublicKey(publicKey *ecdsa.PublicKey) string {
|
|
return generate(uint64(publicKey.X.Int64()))
|
|
}
|
|
|
|
// GenerateFromPublicKeyString returns the 3 words name given a public key
|
|
// prefixed with 0x
|
|
func GenerateFromPublicKeyString(publicKeyString string) (string, error) {
|
|
publicKeyBytes, err := hex.DecodeString(publicKeyString[2:])
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
publicKey, err := crypto.UnmarshalPubkey(publicKeyBytes)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
return GenerateFromPublicKey(publicKey), nil
|
|
}
|