All checks were successful
Go Build Multi-Platform / build (amd64, windows) (push) Successful in 34s
Go Build Multi-Platform / build (amd64, freebsd) (push) Successful in 38s
Go Build Multi-Platform / build (amd64, linux) (push) Successful in 37s
Go Build Multi-Platform / build (arm, freebsd) (push) Successful in 32s
Go Build Multi-Platform / build (arm, linux) (push) Successful in 35s
Go Build Multi-Platform / build (arm64, darwin) (push) Successful in 34s
Go Build Multi-Platform / build (arm, windows) (push) Successful in 37s
Go Build Multi-Platform / build (arm64, freebsd) (push) Successful in 42s
Go Build Multi-Platform / Create Release (push) Has been skipped
Go Test Multi-Platform / Test (ubuntu-latest, amd64) (push) Successful in 1m29s
Go Revive Lint / lint (push) Successful in 47s
Run Gosec / tests (push) Successful in 1m3s
Go Build Multi-Platform / build (amd64, darwin) (push) Successful in 27s
Go Build Multi-Platform / build (arm64, linux) (push) Successful in 44s
Go Build Multi-Platform / build (arm64, windows) (push) Successful in 42s
Go Test Multi-Platform / Test (ubuntu-latest, arm64) (push) Successful in 1m5s
75 lines
1.5 KiB
Go
75 lines
1.5 KiB
Go
package resolver
|
|
|
|
import (
|
|
"crypto/sha256"
|
|
"encoding/hex"
|
|
"errors"
|
|
"strings"
|
|
"sync"
|
|
|
|
"git.quad4.io/Networks/Reticulum-Go/pkg/identity"
|
|
)
|
|
|
|
type Resolver struct {
|
|
cache map[string]*identity.Identity
|
|
cacheLock sync.RWMutex
|
|
}
|
|
|
|
func New() *Resolver {
|
|
return &Resolver{
|
|
cache: make(map[string]*identity.Identity),
|
|
}
|
|
}
|
|
|
|
func (r *Resolver) ResolveIdentity(fullName string) (*identity.Identity, error) {
|
|
if fullName == "" {
|
|
return nil, errors.New("empty identity name")
|
|
}
|
|
|
|
r.cacheLock.RLock()
|
|
if cachedIdentity, exists := r.cache[fullName]; exists {
|
|
r.cacheLock.RUnlock()
|
|
return cachedIdentity, nil
|
|
}
|
|
r.cacheLock.RUnlock()
|
|
|
|
// Hash the full name to create a deterministic identity
|
|
h := sha256.New()
|
|
h.Write([]byte(fullName))
|
|
nameHash := h.Sum(nil)[:identity.NAME_HASH_LENGTH/8]
|
|
hashStr := hex.EncodeToString(nameHash)
|
|
|
|
// Check if this identity is known
|
|
if knownData, exists := identity.GetKnownDestination(hashStr); exists {
|
|
if id, ok := knownData[2].(*identity.Identity); ok {
|
|
r.cacheLock.Lock()
|
|
r.cache[fullName] = id
|
|
r.cacheLock.Unlock()
|
|
return id, nil
|
|
}
|
|
}
|
|
|
|
// Split name into parts for hierarchical resolution
|
|
parts := strings.Split(fullName, ".")
|
|
if len(parts) < 2 {
|
|
return nil, errors.New("invalid identity name format")
|
|
}
|
|
|
|
// Create new identity if not found
|
|
id, err := identity.New()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
r.cacheLock.Lock()
|
|
r.cache[fullName] = id
|
|
r.cacheLock.Unlock()
|
|
|
|
return id, nil
|
|
}
|
|
|
|
func ResolveIdentity(fullName string) (*identity.Identity, error) {
|
|
r := New()
|
|
return r.ResolveIdentity(fullName)
|
|
}
|