mirror of
https://github.com/bitwarden/browser
synced 2025-12-29 06:33:40 +00:00
* Passkey stuff Co-authored-by: Anders Åberg <github@andersaberg.com> * Ugly hacks * Work On Modal State Management * Applying modalStyles * modal * Improved hide/show * fixed promise * File name * fix prettier * Protecting against null API's and undefined data * Only show fake popup to devs * cleanup mock code * rename minmimal-app to modal-app * Added comment * Added comment * removed old comment * Avoided changing minimum size * Add small comment * Rename component * adress feedback * Fixed uppercase file * Fixed build * Added codeowners * added void * commentary * feat: reset setting on app start * Moved reset to be in main / process launch * Add comment to create window * Added a little bit of styling * Use Messaging service to loadUrl * Enable passkeysautofill * Add logging * halfbaked * Integration working * And now it works without extra delay * Clean up * add note about messaging * lb * removed console.logs * Cleanup and adress review feedback * This hides the swift UI * pick credential, draft * Remove logger * a whole lot of wiring * not working * Improved wiring * Cancel after 90s * Introduced observable * Launching bitwarden if its not running * Passing position from native to electron * Rename inModalMode to modalMode * remove tap * revert spaces * added back isDev * cleaned up a bit * Cleanup swift file * tweaked logging * clean up * Update apps/desktop/macos/autofill-extension/CredentialProviderViewController.swift Co-authored-by: Andreas Coroiu <acoroiu@bitwarden.com> * Update apps/desktop/src/platform/main/autofill/native-autofill.main.ts Co-authored-by: Andreas Coroiu <acoroiu@bitwarden.com> * Update apps/desktop/src/platform/services/desktop-settings.service.ts Co-authored-by: Andreas Coroiu <acoroiu@bitwarden.com> * adress position feedback * Update apps/desktop/macos/autofill-extension/CredentialProviderViewController.swift Co-authored-by: Andreas Coroiu <acoroiu@bitwarden.com> * Removed extra logging * Adjusted error logging * Use .error to log errors * remove dead code * Update desktop-autofill.service.ts * use parseCredentialId instead of guidToRawFormat * Update apps/desktop/src/autofill/services/desktop-autofill.service.ts Co-authored-by: Andreas Coroiu <acoroiu@bitwarden.com> * Change windowXy to a Record instead of [number,number] * Update apps/desktop/src/autofill/services/desktop-fido2-user-interface.service.ts Co-authored-by: Andreas Coroiu <acoroiu@bitwarden.com> * Remove unsued dep and comment * changed timeout to be spec recommended maxium, 10 minutes, for now. * Correctly assume UP * Removed extra cancelRequest in deinint * Add timeout and UV to confirmChoseCipher UV is performed by UI, not the service * Improved docs regarding undefined cipherId * cleanup: UP is no longer undefined * Run completeError if ipc messages conversion failed * don't throw, instead return undefined * Disabled passkey provider * Throw error if no activeUserId was found * removed comment * Fixed lint * removed unsued service * reset entitlement formatting * Update entitlements.mas.plist --------- Co-authored-by: Justin Baur <19896123+justindbaur@users.noreply.github.com> Co-authored-by: Colton Hurst <colton@coltonhurst.com> Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com> Co-authored-by: Andreas Coroiu <acoroiu@bitwarden.com>
59 lines
1.8 KiB
Rust
59 lines
1.8 KiB
Rust
use std::sync::Arc;
|
|
|
|
use serde::{Deserialize, Serialize};
|
|
|
|
use crate::{BitwardenError, Callback, Position, UserVerification};
|
|
|
|
#[derive(uniffi::Record, Debug, Serialize, Deserialize)]
|
|
#[serde(rename_all = "camelCase")]
|
|
pub struct PasskeyAssertionRequest {
|
|
rp_id: String,
|
|
client_data_hash: Vec<u8>,
|
|
user_verification: UserVerification,
|
|
allowed_credentials: Vec<Vec<u8>>,
|
|
window_xy: Position,
|
|
//extension_input: Vec<u8>, TODO: Implement support for extensions
|
|
}
|
|
|
|
#[derive(uniffi::Record, Debug, Serialize, Deserialize)]
|
|
#[serde(rename_all = "camelCase")]
|
|
pub struct PasskeyAssertionWithoutUserInterfaceRequest {
|
|
rp_id: String,
|
|
credential_id: Vec<u8>,
|
|
user_name: String,
|
|
user_handle: Vec<u8>,
|
|
record_identifier: Option<String>,
|
|
client_data_hash: Vec<u8>,
|
|
user_verification: UserVerification,
|
|
window_xy: Position,
|
|
}
|
|
|
|
#[derive(uniffi::Record, Serialize, Deserialize)]
|
|
#[serde(rename_all = "camelCase")]
|
|
pub struct PasskeyAssertionResponse {
|
|
rp_id: String,
|
|
user_handle: Vec<u8>,
|
|
signature: Vec<u8>,
|
|
client_data_hash: Vec<u8>,
|
|
authenticator_data: Vec<u8>,
|
|
credential_id: Vec<u8>,
|
|
}
|
|
|
|
#[uniffi::export(with_foreign)]
|
|
pub trait PreparePasskeyAssertionCallback: Send + Sync {
|
|
fn on_complete(&self, credential: PasskeyAssertionResponse);
|
|
fn on_error(&self, error: BitwardenError);
|
|
}
|
|
|
|
impl Callback for Arc<dyn PreparePasskeyAssertionCallback> {
|
|
fn complete(&self, credential: serde_json::Value) -> Result<(), serde_json::Error> {
|
|
let credential = serde_json::from_value(credential)?;
|
|
PreparePasskeyAssertionCallback::on_complete(self.as_ref(), credential);
|
|
Ok(())
|
|
}
|
|
|
|
fn error(&self, error: BitwardenError) {
|
|
PreparePasskeyAssertionCallback::on_error(self.as_ref(), error);
|
|
}
|
|
}
|