status-im/status-go

View on GitHub
protocol/identity/alias/generate.go

Summary

Maintainability
A
0 mins
Test Coverage
B
84%
package alias

import (
    "crypto/ecdsa"
    "encoding/hex"
    "fmt"

    "github.com/status-im/status-go/eth-node/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 {
    // Here we truncate the public key to the least significant 64 bits
    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
}