From d94777acf6fea4a12a0a2a3938bfa98e301f93bf Mon Sep 17 00:00:00 2001 From: Olaoluwa Osuntokun Date: Sun, 29 Jan 2017 14:57:57 -0800 Subject: [PATCH] zpay32: ensure argument to Decode is not an empty string This commit fixes a possible panic which can arise within the library due to poor user-data. We now explicitly check for an empty string, exiting early if found within the Decode method. --- zpay32/zbase32check.go | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/zpay32/zbase32check.go b/zpay32/zbase32check.go index ba69c4a0..d52530a2 100644 --- a/zpay32/zbase32check.go +++ b/zpay32/zbase32check.go @@ -4,6 +4,7 @@ import ( "bytes" "encoding/binary" "errors" + "fmt" "hash/crc32" "io" @@ -77,6 +78,11 @@ func Encode(payReq *PaymentRequest) string { // Decode attempts to decode the zbase32 encoded payment request. If the // trailing checksum doesn't match, then an error is returned. func Decode(payData string) (*PaymentRequest, error) { + if payData == "" { + return nil, fmt.Errorf("encoded payment request must be a " + + "non-empty string") + } + // First we decode the zbase32 encoded string into a series of raw // bytes. payReqBytes, err := zbase32.DecodeString(payData)