From fd63ed13ffca38013967349f45a3f9cadced8418 Mon Sep 17 00:00:00 2001 From: Joost Jager Date: Thu, 29 Aug 2019 13:03:30 +0200 Subject: [PATCH] routing/route: add vertex constructor for hex string --- routing/route/route.go | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/routing/route/route.go b/routing/route/route.go index ef902468..ed51d7d0 100644 --- a/routing/route/route.go +++ b/routing/route/route.go @@ -3,6 +3,7 @@ package route import ( "bytes" "encoding/binary" + "encoding/hex" "fmt" "io" "strconv" @@ -47,6 +48,22 @@ func NewVertexFromBytes(b []byte) (Vertex, error) { return v, nil } +// NewVertexFromStr returns a new Vertex given its hex-encoded string format. +func NewVertexFromStr(v string) (Vertex, error) { + // Return error if hex string is of incorrect length. + if len(v) != VertexSize*2 { + return Vertex{}, fmt.Errorf("invalid vertex string length of "+ + "%v, want %v", len(v), VertexSize*2) + } + + vertex, err := hex.DecodeString(v) + if err != nil { + return Vertex{}, err + } + + return NewVertexFromBytes(vertex) +} + // String returns a human readable version of the Vertex which is the // hex-encoding of the serialized compressed public key. func (v Vertex) String() string {