From da64b1d8cfa6c998a91613482a444fefd814a3c5 Mon Sep 17 00:00:00 2001 From: Dominik Richter Date: Wed, 13 Sep 2023 12:54:07 -0700 Subject: [PATCH] =?UTF-8?q?=F0=9F=90=9B=20support=20null=20resources?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- cli/printer/mql.go | 4 ++++ providers-sdk/v1/plugin/runtime.go | 13 ++++++++----- 2 files changed, 12 insertions(+), 5 deletions(-) diff --git a/cli/printer/mql.go b/cli/printer/mql.go index 2c99bb3ed1..4594070f64 100644 --- a/cli/printer/mql.go +++ b/cli/printer/mql.go @@ -449,6 +449,10 @@ func (print *Printer) autoExpand(blockRef uint64, data interface{}, bundle *llx. return res.String() } + if data == nil { + return print.Secondary("null") + } + m, ok := data.(map[string]interface{}) if !ok { return "data is not a map to auto-expand" diff --git a/providers-sdk/v1/plugin/runtime.go b/providers-sdk/v1/plugin/runtime.go index dde30074f2..e8e98887e3 100644 --- a/providers-sdk/v1/plugin/runtime.go +++ b/providers-sdk/v1/plugin/runtime.go @@ -170,13 +170,16 @@ func (x *TValue[T]) ToDataRes(typ types.Type) *DataRes { return &DataRes{} } if x.State&StateIsNull != 0 { - res := &DataRes{ - Data: &llx.Primitive{Type: string(typ)}, - } if x.Error != nil { - res.Error = x.Error.Error() + return &DataRes{ + Error: x.Error.Error(), + Data: &llx.Primitive{Type: string(typ)}, + } + } + + return &DataRes{ + Data: &llx.Primitive{Type: string(types.Nil)}, } - return res } raw := llx.RawData{Type: typ, Value: x.Data, Error: x.Error} res := raw.Result()