From 0e6722e74d429e2b558cf17031564afad4cfb6e0 Mon Sep 17 00:00:00 2001 From: Donnie Adams Date: Fri, 2 Aug 2024 08:07:57 -0400 Subject: [PATCH] feat: include fields in prompt only when there are fields This essentially allows tools to "display" info to a user, even when using SDKs. Signed-off-by: Donnie Adams --- pkg/prompt/prompt.go | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/pkg/prompt/prompt.go b/pkg/prompt/prompt.go index c1b693be..44cb20f1 100644 --- a/pkg/prompt/prompt.go +++ b/pkg/prompt/prompt.go @@ -61,9 +61,13 @@ func SysPrompt(ctx context.Context, envs []string, input string, _ chan<- string for _, env := range envs { if url, ok := strings.CutPrefix(env, types.PromptURLEnvVar+"="); ok { + var fields []string + if params.Fields != "" { + fields = strings.Split(params.Fields, ",") + } httpPrompt := types.Prompt{ Message: params.Message, - Fields: strings.Split(params.Fields, ","), + Fields: fields, Sensitive: params.Sensitive == "true", } return sysPromptHTTP(ctx, envs, url, httpPrompt) @@ -76,7 +80,7 @@ func SysPrompt(ctx context.Context, envs []string, input string, _ chan<- string func sysPrompt(ctx context.Context, req types.Prompt) (_ string, err error) { defer context2.GetPauseFuncFromCtx(ctx)()() - if req.Message != "" && len(req.Fields) == 1 && strings.TrimSpace(req.Fields[0]) == "" { + if req.Message != "" && len(req.Fields) == 0 { var errs []error _, err := fmt.Fprintln(os.Stderr, req.Message) errs = append(errs, err)