From a6619479522ab3c4b7e344469b694bdfe6494321 Mon Sep 17 00:00:00 2001 From: David Bloss Date: Mon, 30 Sep 2024 15:03:36 -0500 Subject: [PATCH] add skip-welcome-email and skip-invite options to bulk import user cmd --- .changes/unreleased/Feature-20240930-150305.yaml | 3 +++ src/cmd/user.go | 16 ++++++++++++---- 2 files changed, 15 insertions(+), 4 deletions(-) create mode 100644 .changes/unreleased/Feature-20240930-150305.yaml diff --git a/.changes/unreleased/Feature-20240930-150305.yaml b/.changes/unreleased/Feature-20240930-150305.yaml new file mode 100644 index 00000000..4256e1c7 --- /dev/null +++ b/.changes/unreleased/Feature-20240930-150305.yaml @@ -0,0 +1,3 @@ +kind: Feature +body: add skip-welcome-email and skip-invite options to bulk import user cmd +time: 2024-09-30T15:03:05.541886-05:00 diff --git a/src/cmd/user.go b/src/cmd/user.go index c89a7c43..811a9f24 100644 --- a/src/cmd/user.go +++ b/src/cmd/user.go @@ -165,7 +165,7 @@ var importUsersCmd = &cobra.Command{ Long: `Imports a list of users from a CSV file with the column headers: Name,Email,Role,Team`, Example: ` -cat << EOF | opslevel import user -f - +cat << EOF | opslevel import user --skip-send-invite --skip-welcome-email -f - Name,Email,Role,Team Kyle Rockman,kyle@opslevel.com,Admin,platform Edgar Ochoa,edgar@opslevel.com,Admin,platform @@ -175,6 +175,11 @@ EOF Run: func(cmd *cobra.Command, args []string) { reader, err := readImportFilepathAsCSV() cobra.CheckErr(err) + skipSendInvite, err := cmd.Flags().GetBool("skip-send-invite") + cobra.CheckErr(err) + skipWelcomeEmail, err := cmd.Flags().GetBool("skip-welcome-email") + cobra.CheckErr(err) + for reader.Rows() { name := reader.Text("Name") email := reader.Text("Email") @@ -188,10 +193,11 @@ EOF userRole = opslevel.UserRole(role) } input := opslevel.UserInput{ - Name: opslevel.RefOf(name), - Role: opslevel.RefOf(userRole), + Name: opslevel.RefOf(name), + Role: opslevel.RefOf(userRole), + SkipWelcomeEmail: opslevel.RefOf(skipWelcomeEmail), } - user, err := getClientGQL().InviteUser(email, input, false) + user, err := getClientGQL().InviteUser(email, input, !skipSendInvite) if err != nil { log.Error().Err(err).Msgf("error inviting user '%s' with email '%s'", name, email) continue @@ -223,6 +229,8 @@ EOF func init() { createUserCmd.Flags().Bool("skip-send-invite", false, "If this flag is set the welcome e-mail will be not be sent") createUserCmd.Flags().Bool("skip-welcome-email", false, "If this flag is set send an invite email even if notifications are disabled for the account") + importUsersCmd.Flags().Bool("skip-send-invite", false, "If this flag is set the welcome e-mail will be not be sent") + importUsersCmd.Flags().Bool("skip-welcome-email", false, "If this flag is set send an invite email even if notifications are disabled for the account") listUserCmd.Flags().Bool("ignore-deactivated", false, "If this flag is set only return active users") exampleCmd.AddCommand(exampleUserCmd)