From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from firstgate.proxmox.com (firstgate.proxmox.com [IPv6:2a01:7e0:0:424::9]) by lore.proxmox.com (Postfix) with ESMTPS id 8ABC81FF16B for ; Tue, 29 Jul 2025 10:29:18 +0200 (CEST) Received: from firstgate.proxmox.com (localhost [127.0.0.1]) by firstgate.proxmox.com (Proxmox) with ESMTP id CB4E3A95F; Tue, 29 Jul 2025 10:30:40 +0200 (CEST) From: Shan Shaji To: pve-devel@lists.proxmox.com Date: Tue, 29 Jul 2025 10:30:10 +0200 Message-Id: <20250729083010.39570-1-s.shaji@proxmox.com> X-Mailer: git-send-email 2.39.5 MIME-Version: 1.0 X-Bm-Milter-Handled: 55990f41-d878-4baa-be0a-ee34c49e34d2 X-Bm-Transport-Timestamp: 1753777829314 X-SPAM-LEVEL: Spam detection results: 0 AWL 0.224 Adjusted score from AWL reputation of From: address BAYES_00 -1.9 Bayes spam probability is 0 to 1% DMARC_MISSING 0.1 Missing DMARC policy KAM_DMARC_STATUS 0.01 Test Rule for DKIM or SPF Failure with Strict Alignment RCVD_IN_VALIDITY_CERTIFIED_BLOCKED 0.001 ADMINISTRATOR NOTICE: The query to Validity was blocked. See https://knowledge.validity.com/hc/en-us/articles/20961730681243 for more information. RCVD_IN_VALIDITY_RPBL_BLOCKED 0.001 ADMINISTRATOR NOTICE: The query to Validity was blocked. See https://knowledge.validity.com/hc/en-us/articles/20961730681243 for more information. RCVD_IN_VALIDITY_SAFE_BLOCKED 0.001 ADMINISTRATOR NOTICE: The query to Validity was blocked. See https://knowledge.validity.com/hc/en-us/articles/20961730681243 for more information. SPF_HELO_NONE 0.001 SPF: HELO does not publish an SPF Record SPF_PASS -0.001 SPF: sender matches SPF record URIBL_BLOCKED 0.001 ADMINISTRATOR NOTICE: The query to URIBL was blocked. See http://wiki.apache.org/spamassassin/DnsBlocklists#dnsbl-block for more information. [pveum.pm] Subject: [pve-devel] [PATCH pve-access-control] fix #6528: tfa: update user config on removal of TFA X-BeenThere: pve-devel@lists.proxmox.com X-Mailman-Version: 2.1.29 Precedence: list List-Id: Proxmox VE development discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Reply-To: Proxmox VE development discussion Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Errors-To: pve-devel-bounces@lists.proxmox.com Sender: "pve-devel" When removing TFA from a user via the command line, the change was not reflected in the GUI or in the output of `pveum user list`. Both continued to show that TFA was enabled for the user. Fixed the issue by updating the user configuration file. Signed-off-by: Shan Shaji --- Tested Cases: - Case 1: - Added one TFA for a user. - Delete with CLI `pveum user tfa delete ` - Verified if the UI and CLI outputs are updated. - Case 2: - Add two TFA for a user. - Delete with CLI `pveum user tfa delete ` - Verified if the UI and CLI outputs are updated. - Case 3: - Add two TFA for a user. - Delete with CLI `pveum user tfa delete --id ` - Verified if the UI and CLI outputs are updated. src/PVE/CLI/pveum.pm | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/src/PVE/CLI/pveum.pm b/src/PVE/CLI/pveum.pm index 0645a6d..87e68df 100755 --- a/src/PVE/CLI/pveum.pm +++ b/src/PVE/CLI/pveum.pm @@ -141,16 +141,28 @@ __PACKAGE__->register_method({ my $userid = extract_param($param, "userid"); my $tfa_id = extract_param($param, "id"); + my $update_user_config; PVE::AccessControl::lock_tfa_config(sub { my $tfa_cfg = cfs_read_file('priv/tfa.cfg'); if (defined($tfa_id)) { - $tfa_cfg->api_delete_tfa($userid, $tfa_id); + my $has_entries_left = $tfa_cfg->api_delete_tfa($userid, $tfa_id); + $update_user_config = !$has_entries_left; } else { - $tfa_cfg->remove_user($userid); + my $needs_user_saving = $tfa_cfg->remove_user($userid); + $update_user_config = $needs_user_saving; } cfs_write_file('priv/tfa.cfg', $tfa_cfg); }); + + if ($update_user_config) { + PVE::AccessControl::lock_user_config(sub { + my $user_cfg = cfs_read_file('user.cfg'); + my $user = $user_cfg->{users}->{$userid}; + $user->{keys} = undef; + cfs_write_file('user.cfg', $user_cfg); + }); + } return; }, }); -- 2.39.5 _______________________________________________ pve-devel mailing list pve-devel@lists.proxmox.com https://lists.proxmox.com/cgi-bin/mailman/listinfo/pve-devel