From c2e2b33a7e8471919efcf2ea319bd19bf86549bd Mon Sep 17 00:00:00 2001 From: yggverse Date: Thu, 5 Dec 2024 14:55:19 +0200 Subject: [PATCH] add certificate details --- .../window/tab/item/identity/gemini.rs | 68 ++++++++++++------- 1 file changed, 43 insertions(+), 25 deletions(-) diff --git a/src/app/browser/window/tab/item/identity/gemini.rs b/src/app/browser/window/tab/item/identity/gemini.rs index 4dbc0ac3..f7ebdd35 100644 --- a/src/app/browser/window/tab/item/identity/gemini.rs +++ b/src/app/browser/window/tab/item/identity/gemini.rs @@ -5,7 +5,7 @@ use crate::app::browser::window::Action; use crate::profile::Profile; use gtk::{ gio::{prelude::TlsCertificateExt, TlsCertificate}, - glib::Uri, + glib::{gformat, Uri}, prelude::IsA, }; use std::rc::Rc; @@ -66,8 +66,36 @@ impl Gemini { Err(reason) => todo!("{reason}"), }; - // Get auth details for tooltip - let mut auth_scope = Vec::new(); + // Init tooltip components + let mut tooltip = format!("Certificate\n"); + + if let Some(subject_name) = certificate.subject_name() { + tooltip + .push_str(&format!("\nsubject\n{subject_name}")); + } + + if let Some(issuer_name) = certificate.issuer_name() { + tooltip.push_str(&format!("\nissuer\n{issuer_name}")); + } + + if let Some(not_valid_before) = certificate.not_valid_before() { + if let Ok(timestamp) = not_valid_before.format_iso8601() { + tooltip.push_str(&format!( + "\nvalid after\n{timestamp}" + )); + } + } + + if let Some(not_valid_after) = certificate.not_valid_after() { + if let Ok(timestamp) = not_valid_after.format_iso8601() { + tooltip.push_str(&format!( + "\nvalid before\n{timestamp}" + )); + } + } + + // Collect scope info + let mut scope = Vec::new(); for auth in profile .identity @@ -79,45 +107,35 @@ impl Gemini { .iter() .filter(|this| this.profile_identity_gemini_id == identity.id) { - auth_scope.push(format!("{}", auth.scope.clone())) + scope.push(format!("{}", auth.scope.clone())) } - // Build tooltip - let mut tooltip = format!( - "valid\n{} - {}", - certificate - .not_valid_before() - .unwrap() - .format_iso8601() - .unwrap(), - certificate - .not_valid_after() - .unwrap() - .format_iso8601() - .unwrap() - ); - - if auth_scope.len() > 0 { - tooltip.push_str(&format!("\nscope\n{}", auth_scope.join("\n"))); + if scope.len() > 0 { + tooltip.push_str(&format!("\n\nScope\n\n{}", scope.join("\n"))); } // Append record option widget.form.list.append( Value::ProfileIdentityGeminiId(identity.id), - &certificate.subject_name().unwrap().replace("CN=", ""), // trim prefix + // title + &certificate + .subject_name() + .unwrap_or(gformat!("Unknown")) + .replace("CN=", ""), // trim prefix + // subtitle &format!( "{} - {} | scope: {}", certificate .not_valid_before() - .unwrap() + .unwrap() // @TODO .format(DATE_FORMAT) .unwrap(), certificate .not_valid_after() - .unwrap() + .unwrap() // @TODO .format(DATE_FORMAT) .unwrap(), - auth_scope.len(), + scope.len(), ), Some(&tooltip), profile