From 81d90ccdea1d667f9db4ad40ddeb429c835ec7d5 Mon Sep 17 00:00:00 2001 From: Olaoluwa Osuntokun Date: Tue, 9 Jul 2024 20:42:57 -0700 Subject: [PATCH] rpc: update error handling in DecDisplayForAssetID If an old asset didn't have this field, then we can just assume that the value is zero, rather than error out. Fixes https://github.com/lightninglabs/taproot-assets/issues/1001 --- rpcserver.go | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/rpcserver.go b/rpcserver.go index b6768133e..d3bdd99c2 100644 --- a/rpcserver.go +++ b/rpcserver.go @@ -6668,7 +6668,16 @@ func (r *rpcServer) DecDisplayForAssetID(ctx context.Context, } _, decDisplay, err := meta.GetDecDisplay() - if err != nil && !errors.Is(err, proof.ErrNotJSON) { + switch { + // If it isn't JSON, or doesn't have a dec display, we'll just return 0 + // below. + case errors.Is(err, proof.ErrNotJSON): + fallthrough + case errors.Is(err, proof.ErrDecDisplayMissing): + break + case errors.Is(err, proof.ErrDecDisplayInvalidType): + break + case err != nil: return 0, fmt.Errorf("unable to extract decimal "+ "display for asset_id=%v :%v", id, err) }