From 72f06bcc4b513858d3dfa1cee65e82f97cd6ab24 Mon Sep 17 00:00:00 2001 From: Nick Craig-Wood Date: Thu, 24 Oct 2024 13:12:11 +0100 Subject: [PATCH] lib/oauthutil: allow the browser opening function to be overridden --- lib/oauthutil/oauthutil.go | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/lib/oauthutil/oauthutil.go b/lib/oauthutil/oauthutil.go index 2f3d5278f..dae98a3f2 100644 --- a/lib/oauthutil/oauthutil.go +++ b/lib/oauthutil/oauthutil.go @@ -80,6 +80,11 @@ All done. Please go back to rclone. ` ) +// OpenURL is used when rclone wants to open a browser window +// for user authentication. It defaults to something which +// should work for most uses, but may be overridden. +var OpenURL = open.Start + // SharedOptions are shared between backends the utilize an OAuth flow var SharedOptions = []fs.Option{{ Name: config.ConfigClientID, @@ -716,8 +721,12 @@ func configSetup(ctx context.Context, id, name string, m configmap.Mapper, oauth if !authorizeNoAutoBrowser { // Open the URL for the user to visit - _ = open.Start(authURL) - fs.Logf(nil, "If your browser doesn't open automatically go to the following link: %s\n", authURL) + err := OpenURL(authURL) + if err != nil { + fs.Errorf(nil, "Failed to open browser automatically (%v) - please go to the following link: %s\n", err, authURL) + } else { + fs.Logf(nil, "If your browser doesn't open automatically go to the following link: %s\n", authURL) + } } else { fs.Logf(nil, "Please go to the following link: %s\n", authURL) }