2022-09-09 19:41:16 +02:00
<?xml version="1.0" encoding="utf-8"?>
2019-04-10 23:01:25 +02:00
<root>
<!--
Microsoft ResX Schema
Version 2.0
The primary goals of this format is to allow a simple XML format
that is mostly human readable. The generation and parsing of the
various data types are done through the TypeConverter classes
associated with the data types.
Example:
... ado.net/XML headers & schema ...
<resheader name="resmimetype">text/microsoft-resx</resheader>
<resheader name="version">2.0</resheader>
<resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader>
<resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader>
<data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data>
<data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data>
<data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64">
<value>[base64 mime encoded serialized .NET Framework object]</value>
</data>
<data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
<value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value>
<comment>This is a comment</comment>
</data>
There are any number of "resheader" rows that contain simple
name/value pairs.
Each data row contains a name, and value. The row also contains a
type or mimetype. Type corresponds to a .NET class that support
text/value conversion through the TypeConverter architecture.
Classes that don't support this are serialized and stored with the
mimetype set.
The mimetype is used for serialized objects, and tells the
ResXResourceReader how to depersist the object. This is currently not
extensible. For a given mimetype the value must be set accordingly:
Note - application/x-microsoft.net.object.binary.base64 is the format
that the ResXResourceWriter will generate, however the reader can
read any of the formats listed below.
mimetype: application/x-microsoft.net.object.binary.base64
value : The object must be serialized with
: System.Runtime.Serialization.Formatters.Binary.BinaryFormatter
: and then encoded with base64 encoding.
mimetype: application/x-microsoft.net.object.soap.base64
value : The object must be serialized with
: System.Runtime.Serialization.Formatters.Soap.SoapFormatter
: and then encoded with base64 encoding.
mimetype: application/x-microsoft.net.object.bytearray.base64
value : The object must be serialized into a byte array
: using a System.ComponentModel.TypeConverter
: and then encoded with base64 encoding.
-->
<xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
<xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
<xsd:element name="root" msdata:IsDataSet="true">
<xsd:complexType>
<xsd:choice maxOccurs="unbounded">
<xsd:element name="metadata">
<xsd:complexType>
<xsd:sequence>
<xsd:element name="value" type="xsd:string" minOccurs="0" />
</xsd:sequence>
<xsd:attribute name="name" use="required" type="xsd:string" />
<xsd:attribute name="type" type="xsd:string" />
<xsd:attribute name="mimetype" type="xsd:string" />
<xsd:attribute ref="xml:space" />
</xsd:complexType>
</xsd:element>
<xsd:element name="assembly">
<xsd:complexType>
<xsd:attribute name="alias" type="xsd:string" />
<xsd:attribute name="name" type="xsd:string" />
</xsd:complexType>
</xsd:element>
<xsd:element name="data">
<xsd:complexType>
<xsd:sequence>
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
<xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
</xsd:sequence>
<xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
<xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
<xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
<xsd:attribute ref="xml:space" />
</xsd:complexType>
</xsd:element>
<xsd:element name="resheader">
<xsd:complexType>
<xsd:sequence>
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
</xsd:sequence>
<xsd:attribute name="name" type="xsd:string" use="required" />
</xsd:complexType>
</xsd:element>
</xsd:choice>
</xsd:complexType>
</xsd:element>
</xsd:schema>
<resheader name="resmimetype">
<value>text/microsoft-resx</value>
</resheader>
<resheader name="version">
<value>2.0</value>
</resheader>
<resheader name="reader">
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
</resheader>
<resheader name="writer">
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
</resheader>
<data name="About" xml:space="preserve">
<value>About</value>
</data>
<data name="Add" xml:space="preserve">
<value>Add</value>
<comment>Add/create a new entity (verb).</comment>
</data>
<data name="AddFolder" xml:space="preserve">
<value>Add Folder</value>
</data>
<data name="AddItem" xml:space="preserve">
<value>Add Item</value>
<comment>The title for the add item page.</comment>
</data>
<data name="AnErrorHasOccurred" xml:space="preserve">
<value>An error has occurred.</value>
<comment>Alert title when something goes wrong.</comment>
</data>
<data name="Back" xml:space="preserve">
<value>Back</value>
<comment>Navigate back to the previous screen.</comment>
</data>
<data name="Bitwarden" xml:space="preserve">
<value>Bitwarden</value>
<comment>App name. Shouldn't ever change.</comment>
</data>
<data name="Cancel" xml:space="preserve">
<value>Cancel</value>
<comment>Cancel an operation.</comment>
</data>
<data name="Copy" xml:space="preserve">
<value>Copy</value>
<comment>Copy some value to your clipboard.</comment>
</data>
<data name="CopyPassword" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Copy password</value>
2019-04-10 23:01:25 +02:00
<comment>The button text that allows a user to copy the login's password to their clipboard.</comment>
</data>
<data name="CopyUsername" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Copy username</value>
2019-04-10 23:01:25 +02:00
<comment>The button text that allows a user to copy the login's username to their clipboard.</comment>
</data>
<data name="Credits" xml:space="preserve">
<value>Credits</value>
<comment>Title for page that we use to give credit to resources that we use.</comment>
</data>
<data name="Delete" xml:space="preserve">
<value>Delete</value>
<comment>Delete an entity (verb).</comment>
</data>
<data name="Deleting" xml:space="preserve">
<value>Deleting...</value>
<comment>Message shown when interacting with the server</comment>
</data>
<data name="DoYouReallyWantToDelete" xml:space="preserve">
<value>Do you really want to delete? This cannot be undone.</value>
<comment>Confirmation alert message when deleteing something.</comment>
</data>
<data name="Edit" xml:space="preserve">
<value>Edit</value>
</data>
<data name="EditFolder" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Edit folder</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Email" xml:space="preserve">
<value>Email</value>
<comment>Short label for an email address.</comment>
</data>
<data name="EmailAddress" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Email address</value>
2019-04-10 23:01:25 +02:00
<comment>Full label for a email address.</comment>
</data>
<data name="EmailUs" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Email us</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="EmailUsDescription" xml:space="preserve">
<value>Email us directly to get help or leave feedback.</value>
</data>
<data name="EnterPIN" xml:space="preserve">
<value>Enter your PIN code.</value>
</data>
<data name="Favorites" xml:space="preserve">
<value>Favorites</value>
<comment>Title for your favorite items in the vault.</comment>
</data>
<data name="FileBugReport" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>File a bug report</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="FileBugReportDescription" xml:space="preserve">
<value>Open an issue at our GitHub repository.</value>
</data>
<data name="FingerprintDirection" xml:space="preserve">
<value>Use your fingerprint to verify.</value>
</data>
<data name="Folder" xml:space="preserve">
<value>Folder</value>
<comment>Label for a folder.</comment>
</data>
<data name="FolderCreated" xml:space="preserve">
<value>New folder created.</value>
</data>
<data name="FolderDeleted" xml:space="preserve">
<value>Folder deleted.</value>
</data>
<data name="FolderNone" xml:space="preserve">
<value>No Folder</value>
<comment>Items that have no folder specified go in this special "catch-all" folder.</comment>
</data>
<data name="Folders" xml:space="preserve">
<value>Folders</value>
</data>
<data name="FolderUpdated" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Folder saved</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="GoToWebsite" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Go to website</value>
2019-04-10 23:01:25 +02:00
<comment>The button text that allows user to launch the website to their web browser.</comment>
</data>
<data name="HelpAndFeedback" xml:space="preserve">
2022-07-11 08:45:42 +02:00
<value>Help and feedback</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Hide" xml:space="preserve">
<value>Hide</value>
<comment>Hide a secret value that is currently shown (password).</comment>
</data>
<data name="InternetConnectionRequiredMessage" xml:space="preserve">
<value>Please connect to the internet before continuing.</value>
<comment>Description message for the alert when internet connection is required to continue.</comment>
</data>
<data name="InternetConnectionRequiredTitle" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Internet connection required</value>
2019-04-10 23:01:25 +02:00
<comment>Title for the alert when internet connection is required to continue.</comment>
</data>
<data name="InvalidMasterPassword" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Invalid master password. Try again.</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="InvalidPIN" xml:space="preserve">
<value>Invalid PIN. Try again.</value>
</data>
<data name="Launch" xml:space="preserve">
<value>Launch</value>
<comment>The button text that allows user to launch the website to their web browser.</comment>
</data>
<data name="LogIn" xml:space="preserve">
<value>Log In</value>
<comment>The login button text (verb).</comment>
</data>
<data name="LogInNoun" xml:space="preserve">
<value>Login</value>
<comment>Title for login page. (noun)</comment>
</data>
<data name="LogOut" xml:space="preserve">
2022-07-11 08:45:42 +02:00
<value>Log out</value>
2019-04-10 23:01:25 +02:00
<comment>The log out button text (verb).</comment>
</data>
<data name="LogoutConfirmation" xml:space="preserve">
<value>Are you sure you want to log out?</value>
</data>
2022-02-23 18:40:17 +01:00
<data name="RemoveAccount" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Remove account</value>
2022-02-23 18:40:17 +01:00
</data>
<data name="RemoveAccountConfirmation" xml:space="preserve">
<value>Are you sure you want to remove this account?</value>
</data>
<data name="AccountAlreadyAdded" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Account already added</value>
2022-02-23 18:40:17 +01:00
</data>
<data name="SwitchToAlreadyAddedAccountConfirmation" xml:space="preserve">
<value>Would you like to switch to it now?</value>
</data>
2019-04-10 23:01:25 +02:00
<data name="MasterPassword" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Master password</value>
2019-04-10 23:01:25 +02:00
<comment>Label for a master password.</comment>
</data>
<data name="More" xml:space="preserve">
<value>More</value>
<comment>Text to define that there are more options things to see.</comment>
</data>
<data name="MyVault" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>My vault</value>
2019-04-10 23:01:25 +02:00
<comment>The title for the vault page.</comment>
</data>
2022-08-17 23:10:16 +02:00
<data name="Authenticator" xml:space="preserve">
<value>Authenticator</value>
<comment>Authenticator TOTP feature</comment>
</data>
2019-04-10 23:01:25 +02:00
<data name="Name" xml:space="preserve">
<value>Name</value>
<comment>Label for an entity name.</comment>
</data>
<data name="No" xml:space="preserve">
<value>No</value>
</data>
<data name="Notes" xml:space="preserve">
<value>Notes</value>
<comment>Label for notes.</comment>
</data>
<data name="Ok" xml:space="preserve">
<value>Ok</value>
<comment>Acknowledgement.</comment>
</data>
<data name="Password" xml:space="preserve">
<value>Password</value>
<comment>Label for a password.</comment>
</data>
<data name="Save" xml:space="preserve">
<value>Save</value>
<comment>Button text for a save operation (verb).</comment>
</data>
2021-08-04 21:46:28 +02:00
<data name="Move" xml:space="preserve">
<value>Move</value>
</data>
2019-04-10 23:01:25 +02:00
<data name="Saving" xml:space="preserve">
<value>Saving...</value>
<comment>Message shown when interacting with the server</comment>
</data>
<data name="Settings" xml:space="preserve">
<value>Settings</value>
<comment>The title for the settings page.</comment>
</data>
<data name="Show" xml:space="preserve">
<value>Show</value>
<comment>Reveal a hidden value (password).</comment>
</data>
<data name="ItemDeleted" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Item deleted</value>
2019-04-10 23:01:25 +02:00
<comment>Confirmation message after successfully deleting a login.</comment>
</data>
<data name="Submit" xml:space="preserve">
<value>Submit</value>
</data>
<data name="Sync" xml:space="preserve">
<value>Sync</value>
<comment>The title for the sync page.</comment>
</data>
<data name="ThankYou" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Thank you</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Tools" xml:space="preserve">
<value>Tools</value>
<comment>The title for the tools page.</comment>
</data>
<data name="URI" xml:space="preserve">
<value>URI</value>
<comment>Label for a uri/url.</comment>
</data>
<data name="UseFingerprintToUnlock" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Use fingerprint to unlock</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Username" xml:space="preserve">
<value>Username</value>
<comment>Label for a username.</comment>
</data>
<data name="ValidationFieldRequired" xml:space="preserve">
<value>The {0} field is required.</value>
<comment>Validation message for when a form field is left blank and is required to be entered.</comment>
</data>
<data name="ValueHasBeenCopied" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>{0} copied</value>
2022-12-19 18:03:22 +01:00
<comment>Confirmation message after successfully copying a value to the clipboard.</comment>
2019-04-10 23:01:25 +02:00
</data>
<data name="VerifyFingerprint" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Verify fingerprint</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="VerifyMasterPassword" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Verify master password</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="VerifyPIN" xml:space="preserve">
<value>Verify PIN</value>
</data>
<data name="Version" xml:space="preserve">
<value>Version</value>
</data>
<data name="View" xml:space="preserve">
<value>View</value>
</data>
<data name="VisitOurWebsite" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Visit our website</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Website" xml:space="preserve">
<value>Website</value>
<comment>Label for a website.</comment>
</data>
<data name="Yes" xml:space="preserve">
<value>Yes</value>
</data>
<data name="Account" xml:space="preserve">
<value>Account</value>
</data>
<data name="AccountCreated" xml:space="preserve">
<value>Your new account has been created! You may now log in.</value>
</data>
<data name="AddAnItem" xml:space="preserve">
<value>Add an Item</value>
</data>
<data name="AppExtension" xml:space="preserve">
2022-07-11 08:45:42 +02:00
<value>App extension</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="AutofillAccessibilityDescription" xml:space="preserve">
<value>Use the Bitwarden accessibility service to auto-fill your logins across apps and the web.</value>
</data>
<data name="AutofillService" xml:space="preserve">
2022-07-22 10:16:50 +02:00
<value>Auto-fill service</value>
2019-04-10 23:01:25 +02:00
</data>
[PM-5894] Implement Passkey Providers (#3173)
* PM-3349 PM-3350 Added the partial MAUI Community Toolkit implementation for TouchEffect. This is a temporary solution until they finalize this and add it to their nuget package.
This allows implementing the LongPressCommand in AccountSwitchingOverlay and also have the "Ripple effect" animation when touching an item in Android
* PM-3349 PM-3350 Changed SendViewCell and its binding to be directly against the ViewModel
* PM-3350 Fixed iOS Share extension lazy views loading and an issue with the avatar loading. Also discovered issue with TapGestureRecognizer not working on MAUI Embedding
* PM-3350 Fixed iOS Extensions navigation to several pages and improved avoiding duplicate calls to OnNavigatedTo
* PM-3350 Updated PCL Crypto to latest alpha version to fix "Dll not found NCrypt" issue
* PM-3350 Removed workaround for iOS issue with Avatar icon as it's now fixed in latest .Net8 release.
* PM-3349 PM-3350 Removed AsyncCommand "wrapper" and added AsyncRelayCommand directly in all ViewModels that were using the other one.
* PM-3350 Added watchOS app to main project and fixed some csproj conditions for runtime identifiers on iOS.
* PM-3350 Fixed/Updated all MAUI-Migration TODOs
* PM-3350 Fixed account toolbar item and TitleView on SendAddOnlyPage, also removed comments on AvatarImageSource given the workaround is not needed anymore to draw the image successfully.
* PM-3350 Updated AppCenter package to latest version 5.0.3 and updated some things into MAUI style
* PM-3350 Added workaround for iOS Avatar icon again.
* PM-3349 Added workaround for Android to avoid issues with setting MainPage when app is in background. They are now kept on a Queue to be executed after the app has resumed.
Updated some things on App.xaml.cs to the new MAUI style
* PM-3349 PM-3350 Fixed issue where creating an account with weak/exposed password would get stuck after the Captcha (if a captcha is shown)
Changed App.xaml.cs NavigateImpl to be private
* PM-3349 Started to configure build.yml for MAUI Android
* PM-3349 build.yml update paths for MAUI Android
* PM-3349 build.yml commented verify format and just set qa as variant on MAUI Android for faster checks on CI
* PM-3349 PM-3350 build.cake updated paths
* PM-3349 build.yml updated env helpers variables and set specific csproj to build on Android so not to build iOS extensions
* PM-3349 build.yml add Android "prod" variant
* PM-3350 build.yml updated iOS build and ignore Android build to try the CI faster
* PM-3350 build.yml changed nuget restore for dotnet restore on iOS build to fix issue on restoring due to msbuild
* PM-3350 build.yml Upgraded iOS build to run on macos-13 image which has XCode 15, and set the XCode 15 version as currently the default one is 14.x
* PM-3350 build.yml try to fix ILLINK warnings and changed image to be macos-13-arm64 to see if the build is faster
* PM-3350 build.yml changed image back to be macos-13 to see if the build is faster
* PM-3350 Added Document.Build.props to disable trimming on publish
* PM-3350 build.yml disable trimming on publish so it's faster
* PM-3350 added linkskip for iOS csprojs
* PM-3350 iOS projs disable linking and set Newstandkit as weak framework
* Update build.yml disabling iOS job to avoid long running process of publish until we can fix that
* PM-3349 PM-3350 Workaround to fix issues with text getting cropped/truncated when a Label has both Multiline and LinebreakMode set
* PM-3349 build.yml enabled android build workflow
* PM-3349 build.yml configured FDROID job for MAUI
* PM-3350 iOS extensions TapGestureRecognizer try Window workaround
* PM-3350 iOS applied workaround on the iOS Autofill and Share extension to maui embed the navigation page with its content page in the Window
* PM-3349 PM-3350 Added workaround for More Options to work on Search and Groupings Page
Updated some code to MAUI Style also
* PM-3349 PM-3350 Added the ability for users to press "Continue" button as a fallback when using the Yubikey if the "SubmitCommand" doesn't trigger automatically.
* PM-3349 PM-3350 Fix for text getting cut/truncated in both account switcher and ciphers/search lists
Issue is due to MAUI but can be avoided by using slightly different layout
* PM-3350 iOS updated CFBundlerShortVersionString to latest one 2023.10.1
* PM-3350 fix build.yml Bitwarden.ipa AppStore exported file
* PM-3350 build.yml added step to validate app for submitting into App Store and have better logs of it
* PM-3350 build.yml Added several fixes like not using MtouchUseLLVM on the iOS builds to fix they taking forever to build and some changes on the automation CI to do a debug build for the moment
* PM-3350 Improved MTouch linking and extra args on iOS related csprojs
* PM-3349 PM-3350 Added MAUI label on self-host settings and on about settings to differentiate from XF app
* PM-3349 PM-3350 build.yml uncommented jobs so we have a more complete workflow
* PM-3349 PM-3350 Minor change: removed unneeded HorizontalTextAlignment from Label.
* PM-3349 Replaced CrossCurrentActivity plugin with MAUI internal CurrentActivity
* PM-3350 Fix iOS extensions navigation and Window/RootViewController handling for TapGestureRecognizer to work
* PM-3350 Cleared left ClipLogger from the iOS extensions debug logging.
* PM-3349 PM-3350 Refactored cipher bindings to have a simpler approach reusing a new CipherItemViewModel to avoid unwanted issues in the app
* PM-3349 Added base structure for avoiding Android Autofill crash. This workaround works but it's not complete as it can't handle the entire workflow when showing CipherSelectionPAge (like checking if it should show LockPage)
* PM-3350 Bumped iOS version
* PM-3350 Changed linker to use default mode given that "Full" is presenting some problems as the linker is stripping things it shouldn't and we're trying to solve it. So for now we will use the mode "Link SDK assemblies only" so QA can test.
* PM-3349 Fix for app crashing on Android when Dark mode is enabled
Removed unused button style for android
* Proof of concept for having multiple window in Android for autofill support and navigating with the help of an Extended splash page.
* PM-3350 Fix crash on Release by adding Interpreter on iOS and also adding System.Security.Cryptography to be ignored by the linker
* PM-3350 Apply Cryptography TrimmerRootAssembly only to iOS
* PM-3350 Updated Plugin.Fingerprint so biometrics work
* Update .github/workflows/build.yml setup-xcode commit hash
Co-authored-by: Vince Grassia <593223+vgrassia@users.noreply.github.com>
* PM-3349 PM-3350 Enabled argon2id and fixed one issue with the Uris when getting the icon image
* PM-3349 Upgraded Android targetSdkVersion to 34
* minor change (public to private fields)
* minor improvemments on autofill-redirect
* PM-3349 Commented the Deploy step for Android job given that we're using the hotfix-rc branch for testing iOS on TestFlight
* PM-3349 Uncommented the Deploy step for Android job
* PM-3349 Ensure "_isResumed=true" is set on App.xaml.cs:Bootstrap
* Reusing App.xaml.cs Navigation for the Android RedirectPage
Some other cleanup and changes
* Improved autofill workaround to better handle switching between windows.
* PM-3349 minor fix to add space in HomePage between the region picker labels.
* Added some comments and improvemments.
* PM-3349 Added Window events unsubscription of events. Also changed code to avoid potentially having multiple autofillwindow
* PM-3349 Minor ui fix (space between buttons in delete account page)
* initial commit of android credential provider service (wip)
* Revert "initial commit of android credential provider service (wip)"
This reverts commit 6011b639586d081687d22d77352a024272ca6841.
* PM-3350 Fix for Delete Account buttons on iOS
* PM-3349 PM-3350 Changed search icon used in app to avoid issue with icon size on iOS
* PM-3349 Added custom window so that we can always get the current Active Window. This is used to support the Android Autofil and multi-window scenarios.
* PM-3349 Fix for icon and text spacing in some list items
* PM-3349 Minor aligment improvemment for region selection in HomePage
* PM-3349 Changed the "track color" for the Android switch so that the color is different from the "thumb"
* PM-3350 Updated version to 2024.1.0 on iOS
* PM-5154 Start implementing Passkeys Autofill in iOS
* PM-5154 Continue Passkeys Autofill in iOS
* initial commit of android credential provider service (wip)
* add cred manager project to build config
* PM-5154 Added Fido2AuthenticationService to provide us a wrapper for the actual implementation
* PM-3349 Fix Picker selection style by doing a custom PickerHandler for Android which uses SetSingleChoiceItems(...) to provide with the appropriate UI
* PM-3350 Updated MauiVersion to 8.0.4-nightly.* to have the TapGestureRecognizer fix applied. This is done on the Directory.Build.props so we don't have to change it on every csproj. Also removed the workaround of TapGestureHack and fix the Show environment picker to work on the extensions as well.
* PM-3350 Added nuget.config so we add the nuget package source for MAUI Nightly builds
* Bump main iOS version
* PM-3350 Removed "iOS" old folder project that has been moved into the MAUI Single app project.
* PM-3350 Improved code safety adding a lot of try...catch and logging throughout the app. Also made the invoking on main thread safer on several places of the app. Additionally, on the GroupingsPageViewModel changed the code removing the old Xamarin hack and just using Replace directly instead of Clearing first to see if that fixes the crash we're having sometimes on the app.
* PM-3350 PM-3349 Updated Unit Test projects to NET 8.0 and fixed it to work with Core project reference. Also fixed a test that was breaking due to CIpherKey creation being wrong. Added "UT" as a constant to add when building/running Core.Test project so we have something on the context that tells us that is for a UT. With this I had to remove FFImageLoading on UT context because it doesn't support NET 8.0
* PM-3350 PM-3349 Updated Readme with MAUI and main branch
* PM-3350 PM-3349 Enable running Core tests
* PM-3350 Fix build.yml format
* PM-3349 Fix navigation when coming from autofill with Accessibility Services enabled. The user was getting into Home page instead of where they were, with this workaround the app navigates as if the account has been switched, leaving the user as closely as possible to where they were, basically on the first screen for the current state of the user.
* PM-3350 PM-3349 Added property to Directory.Build.props to enable Unit Testing globally so Test runners work
* Improve TOTP scan performance on Android
* Move Android camera/scan changes to xaml
* PM-3350 Testing UseInterpreter false on CI build
* PM-3350 Enabled back UseInterpreter on iOS Release given that it crashes on startup without it.
* PM-3349 PM-3350 Improved code safety with try...catch, better invoke on main thread and better null handling.
* PM-3349 PM-3350 Updated XCode version on build.yml to 15.1
* PM-3350 Removed TapGesture Window MAUI hack from iOS.Extension and iOS.ShareExtension
* PM-3350 Fixed CancellationTokenSource proper disposal
* PM-3350 Fix Avatar toolbar icon on extensions to load properly and to take advantage of using directly SkiaSharp to do the native conversion to UIImage. Also improved the toolbar item so that size is set appropriately.
* PM-3349 PM-3350 Fix external link icon
* PM-3350 Added new style to prevent spell check and text prediction
* Fix merge from main
* PM-3350 Commented event collection upload on the timer and when sending the app to background to see if that prevents the app from crashing on release mode.
* PM-3350 Added check for state migration version before trying to migrate LiteDB values into Prefs when there's no need to and that may be inducing crashes on backgrounded iOS apps.
* PM-3350 Try to disable Interpreter to have better crash knowledge. This time testing if avoiding loading the argon2id lib we're able to not use the interpreter.
* PM-5928 Fix circle animation to be shown on verification codes list on each item
* PM-3350 Go back to use Interpreter and added some Directory.Build.props to easily change Codesign properties and also include/exclude iOS extensions / WatchOS from the build.
* PM-3350 Enabled iOS extensions and WatchOS app to be included based on the Directory.Build.props
* PM-3350 Go back to include argon2id and interpreter
* Removing error/loading placeholders of icons on the cells to see if that is causing the background crash on iOS; so we can test this in TestFlight
* [PM-5910] Workaround for for sliding elements in Duo 2FA flow (#2967)
* workaround for sliding elements in duo 2fa flow
* restrict workaround to Android
* restrict workaround to Android
* Revert "restrict workaround to Android"
This reverts commit c2753d5dc4960aeacdb4c798e7273ca86c08881d.
* Revert "restrict workaround to Android"
This reverts commit 69688cfb98e8e3e17812f126b4fd90ffd2ac3cf8.
* PM-5902 fix for account switcher not dismissing when tapping outside (#2974)
* PM-3350 Fix iossimulator-x64 argon2id load so we can test on simulators and also made easier to maintain loading the argon2id library on the iOS projects by setting a general Directory.Build.props that is shared.
* PM-5903 Changed App.xaml.cs SetOption to only update the needed properties instead of replacing the existing Options object which would cause the AccountSwitcher button bug (#2973)
* [PM-5896] Fix MAUI iOS Background crash due to lock files on suspension (#2969)
* PM-5896 Fix background crash on iOS due to lock files when app gets suspended. Changed loading and error placeholders of the CachedImage to not be used and use default icon of IconLabel instead changing visibility.
* PM-5896 Changed methods to be protected so that they don't get removed by the linker.
* PM-5896 Added stub class and references to it so to have stronger references to Icon_Success and Icon_Error so the linker doesn't remove them.
* PM-3349 Removed commented code from build.yml regarding FDroid that is not needed anymore.
* PM-3349 PM-3350 Fix crash on iOS AppGroup container URL because of sln config on AndroidX Credentials. Changed the project reference of Credentials to be a local NuGet.
* PM-6077 Separated Android and iOS HybridWebViewHandler so that it can be used on iOS.Core (#2983)
* [PM-5907] Fix for incorrect TOTP white text color on label when using light theme on iOS (#2982)
* PM-5907 workaround for incorrect textcolor when programmatically changing text on Entry
* Update src/Core/Pages/Vault/CipherAddEditPage.xaml.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-5906] Fix for incorrect Send MaxAccess white text color on label when using light theme on iOS (#2981)
* PM-5906 workaround for incorrect textcolor when programmatically changing text on Entry
* Update src/Core/Pages/Send/SendAddEditPage.xaml.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* PM-3349 PM-3350 Fixed Unit tests because of referencing FFImageLoading when it's not possible
* PM-3349 Added exception on gitignore so the nupkg for the AndroidX Credentials is added
* [PM-5731] Create C# WebAuthn authenticator to support maui apps (#2951)
* [PM-5731] feat: implement get assertion params object
* [PM-5731] feat: add first test
* [PM-5731] feat: add rp mismatch test
* [PM-5731] feat: ask for credentials when found
* [PM-5731] feat: find discoverable credentials
* [PM-5731] feat: add tests for successful UV requests
* [PM-5731] feat: add user does not consent test
* [PM-5731] feat: check for UV when reprompt is active
* [PM-5731] fix: tests a bit, needed some additional "arrange" steps
* [PM-5731] feat: add support for counter
* [PM-5731] feat: implement assertion without signature
* [PM-5732] feat: finish authenticator assertion implementation
note: CryptoFunctionService still needs Sign implemenation
* [PM-5731] chore: minor clean up
* [PM-5731] feat: scaffold make credential
* [PM-5731] feat: start implementing attestation
* [PM-5731] feat: implement credential exclusion
* [PM-5731] feat: add new credential confirmaiton
* [PM-5731] feat: implement credential creation
* [PM-5731] feat: add user verification checks
* [PM-5731] feat: add unknown error handling
* [PM-5731] chore: clean up unusued params
* [PM-5731] feat: partial attestation implementation
* [PM-5731] feat: implement key generation
* [PM-5731] feat: return public key in DER format
* [PM-5731] feat: implement signing
* [PM-5731] feat: remove logging
* [PM-5731] chore: use primary constructor
* [PM-5731] chore: add Async to method names
* [PM-5731] feat: add support for silent discoverability
* [PM-5731] feat: add support for specifying user presence requirement
* [PM-5731] feat: ensure unlocked vault
* [PM-5731] chore: clean up and refactor assertion tests
* [PM-5731] chore: clean up and refactor attestation tests
* [PM-5731] chore: add user presence todo comment
* [PM-5731] feat: scaffold fido2 client
* PM-5731 Fix build updating discoverable flag
* [PM-5731] fix: failing test
* [PM-5731] feat: add sameOriginWithAncestor and user id length checks
* [PM-5731] feat: add incomplete rpId verification
* [PM-5731] chore: document uri helpers
* [PM-5731] feat: implement fido2 client createCredential
* [PM-5731] feat: implement credential assertion in client
* fix wrong signature format
(cherry picked from commit a1c9ebf01fdcf7c64a0ca2533586b2647cc5cf3e)
* [PM-5731] fix: issues after cherry-pick
* Fix incompatible GUID conversions
(cherry picked from commit c801b2fc3aa4400032bb1bda74c034132cc677f1)
* [PM-5731] chore: remove default constructor
* [PM-5731] feat: refactor user interface to increase flexibility
* [PM-5731] feat: implement generic assertion user interface class
* [PM-5731] feat: remove ability to make user presence optional
* [PM-5731] chore: remove logging comments
* [PM-5731] feat: add native reprompt support to the authenticator
* [PM-5731] feat: allow pre and post UV
* [PM-5731] chore: add `Async` to method name. Remove `I` from struct
* [PM-5731] fix: discoverable string repr lowercase
* [PM-5731] chore: don't use C# 12 features
* [PM-5731] fix: replace magic strings and numbers with contants and enums
* [PM-5731] fix: use UTC creation date
* [PM-5731] fix: formatting
* [PM-5731] chore: use properties for public fields
* [PM-5731] chore: remove TODO
* [PM-5731] fix: IsValidRpId
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
* [PM-5154] Implement Passkeys on iOS (#3017)
* [PM-5731] feat: implement get assertion params object
* [PM-5731] feat: add first test
* [PM-5731] feat: add rp mismatch test
* [PM-5731] feat: ask for credentials when found
* [PM-5731] feat: find discoverable credentials
* [PM-5731] feat: add tests for successful UV requests
* [PM-5731] feat: add user does not consent test
* [PM-5731] feat: check for UV when reprompt is active
* [PM-5731] fix: tests a bit, needed some additional "arrange" steps
* [PM-5731] feat: add support for counter
* [PM-5731] feat: implement assertion without signature
* [PM-5732] feat: finish authenticator assertion implementation
note: CryptoFunctionService still needs Sign implemenation
* [PM-5731] chore: minor clean up
* [PM-5731] feat: scaffold make credential
* [PM-5731] feat: start implementing attestation
* [PM-5731] feat: implement credential exclusion
* [PM-5731] feat: add new credential confirmaiton
* [PM-5731] feat: implement credential creation
* [PM-5731] feat: add user verification checks
* [PM-5731] feat: add unknown error handling
* [PM-5731] chore: clean up unusued params
* [PM-5731] feat: partial attestation implementation
* [PM-5731] feat: implement key generation
* [PM-5731] feat: return public key in DER format
* [PM-5731] feat: implement signing
* [PM-5731] feat: remove logging
* [PM-5731] chore: use primary constructor
* [PM-5731] chore: add Async to method names
* [PM-5731] feat: add support for silent discoverability
* [PM-5731] feat: add support for specifying user presence requirement
* [PM-5731] feat: ensure unlocked vault
* [PM-5731] chore: clean up and refactor assertion tests
* [PM-5731] chore: clean up and refactor attestation tests
* [PM-5731] chore: add user presence todo comment
* [PM-5731] feat: scaffold fido2 client
* PM-5731 Fix build updating discoverable flag
* [PM-5731] fix: failing test
* [PM-5731] feat: add sameOriginWithAncestor and user id length checks
* [PM-5731] feat: add incomplete rpId verification
* [PM-5731] chore: document uri helpers
* [PM-5731] feat: implement fido2 client createCredential
* Added iOS passkeys integration, warning this branch has lots of logs to ease "debugging" extensions.
* [PM-5731] feat: implement credential assertion in client
* PM-5154 Fixed select passkey flow and started implementing create passkey on iOS
* fix wrong signature format
* PM-5154 [Passkeys iOS] Fix Credential ID handling on bytes and string formats. Fix Discoverable to be lowercase on set so it doesn't break parsing on clients. Added UserDisplayName on Fido2 entities. Extracted the Guid Standard/Raw format helpers to a extensions class.
* Fix incompatible GUID conversions
* PM-5154 [Passkeys iOS] Added custom UI flow for passkey creation
* PM-5154 [Passkeys iOS] Updated UI for passkey creation
* PM-5154 [Passkeys iOS] Refactored and added cipher selection for passkey creation on autofill search.
* PM-5154 [Passkeys iOS] Fixed empty top space on autofill password list
---------
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
* feat: optimize assertion network calls (#3021)
The server only needs to be updated if we have changed the counter. New passkeys that leave their counters at zero can therefore skip this step.
* [PM-5154] Implement iOS Passkey -> Add login item (#3019)
* PM-5154 Implement iOS passkey add login
* PM-5154 Added Username to Create new login for passkey, for this the param was changed to the Fido2ConfirmNewCredentialParams object so we have access to the proper values. Also added back RpId to the params to have access to it when creating the vault item. Finally added loading to saving the passkey as new login
* [PM-6513] Omit creating CredentialIdentity if it throws an exception (#3040)
* PM-6513 Omit creating CredentialIdentity if that throws, so it doesn't affect other ciphers. E.g. if a Passkey doesn't have a UserName it will throw here and it shouldn't break replacing all the other identities.
* PM-6513 Added fallback values to passkey username not being set
* Fix FIDO2 client bugs (#3056)
* fix: blockedUris null issue
* fix: trailing slash in origin breaking check
* [PM-6466] Implement passkeys User Verification (#3044)
* PM-6441 Implement passkeys User Verification
* PM-6441 Reorganized UserVerificationMediatorService so everything is not in the same file
* PM-6441 Fix Unit tests
* PM-6441 Refactor UserVerification on Fido2Authenticator and Client services to be of an enum type so we can see which specific preference the RP sent and to be passed into the user verification mediator service to perform the correct flow depending on that. Also updated Unit tests.
* PM-6441 Changed user verification logic a bit so if preference is Preferred and the app has the ability to verify the user then enforce required UV and fix issue on on Discouraged to take into account MP reprompt
* [PM-6474] Remove header on Save passkey as new login (#3054)
* PM-6474 Removed header on empty list view on iOS Autofill create passkey flow
* PM-6474 Fix TableView being hidden on Logins scene
* [PM-6496] Improved iOS extensions cipher cell UI (#3058)
* PM-6496 Improved iOS extensions cipher list to have an updated UI for each cell
* PM-6496 Improved UI on iOS extensions list cells
* [PM-5154] Implement combined view for passwords and passkeys on iOS Autofill extension (#3075)
* PM-5154 Implemented combined view of passwords and passkeys and improved search and items UI
* PM-5154 Code improvement from PR feedback
* PM-5154 Code improvement to log unknown exceptions
* PM-6685 Fix race condition issue where the biometrics check is being done before the iOS extension is being shown. So when we need the UI, we wait until ViewDidAppear happens. (#3078)
* PM-6468 Implemented copy TOTP if needed after using a Fido2 credential. Also added the Fido2MediatorService to have one point to interact with the authentication and also to add any new logic we need. (#3082)
* PM-6706 Add maximum attempts to UV with MP and with PIN (#3079)
* [PM-6848] Improved User verification on passkeys creation (#3099)
* PM-6848 Updated cancellation flow on passkey user verification and improved UV enforcement on creation
* PM-6848 Added null checks to help diagnosing if NRE is presented
* PM-6706 Fixed UV attempts to be maximum 5 attempts and not 6 (#3103)
* PM-6793 Updated autofill settings copy (#3102)
* [PM-6655] Add username empty fallback on passkey (#3101)
* PM-6655 Added fallback "Unknown account" to passkey username and moved it so it can be shared with Android
* PM-6655 Improved code lines formatting
* PM-6844 Fix passkey creation cipher list empty label on small devices (#3104)
* [PM-6798] Fix account switch on autofill (#3106)
* PM-6798 Force state update when opening the Autofill extension
* PM-6798 Fix InitAppIfNeededAsync to be awaited and also ignored Fido2AuthenticatorException from logging them to AppCenter since they don't add much information and we're logging in other places what we need
* PM-6475 Fix dark theme on iOS Autofill extension (#3114)
* PM-6850 Removed duplicate MP Reprompt on passkey creation item selection (#3118)
* PM-6538 Removed non-discoverable passkeys filter for credentials that go to the ASStore (#3117)
* [PM-6655] Add null fallback cipher name on passkeys (#3116)
* PM-6655 Fixed fallback value on passkeys to take into account CipherView.Name. Also removed non-discoverable passkey filter on adding credentials to the ASStore and also added the fallback consideration on the passkeys list iOS extension
* PM-6655 Restored non-discoverable filter on credentials set for ASStore on this PR
* PM-6798 Fix account switch on iOS Autofill extension and also changed to Try... actions for TaskCompletionSource to avoid exceptions on some occasions. (#3121)
Co-authored-by: Álison Fernandes <vvolkgang@users.noreply.github.com>
* PM-6209 Removed MAUI label from environment and about pages (#2990)
* [PM-7186] Fallback to password list on exception (#3127)
* PM-7186 Added fallback in case of exception that loads password list
* PM-7186 Added back the error message removed in last commit.
* feat: add support for `credProps.rk` extension (#3132)
* PM-7186 Remove error message when showing password list as a fallback with user interaction (#3133)
* [PM-5153] Android Passkey Implementation (#3020)
* Initial WIP implementation for the app unlock flow when called from Passkey. Still needs code organization and to be finished.
Also added a new Window workaround in App.xaml.cs to allow CredentialProviderSelectionActivity to launch separately.
* Added missing IDeviceActionService.cs implementation for iOS to build.
* Added Async to ReturnToPasskeyAfterUnlockMethod
Changed i18n to AppResource.Unlock
Removed unecessary cast
* minor code change (added comment)
* Added back the case for loading a specific Window for CredentialProviverSelectionActivity
* Added fix for Intent not passing properly to CredentialProviderSelectionActivity
Added Activity cancellation on error during execution of ReturnToPasskeyAfterUnlockAsync()
* Added WIP code for Android passkey implementation. Currently returns a mostly complete response that is missing the ClientDataJson
* Added WIP code for creating passkeys on Android. Still missing unlock flow and response of passkey creation is still not correct.
Removed unused throw NotImplementedException from Fido2ClientService
Added CredentialCreationActivity for passkey creation
Added alternative code on CredentialProviderSelectionActivity to try to debug issue with response not being valid
* Started working on logic to adding unlock flow. It's already handling the unlock but not passing the PendingIntentHandler info for CredentialCreation to CredentialCreationActivity
* Changed "cross-platform" to "platform"
* Created CredentialHelpers.cs class to share code used for Populating Passkeys in Android.
* Added Passkey Credential Creation shared code to CredentialHelpers.
Unlock flow for Passkey creation should now be working also.
* Updated code for checking if the CredentialProviderService has been enabled by the user or not. Still WIP, somes notes in code due to Credential API not being complete.
Also changed the disable code to open the Credential Settings.
* Replaced the AndroidX.Credential helpers with custom JSON creation to fix the response for Credential Creation
* minor code cleanup on CredentialProviderSelectionActivity
* added todo comment
* Feature/maui migraton passkeys android unlock fix andreas (#3077)
* fix: bitwarden providing too many/wrong credentials
* feat: use authenticator instead of client
---------
Co-authored-by: Dinis Vieira <dinisvieira@outlook.com>
* Removed / commented some older Passkey Proof of concept code.
Auth and creation of passkey should still work both when device is unlocked (and not)
Added some initial code in AutofillCiphersPageViewModel and CipherAddEditPageViewModel for handling Passkey creation
* PM-6829 Implemented Fido2...UserInterfaces on Android and necessary logic to get/make a credential with those
* Added IFido2MediatorService registrations
Inverted two IsLockedAsync checks
* Added navigation to autofillCipher when creating passkey
* Updated LockPage to avoid multiple executions of SubmitAsync
* Added new flow for creating new passkey on Android with the Cipher page for editing details
* Changed the Credential Provider Switch to an external link control
* Added i18n for Passkey Settings
* Cleanup of older Credentials code used for Android Fido2 POC.
Removed CredentialCreationActivity as it's no longer needed
* fixed merge conflict/error and added error check to Fido2 navigation in App.xaml.cs
* Removed from MainActivity casts from DeviceActionService
Changed CredentialProviderServiceActivity to handle Fido errors and exceptions gracefully and show the user an error. Still not with the correct messages.
* Added some error messages. Still need to confirm the Text Resource to use and change.
* Changed some messages to use AppResources
* Cleanup of Credential Android code and added exception result if the clientCreateCredentialResult is null
* Updated Add new item button text when creating a new passkey
* Added AccountSwitchedException for the Fido Mediator Service
* Removed TODO that is no longer needed
* Updated some todo messages in Android AutofillHandler
* When authenticating a passkey on Android the "showDialog" callback can be called and there's no MainPage available so it was changed for that specific scenario to use _deviceActionService instead of MainPage.
---------
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-7369] Show passkey icon on android when the item has a Fido2 credential (#3148)
* PM-7369 Show passkey icon on android when the item has a Fido2 credential
* PM-7369 alternative way to show passkey icon only in scenarios where we are trying to create a passkey
* PM-7369 moved logic to show passkey icon to CipherItemViewModel
* Update src/Core/Utilities/IconGlyphConverter.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* PM-7379 Fix creating the PendingIntent for a passkey credential on Android so it has different request codes amongst each other so the extras are not overriden by the last credential entry created. (#3149)
* PM-7365 Fix setting HasUnlockedInThisTransaction on passkey creation on android (#3153)
* PM-7367 Fix empty items state placeholder on Android cipher selection page (#3160)
* [PM-7366] Select cipher on search on Fido2 creation (#3154)
* PM-7366 Implemented cipher selection on search on passkey creation
* PM-7366 Fix typo
* [PM-7385] Fix for allowing switching accounts while creating a passkey of Android (#3155)
* PM-7385 Fixed for allowing switching accounts while creating a passkey on Android.
This fixes also include scenarios where we need to unlock the vault after switching
Also fixed the issue where tapping on cipher won't do anything after switching.
* PM-7385 ensure the Options.Fido2CredentialAction and FromFido2Framework are reset when the Credential flow is started to avoid erratic behaviors when switching accounts, app is in background or other edge case scenarios.
These properties where replaced by calls to _fido2MakeCredentialConfirmationUserInterface.IsConfirmingNewCredential instead.
* Minor changes and added comments
* [PM-7385] Implemented several changes suggested in PR for better/cleaner code.
* PM-7385 Added several minor code improvemments.
* PM-7385 Fix IFido2MakeCredentialConfirmationUserInterface resolve and usage to be constrained to Android. (#3164)
* PM-7385 Fix unit tests for Fido2 service (#3167)
* PM-7518 Updated favicon placeholder color on iOS Autofill extension. (#3165)
* PM-7365 Fix UserVerification on Fido2 credential creation on Android by updating the HasUnlockedInThisTransaction flag when a new transaction starts. (#3168)
* PM-5154 Avoid logging Fido2AuthenticatorExceptions (#3169)
* PM-7258 Updated Android Credential creation details on description to be localized and passed the user email for further details. (#3162)
* [PM-7257] android add support for web authn resident key credential property in our net mobile app 2 (#3170)
* [PM-7257] feat: add ability to override `clientDataHash`
* [PM-7257] feat: add support for clientDataHash and extensions
* PM-7257 Updated the origin to be the correct one and not the android one to be passed to the Fido2Client
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-7365] Fix UV not being performed on Fido2 credential creation Android (#3171)
* PM-7365 Fix UV not being performed on Fido2 credential creation on Android
* PM-7365 Fix PublicKeyCredentialCreationOptions mapping from json on AuthenticatorSelection so mainly userVerification has correct value
* PM-7585 Show error message when Origin is null, given no support for passkeys from native apps yet (#3175)
* PM-7623 Fix proper implementation of IFido2GetAssertionUserInterface now that the Fido2ClientService is being used for passkey autofill (#3174)
* PM-7553 Fix native apps passkeys autofill and creation (#3188)
* [PM-7658] Implement Fido2 privileged apps verification (#3190)
* PM-7553 Fix native apps passkeys autofill and creation
* PM-7658 Implemented Fido2 priviliged apps verification
* [PM-7576] Implemented digital asset links verification on Fido2 flows (#3191)
* PM-7553 Fix native apps passkeys autofill and creation
* PM-7658 Implemented Fido2 priviliged apps verification
* PM-7576 Implemented digital asset links verification on Fido2 flows for native apps.
* PM-7576 Renamed to ValidateAssetLinksAndGetOriginAsync to go along with Google naming and also changed method to private given that public is not necessary
* PM-7576 Moved digital asset links verification to a Core service AssetLinksService and added unit tests for it.
---------
Co-authored-by: Dinis Vieira <dinisvieira@outlook.com>
Co-authored-by: Vince Grassia <593223+vgrassia@users.noreply.github.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: Álison Fernandes <vvolkgang@users.noreply.github.com>
2024-04-25 22:26:12 +02:00
<data name="SetBitwardenAsPasskeyManagerDescription" xml:space="preserve">
<value>Set Bitwarden as your passkey provider in device settings.</value>
</data>
2019-04-10 23:01:25 +02:00
<data name="AvoidAmbiguousCharacters" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Avoid ambiguous characters</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="BitwardenAppExtension" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Bitwarden app extension</value>
2019-04-10 23:01:25 +02:00
</data>
2019-06-04 05:00:48 +02:00
<data name="BitwardenAppExtensionAlert2" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>The easiest way to add new logins to your vault is from the Bitwarden app extension. Learn more about using the Bitwarden app extension by navigating to the "Settings" screen.</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="BitwardenAppExtensionDescription" xml:space="preserve">
<value>Use Bitwarden in Safari and other apps to auto-fill your logins.</value>
</data>
<data name="BitwardenAutofillService" xml:space="preserve">
<value>Bitwarden Auto-fill Service</value>
</data>
<data name="BitwardenAutofillAccessibilityServiceDescription" xml:space="preserve">
<value>Use the Bitwarden accessibility service to auto-fill your logins.</value>
</data>
<data name="ChangeEmail" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Change email</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="ChangeEmailConfirmation" xml:space="preserve">
<value>You can change your email address on the bitwarden.com web vault. Do you want to visit the website now?</value>
</data>
<data name="ChangeMasterPassword" xml:space="preserve">
2022-07-22 10:16:50 +02:00
<value>Change master password</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Close" xml:space="preserve">
<value>Close</value>
</data>
<data name="Continue" xml:space="preserve">
<value>Continue</value>
</data>
<data name="CreateAccount" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Create account</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="CreatingAccount" xml:space="preserve">
<value>Creating account...</value>
<comment>Message shown when interacting with the server</comment>
</data>
<data name="EditItem" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Edit item</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="EnableAutomaticSyncing" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Allow automatic syncing</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="EnterEmailForHint" xml:space="preserve">
<value>Enter your account email address to receive your master password hint.</value>
</data>
<data name="ExntesionReenable" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Reactivate app extension</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="ExtensionAlmostDone" xml:space="preserve">
<value>Almost done!</value>
</data>
<data name="ExtensionEnable" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Activate app extension</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="ExtensionInSafari" xml:space="preserve">
<value>In Safari, find Bitwarden using the share icon (hint: scroll to the right on the bottom row of the menu).</value>
<comment>Safari is the name of apple's web browser</comment>
</data>
<data name="ExtensionInstantAccess" xml:space="preserve">
<value>Get instant access to your passwords!</value>
</data>
<data name="ExtensionReady" xml:space="preserve">
<value>You're ready to log in!</value>
</data>
<data name="ExtensionSetup" xml:space="preserve">
<value>Your logins are now easily accessible from Safari, Chrome, and other supported apps.</value>
</data>
<data name="ExtensionSetup2" xml:space="preserve">
<value>In Safari and Chrome, find Bitwarden using the share icon (hint: scroll to the right on the bottom row of the share menu).</value>
</data>
<data name="ExtensionTapIcon" xml:space="preserve">
<value>Tap the Bitwarden icon in the menu to launch the extension.</value>
</data>
<data name="ExtensionTurnOn" xml:space="preserve">
<value>To turn on Bitwarden in Safari and other apps, tap the "more" icon on the bottom row of the menu.</value>
</data>
<data name="Favorite" xml:space="preserve">
<value>Favorite</value>
</data>
<data name="Fingerprint" xml:space="preserve">
<value>Fingerprint</value>
</data>
<data name="GeneratePassword" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Generate password</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="GetPasswordHint" xml:space="preserve">
<value>Get your master password hint</value>
</data>
<data name="ImportItems" xml:space="preserve">
2022-07-11 08:45:42 +02:00
<value>Import items</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="ImportItemsConfirmation" xml:space="preserve">
<value>You can bulk import items from the bitwarden.com web vault. Do you want to visit the website now?</value>
</data>
<data name="ImportItemsDescription" xml:space="preserve">
<value>Quickly bulk import your items from other password management apps.</value>
</data>
<data name="LastSync" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Last sync:</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Length" xml:space="preserve">
<value>Length</value>
</data>
<data name="Lock" xml:space="preserve">
<value>Lock</value>
</data>
2020-05-29 18:26:36 +02:00
<data name="FifteenMinutes" xml:space="preserve">
2019-04-10 23:01:25 +02:00
<value>15 minutes</value>
</data>
2020-05-29 18:26:36 +02:00
<data name="OneHour" xml:space="preserve">
2019-04-10 23:01:25 +02:00
<value>1 hour</value>
</data>
2020-05-29 18:26:36 +02:00
<data name="OneMinute" xml:space="preserve">
2019-04-10 23:01:25 +02:00
<value>1 minute</value>
</data>
2020-05-29 18:26:36 +02:00
<data name="FourHours" xml:space="preserve">
2019-04-10 23:01:25 +02:00
<value>4 hours</value>
</data>
2020-05-29 18:26:36 +02:00
<data name="Immediately" xml:space="preserve">
2019-04-10 23:01:25 +02:00
<value>Immediately</value>
</data>
2020-05-29 18:26:36 +02:00
<data name="VaultTimeout" xml:space="preserve">
2022-07-11 08:45:42 +02:00
<value>Vault timeout</value>
2020-05-29 18:26:36 +02:00
</data>
<data name="VaultTimeoutAction" xml:space="preserve">
2022-07-11 08:45:42 +02:00
<value>Vault timeout action</value>
2020-05-29 18:26:36 +02:00
</data>
<data name="VaultTimeoutLogOutConfirmation" xml:space="preserve">
<value>Logging out will remove all access to your vault and requires online authentication after the timeout period. Are you sure you want to use this setting?</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="LoggingIn" xml:space="preserve">
<value>Logging in...</value>
<comment>Message shown when interacting with the server</comment>
</data>
<data name="LoginOrCreateNewAccount" xml:space="preserve">
<value>Log in or create a new account to access your secure vault.</value>
</data>
<data name="Manage" xml:space="preserve">
<value>Manage</value>
</data>
<data name="MasterPasswordConfirmationValMessage" xml:space="preserve">
<value>Password confirmation is not correct.</value>
</data>
<data name="MasterPasswordDescription" xml:space="preserve">
<value>The master password is the password you use to access your vault. It is very important that you do not forget your master password. There is no way to recover the password in the event that you forget it.</value>
</data>
<data name="MasterPasswordHint" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Master password hint (optional)</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="MasterPasswordHintDescription" xml:space="preserve">
<value>A master password hint can help you remember your password if you forget it.</value>
</data>
2023-02-16 19:15:40 +01:00
<data name="MasterPasswordLengthValMessageX" xml:space="preserve">
<value>Master password must be at least {0} characters long.</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="MinNumbers" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Minimum numbers</value>
2019-04-10 23:01:25 +02:00
<comment>Minimum numeric characters for password generator settings</comment>
</data>
<data name="MinSpecial" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Minimum special</value>
2019-04-10 23:01:25 +02:00
<comment>Minimum special characters for password generator settings</comment>
</data>
<data name="MoreSettings" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>More settings</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="MustLogInMainApp" xml:space="preserve">
<value>You must log into the main Bitwarden app before you can use the extension.</value>
</data>
<data name="Never" xml:space="preserve">
<value>Never</value>
</data>
<data name="NewItemCreated" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Item added</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="NoFavorites" xml:space="preserve">
<value>There are no favorites in your vault.</value>
</data>
<data name="NoItems" xml:space="preserve">
<value>There are no items in your vault.</value>
</data>
<data name="NoItemsTap" xml:space="preserve">
<value>There are no items in your vault for this website/app. Tap to add one.</value>
</data>
<data name="NoUsernamePasswordConfigured" xml:space="preserve">
<value>This login does not have a username or password configured.</value>
</data>
<data name="OkGotIt" xml:space="preserve">
<value>Ok, got it!</value>
<comment>Confirmation, like "Ok, I understand it"</comment>
</data>
<data name="OptionDefaults" xml:space="preserve">
<value>Option defaults are set from the main Bitwarden app's password generator tool.</value>
</data>
<data name="Options" xml:space="preserve">
<value>Options</value>
</data>
<data name="Other" xml:space="preserve">
<value>Other</value>
</data>
<data name="PasswordGenerated" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Password generated</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="PasswordGenerator" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Password generator</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="PasswordHint" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Password hint</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="PasswordHintAlert" xml:space="preserve">
<value>We've sent you an email with your master password hint.</value>
</data>
<data name="PasswordOverrideAlert" xml:space="preserve">
<value>Are you sure you want to overwrite the current password?</value>
</data>
<data name="PushNotificationAlert" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Bitwarden keeps your vault automatically synced by using push notifications. For the best possible experience, please select "Allow" on the following prompt when asked to allow push notifications.</value>
2019-04-10 23:01:25 +02:00
<comment>Push notifications for apple products</comment>
</data>
<data name="RateTheApp" xml:space="preserve">
2022-07-11 08:45:42 +02:00
<value>Rate the app</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="RateTheAppDescription" xml:space="preserve">
<value>Please consider helping us out with a good review!</value>
</data>
<data name="RegeneratePassword" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Regenerate password</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="RetypeMasterPassword" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Re-type master password</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="SearchVault" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Search vault</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Security" xml:space="preserve">
<value>Security</value>
</data>
<data name="Select" xml:space="preserve">
<value>Select</value>
</data>
<data name="SetPIN" xml:space="preserve">
<value>Set PIN</value>
</data>
<data name="SetPINDirection" xml:space="preserve">
<value>Enter a 4 digit PIN code to unlock the app with.</value>
</data>
<data name="ItemInformation" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Item information</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="ItemUpdated" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Item saved</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Submitting" xml:space="preserve">
<value>Submitting...</value>
<comment>Message shown when interacting with the server</comment>
</data>
<data name="Syncing" xml:space="preserve">
<value>Syncing...</value>
<comment>Message shown when interacting with the server</comment>
</data>
<data name="SyncingComplete" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Syncing complete</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="SyncingFailed" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Syncing failed</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="SyncVaultNow" xml:space="preserve">
2022-07-22 10:16:50 +02:00
<value>Sync vault now</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="TouchID" xml:space="preserve">
<value>Touch ID</value>
<comment>What Apple calls their fingerprint reader.</comment>
</data>
<data name="TwoStepLogin" xml:space="preserve">
2022-07-11 08:45:42 +02:00
<value>Two-step login</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="UnlockWith" xml:space="preserve">
<value>Unlock with {0}</value>
</data>
<data name="UnlockWithPIN" xml:space="preserve">
2022-07-11 08:45:42 +02:00
<value>Unlock with PIN code</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Validating" xml:space="preserve">
<value>Validating</value>
<comment>Message shown when interacting with the server</comment>
</data>
<data name="VerificationCode" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Verification code</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="ViewItem" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>View item</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="WebVault" xml:space="preserve">
2022-07-22 10:16:50 +02:00
<value>Bitwarden web vault</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Lost2FAApp" xml:space="preserve">
<value>Lost authenticator app?</value>
</data>
<data name="Items" xml:space="preserve">
<value>Items</value>
<comment>Screen title</comment>
</data>
<data name="ExtensionActivated" xml:space="preserve">
2022-07-22 10:16:50 +02:00
<value>Extension activated!</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Icons" xml:space="preserve">
<value>Icons</value>
</data>
<data name="Translations" xml:space="preserve">
<value>Translations</value>
</data>
<data name="ItemsForUri" xml:space="preserve">
<value>Items for {0}</value>
<comment>This is used for the autofill service. ex. "Logins for twitter.com"</comment>
</data>
<data name="NoItemsForUri" xml:space="preserve">
<value>There are no items in your vault for {0}.</value>
<comment>This is used for the autofill service. ex. "There are no items in your vault for twitter.com".</comment>
</data>
2020-01-10 16:20:19 +01:00
<data name="BitwardenAutofillServiceOverlay" xml:space="preserve">
<value>When you select an input field and see a Bitwarden auto-fill overlay, you can tap it to launch the auto-fill service.</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="BitwardenAutofillServiceNotificationContent" xml:space="preserve">
<value>Tap this notification to auto-fill an item from your vault.</value>
</data>
<data name="BitwardenAutofillServiceOpenAccessibilitySettings" xml:space="preserve">
<value>Open Accessibility Settings</value>
</data>
<data name="BitwardenAutofillServiceStep1" xml:space="preserve">
<value>1. On the Android Accessibility Settings screen, touch "Bitwarden" under the Services heading.</value>
</data>
<data name="BitwardenAutofillServiceStep2" xml:space="preserve">
<value>2. Switch on the toggle and press OK to accept.</value>
</data>
<data name="Disabled" xml:space="preserve">
<value>Disabled</value>
</data>
<data name="Enabled" xml:space="preserve">
<value>Enabled</value>
</data>
2022-07-21 15:57:08 +02:00
<data name="Off" xml:space="preserve">
<value>Off</value>
</data>
<data name="On" xml:space="preserve">
<value>On</value>
</data>
2019-04-10 23:01:25 +02:00
<data name="Status" xml:space="preserve">
<value>Status</value>
</data>
2019-06-04 05:00:48 +02:00
<data name="BitwardenAutofillServiceAlert2" xml:space="preserve">
2019-06-04 05:01:31 +02:00
<value>The easiest way to add new logins to your vault is from the Bitwarden Auto-fill Service. Learn more about using the Bitwarden Auto-fill Service by navigating to the "Settings" screen.</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Autofill" xml:space="preserve">
<value>Auto-fill</value>
</data>
<data name="AutofillOrView" xml:space="preserve">
<value>Do you want to auto-fill or view this item?</value>
</data>
<data name="BitwardenAutofillServiceMatchConfirm" xml:space="preserve">
<value>Are you sure you want to auto-fill this item? It is not a complete match for "{0}".</value>
</data>
<data name="MatchingItems" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Matching items</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="PossibleMatchingItems" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Possible matching items</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Search" xml:space="preserve">
<value>Search</value>
</data>
<data name="BitwardenAutofillServiceSearch" xml:space="preserve">
<value>You are searching for an auto-fill item for "{0}".</value>
</data>
2021-08-04 21:46:28 +02:00
<data name="LearnOrg" xml:space="preserve">
2022-07-22 10:16:50 +02:00
<value>Learn about organizations</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="CannotOpenApp" xml:space="preserve">
<value>Cannot open the app "{0}".</value>
<comment>Message shown when trying to launch an app that does not exist on the user's device.</comment>
</data>
<data name="AuthenticatorAppTitle" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Authenticator app</value>
2019-04-10 23:01:25 +02:00
<comment>For 2FA</comment>
</data>
<data name="EnterVerificationCodeApp" xml:space="preserve">
<value>Enter the 6 digit verification code from your authenticator app.</value>
<comment>For 2FA</comment>
</data>
<data name="EnterVerificationCodeEmail" xml:space="preserve">
<value>Enter the 6 digit verification code that was emailed to {0}.</value>
<comment>For 2FA</comment>
</data>
<data name="LoginUnavailable" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Login unavailable</value>
2019-04-10 23:01:25 +02:00
<comment>For 2FA whenever there are no available providers on this device.</comment>
</data>
<data name="NoTwoStepAvailable" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>This account has two-step login set up, however, none of the configured two-step providers are supported on this device. Please use a supported device and/or add additional providers that are better supported across devices (such as an authenticator app).</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="RecoveryCodeTitle" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Recovery code</value>
2019-04-10 23:01:25 +02:00
<comment>For 2FA</comment>
</data>
<data name="RememberMe" xml:space="preserve">
<value>Remember me</value>
<comment>Remember my two-step login</comment>
</data>
<data name="SendVerificationCodeAgain" xml:space="preserve">
<value>Send verification code email again</value>
<comment>For 2FA</comment>
</data>
<data name="TwoStepLoginOptions" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Two-step login options</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="UseAnotherTwoStepMethod" xml:space="preserve">
<value>Use another two-step login method</value>
</data>
<data name="VerificationEmailNotSent" xml:space="preserve">
<value>Could not send verification email. Try again.</value>
<comment>For 2FA</comment>
</data>
<data name="VerificationEmailSent" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Verification email sent</value>
2019-04-10 23:01:25 +02:00
<comment>For 2FA</comment>
</data>
<data name="YubiKeyInstruction" xml:space="preserve">
<value>To continue, hold your YubiKey NEO against the back of the device or insert your YubiKey into your device's USB port, then touch its button.</value>
</data>
<data name="YubiKeyTitle" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>YubiKey security key</value>
2019-04-10 23:01:25 +02:00
<comment>"YubiKey" is the product name and should not be translated.</comment>
</data>
<data name="AddNewAttachment" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Add new attachment</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Attachments" xml:space="preserve">
<value>Attachments</value>
</data>
<data name="UnableToDownloadFile" xml:space="preserve">
<value>Unable to download file.</value>
</data>
<data name="UnableToOpenFile" xml:space="preserve">
<value>Your device cannot open this type of file.</value>
</data>
<data name="Downloading" xml:space="preserve">
<value>Downloading...</value>
<comment>Message shown when downloading a file</comment>
</data>
<data name="AttachmentLargeWarning" xml:space="preserve">
<value>This attachment is {0} in size. Are you sure you want to download it onto your device?</value>
<comment>The placeholder will show the file size of the attachment. Ex "25 MB"</comment>
</data>
<data name="AuthenticatorKey" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Authenticator key (TOTP)</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="VerificationCodeTotp" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Verification code (TOTP)</value>
2019-04-10 23:01:25 +02:00
<comment>Totp code label</comment>
</data>
<data name="AuthenticatorKeyAdded" xml:space="preserve">
<value>Authenticator key added.</value>
</data>
<data name="AuthenticatorKeyReadError" xml:space="preserve">
<value>Cannot read authenticator key.</value>
</data>
2022-08-17 23:10:16 +02:00
<data name="PointYourCameraAtTheQRCode" xml:space="preserve">
<value>Point your camera at the QR Code.
Scanning will happen automatically.</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="ScanQrTitle" xml:space="preserve">
<value>Scan QR Code</value>
</data>
<data name="Camera" xml:space="preserve">
<value>Camera</value>
</data>
<data name="Photos" xml:space="preserve">
<value>Photos</value>
</data>
<data name="CopyTotp" xml:space="preserve">
<value>Copy TOTP</value>
</data>
2022-07-11 08:45:42 +02:00
<data name="CopyTotpAutomaticallyDescription" xml:space="preserve">
2023-09-28 18:55:18 +02:00
<value>If a login has an authenticator key, copy the TOTP verification code to your clipboard when you auto-fill the login.</value>
2019-04-10 23:01:25 +02:00
</data>
2022-07-11 08:45:42 +02:00
<data name="CopyTotpAutomatically" xml:space="preserve">
<value>Copy TOTP automatically</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="PremiumRequired" xml:space="preserve">
<value>A premium membership is required to use this feature.</value>
</data>
<data name="AttachementAdded" xml:space="preserve">
<value>Attachment added</value>
</data>
<data name="AttachmentDeleted" xml:space="preserve">
<value>Attachment deleted</value>
</data>
<data name="ChooseFile" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Choose file</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="File" xml:space="preserve">
<value>File</value>
</data>
<data name="NoFileChosen" xml:space="preserve">
<value>No file chosen</value>
</data>
<data name="NoAttachments" xml:space="preserve">
<value>There are no attachments.</value>
</data>
<data name="FileSource" xml:space="preserve">
<value>File Source</value>
</data>
<data name="FeatureUnavailable" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Feature unavailable</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="MaxFileSize" xml:space="preserve">
2021-04-27 22:14:54 +02:00
<value>Maximum file size is 100 MB.</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="UpdateKey" xml:space="preserve">
<value>You cannot use this feature until you update your encryption key.</value>
</data>
2023-09-20 21:56:51 +02:00
<data name="EncryptionKeyMigrationRequiredDescriptionLong" xml:space="preserve">
<value>Encryption key migration required. Please login through the web vault to update your encryption key.</value>
</data>
2019-04-10 23:01:25 +02:00
<data name="LearnMore" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Learn more</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="ApiUrl" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>API server URL</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="CustomEnvironment" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Custom environment</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="CustomEnvironmentFooter" xml:space="preserve">
<value>For advanced users. You can specify the base URL of each service independently.</value>
</data>
<data name="EnvironmentSaved" xml:space="preserve">
<value>The environment URLs have been saved.</value>
</data>
<data name="FormattedIncorrectly" xml:space="preserve">
<value>{0} is not correctly formatted.</value>
<comment>Validation error when something is not formatted correctly, such as a URL or email address.</comment>
</data>
<data name="IdentityUrl" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Identity server URL</value>
2019-04-10 23:01:25 +02:00
<comment>"Identity" refers to an identity server. See more context here https://en.wikipedia.org/wiki/Identity_management</comment>
</data>
<data name="SelfHostedEnvironment" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Self-hosted environment</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="SelfHostedEnvironmentFooter" xml:space="preserve">
<value>Specify the base URL of your on-premise hosted Bitwarden installation.</value>
</data>
<data name="ServerUrl" xml:space="preserve">
<value>Server URL</value>
</data>
<data name="WebVaultUrl" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Web vault server URL</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="BitwardenAutofillServiceNotificationContentOld" xml:space="preserve">
<value>Tap this notification to view items from your vault.</value>
</data>
<data name="CustomFields" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Custom fields</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="CopyNumber" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Copy number</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="CopySecurityCode" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Copy security code</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Number" xml:space="preserve">
<value>Number</value>
</data>
<data name="SecurityCode" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Security code</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="TypeCard" xml:space="preserve">
<value>Card</value>
</data>
<data name="TypeIdentity" xml:space="preserve">
<value>Identity</value>
</data>
<data name="TypeLogin" xml:space="preserve">
<value>Login</value>
</data>
<data name="TypeSecureNote" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Secure note</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Address1" xml:space="preserve">
<value>Address 1</value>
</data>
<data name="Address2" xml:space="preserve">
<value>Address 2</value>
</data>
<data name="Address3" xml:space="preserve">
<value>Address 3</value>
</data>
<data name="April" xml:space="preserve">
<value>April</value>
</data>
<data name="August" xml:space="preserve">
<value>August</value>
</data>
<data name="Brand" xml:space="preserve">
<value>Brand</value>
</data>
<data name="CardholderName" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Cardholder name</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="CityTown" xml:space="preserve">
<value>City / Town</value>
</data>
<data name="Company" xml:space="preserve">
<value>Company</value>
</data>
<data name="Country" xml:space="preserve">
<value>Country</value>
</data>
<data name="December" xml:space="preserve">
<value>December</value>
</data>
<data name="Dr" xml:space="preserve">
<value>Dr</value>
</data>
<data name="ExpirationMonth" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Expiration month</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="ExpirationYear" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Expiration year</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="February" xml:space="preserve">
<value>February</value>
</data>
<data name="FirstName" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>First name</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="January" xml:space="preserve">
<value>January</value>
</data>
<data name="July" xml:space="preserve">
<value>July</value>
</data>
<data name="June" xml:space="preserve">
<value>June</value>
</data>
<data name="LastName" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Last name</value>
2019-04-10 23:01:25 +02:00
</data>
2021-11-08 22:34:16 +01:00
<data name="FullName" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Full name</value>
2021-11-08 22:34:16 +01:00
</data>
2019-04-10 23:01:25 +02:00
<data name="LicenseNumber" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>License number</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="March" xml:space="preserve">
<value>March</value>
</data>
<data name="May" xml:space="preserve">
<value>May</value>
</data>
<data name="MiddleName" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Middle name</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Mr" xml:space="preserve">
<value>Mr</value>
</data>
<data name="Mrs" xml:space="preserve">
<value>Mrs</value>
</data>
<data name="Ms" xml:space="preserve">
<value>Ms</value>
</data>
2023-01-23 16:28:04 +01:00
<data name="Mx" xml:space="preserve">
<value>Mx</value>
</data>
2019-04-10 23:01:25 +02:00
<data name="November" xml:space="preserve">
<value>November</value>
</data>
<data name="October" xml:space="preserve">
<value>October</value>
</data>
<data name="PassportNumber" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Passport number</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Phone" xml:space="preserve">
<value>Phone</value>
</data>
<data name="September" xml:space="preserve">
<value>September</value>
</data>
<data name="SSN" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Social Security number</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="StateProvince" xml:space="preserve">
<value>State / Province</value>
</data>
<data name="Title" xml:space="preserve">
<value>Title</value>
</data>
<data name="ZipPostalCode" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Zip / Postal code</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="Address" xml:space="preserve">
<value>Address</value>
</data>
<data name="Expiration" xml:space="preserve">
<value>Expiration</value>
</data>
2022-07-11 08:45:42 +02:00
<data name="ShowWebsiteIcons" xml:space="preserve">
<value>Show website icons</value>
2019-04-10 23:01:25 +02:00
</data>
2022-07-11 08:45:42 +02:00
<data name="ShowWebsiteIconsDescription" xml:space="preserve">
<value>Show a recognizable image next to each login.</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="IconsUrl" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Icons server URL</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="AutofillWithBitwarden" xml:space="preserve">
<value>Auto-fill with Bitwarden</value>
</data>
<data name="VaultIsLocked" xml:space="preserve">
<value>Vault is locked</value>
</data>
<data name="GoToMyVault" xml:space="preserve">
<value>Go to my vault</value>
</data>
<data name="Collections" xml:space="preserve">
<value>Collections</value>
</data>
<data name="NoItemsCollection" xml:space="preserve">
<value>There are no items in this collection.</value>
</data>
<data name="NoItemsFolder" xml:space="preserve">
<value>There are no items in this folder.</value>
</data>
2020-05-20 19:35:20 +02:00
<data name="NoItemsTrash" xml:space="preserve">
<value>There are no items in the trash.</value>
</data>
2019-04-10 23:01:25 +02:00
<data name="AutofillAccessibilityService" xml:space="preserve">
<value>Auto-fill Accessibility Service</value>
</data>
<data name="AutofillServiceDescription" xml:space="preserve">
2022-02-15 16:46:33 +01:00
<value>The Bitwarden auto-fill service uses the Android Autofill Framework to assist in filling login information into other apps on your device.</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="BitwardenAutofillServiceDescription" xml:space="preserve">
2022-02-15 16:46:33 +01:00
<value>Use the Bitwarden auto-fill service to fill login information into other apps.</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="BitwardenAutofillServiceOpenAutofillSettings" xml:space="preserve">
<value>Open Autofill Settings</value>
</data>
<data name="FaceID" xml:space="preserve">
<value>Face ID</value>
<comment>What Apple calls their facial recognition reader.</comment>
</data>
<data name="FaceIDDirection" xml:space="preserve">
<value>Use Face ID to verify.</value>
</data>
<data name="UseFaceIDToUnlock" xml:space="preserve">
<value>Use Face ID To Unlock</value>
</data>
<data name="VerifyFaceID" xml:space="preserve">
<value>Verify Face ID</value>
</data>
<data name="WindowsHello" xml:space="preserve">
<value>Windows Hello</value>
</data>
[PM-5894] Implement Passkey Providers (#3173)
* PM-3349 PM-3350 Added the partial MAUI Community Toolkit implementation for TouchEffect. This is a temporary solution until they finalize this and add it to their nuget package.
This allows implementing the LongPressCommand in AccountSwitchingOverlay and also have the "Ripple effect" animation when touching an item in Android
* PM-3349 PM-3350 Changed SendViewCell and its binding to be directly against the ViewModel
* PM-3350 Fixed iOS Share extension lazy views loading and an issue with the avatar loading. Also discovered issue with TapGestureRecognizer not working on MAUI Embedding
* PM-3350 Fixed iOS Extensions navigation to several pages and improved avoiding duplicate calls to OnNavigatedTo
* PM-3350 Updated PCL Crypto to latest alpha version to fix "Dll not found NCrypt" issue
* PM-3350 Removed workaround for iOS issue with Avatar icon as it's now fixed in latest .Net8 release.
* PM-3349 PM-3350 Removed AsyncCommand "wrapper" and added AsyncRelayCommand directly in all ViewModels that were using the other one.
* PM-3350 Added watchOS app to main project and fixed some csproj conditions for runtime identifiers on iOS.
* PM-3350 Fixed/Updated all MAUI-Migration TODOs
* PM-3350 Fixed account toolbar item and TitleView on SendAddOnlyPage, also removed comments on AvatarImageSource given the workaround is not needed anymore to draw the image successfully.
* PM-3350 Updated AppCenter package to latest version 5.0.3 and updated some things into MAUI style
* PM-3350 Added workaround for iOS Avatar icon again.
* PM-3349 Added workaround for Android to avoid issues with setting MainPage when app is in background. They are now kept on a Queue to be executed after the app has resumed.
Updated some things on App.xaml.cs to the new MAUI style
* PM-3349 PM-3350 Fixed issue where creating an account with weak/exposed password would get stuck after the Captcha (if a captcha is shown)
Changed App.xaml.cs NavigateImpl to be private
* PM-3349 Started to configure build.yml for MAUI Android
* PM-3349 build.yml update paths for MAUI Android
* PM-3349 build.yml commented verify format and just set qa as variant on MAUI Android for faster checks on CI
* PM-3349 PM-3350 build.cake updated paths
* PM-3349 build.yml updated env helpers variables and set specific csproj to build on Android so not to build iOS extensions
* PM-3349 build.yml add Android "prod" variant
* PM-3350 build.yml updated iOS build and ignore Android build to try the CI faster
* PM-3350 build.yml changed nuget restore for dotnet restore on iOS build to fix issue on restoring due to msbuild
* PM-3350 build.yml Upgraded iOS build to run on macos-13 image which has XCode 15, and set the XCode 15 version as currently the default one is 14.x
* PM-3350 build.yml try to fix ILLINK warnings and changed image to be macos-13-arm64 to see if the build is faster
* PM-3350 build.yml changed image back to be macos-13 to see if the build is faster
* PM-3350 Added Document.Build.props to disable trimming on publish
* PM-3350 build.yml disable trimming on publish so it's faster
* PM-3350 added linkskip for iOS csprojs
* PM-3350 iOS projs disable linking and set Newstandkit as weak framework
* Update build.yml disabling iOS job to avoid long running process of publish until we can fix that
* PM-3349 PM-3350 Workaround to fix issues with text getting cropped/truncated when a Label has both Multiline and LinebreakMode set
* PM-3349 build.yml enabled android build workflow
* PM-3349 build.yml configured FDROID job for MAUI
* PM-3350 iOS extensions TapGestureRecognizer try Window workaround
* PM-3350 iOS applied workaround on the iOS Autofill and Share extension to maui embed the navigation page with its content page in the Window
* PM-3349 PM-3350 Added workaround for More Options to work on Search and Groupings Page
Updated some code to MAUI Style also
* PM-3349 PM-3350 Added the ability for users to press "Continue" button as a fallback when using the Yubikey if the "SubmitCommand" doesn't trigger automatically.
* PM-3349 PM-3350 Fix for text getting cut/truncated in both account switcher and ciphers/search lists
Issue is due to MAUI but can be avoided by using slightly different layout
* PM-3350 iOS updated CFBundlerShortVersionString to latest one 2023.10.1
* PM-3350 fix build.yml Bitwarden.ipa AppStore exported file
* PM-3350 build.yml added step to validate app for submitting into App Store and have better logs of it
* PM-3350 build.yml Added several fixes like not using MtouchUseLLVM on the iOS builds to fix they taking forever to build and some changes on the automation CI to do a debug build for the moment
* PM-3350 Improved MTouch linking and extra args on iOS related csprojs
* PM-3349 PM-3350 Added MAUI label on self-host settings and on about settings to differentiate from XF app
* PM-3349 PM-3350 build.yml uncommented jobs so we have a more complete workflow
* PM-3349 PM-3350 Minor change: removed unneeded HorizontalTextAlignment from Label.
* PM-3349 Replaced CrossCurrentActivity plugin with MAUI internal CurrentActivity
* PM-3350 Fix iOS extensions navigation and Window/RootViewController handling for TapGestureRecognizer to work
* PM-3350 Cleared left ClipLogger from the iOS extensions debug logging.
* PM-3349 PM-3350 Refactored cipher bindings to have a simpler approach reusing a new CipherItemViewModel to avoid unwanted issues in the app
* PM-3349 Added base structure for avoiding Android Autofill crash. This workaround works but it's not complete as it can't handle the entire workflow when showing CipherSelectionPAge (like checking if it should show LockPage)
* PM-3350 Bumped iOS version
* PM-3350 Changed linker to use default mode given that "Full" is presenting some problems as the linker is stripping things it shouldn't and we're trying to solve it. So for now we will use the mode "Link SDK assemblies only" so QA can test.
* PM-3349 Fix for app crashing on Android when Dark mode is enabled
Removed unused button style for android
* Proof of concept for having multiple window in Android for autofill support and navigating with the help of an Extended splash page.
* PM-3350 Fix crash on Release by adding Interpreter on iOS and also adding System.Security.Cryptography to be ignored by the linker
* PM-3350 Apply Cryptography TrimmerRootAssembly only to iOS
* PM-3350 Updated Plugin.Fingerprint so biometrics work
* Update .github/workflows/build.yml setup-xcode commit hash
Co-authored-by: Vince Grassia <593223+vgrassia@users.noreply.github.com>
* PM-3349 PM-3350 Enabled argon2id and fixed one issue with the Uris when getting the icon image
* PM-3349 Upgraded Android targetSdkVersion to 34
* minor change (public to private fields)
* minor improvemments on autofill-redirect
* PM-3349 Commented the Deploy step for Android job given that we're using the hotfix-rc branch for testing iOS on TestFlight
* PM-3349 Uncommented the Deploy step for Android job
* PM-3349 Ensure "_isResumed=true" is set on App.xaml.cs:Bootstrap
* Reusing App.xaml.cs Navigation for the Android RedirectPage
Some other cleanup and changes
* Improved autofill workaround to better handle switching between windows.
* PM-3349 minor fix to add space in HomePage between the region picker labels.
* Added some comments and improvemments.
* PM-3349 Added Window events unsubscription of events. Also changed code to avoid potentially having multiple autofillwindow
* PM-3349 Minor ui fix (space between buttons in delete account page)
* initial commit of android credential provider service (wip)
* Revert "initial commit of android credential provider service (wip)"
This reverts commit 6011b639586d081687d22d77352a024272ca6841.
* PM-3350 Fix for Delete Account buttons on iOS
* PM-3349 PM-3350 Changed search icon used in app to avoid issue with icon size on iOS
* PM-3349 Added custom window so that we can always get the current Active Window. This is used to support the Android Autofil and multi-window scenarios.
* PM-3349 Fix for icon and text spacing in some list items
* PM-3349 Minor aligment improvemment for region selection in HomePage
* PM-3349 Changed the "track color" for the Android switch so that the color is different from the "thumb"
* PM-3350 Updated version to 2024.1.0 on iOS
* PM-5154 Start implementing Passkeys Autofill in iOS
* PM-5154 Continue Passkeys Autofill in iOS
* initial commit of android credential provider service (wip)
* add cred manager project to build config
* PM-5154 Added Fido2AuthenticationService to provide us a wrapper for the actual implementation
* PM-3349 Fix Picker selection style by doing a custom PickerHandler for Android which uses SetSingleChoiceItems(...) to provide with the appropriate UI
* PM-3350 Updated MauiVersion to 8.0.4-nightly.* to have the TapGestureRecognizer fix applied. This is done on the Directory.Build.props so we don't have to change it on every csproj. Also removed the workaround of TapGestureHack and fix the Show environment picker to work on the extensions as well.
* PM-3350 Added nuget.config so we add the nuget package source for MAUI Nightly builds
* Bump main iOS version
* PM-3350 Removed "iOS" old folder project that has been moved into the MAUI Single app project.
* PM-3350 Improved code safety adding a lot of try...catch and logging throughout the app. Also made the invoking on main thread safer on several places of the app. Additionally, on the GroupingsPageViewModel changed the code removing the old Xamarin hack and just using Replace directly instead of Clearing first to see if that fixes the crash we're having sometimes on the app.
* PM-3350 PM-3349 Updated Unit Test projects to NET 8.0 and fixed it to work with Core project reference. Also fixed a test that was breaking due to CIpherKey creation being wrong. Added "UT" as a constant to add when building/running Core.Test project so we have something on the context that tells us that is for a UT. With this I had to remove FFImageLoading on UT context because it doesn't support NET 8.0
* PM-3350 PM-3349 Updated Readme with MAUI and main branch
* PM-3350 PM-3349 Enable running Core tests
* PM-3350 Fix build.yml format
* PM-3349 Fix navigation when coming from autofill with Accessibility Services enabled. The user was getting into Home page instead of where they were, with this workaround the app navigates as if the account has been switched, leaving the user as closely as possible to where they were, basically on the first screen for the current state of the user.
* PM-3350 PM-3349 Added property to Directory.Build.props to enable Unit Testing globally so Test runners work
* Improve TOTP scan performance on Android
* Move Android camera/scan changes to xaml
* PM-3350 Testing UseInterpreter false on CI build
* PM-3350 Enabled back UseInterpreter on iOS Release given that it crashes on startup without it.
* PM-3349 PM-3350 Improved code safety with try...catch, better invoke on main thread and better null handling.
* PM-3349 PM-3350 Updated XCode version on build.yml to 15.1
* PM-3350 Removed TapGesture Window MAUI hack from iOS.Extension and iOS.ShareExtension
* PM-3350 Fixed CancellationTokenSource proper disposal
* PM-3350 Fix Avatar toolbar icon on extensions to load properly and to take advantage of using directly SkiaSharp to do the native conversion to UIImage. Also improved the toolbar item so that size is set appropriately.
* PM-3349 PM-3350 Fix external link icon
* PM-3350 Added new style to prevent spell check and text prediction
* Fix merge from main
* PM-3350 Commented event collection upload on the timer and when sending the app to background to see if that prevents the app from crashing on release mode.
* PM-3350 Added check for state migration version before trying to migrate LiteDB values into Prefs when there's no need to and that may be inducing crashes on backgrounded iOS apps.
* PM-3350 Try to disable Interpreter to have better crash knowledge. This time testing if avoiding loading the argon2id lib we're able to not use the interpreter.
* PM-5928 Fix circle animation to be shown on verification codes list on each item
* PM-3350 Go back to use Interpreter and added some Directory.Build.props to easily change Codesign properties and also include/exclude iOS extensions / WatchOS from the build.
* PM-3350 Enabled iOS extensions and WatchOS app to be included based on the Directory.Build.props
* PM-3350 Go back to include argon2id and interpreter
* Removing error/loading placeholders of icons on the cells to see if that is causing the background crash on iOS; so we can test this in TestFlight
* [PM-5910] Workaround for for sliding elements in Duo 2FA flow (#2967)
* workaround for sliding elements in duo 2fa flow
* restrict workaround to Android
* restrict workaround to Android
* Revert "restrict workaround to Android"
This reverts commit c2753d5dc4960aeacdb4c798e7273ca86c08881d.
* Revert "restrict workaround to Android"
This reverts commit 69688cfb98e8e3e17812f126b4fd90ffd2ac3cf8.
* PM-5902 fix for account switcher not dismissing when tapping outside (#2974)
* PM-3350 Fix iossimulator-x64 argon2id load so we can test on simulators and also made easier to maintain loading the argon2id library on the iOS projects by setting a general Directory.Build.props that is shared.
* PM-5903 Changed App.xaml.cs SetOption to only update the needed properties instead of replacing the existing Options object which would cause the AccountSwitcher button bug (#2973)
* [PM-5896] Fix MAUI iOS Background crash due to lock files on suspension (#2969)
* PM-5896 Fix background crash on iOS due to lock files when app gets suspended. Changed loading and error placeholders of the CachedImage to not be used and use default icon of IconLabel instead changing visibility.
* PM-5896 Changed methods to be protected so that they don't get removed by the linker.
* PM-5896 Added stub class and references to it so to have stronger references to Icon_Success and Icon_Error so the linker doesn't remove them.
* PM-3349 Removed commented code from build.yml regarding FDroid that is not needed anymore.
* PM-3349 PM-3350 Fix crash on iOS AppGroup container URL because of sln config on AndroidX Credentials. Changed the project reference of Credentials to be a local NuGet.
* PM-6077 Separated Android and iOS HybridWebViewHandler so that it can be used on iOS.Core (#2983)
* [PM-5907] Fix for incorrect TOTP white text color on label when using light theme on iOS (#2982)
* PM-5907 workaround for incorrect textcolor when programmatically changing text on Entry
* Update src/Core/Pages/Vault/CipherAddEditPage.xaml.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-5906] Fix for incorrect Send MaxAccess white text color on label when using light theme on iOS (#2981)
* PM-5906 workaround for incorrect textcolor when programmatically changing text on Entry
* Update src/Core/Pages/Send/SendAddEditPage.xaml.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* PM-3349 PM-3350 Fixed Unit tests because of referencing FFImageLoading when it's not possible
* PM-3349 Added exception on gitignore so the nupkg for the AndroidX Credentials is added
* [PM-5731] Create C# WebAuthn authenticator to support maui apps (#2951)
* [PM-5731] feat: implement get assertion params object
* [PM-5731] feat: add first test
* [PM-5731] feat: add rp mismatch test
* [PM-5731] feat: ask for credentials when found
* [PM-5731] feat: find discoverable credentials
* [PM-5731] feat: add tests for successful UV requests
* [PM-5731] feat: add user does not consent test
* [PM-5731] feat: check for UV when reprompt is active
* [PM-5731] fix: tests a bit, needed some additional "arrange" steps
* [PM-5731] feat: add support for counter
* [PM-5731] feat: implement assertion without signature
* [PM-5732] feat: finish authenticator assertion implementation
note: CryptoFunctionService still needs Sign implemenation
* [PM-5731] chore: minor clean up
* [PM-5731] feat: scaffold make credential
* [PM-5731] feat: start implementing attestation
* [PM-5731] feat: implement credential exclusion
* [PM-5731] feat: add new credential confirmaiton
* [PM-5731] feat: implement credential creation
* [PM-5731] feat: add user verification checks
* [PM-5731] feat: add unknown error handling
* [PM-5731] chore: clean up unusued params
* [PM-5731] feat: partial attestation implementation
* [PM-5731] feat: implement key generation
* [PM-5731] feat: return public key in DER format
* [PM-5731] feat: implement signing
* [PM-5731] feat: remove logging
* [PM-5731] chore: use primary constructor
* [PM-5731] chore: add Async to method names
* [PM-5731] feat: add support for silent discoverability
* [PM-5731] feat: add support for specifying user presence requirement
* [PM-5731] feat: ensure unlocked vault
* [PM-5731] chore: clean up and refactor assertion tests
* [PM-5731] chore: clean up and refactor attestation tests
* [PM-5731] chore: add user presence todo comment
* [PM-5731] feat: scaffold fido2 client
* PM-5731 Fix build updating discoverable flag
* [PM-5731] fix: failing test
* [PM-5731] feat: add sameOriginWithAncestor and user id length checks
* [PM-5731] feat: add incomplete rpId verification
* [PM-5731] chore: document uri helpers
* [PM-5731] feat: implement fido2 client createCredential
* [PM-5731] feat: implement credential assertion in client
* fix wrong signature format
(cherry picked from commit a1c9ebf01fdcf7c64a0ca2533586b2647cc5cf3e)
* [PM-5731] fix: issues after cherry-pick
* Fix incompatible GUID conversions
(cherry picked from commit c801b2fc3aa4400032bb1bda74c034132cc677f1)
* [PM-5731] chore: remove default constructor
* [PM-5731] feat: refactor user interface to increase flexibility
* [PM-5731] feat: implement generic assertion user interface class
* [PM-5731] feat: remove ability to make user presence optional
* [PM-5731] chore: remove logging comments
* [PM-5731] feat: add native reprompt support to the authenticator
* [PM-5731] feat: allow pre and post UV
* [PM-5731] chore: add `Async` to method name. Remove `I` from struct
* [PM-5731] fix: discoverable string repr lowercase
* [PM-5731] chore: don't use C# 12 features
* [PM-5731] fix: replace magic strings and numbers with contants and enums
* [PM-5731] fix: use UTC creation date
* [PM-5731] fix: formatting
* [PM-5731] chore: use properties for public fields
* [PM-5731] chore: remove TODO
* [PM-5731] fix: IsValidRpId
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
* [PM-5154] Implement Passkeys on iOS (#3017)
* [PM-5731] feat: implement get assertion params object
* [PM-5731] feat: add first test
* [PM-5731] feat: add rp mismatch test
* [PM-5731] feat: ask for credentials when found
* [PM-5731] feat: find discoverable credentials
* [PM-5731] feat: add tests for successful UV requests
* [PM-5731] feat: add user does not consent test
* [PM-5731] feat: check for UV when reprompt is active
* [PM-5731] fix: tests a bit, needed some additional "arrange" steps
* [PM-5731] feat: add support for counter
* [PM-5731] feat: implement assertion without signature
* [PM-5732] feat: finish authenticator assertion implementation
note: CryptoFunctionService still needs Sign implemenation
* [PM-5731] chore: minor clean up
* [PM-5731] feat: scaffold make credential
* [PM-5731] feat: start implementing attestation
* [PM-5731] feat: implement credential exclusion
* [PM-5731] feat: add new credential confirmaiton
* [PM-5731] feat: implement credential creation
* [PM-5731] feat: add user verification checks
* [PM-5731] feat: add unknown error handling
* [PM-5731] chore: clean up unusued params
* [PM-5731] feat: partial attestation implementation
* [PM-5731] feat: implement key generation
* [PM-5731] feat: return public key in DER format
* [PM-5731] feat: implement signing
* [PM-5731] feat: remove logging
* [PM-5731] chore: use primary constructor
* [PM-5731] chore: add Async to method names
* [PM-5731] feat: add support for silent discoverability
* [PM-5731] feat: add support for specifying user presence requirement
* [PM-5731] feat: ensure unlocked vault
* [PM-5731] chore: clean up and refactor assertion tests
* [PM-5731] chore: clean up and refactor attestation tests
* [PM-5731] chore: add user presence todo comment
* [PM-5731] feat: scaffold fido2 client
* PM-5731 Fix build updating discoverable flag
* [PM-5731] fix: failing test
* [PM-5731] feat: add sameOriginWithAncestor and user id length checks
* [PM-5731] feat: add incomplete rpId verification
* [PM-5731] chore: document uri helpers
* [PM-5731] feat: implement fido2 client createCredential
* Added iOS passkeys integration, warning this branch has lots of logs to ease "debugging" extensions.
* [PM-5731] feat: implement credential assertion in client
* PM-5154 Fixed select passkey flow and started implementing create passkey on iOS
* fix wrong signature format
* PM-5154 [Passkeys iOS] Fix Credential ID handling on bytes and string formats. Fix Discoverable to be lowercase on set so it doesn't break parsing on clients. Added UserDisplayName on Fido2 entities. Extracted the Guid Standard/Raw format helpers to a extensions class.
* Fix incompatible GUID conversions
* PM-5154 [Passkeys iOS] Added custom UI flow for passkey creation
* PM-5154 [Passkeys iOS] Updated UI for passkey creation
* PM-5154 [Passkeys iOS] Refactored and added cipher selection for passkey creation on autofill search.
* PM-5154 [Passkeys iOS] Fixed empty top space on autofill password list
---------
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
* feat: optimize assertion network calls (#3021)
The server only needs to be updated if we have changed the counter. New passkeys that leave their counters at zero can therefore skip this step.
* [PM-5154] Implement iOS Passkey -> Add login item (#3019)
* PM-5154 Implement iOS passkey add login
* PM-5154 Added Username to Create new login for passkey, for this the param was changed to the Fido2ConfirmNewCredentialParams object so we have access to the proper values. Also added back RpId to the params to have access to it when creating the vault item. Finally added loading to saving the passkey as new login
* [PM-6513] Omit creating CredentialIdentity if it throws an exception (#3040)
* PM-6513 Omit creating CredentialIdentity if that throws, so it doesn't affect other ciphers. E.g. if a Passkey doesn't have a UserName it will throw here and it shouldn't break replacing all the other identities.
* PM-6513 Added fallback values to passkey username not being set
* Fix FIDO2 client bugs (#3056)
* fix: blockedUris null issue
* fix: trailing slash in origin breaking check
* [PM-6466] Implement passkeys User Verification (#3044)
* PM-6441 Implement passkeys User Verification
* PM-6441 Reorganized UserVerificationMediatorService so everything is not in the same file
* PM-6441 Fix Unit tests
* PM-6441 Refactor UserVerification on Fido2Authenticator and Client services to be of an enum type so we can see which specific preference the RP sent and to be passed into the user verification mediator service to perform the correct flow depending on that. Also updated Unit tests.
* PM-6441 Changed user verification logic a bit so if preference is Preferred and the app has the ability to verify the user then enforce required UV and fix issue on on Discouraged to take into account MP reprompt
* [PM-6474] Remove header on Save passkey as new login (#3054)
* PM-6474 Removed header on empty list view on iOS Autofill create passkey flow
* PM-6474 Fix TableView being hidden on Logins scene
* [PM-6496] Improved iOS extensions cipher cell UI (#3058)
* PM-6496 Improved iOS extensions cipher list to have an updated UI for each cell
* PM-6496 Improved UI on iOS extensions list cells
* [PM-5154] Implement combined view for passwords and passkeys on iOS Autofill extension (#3075)
* PM-5154 Implemented combined view of passwords and passkeys and improved search and items UI
* PM-5154 Code improvement from PR feedback
* PM-5154 Code improvement to log unknown exceptions
* PM-6685 Fix race condition issue where the biometrics check is being done before the iOS extension is being shown. So when we need the UI, we wait until ViewDidAppear happens. (#3078)
* PM-6468 Implemented copy TOTP if needed after using a Fido2 credential. Also added the Fido2MediatorService to have one point to interact with the authentication and also to add any new logic we need. (#3082)
* PM-6706 Add maximum attempts to UV with MP and with PIN (#3079)
* [PM-6848] Improved User verification on passkeys creation (#3099)
* PM-6848 Updated cancellation flow on passkey user verification and improved UV enforcement on creation
* PM-6848 Added null checks to help diagnosing if NRE is presented
* PM-6706 Fixed UV attempts to be maximum 5 attempts and not 6 (#3103)
* PM-6793 Updated autofill settings copy (#3102)
* [PM-6655] Add username empty fallback on passkey (#3101)
* PM-6655 Added fallback "Unknown account" to passkey username and moved it so it can be shared with Android
* PM-6655 Improved code lines formatting
* PM-6844 Fix passkey creation cipher list empty label on small devices (#3104)
* [PM-6798] Fix account switch on autofill (#3106)
* PM-6798 Force state update when opening the Autofill extension
* PM-6798 Fix InitAppIfNeededAsync to be awaited and also ignored Fido2AuthenticatorException from logging them to AppCenter since they don't add much information and we're logging in other places what we need
* PM-6475 Fix dark theme on iOS Autofill extension (#3114)
* PM-6850 Removed duplicate MP Reprompt on passkey creation item selection (#3118)
* PM-6538 Removed non-discoverable passkeys filter for credentials that go to the ASStore (#3117)
* [PM-6655] Add null fallback cipher name on passkeys (#3116)
* PM-6655 Fixed fallback value on passkeys to take into account CipherView.Name. Also removed non-discoverable passkey filter on adding credentials to the ASStore and also added the fallback consideration on the passkeys list iOS extension
* PM-6655 Restored non-discoverable filter on credentials set for ASStore on this PR
* PM-6798 Fix account switch on iOS Autofill extension and also changed to Try... actions for TaskCompletionSource to avoid exceptions on some occasions. (#3121)
Co-authored-by: Álison Fernandes <vvolkgang@users.noreply.github.com>
* PM-6209 Removed MAUI label from environment and about pages (#2990)
* [PM-7186] Fallback to password list on exception (#3127)
* PM-7186 Added fallback in case of exception that loads password list
* PM-7186 Added back the error message removed in last commit.
* feat: add support for `credProps.rk` extension (#3132)
* PM-7186 Remove error message when showing password list as a fallback with user interaction (#3133)
* [PM-5153] Android Passkey Implementation (#3020)
* Initial WIP implementation for the app unlock flow when called from Passkey. Still needs code organization and to be finished.
Also added a new Window workaround in App.xaml.cs to allow CredentialProviderSelectionActivity to launch separately.
* Added missing IDeviceActionService.cs implementation for iOS to build.
* Added Async to ReturnToPasskeyAfterUnlockMethod
Changed i18n to AppResource.Unlock
Removed unecessary cast
* minor code change (added comment)
* Added back the case for loading a specific Window for CredentialProviverSelectionActivity
* Added fix for Intent not passing properly to CredentialProviderSelectionActivity
Added Activity cancellation on error during execution of ReturnToPasskeyAfterUnlockAsync()
* Added WIP code for Android passkey implementation. Currently returns a mostly complete response that is missing the ClientDataJson
* Added WIP code for creating passkeys on Android. Still missing unlock flow and response of passkey creation is still not correct.
Removed unused throw NotImplementedException from Fido2ClientService
Added CredentialCreationActivity for passkey creation
Added alternative code on CredentialProviderSelectionActivity to try to debug issue with response not being valid
* Started working on logic to adding unlock flow. It's already handling the unlock but not passing the PendingIntentHandler info for CredentialCreation to CredentialCreationActivity
* Changed "cross-platform" to "platform"
* Created CredentialHelpers.cs class to share code used for Populating Passkeys in Android.
* Added Passkey Credential Creation shared code to CredentialHelpers.
Unlock flow for Passkey creation should now be working also.
* Updated code for checking if the CredentialProviderService has been enabled by the user or not. Still WIP, somes notes in code due to Credential API not being complete.
Also changed the disable code to open the Credential Settings.
* Replaced the AndroidX.Credential helpers with custom JSON creation to fix the response for Credential Creation
* minor code cleanup on CredentialProviderSelectionActivity
* added todo comment
* Feature/maui migraton passkeys android unlock fix andreas (#3077)
* fix: bitwarden providing too many/wrong credentials
* feat: use authenticator instead of client
---------
Co-authored-by: Dinis Vieira <dinisvieira@outlook.com>
* Removed / commented some older Passkey Proof of concept code.
Auth and creation of passkey should still work both when device is unlocked (and not)
Added some initial code in AutofillCiphersPageViewModel and CipherAddEditPageViewModel for handling Passkey creation
* PM-6829 Implemented Fido2...UserInterfaces on Android and necessary logic to get/make a credential with those
* Added IFido2MediatorService registrations
Inverted two IsLockedAsync checks
* Added navigation to autofillCipher when creating passkey
* Updated LockPage to avoid multiple executions of SubmitAsync
* Added new flow for creating new passkey on Android with the Cipher page for editing details
* Changed the Credential Provider Switch to an external link control
* Added i18n for Passkey Settings
* Cleanup of older Credentials code used for Android Fido2 POC.
Removed CredentialCreationActivity as it's no longer needed
* fixed merge conflict/error and added error check to Fido2 navigation in App.xaml.cs
* Removed from MainActivity casts from DeviceActionService
Changed CredentialProviderServiceActivity to handle Fido errors and exceptions gracefully and show the user an error. Still not with the correct messages.
* Added some error messages. Still need to confirm the Text Resource to use and change.
* Changed some messages to use AppResources
* Cleanup of Credential Android code and added exception result if the clientCreateCredentialResult is null
* Updated Add new item button text when creating a new passkey
* Added AccountSwitchedException for the Fido Mediator Service
* Removed TODO that is no longer needed
* Updated some todo messages in Android AutofillHandler
* When authenticating a passkey on Android the "showDialog" callback can be called and there's no MainPage available so it was changed for that specific scenario to use _deviceActionService instead of MainPage.
---------
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-7369] Show passkey icon on android when the item has a Fido2 credential (#3148)
* PM-7369 Show passkey icon on android when the item has a Fido2 credential
* PM-7369 alternative way to show passkey icon only in scenarios where we are trying to create a passkey
* PM-7369 moved logic to show passkey icon to CipherItemViewModel
* Update src/Core/Utilities/IconGlyphConverter.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* PM-7379 Fix creating the PendingIntent for a passkey credential on Android so it has different request codes amongst each other so the extras are not overriden by the last credential entry created. (#3149)
* PM-7365 Fix setting HasUnlockedInThisTransaction on passkey creation on android (#3153)
* PM-7367 Fix empty items state placeholder on Android cipher selection page (#3160)
* [PM-7366] Select cipher on search on Fido2 creation (#3154)
* PM-7366 Implemented cipher selection on search on passkey creation
* PM-7366 Fix typo
* [PM-7385] Fix for allowing switching accounts while creating a passkey of Android (#3155)
* PM-7385 Fixed for allowing switching accounts while creating a passkey on Android.
This fixes also include scenarios where we need to unlock the vault after switching
Also fixed the issue where tapping on cipher won't do anything after switching.
* PM-7385 ensure the Options.Fido2CredentialAction and FromFido2Framework are reset when the Credential flow is started to avoid erratic behaviors when switching accounts, app is in background or other edge case scenarios.
These properties where replaced by calls to _fido2MakeCredentialConfirmationUserInterface.IsConfirmingNewCredential instead.
* Minor changes and added comments
* [PM-7385] Implemented several changes suggested in PR for better/cleaner code.
* PM-7385 Added several minor code improvemments.
* PM-7385 Fix IFido2MakeCredentialConfirmationUserInterface resolve and usage to be constrained to Android. (#3164)
* PM-7385 Fix unit tests for Fido2 service (#3167)
* PM-7518 Updated favicon placeholder color on iOS Autofill extension. (#3165)
* PM-7365 Fix UserVerification on Fido2 credential creation on Android by updating the HasUnlockedInThisTransaction flag when a new transaction starts. (#3168)
* PM-5154 Avoid logging Fido2AuthenticatorExceptions (#3169)
* PM-7258 Updated Android Credential creation details on description to be localized and passed the user email for further details. (#3162)
* [PM-7257] android add support for web authn resident key credential property in our net mobile app 2 (#3170)
* [PM-7257] feat: add ability to override `clientDataHash`
* [PM-7257] feat: add support for clientDataHash and extensions
* PM-7257 Updated the origin to be the correct one and not the android one to be passed to the Fido2Client
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-7365] Fix UV not being performed on Fido2 credential creation Android (#3171)
* PM-7365 Fix UV not being performed on Fido2 credential creation on Android
* PM-7365 Fix PublicKeyCredentialCreationOptions mapping from json on AuthenticatorSelection so mainly userVerification has correct value
* PM-7585 Show error message when Origin is null, given no support for passkeys from native apps yet (#3175)
* PM-7623 Fix proper implementation of IFido2GetAssertionUserInterface now that the Fido2ClientService is being used for passkey autofill (#3174)
* PM-7553 Fix native apps passkeys autofill and creation (#3188)
* [PM-7658] Implement Fido2 privileged apps verification (#3190)
* PM-7553 Fix native apps passkeys autofill and creation
* PM-7658 Implemented Fido2 priviliged apps verification
* [PM-7576] Implemented digital asset links verification on Fido2 flows (#3191)
* PM-7553 Fix native apps passkeys autofill and creation
* PM-7658 Implemented Fido2 priviliged apps verification
* PM-7576 Implemented digital asset links verification on Fido2 flows for native apps.
* PM-7576 Renamed to ValidateAssetLinksAndGetOriginAsync to go along with Google naming and also changed method to private given that public is not necessary
* PM-7576 Moved digital asset links verification to a Core service AssetLinksService and added unit tests for it.
---------
Co-authored-by: Dinis Vieira <dinisvieira@outlook.com>
Co-authored-by: Vince Grassia <593223+vgrassia@users.noreply.github.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: Álison Fernandes <vvolkgang@users.noreply.github.com>
2024-04-25 22:26:12 +02:00
<data name="BitwardenCredentialProviderGoToSettings" xml:space="preserve">
<value>We were unable to automatically open the Android credential provider settings menu for you. You can navigate to the credential provider settings menu manually from Android Settings > System > Passwords & accounts > Passwords, passkeys and data services.</value>
</data>
2019-04-10 23:01:25 +02:00
<data name="BitwardenAutofillGoToSettings" xml:space="preserve">
<value>We were unable to automatically open the Android autofill settings menu for you. You can navigate to the autofill settings menu manually from Android Settings > System > Languages and input > Advanced > Autofill service.</value>
</data>
<data name="CustomFieldName" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Custom field name</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="FieldTypeBoolean" xml:space="preserve">
<value>Boolean</value>
</data>
<data name="FieldTypeHidden" xml:space="preserve">
<value>Hidden</value>
</data>
2021-11-08 22:34:16 +01:00
<data name="FieldTypeLinked" xml:space="preserve">
<value>Linked</value>
</data>
2019-04-10 23:01:25 +02:00
<data name="FieldTypeText" xml:space="preserve">
<value>Text</value>
</data>
<data name="NewCustomField" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>New custom field</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="SelectTypeField" xml:space="preserve">
<value>What type of custom field do you want to add?</value>
</data>
<data name="Remove" xml:space="preserve">
<value>Remove</value>
</data>
<data name="NewUri" xml:space="preserve">
<value>New URI</value>
</data>
<data name="URIPosition" xml:space="preserve">
<value>URI {0}</value>
<comment>Label for a uri/url with position. i.e. URI 1, URI 2, etc</comment>
</data>
<data name="BaseDomain" xml:space="preserve">
<value>Base domain</value>
</data>
<data name="Default" xml:space="preserve">
<value>Default</value>
</data>
<data name="Exact" xml:space="preserve">
<value>Exact</value>
</data>
<data name="Host" xml:space="preserve">
<value>Host</value>
<comment>A URL's host value. For example, the host of https://sub.domain.com:443 is 'sub.domain.com:443'.</comment>
</data>
<data name="RegEx" xml:space="preserve">
<value>Regular expression</value>
<comment>A programming term, also known as 'RegEx'.</comment>
</data>
<data name="StartsWith" xml:space="preserve">
<value>Starts with</value>
</data>
<data name="URIMatchDetection" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>URI match detection</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="MatchDetection" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Match detection</value>
2019-04-10 23:01:25 +02:00
<comment>URI match detection for auto-fill.</comment>
</data>
<data name="YesAndSave" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Yes, and save</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="AutofillAndSave" xml:space="preserve">
<value>Auto-fill and save</value>
</data>
<data name="Organization" xml:space="preserve">
<value>Organization</value>
<comment>An entity of multiple related people (ex. a team or business organization).</comment>
</data>
<data name="HoldYubikeyNearTop" xml:space="preserve">
<value>Hold your Yubikey near the top of the device.</value>
</data>
<data name="TryAgain" xml:space="preserve">
2019-07-07 03:59:13 +02:00
<value>Try again</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="YubiKeyInstructionIos" xml:space="preserve">
<value>To continue, hold your YubiKey NEO against the back of the device.</value>
</data>
<data name="BitwardenAutofillAccessibilityServiceDescription2" xml:space="preserve">
<value>The accessibility service may be helpful to use when apps do not support the standard auto-fill service.</value>
</data>
<data name="DatePasswordUpdated" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Password updated</value>
2019-04-10 23:01:25 +02:00
<comment>ex. Date this password was updated</comment>
</data>
<data name="DateUpdated" xml:space="preserve">
<value>Updated</value>
<comment>ex. Date this item was updated</comment>
</data>
<data name="AutofillActivated" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>AutoFill activated!</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="MustLogInMainAppAutofill" xml:space="preserve">
<value>You must log into the main Bitwarden app before you can use AutoFill.</value>
</data>
<data name="AutofillSetup" xml:space="preserve">
<value>Your logins are now easily accessible right from your keyboard while logging into apps and websites.</value>
</data>
<data name="AutofillSetup2" xml:space="preserve">
<value>We recommend disabling any other AutoFill apps under Settings if you do not plan to use them.</value>
</data>
<data name="BitwardenAutofillDescription" xml:space="preserve">
<value>Access your vault directly from your keyboard to quickly autofill passwords.</value>
</data>
<data name="AutofillTurnOn" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>To set up password auto-fill on your device, follow these instructions:</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="AutofillTurnOn1" xml:space="preserve">
<value>1. Go to the iOS "Settings" app</value>
</data>
<data name="AutofillTurnOn2" xml:space="preserve">
2022-03-18 21:00:37 +01:00
<value>2. Tap "Passwords"</value>
2019-04-10 23:01:25 +02:00
</data>
<data name="AutofillTurnOn3" xml:space="preserve">
<value>3. Tap "AutoFill Passwords"</value>
</data>
<data name="AutofillTurnOn4" xml:space="preserve">
<value>4. Turn on AutoFill</value>
</data>
<data name="AutofillTurnOn5" xml:space="preserve">
<value>5. Select "Bitwarden"</value>
</data>
<data name="PasswordAutofill" xml:space="preserve">
2022-07-11 08:45:42 +02:00
<value>Password auto-fill</value>
2019-04-10 23:01:25 +02:00
</data>
2019-06-04 05:00:48 +02:00
<data name="BitwardenAutofillAlert2" xml:space="preserve">
2019-06-04 05:01:31 +02:00
<value>The easiest way to add new logins to your vault is by using the Bitwarden Password AutoFill extension. Learn more about using the Bitwarden Password AutoFill extension by navigating to the "Settings" screen.</value>
2019-04-10 23:01:25 +02:00
</data>
2019-04-19 15:42:55 +02:00
<data name="InvalidEmail" xml:space="preserve">
<value>Invalid email address.</value>
</data>
2019-04-24 22:50:34 +02:00
<data name="Cards" xml:space="preserve">
<value>Cards</value>
</data>
<data name="Identities" xml:space="preserve">
<value>Identities</value>
</data>
<data name="Logins" xml:space="preserve">
<value>Logins</value>
</data>
<data name="SecureNotes" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Secure notes</value>
2019-04-24 22:50:34 +02:00
</data>
<data name="AllItems" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>All items</value>
2019-04-24 22:50:34 +02:00
</data>
2019-04-26 22:58:20 +02:00
<data name="URIs" xml:space="preserve">
<value>URIs</value>
<comment>Plural form of a URI</comment>
</data>
2019-04-27 06:19:44 +02:00
<data name="CheckingPassword" xml:space="preserve">
<value>Checking password...</value>
<comment>A loading message when doing an exposed password check.</comment>
</data>
<data name="CheckPassword" xml:space="preserve">
<value>Check if password has been exposed.</value>
</data>
<data name="PasswordExposed" xml:space="preserve">
<value>This password has been exposed {0} time(s) in data breaches. You should change it.</value>
</data>
<data name="PasswordSafe" xml:space="preserve">
<value>This password was not found in any known data breaches. It should be safe to use.</value>
</data>
2019-04-29 16:20:29 +02:00
<data name="IdentityName" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Identity name</value>
2019-04-29 16:20:29 +02:00
</data>
2019-04-29 19:51:05 +02:00
<data name="Value" xml:space="preserve">
<value>Value</value>
</data>
2019-04-30 15:50:35 +02:00
<data name="PasswordHistory" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Password history</value>
2019-04-30 15:50:35 +02:00
</data>
2019-05-01 17:31:00 +02:00
<data name="Types" xml:space="preserve">
<value>Types</value>
</data>
2019-05-02 20:53:45 +02:00
<data name="NoPasswordsToList" xml:space="preserve">
<value>No passwords to list.</value>
</data>
2019-05-07 04:35:42 +02:00
<data name="NoItemsToList" xml:space="preserve">
<value>There are no items to list.</value>
</data>
<data name="SearchCollection" xml:space="preserve">
<value>Search collection</value>
</data>
2022-04-10 19:00:52 +02:00
<data name="SearchFileSends" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Search file Sends</value>
2019-05-07 04:35:42 +02:00
</data>
2022-04-10 19:00:52 +02:00
<data name="SearchTextSends" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Search text Sends</value>
2022-04-10 19:00:52 +02:00
</data>
<data name="SearchGroup" xml:space="preserve">
<value>Search {0}</value>
<comment>ex: Search Logins</comment>
2019-05-07 04:35:42 +02:00
</data>
2019-05-08 20:37:12 +02:00
<data name="Type" xml:space="preserve">
<value>Type</value>
</data>
2019-05-09 05:13:10 +02:00
<data name="MoveDown" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Move down</value>
2019-05-09 05:13:10 +02:00
</data>
<data name="MoveUp" xml:space="preserve">
<value>Move Up</value>
</data>
2019-05-09 18:18:23 +02:00
<data name="Miscellaneous" xml:space="preserve">
<value>Miscellaneous</value>
</data>
2019-05-09 22:55:11 +02:00
<data name="Ownership" xml:space="preserve">
<value>Ownership</value>
</data>
<data name="WhoOwnsThisItem" xml:space="preserve">
<value>Who owns this item?</value>
</data>
<data name="NoCollectionsToList" xml:space="preserve">
<value>There are no collections to list.</value>
</data>
2021-08-04 21:46:28 +02:00
<data name="MovedItemToOrg" xml:space="preserve">
<value>{0} moved to {1}.</value>
<comment>ex: Item moved to Organization.</comment>
</data>
2019-05-10 19:22:35 +02:00
<data name="ItemShared" xml:space="preserve">
<value>Item has been shared.</value>
</data>
<data name="SelectOneCollection" xml:space="preserve">
<value>You must select at least one collection.</value>
</data>
<data name="Share" xml:space="preserve">
<value>Share</value>
</data>
<data name="ShareItem" xml:space="preserve">
<value>Share Item</value>
</data>
2021-08-04 21:46:28 +02:00
<data name="MoveToOrganization" xml:space="preserve">
<value>Move to Organization</value>
</data>
2019-05-10 19:22:35 +02:00
<data name="NoOrgsToList" xml:space="preserve">
<value>No organizations to list.</value>
</data>
2021-08-04 21:46:28 +02:00
<data name="MoveToOrgDesc" xml:space="preserve">
<value>Choose an organization that you wish to move this item to. Moving to an organization transfers ownership of the item to that organization. You will no longer be the direct owner of this item once it has been moved.</value>
2019-05-10 19:22:35 +02:00
</data>
2019-05-13 18:13:23 +02:00
<data name="NumberOfWords" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Number of words</value>
2019-05-13 18:13:23 +02:00
</data>
<data name="Passphrase" xml:space="preserve">
<value>Passphrase</value>
</data>
<data name="WordSeparator" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Word separator</value>
2019-05-13 18:13:23 +02:00
</data>
2019-05-14 15:01:07 +02:00
<data name="Clear" xml:space="preserve">
<value>Clear</value>
<comment>To clear something out. example: To clear browser history.</comment>
</data>
2019-05-14 15:43:46 +02:00
<data name="Generator" xml:space="preserve">
<value>Generator</value>
<comment>Short for "Password Generator"</comment>
</data>
2019-05-14 23:02:24 +02:00
<data name="NoFoldersToList" xml:space="preserve">
<value>There are no folders to list.</value>
</data>
2019-05-15 18:54:48 +02:00
<data name="FingerprintPhrase" xml:space="preserve">
2022-07-11 08:45:42 +02:00
<value>Fingerprint phrase</value>
2019-05-15 18:54:48 +02:00
<comment>A 'fingerprint phrase' is a unique word phrase (similar to a passphrase) that a user can use to authenticate their public key with another user, for the purposes of sharing.</comment>
</data>
<data name="YourAccountsFingerprint" xml:space="preserve">
<value>Your account's fingerprint phrase</value>
<comment>A 'fingerprint phrase' is a unique word phrase (similar to a passphrase) that a user can use to authenticate their public key with another user, for the purposes of sharing.</comment>
</data>
2021-08-04 21:46:28 +02:00
<data name="LearnOrgConfirmation" xml:space="preserve">
<value>Bitwarden allows you to share your vault items with others by using an organization account. Would you like to visit the bitwarden.com website to learn more?</value>
2019-05-15 19:26:55 +02:00
</data>
<data name="ExportVault" xml:space="preserve">
2022-07-11 08:45:42 +02:00
<value>Export vault</value>
2019-05-15 19:26:55 +02:00
</data>
2019-05-15 19:35:17 +02:00
<data name="LockNow" xml:space="preserve">
2022-07-11 08:45:42 +02:00
<value>Lock now</value>
2019-05-15 19:35:17 +02:00
</data>
2019-05-15 23:37:59 +02:00
<data name="PIN" xml:space="preserve">
<value>PIN</value>
</data>
2019-05-16 14:41:57 +02:00
<data name="Unlock" xml:space="preserve">
<value>Unlock</value>
</data>
2021-11-19 23:25:19 +01:00
<data name="UnlockVault" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Unlock vault</value>
2021-11-19 23:25:19 +01:00
</data>
2020-05-29 18:26:36 +02:00
<data name="ThirtyMinutes" xml:space="preserve">
2019-05-16 20:55:18 +02:00
<value>30 minutes</value>
</data>
2019-05-16 21:54:21 +02:00
<data name="SetPINDescription" xml:space="preserve">
<value>Set your PIN code for unlocking Bitwarden. Your PIN settings will be reset if you ever fully log out of the application.</value>
</data>
2019-06-03 15:58:35 +02:00
<data name="LoggedInAsOn" xml:space="preserve">
<value>Logged in as {0} on {1}.</value>
<comment>ex: Logged in as user@example.com on bitwarden.com.</comment>
2019-05-17 16:01:45 +02:00
</data>
<data name="VaultLockedMasterPassword" xml:space="preserve">
<value>Your vault is locked. Verify your master password to continue.</value>
</data>
<data name="VaultLockedPIN" xml:space="preserve">
<value>Your vault is locked. Verify your PIN code to continue.</value>
</data>
2021-11-19 23:25:19 +01:00
<data name="VaultLockedIdentity" xml:space="preserve">
<value>Your vault is locked. Verify your identity to continue.</value>
</data>
2019-05-29 20:11:15 +02:00
<data name="Dark" xml:space="preserve">
<value>Dark</value>
<comment>A dark color</comment>
</data>
<data name="Light" xml:space="preserve">
<value>Light</value>
<comment>A light color</comment>
</data>
<data name="FiveMinutes" xml:space="preserve">
<value>5 minutes</value>
</data>
<data name="TenSeconds" xml:space="preserve">
<value>10 seconds</value>
</data>
<data name="ThirtySeconds" xml:space="preserve">
<value>30 seconds</value>
</data>
<data name="TwentySeconds" xml:space="preserve">
<value>20 seconds</value>
</data>
<data name="TwoMinutes" xml:space="preserve">
<value>2 minutes</value>
</data>
<data name="ClearClipboard" xml:space="preserve">
2022-07-11 08:45:42 +02:00
<value>Clear clipboard</value>
2019-05-29 20:11:15 +02:00
<comment>Clipboard is the operating system thing where you copy/paste data to on your device.</comment>
</data>
<data name="ClearClipboardDescription" xml:space="preserve">
<value>Automatically clear copied values from your clipboard.</value>
<comment>Clipboard is the operating system thing where you copy/paste data to on your device.</comment>
</data>
<data name="DefaultUriMatchDetection" xml:space="preserve">
2022-07-11 08:45:42 +02:00
<value>Default URI match detection</value>
2019-05-29 20:11:15 +02:00
<comment>Default URI match detection for auto-fill.</comment>
</data>
<data name="DefaultUriMatchDetectionDescription" xml:space="preserve">
<value>Choose the default way that URI match detection is handled for logins when performing actions such as auto-fill.</value>
</data>
<data name="Theme" xml:space="preserve">
<value>Theme</value>
<comment>Color theme</comment>
</data>
<data name="ThemeDescription" xml:space="preserve">
<value>Change the application's color theme.</value>
</data>
2021-10-08 14:47:40 +02:00
<data name="ThemeDefault" xml:space="preserve">
<value>Default (System)</value>
2019-05-30 05:02:30 +02:00
</data>
2022-06-21 20:59:30 +02:00
<data name="DefaultDarkTheme" xml:space="preserve">
2022-07-22 10:16:50 +02:00
<value>Default dark theme</value>
2022-06-21 20:59:30 +02:00
</data>
2019-05-30 05:35:34 +02:00
<data name="CopyNotes" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Copy note</value>
2019-05-30 05:35:34 +02:00
</data>
2019-05-30 06:29:00 +02:00
<data name="Exit" xml:space="preserve">
<value>Exit</value>
</data>
<data name="ExitConfirmation" xml:space="preserve">
<value>Are you sure you want to exit Bitwarden?</value>
</data>
2019-05-31 21:30:22 +02:00
<data name="PINRequireMasterPasswordRestart" xml:space="preserve">
2019-06-04 18:18:23 +02:00
<value>Do you want to require unlocking with your master password when the application is restarted?</value>
2019-05-31 21:30:22 +02:00
</data>
2019-06-02 06:08:20 +02:00
<data name="Black" xml:space="preserve">
<value>Black</value>
<comment>The color black</comment>
</data>
2022-06-21 20:59:30 +02:00
<data name="Nord" xml:space="preserve">
<value>Nord</value>
<comment>'Nord' is the name of a specific color scheme. It should not be translated.</comment>
</data>
2022-10-19 11:57:01 +02:00
<data name="SolarizedDark" xml:space="preserve">
<value>Solarized Dark</value>
<comment>'Solarized Dark' is the name of a specific color scheme. It should not be translated.</comment>
</data>
2022-07-26 09:55:16 +02:00
<data name="AutofillBlockedUris" xml:space="preserve">
<value>Auto-fill blocked URIs</value>
2019-06-03 16:45:27 +02:00
</data>
2022-07-11 08:45:42 +02:00
<data name="AskToAddLogin" xml:space="preserve">
<value>Ask to add login</value>
2019-06-03 16:45:27 +02:00
</data>
2022-07-11 08:45:42 +02:00
<data name="AskToAddLoginDescription" xml:space="preserve">
<value>Ask to add an item if one isn't found in your vault.</value>
2019-06-03 16:45:27 +02:00
</data>
2020-05-29 18:26:36 +02:00
<data name="OnRestart" xml:space="preserve">
2022-07-11 08:45:42 +02:00
<value>On app restart</value>
2019-06-03 18:30:26 +02:00
</data>
2019-06-04 16:51:10 +02:00
<data name="AutofillServiceNotEnabled" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Auto-fill makes it easy to securely access your Bitwarden vault from other websites and apps. It looks like you have not set up an auto-fill service for Bitwarden. Set up auto-fill for Bitwarden from the "Settings" screen.</value>
2019-06-04 16:51:10 +02:00
</data>
2019-06-24 23:32:24 +02:00
<data name="ThemeAppliedOnRestart" xml:space="preserve">
<value>Your theme changes will apply when the app is restarted.</value>
</data>
2019-07-01 21:35:26 +02:00
<data name="Capitalize" xml:space="preserve">
<value>Capitalize</value>
<comment>ex. Uppercase the first character of a word.</comment>
</data>
<data name="IncludeNumber" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Include number</value>
2019-07-01 21:35:26 +02:00
</data>
2019-07-22 18:04:17 +02:00
<data name="Download" xml:space="preserve">
<value>Download</value>
</data>
<data name="Shared" xml:space="preserve">
<value>Shared</value>
</data>
<data name="ToggleVisibility" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Toggle visibility</value>
2019-07-22 18:04:17 +02:00
</data>
2019-10-22 22:30:28 +02:00
<data name="LoginExpired" xml:space="preserve">
<value>Your login session has expired.</value>
</data>
2019-10-23 15:24:34 +02:00
<data name="BiometricsDirection" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Biometric verification</value>
2019-10-23 15:11:48 +02:00
</data>
2019-10-23 15:24:34 +02:00
<data name="Biometrics" xml:space="preserve">
<value>Biometrics</value>
</data>
<data name="UseBiometricsToUnlock" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Use biometrics to unlock</value>
2019-10-23 15:24:34 +02:00
</data>
2020-01-09 18:17:16 +01:00
<data name="AccessibilityOverlayPermissionAlert" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Bitwarden needs attention - See "Auto-fill Accessibility Service" from Bitwarden settings</value>
2020-01-10 16:20:19 +01:00
</data>
<data name="BitwardenAutofillServiceOverlayPermission" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>3. On the Android App Settings screen for Bitwarden, go to the "Display over other apps" options (under Advanced) and tap the toggle to allow overlay support.</value>
2020-01-10 16:20:19 +01:00
</data>
<data name="OverlayPermission" xml:space="preserve">
<value>Permission</value>
</data>
<data name="BitwardenAutofillServiceOpenOverlayPermissionSettings" xml:space="preserve">
<value>Open Overlay Permission Settings</value>
</data>
<data name="BitwardenAutofillServiceStep3" xml:space="preserve">
<value>3. On the Android App Settings screen for Bitwarden, select "Display over other apps" (under "Advanced") and switch on the toggle to allow the overlay.</value>
</data>
<data name="Denied" xml:space="preserve">
<value>Denied</value>
</data>
<data name="Granted" xml:space="preserve">
<value>Granted</value>
2020-01-09 18:17:16 +01:00
</data>
2020-02-14 22:10:58 +01:00
<data name="FileFormat" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>File format</value>
2020-02-14 22:10:58 +01:00
</data>
<data name="ExportVaultMasterPasswordDescription" xml:space="preserve">
<value>Enter your master password to export your vault data.</value>
2021-11-11 02:46:48 +01:00
</data>
2021-11-19 15:44:01 +01:00
<data name="SendVerificationCodeToEmail" xml:space="preserve">
<value>Send a verification code to your email</value>
</data>
<data name="CodeSent" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Code sent!</value>
2021-11-19 15:44:01 +01:00
</data>
<data name="ConfirmYourIdentity" xml:space="preserve">
<value>Confirm your identity to continue.</value>
2020-02-14 22:10:58 +01:00
</data>
<data name="ExportVaultWarning" xml:space="preserve">
<value>This export contains your vault data in an unencrypted format. You should not store or send the exported file over unsecure channels (such as email). Delete it immediately after you are done using it.</value>
</data>
2021-03-05 00:33:29 +01:00
<data name="EncExportKeyWarning" xml:space="preserve">
2020-12-14 18:56:13 +01:00
<value>This export encrypts your data using your account's encryption key. If you ever rotate your account's encryption key you should export again since you will not be able to decrypt this export file.</value>
</data>
2021-03-05 00:33:29 +01:00
<data name="EncExportAccountWarning" xml:space="preserve">
<value>Account encryption keys are unique to each Bitwarden user account, so you can't import an encrypted export into a different account.</value>
</data>
2020-12-18 23:47:34 +01:00
<data name="ExportVaultConfirmationTitle" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Confirm vault export</value>
2020-12-18 23:47:34 +01:00
<comment>Title for the alert to confirm vault exports.</comment>
</data>
2020-02-14 22:10:58 +01:00
<data name="Warning" xml:space="preserve">
<value>Warning</value>
</data>
<data name="ExportVaultFailure" xml:space="preserve">
<value>There was a problem exporting your vault. If the problem persists, you'll need to export from the web vault.</value>
</data>
<data name="ExportVaultSuccess" xml:space="preserve">
<value>Vault exported successfully</value>
</data>
2020-02-18 22:48:23 +01:00
<data name="Clone" xml:space="preserve">
<value>Clone</value>
<comment>Clone an entity (verb).</comment>
</data>
2020-02-28 01:53:02 +01:00
<data name="PasswordGeneratorPolicyInEffect" xml:space="preserve">
<value>One or more organization policies are affecting your generator settings</value>
</data>
2020-03-03 04:14:14 +01:00
<data name="Open" xml:space="preserve">
<value>Open</value>
<comment>Button text for an open operation (verb).</comment>
</data>
<data name="UnableToSaveAttachment" xml:space="preserve">
<value>There was a problem saving this attachment. If the problem persists, you can save it from the web vault.</value>
</data>
<data name="SaveAttachmentSuccess" xml:space="preserve">
<value>Attachment saved successfully</value>
</data>
2020-03-26 17:15:33 +01:00
<data name="AutofillTileAccessibilityRequired" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Please turn on "Auto-fill Accessibility Service" from Bitwarden Settings to use the Auto-fill tile.</value>
2020-03-26 17:15:33 +01:00
</data>
<data name="AutofillTileUriNotFound" xml:space="preserve">
<value>No password fields detected</value>
</data>
2020-05-20 19:35:20 +02:00
<data name="SoftDeleting" xml:space="preserve">
<value>Sending to trash...</value>
<comment>Message shown when interacting with the server</comment>
</data>
<data name="ItemSoftDeleted" xml:space="preserve">
<value>Item has been sent to trash.</value>
<comment>Confirmation message after successfully soft-deleting a login</comment>
</data>
<data name="Restore" xml:space="preserve">
<value>Restore</value>
<comment>Restores an entity (verb).</comment>
</data>
<data name="Restoring" xml:space="preserve">
<value>Restoring...</value>
<comment>Message shown when interacting with the server</comment>
</data>
<data name="ItemRestored" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Item restored</value>
2020-05-20 19:35:20 +02:00
<comment>Confirmation message after successfully restoring a soft-deleted item</comment>
</data>
<data name="Trash" xml:space="preserve">
<value>Trash</value>
<comment>(noun) Location of deleted items which have not yet been permanently deleted</comment>
</data>
<data name="SearchTrash" xml:space="preserve">
<value>Search trash</value>
<comment>(action prompt) Label for the search text field when viewing the trash folder</comment>
</data>
<data name="DoYouReallyWantToPermanentlyDeleteCipher" xml:space="preserve">
<value>Do you really want to permanently delete? This cannot be undone.</value>
<comment>Confirmation alert message when permanently deleteing a cipher.</comment>
</data>
<data name="DoYouReallyWantToRestoreCipher" xml:space="preserve">
<value>Do you really want to restore this item?</value>
<comment>Confirmation alert message when restoring a soft-deleted cipher.</comment>
</data>
<data name="DoYouReallyWantToSoftDeleteCipher" xml:space="preserve">
<value>Do you really want to send to the trash?</value>
<comment>Confirmation alert message when soft-deleting a cipher.</comment>
</data>
2023-05-01 15:47:00 +02:00
<data name="AccountBiometricInvalidated" xml:space="preserve">
<value>Biometric unlock for this account is disabled pending verification of master password.</value>
2020-12-01 21:30:23 +01:00
</data>
2023-05-01 15:47:00 +02:00
<data name="AccountBiometricInvalidatedExtension" xml:space="preserve">
<value>Autofill biometric unlock for this account is disabled pending verification of master password.</value>
2020-08-09 03:33:49 +02:00
</data>
2020-08-05 19:19:27 +02:00
<data name="EnableSyncOnRefresh" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Allow sync on refresh</value>
2020-08-05 19:19:27 +02:00
</data>
<data name="EnableSyncOnRefreshDescription" xml:space="preserve">
<value>Syncing vault with pull down gesture.</value>
</data>
2020-09-03 18:30:40 +02:00
<data name="LogInSso" xml:space="preserve">
2022-11-10 19:44:18 +01:00
<value>Enterprise single sign-on</value>
2020-09-03 18:30:40 +02:00
</data>
<data name="LogInSsoSummary" xml:space="preserve">
<value>Quickly log in using your organization's single sign-on portal. Please enter your organization's identifier to begin.</value>
</data>
<data name="OrgIdentifier" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Organization identifier</value>
2020-09-03 18:30:40 +02:00
</data>
<data name="LoginSsoError" xml:space="preserve">
<value>Currently unable to login with SSO</value>
</data>
<data name="SetMasterPassword" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Set master password</value>
2020-09-03 18:30:40 +02:00
</data>
<data name="SetMasterPasswordSummary" xml:space="preserve">
<value>In order to complete logging in with SSO, please set a master password to access and protect your vault.</value>
</data>
<data name="MasterPasswordPolicyInEffect" xml:space="preserve">
<value>One or more organization policies require your master password to meet the following requirements:</value>
</data>
<data name="PolicyInEffectMinComplexity" xml:space="preserve">
<value>Minimum complexity score of {0}</value>
</data>
<data name="PolicyInEffectMinLength" xml:space="preserve">
<value>Minimum length of {0}</value>
</data>
<data name="PolicyInEffectUppercase" xml:space="preserve">
<value>Contain one or more uppercase characters</value>
</data>
<data name="PolicyInEffectLowercase" xml:space="preserve">
<value>Contain one or more lowercase characters</value>
</data>
<data name="PolicyInEffectNumbers" xml:space="preserve">
<value>Contain one or more numbers</value>
</data>
<data name="PolicyInEffectSpecial" xml:space="preserve">
<value>Contain one or more of the following special characters: {0}</value>
</data>
<data name="MasterPasswordPolicyValidationTitle" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Invalid password</value>
2020-09-03 18:30:40 +02:00
</data>
<data name="MasterPasswordPolicyValidationMessage" xml:space="preserve">
<value>Password does not meet organization requirements. Please check the policy information and try again.</value>
</data>
<data name="Loading" xml:space="preserve">
<value>Loading</value>
</data>
2020-11-05 17:50:18 +01:00
<data name="AcceptPolicies" xml:space="preserve">
<value>By activating this switch you agree to the following:
</value>
</data>
<data name="AcceptPoliciesError" xml:space="preserve">
<value>Terms of Service and Privacy Policy have not been acknowledged.</value>
</data>
<data name="TermsOfService" xml:space="preserve">
<value>Terms of Service</value>
</data>
<data name="PrivacyPolicy" xml:space="preserve">
<value>Privacy Policy</value>
</data>
2020-11-17 15:37:57 +01:00
<data name="AccessibilityDrawOverPermissionAlert" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Bitwarden needs attention - Turn on "Draw-Over" in "Auto-fill Services" from Bitwarden Settings</value>
2020-11-17 15:37:57 +01:00
</data>
[PM-5894] Implement Passkey Providers (#3173)
* PM-3349 PM-3350 Added the partial MAUI Community Toolkit implementation for TouchEffect. This is a temporary solution until they finalize this and add it to their nuget package.
This allows implementing the LongPressCommand in AccountSwitchingOverlay and also have the "Ripple effect" animation when touching an item in Android
* PM-3349 PM-3350 Changed SendViewCell and its binding to be directly against the ViewModel
* PM-3350 Fixed iOS Share extension lazy views loading and an issue with the avatar loading. Also discovered issue with TapGestureRecognizer not working on MAUI Embedding
* PM-3350 Fixed iOS Extensions navigation to several pages and improved avoiding duplicate calls to OnNavigatedTo
* PM-3350 Updated PCL Crypto to latest alpha version to fix "Dll not found NCrypt" issue
* PM-3350 Removed workaround for iOS issue with Avatar icon as it's now fixed in latest .Net8 release.
* PM-3349 PM-3350 Removed AsyncCommand "wrapper" and added AsyncRelayCommand directly in all ViewModels that were using the other one.
* PM-3350 Added watchOS app to main project and fixed some csproj conditions for runtime identifiers on iOS.
* PM-3350 Fixed/Updated all MAUI-Migration TODOs
* PM-3350 Fixed account toolbar item and TitleView on SendAddOnlyPage, also removed comments on AvatarImageSource given the workaround is not needed anymore to draw the image successfully.
* PM-3350 Updated AppCenter package to latest version 5.0.3 and updated some things into MAUI style
* PM-3350 Added workaround for iOS Avatar icon again.
* PM-3349 Added workaround for Android to avoid issues with setting MainPage when app is in background. They are now kept on a Queue to be executed after the app has resumed.
Updated some things on App.xaml.cs to the new MAUI style
* PM-3349 PM-3350 Fixed issue where creating an account with weak/exposed password would get stuck after the Captcha (if a captcha is shown)
Changed App.xaml.cs NavigateImpl to be private
* PM-3349 Started to configure build.yml for MAUI Android
* PM-3349 build.yml update paths for MAUI Android
* PM-3349 build.yml commented verify format and just set qa as variant on MAUI Android for faster checks on CI
* PM-3349 PM-3350 build.cake updated paths
* PM-3349 build.yml updated env helpers variables and set specific csproj to build on Android so not to build iOS extensions
* PM-3349 build.yml add Android "prod" variant
* PM-3350 build.yml updated iOS build and ignore Android build to try the CI faster
* PM-3350 build.yml changed nuget restore for dotnet restore on iOS build to fix issue on restoring due to msbuild
* PM-3350 build.yml Upgraded iOS build to run on macos-13 image which has XCode 15, and set the XCode 15 version as currently the default one is 14.x
* PM-3350 build.yml try to fix ILLINK warnings and changed image to be macos-13-arm64 to see if the build is faster
* PM-3350 build.yml changed image back to be macos-13 to see if the build is faster
* PM-3350 Added Document.Build.props to disable trimming on publish
* PM-3350 build.yml disable trimming on publish so it's faster
* PM-3350 added linkskip for iOS csprojs
* PM-3350 iOS projs disable linking and set Newstandkit as weak framework
* Update build.yml disabling iOS job to avoid long running process of publish until we can fix that
* PM-3349 PM-3350 Workaround to fix issues with text getting cropped/truncated when a Label has both Multiline and LinebreakMode set
* PM-3349 build.yml enabled android build workflow
* PM-3349 build.yml configured FDROID job for MAUI
* PM-3350 iOS extensions TapGestureRecognizer try Window workaround
* PM-3350 iOS applied workaround on the iOS Autofill and Share extension to maui embed the navigation page with its content page in the Window
* PM-3349 PM-3350 Added workaround for More Options to work on Search and Groupings Page
Updated some code to MAUI Style also
* PM-3349 PM-3350 Added the ability for users to press "Continue" button as a fallback when using the Yubikey if the "SubmitCommand" doesn't trigger automatically.
* PM-3349 PM-3350 Fix for text getting cut/truncated in both account switcher and ciphers/search lists
Issue is due to MAUI but can be avoided by using slightly different layout
* PM-3350 iOS updated CFBundlerShortVersionString to latest one 2023.10.1
* PM-3350 fix build.yml Bitwarden.ipa AppStore exported file
* PM-3350 build.yml added step to validate app for submitting into App Store and have better logs of it
* PM-3350 build.yml Added several fixes like not using MtouchUseLLVM on the iOS builds to fix they taking forever to build and some changes on the automation CI to do a debug build for the moment
* PM-3350 Improved MTouch linking and extra args on iOS related csprojs
* PM-3349 PM-3350 Added MAUI label on self-host settings and on about settings to differentiate from XF app
* PM-3349 PM-3350 build.yml uncommented jobs so we have a more complete workflow
* PM-3349 PM-3350 Minor change: removed unneeded HorizontalTextAlignment from Label.
* PM-3349 Replaced CrossCurrentActivity plugin with MAUI internal CurrentActivity
* PM-3350 Fix iOS extensions navigation and Window/RootViewController handling for TapGestureRecognizer to work
* PM-3350 Cleared left ClipLogger from the iOS extensions debug logging.
* PM-3349 PM-3350 Refactored cipher bindings to have a simpler approach reusing a new CipherItemViewModel to avoid unwanted issues in the app
* PM-3349 Added base structure for avoiding Android Autofill crash. This workaround works but it's not complete as it can't handle the entire workflow when showing CipherSelectionPAge (like checking if it should show LockPage)
* PM-3350 Bumped iOS version
* PM-3350 Changed linker to use default mode given that "Full" is presenting some problems as the linker is stripping things it shouldn't and we're trying to solve it. So for now we will use the mode "Link SDK assemblies only" so QA can test.
* PM-3349 Fix for app crashing on Android when Dark mode is enabled
Removed unused button style for android
* Proof of concept for having multiple window in Android for autofill support and navigating with the help of an Extended splash page.
* PM-3350 Fix crash on Release by adding Interpreter on iOS and also adding System.Security.Cryptography to be ignored by the linker
* PM-3350 Apply Cryptography TrimmerRootAssembly only to iOS
* PM-3350 Updated Plugin.Fingerprint so biometrics work
* Update .github/workflows/build.yml setup-xcode commit hash
Co-authored-by: Vince Grassia <593223+vgrassia@users.noreply.github.com>
* PM-3349 PM-3350 Enabled argon2id and fixed one issue with the Uris when getting the icon image
* PM-3349 Upgraded Android targetSdkVersion to 34
* minor change (public to private fields)
* minor improvemments on autofill-redirect
* PM-3349 Commented the Deploy step for Android job given that we're using the hotfix-rc branch for testing iOS on TestFlight
* PM-3349 Uncommented the Deploy step for Android job
* PM-3349 Ensure "_isResumed=true" is set on App.xaml.cs:Bootstrap
* Reusing App.xaml.cs Navigation for the Android RedirectPage
Some other cleanup and changes
* Improved autofill workaround to better handle switching between windows.
* PM-3349 minor fix to add space in HomePage between the region picker labels.
* Added some comments and improvemments.
* PM-3349 Added Window events unsubscription of events. Also changed code to avoid potentially having multiple autofillwindow
* PM-3349 Minor ui fix (space between buttons in delete account page)
* initial commit of android credential provider service (wip)
* Revert "initial commit of android credential provider service (wip)"
This reverts commit 6011b639586d081687d22d77352a024272ca6841.
* PM-3350 Fix for Delete Account buttons on iOS
* PM-3349 PM-3350 Changed search icon used in app to avoid issue with icon size on iOS
* PM-3349 Added custom window so that we can always get the current Active Window. This is used to support the Android Autofil and multi-window scenarios.
* PM-3349 Fix for icon and text spacing in some list items
* PM-3349 Minor aligment improvemment for region selection in HomePage
* PM-3349 Changed the "track color" for the Android switch so that the color is different from the "thumb"
* PM-3350 Updated version to 2024.1.0 on iOS
* PM-5154 Start implementing Passkeys Autofill in iOS
* PM-5154 Continue Passkeys Autofill in iOS
* initial commit of android credential provider service (wip)
* add cred manager project to build config
* PM-5154 Added Fido2AuthenticationService to provide us a wrapper for the actual implementation
* PM-3349 Fix Picker selection style by doing a custom PickerHandler for Android which uses SetSingleChoiceItems(...) to provide with the appropriate UI
* PM-3350 Updated MauiVersion to 8.0.4-nightly.* to have the TapGestureRecognizer fix applied. This is done on the Directory.Build.props so we don't have to change it on every csproj. Also removed the workaround of TapGestureHack and fix the Show environment picker to work on the extensions as well.
* PM-3350 Added nuget.config so we add the nuget package source for MAUI Nightly builds
* Bump main iOS version
* PM-3350 Removed "iOS" old folder project that has been moved into the MAUI Single app project.
* PM-3350 Improved code safety adding a lot of try...catch and logging throughout the app. Also made the invoking on main thread safer on several places of the app. Additionally, on the GroupingsPageViewModel changed the code removing the old Xamarin hack and just using Replace directly instead of Clearing first to see if that fixes the crash we're having sometimes on the app.
* PM-3350 PM-3349 Updated Unit Test projects to NET 8.0 and fixed it to work with Core project reference. Also fixed a test that was breaking due to CIpherKey creation being wrong. Added "UT" as a constant to add when building/running Core.Test project so we have something on the context that tells us that is for a UT. With this I had to remove FFImageLoading on UT context because it doesn't support NET 8.0
* PM-3350 PM-3349 Updated Readme with MAUI and main branch
* PM-3350 PM-3349 Enable running Core tests
* PM-3350 Fix build.yml format
* PM-3349 Fix navigation when coming from autofill with Accessibility Services enabled. The user was getting into Home page instead of where they were, with this workaround the app navigates as if the account has been switched, leaving the user as closely as possible to where they were, basically on the first screen for the current state of the user.
* PM-3350 PM-3349 Added property to Directory.Build.props to enable Unit Testing globally so Test runners work
* Improve TOTP scan performance on Android
* Move Android camera/scan changes to xaml
* PM-3350 Testing UseInterpreter false on CI build
* PM-3350 Enabled back UseInterpreter on iOS Release given that it crashes on startup without it.
* PM-3349 PM-3350 Improved code safety with try...catch, better invoke on main thread and better null handling.
* PM-3349 PM-3350 Updated XCode version on build.yml to 15.1
* PM-3350 Removed TapGesture Window MAUI hack from iOS.Extension and iOS.ShareExtension
* PM-3350 Fixed CancellationTokenSource proper disposal
* PM-3350 Fix Avatar toolbar icon on extensions to load properly and to take advantage of using directly SkiaSharp to do the native conversion to UIImage. Also improved the toolbar item so that size is set appropriately.
* PM-3349 PM-3350 Fix external link icon
* PM-3350 Added new style to prevent spell check and text prediction
* Fix merge from main
* PM-3350 Commented event collection upload on the timer and when sending the app to background to see if that prevents the app from crashing on release mode.
* PM-3350 Added check for state migration version before trying to migrate LiteDB values into Prefs when there's no need to and that may be inducing crashes on backgrounded iOS apps.
* PM-3350 Try to disable Interpreter to have better crash knowledge. This time testing if avoiding loading the argon2id lib we're able to not use the interpreter.
* PM-5928 Fix circle animation to be shown on verification codes list on each item
* PM-3350 Go back to use Interpreter and added some Directory.Build.props to easily change Codesign properties and also include/exclude iOS extensions / WatchOS from the build.
* PM-3350 Enabled iOS extensions and WatchOS app to be included based on the Directory.Build.props
* PM-3350 Go back to include argon2id and interpreter
* Removing error/loading placeholders of icons on the cells to see if that is causing the background crash on iOS; so we can test this in TestFlight
* [PM-5910] Workaround for for sliding elements in Duo 2FA flow (#2967)
* workaround for sliding elements in duo 2fa flow
* restrict workaround to Android
* restrict workaround to Android
* Revert "restrict workaround to Android"
This reverts commit c2753d5dc4960aeacdb4c798e7273ca86c08881d.
* Revert "restrict workaround to Android"
This reverts commit 69688cfb98e8e3e17812f126b4fd90ffd2ac3cf8.
* PM-5902 fix for account switcher not dismissing when tapping outside (#2974)
* PM-3350 Fix iossimulator-x64 argon2id load so we can test on simulators and also made easier to maintain loading the argon2id library on the iOS projects by setting a general Directory.Build.props that is shared.
* PM-5903 Changed App.xaml.cs SetOption to only update the needed properties instead of replacing the existing Options object which would cause the AccountSwitcher button bug (#2973)
* [PM-5896] Fix MAUI iOS Background crash due to lock files on suspension (#2969)
* PM-5896 Fix background crash on iOS due to lock files when app gets suspended. Changed loading and error placeholders of the CachedImage to not be used and use default icon of IconLabel instead changing visibility.
* PM-5896 Changed methods to be protected so that they don't get removed by the linker.
* PM-5896 Added stub class and references to it so to have stronger references to Icon_Success and Icon_Error so the linker doesn't remove them.
* PM-3349 Removed commented code from build.yml regarding FDroid that is not needed anymore.
* PM-3349 PM-3350 Fix crash on iOS AppGroup container URL because of sln config on AndroidX Credentials. Changed the project reference of Credentials to be a local NuGet.
* PM-6077 Separated Android and iOS HybridWebViewHandler so that it can be used on iOS.Core (#2983)
* [PM-5907] Fix for incorrect TOTP white text color on label when using light theme on iOS (#2982)
* PM-5907 workaround for incorrect textcolor when programmatically changing text on Entry
* Update src/Core/Pages/Vault/CipherAddEditPage.xaml.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-5906] Fix for incorrect Send MaxAccess white text color on label when using light theme on iOS (#2981)
* PM-5906 workaround for incorrect textcolor when programmatically changing text on Entry
* Update src/Core/Pages/Send/SendAddEditPage.xaml.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* PM-3349 PM-3350 Fixed Unit tests because of referencing FFImageLoading when it's not possible
* PM-3349 Added exception on gitignore so the nupkg for the AndroidX Credentials is added
* [PM-5731] Create C# WebAuthn authenticator to support maui apps (#2951)
* [PM-5731] feat: implement get assertion params object
* [PM-5731] feat: add first test
* [PM-5731] feat: add rp mismatch test
* [PM-5731] feat: ask for credentials when found
* [PM-5731] feat: find discoverable credentials
* [PM-5731] feat: add tests for successful UV requests
* [PM-5731] feat: add user does not consent test
* [PM-5731] feat: check for UV when reprompt is active
* [PM-5731] fix: tests a bit, needed some additional "arrange" steps
* [PM-5731] feat: add support for counter
* [PM-5731] feat: implement assertion without signature
* [PM-5732] feat: finish authenticator assertion implementation
note: CryptoFunctionService still needs Sign implemenation
* [PM-5731] chore: minor clean up
* [PM-5731] feat: scaffold make credential
* [PM-5731] feat: start implementing attestation
* [PM-5731] feat: implement credential exclusion
* [PM-5731] feat: add new credential confirmaiton
* [PM-5731] feat: implement credential creation
* [PM-5731] feat: add user verification checks
* [PM-5731] feat: add unknown error handling
* [PM-5731] chore: clean up unusued params
* [PM-5731] feat: partial attestation implementation
* [PM-5731] feat: implement key generation
* [PM-5731] feat: return public key in DER format
* [PM-5731] feat: implement signing
* [PM-5731] feat: remove logging
* [PM-5731] chore: use primary constructor
* [PM-5731] chore: add Async to method names
* [PM-5731] feat: add support for silent discoverability
* [PM-5731] feat: add support for specifying user presence requirement
* [PM-5731] feat: ensure unlocked vault
* [PM-5731] chore: clean up and refactor assertion tests
* [PM-5731] chore: clean up and refactor attestation tests
* [PM-5731] chore: add user presence todo comment
* [PM-5731] feat: scaffold fido2 client
* PM-5731 Fix build updating discoverable flag
* [PM-5731] fix: failing test
* [PM-5731] feat: add sameOriginWithAncestor and user id length checks
* [PM-5731] feat: add incomplete rpId verification
* [PM-5731] chore: document uri helpers
* [PM-5731] feat: implement fido2 client createCredential
* [PM-5731] feat: implement credential assertion in client
* fix wrong signature format
(cherry picked from commit a1c9ebf01fdcf7c64a0ca2533586b2647cc5cf3e)
* [PM-5731] fix: issues after cherry-pick
* Fix incompatible GUID conversions
(cherry picked from commit c801b2fc3aa4400032bb1bda74c034132cc677f1)
* [PM-5731] chore: remove default constructor
* [PM-5731] feat: refactor user interface to increase flexibility
* [PM-5731] feat: implement generic assertion user interface class
* [PM-5731] feat: remove ability to make user presence optional
* [PM-5731] chore: remove logging comments
* [PM-5731] feat: add native reprompt support to the authenticator
* [PM-5731] feat: allow pre and post UV
* [PM-5731] chore: add `Async` to method name. Remove `I` from struct
* [PM-5731] fix: discoverable string repr lowercase
* [PM-5731] chore: don't use C# 12 features
* [PM-5731] fix: replace magic strings and numbers with contants and enums
* [PM-5731] fix: use UTC creation date
* [PM-5731] fix: formatting
* [PM-5731] chore: use properties for public fields
* [PM-5731] chore: remove TODO
* [PM-5731] fix: IsValidRpId
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
* [PM-5154] Implement Passkeys on iOS (#3017)
* [PM-5731] feat: implement get assertion params object
* [PM-5731] feat: add first test
* [PM-5731] feat: add rp mismatch test
* [PM-5731] feat: ask for credentials when found
* [PM-5731] feat: find discoverable credentials
* [PM-5731] feat: add tests for successful UV requests
* [PM-5731] feat: add user does not consent test
* [PM-5731] feat: check for UV when reprompt is active
* [PM-5731] fix: tests a bit, needed some additional "arrange" steps
* [PM-5731] feat: add support for counter
* [PM-5731] feat: implement assertion without signature
* [PM-5732] feat: finish authenticator assertion implementation
note: CryptoFunctionService still needs Sign implemenation
* [PM-5731] chore: minor clean up
* [PM-5731] feat: scaffold make credential
* [PM-5731] feat: start implementing attestation
* [PM-5731] feat: implement credential exclusion
* [PM-5731] feat: add new credential confirmaiton
* [PM-5731] feat: implement credential creation
* [PM-5731] feat: add user verification checks
* [PM-5731] feat: add unknown error handling
* [PM-5731] chore: clean up unusued params
* [PM-5731] feat: partial attestation implementation
* [PM-5731] feat: implement key generation
* [PM-5731] feat: return public key in DER format
* [PM-5731] feat: implement signing
* [PM-5731] feat: remove logging
* [PM-5731] chore: use primary constructor
* [PM-5731] chore: add Async to method names
* [PM-5731] feat: add support for silent discoverability
* [PM-5731] feat: add support for specifying user presence requirement
* [PM-5731] feat: ensure unlocked vault
* [PM-5731] chore: clean up and refactor assertion tests
* [PM-5731] chore: clean up and refactor attestation tests
* [PM-5731] chore: add user presence todo comment
* [PM-5731] feat: scaffold fido2 client
* PM-5731 Fix build updating discoverable flag
* [PM-5731] fix: failing test
* [PM-5731] feat: add sameOriginWithAncestor and user id length checks
* [PM-5731] feat: add incomplete rpId verification
* [PM-5731] chore: document uri helpers
* [PM-5731] feat: implement fido2 client createCredential
* Added iOS passkeys integration, warning this branch has lots of logs to ease "debugging" extensions.
* [PM-5731] feat: implement credential assertion in client
* PM-5154 Fixed select passkey flow and started implementing create passkey on iOS
* fix wrong signature format
* PM-5154 [Passkeys iOS] Fix Credential ID handling on bytes and string formats. Fix Discoverable to be lowercase on set so it doesn't break parsing on clients. Added UserDisplayName on Fido2 entities. Extracted the Guid Standard/Raw format helpers to a extensions class.
* Fix incompatible GUID conversions
* PM-5154 [Passkeys iOS] Added custom UI flow for passkey creation
* PM-5154 [Passkeys iOS] Updated UI for passkey creation
* PM-5154 [Passkeys iOS] Refactored and added cipher selection for passkey creation on autofill search.
* PM-5154 [Passkeys iOS] Fixed empty top space on autofill password list
---------
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
* feat: optimize assertion network calls (#3021)
The server only needs to be updated if we have changed the counter. New passkeys that leave their counters at zero can therefore skip this step.
* [PM-5154] Implement iOS Passkey -> Add login item (#3019)
* PM-5154 Implement iOS passkey add login
* PM-5154 Added Username to Create new login for passkey, for this the param was changed to the Fido2ConfirmNewCredentialParams object so we have access to the proper values. Also added back RpId to the params to have access to it when creating the vault item. Finally added loading to saving the passkey as new login
* [PM-6513] Omit creating CredentialIdentity if it throws an exception (#3040)
* PM-6513 Omit creating CredentialIdentity if that throws, so it doesn't affect other ciphers. E.g. if a Passkey doesn't have a UserName it will throw here and it shouldn't break replacing all the other identities.
* PM-6513 Added fallback values to passkey username not being set
* Fix FIDO2 client bugs (#3056)
* fix: blockedUris null issue
* fix: trailing slash in origin breaking check
* [PM-6466] Implement passkeys User Verification (#3044)
* PM-6441 Implement passkeys User Verification
* PM-6441 Reorganized UserVerificationMediatorService so everything is not in the same file
* PM-6441 Fix Unit tests
* PM-6441 Refactor UserVerification on Fido2Authenticator and Client services to be of an enum type so we can see which specific preference the RP sent and to be passed into the user verification mediator service to perform the correct flow depending on that. Also updated Unit tests.
* PM-6441 Changed user verification logic a bit so if preference is Preferred and the app has the ability to verify the user then enforce required UV and fix issue on on Discouraged to take into account MP reprompt
* [PM-6474] Remove header on Save passkey as new login (#3054)
* PM-6474 Removed header on empty list view on iOS Autofill create passkey flow
* PM-6474 Fix TableView being hidden on Logins scene
* [PM-6496] Improved iOS extensions cipher cell UI (#3058)
* PM-6496 Improved iOS extensions cipher list to have an updated UI for each cell
* PM-6496 Improved UI on iOS extensions list cells
* [PM-5154] Implement combined view for passwords and passkeys on iOS Autofill extension (#3075)
* PM-5154 Implemented combined view of passwords and passkeys and improved search and items UI
* PM-5154 Code improvement from PR feedback
* PM-5154 Code improvement to log unknown exceptions
* PM-6685 Fix race condition issue where the biometrics check is being done before the iOS extension is being shown. So when we need the UI, we wait until ViewDidAppear happens. (#3078)
* PM-6468 Implemented copy TOTP if needed after using a Fido2 credential. Also added the Fido2MediatorService to have one point to interact with the authentication and also to add any new logic we need. (#3082)
* PM-6706 Add maximum attempts to UV with MP and with PIN (#3079)
* [PM-6848] Improved User verification on passkeys creation (#3099)
* PM-6848 Updated cancellation flow on passkey user verification and improved UV enforcement on creation
* PM-6848 Added null checks to help diagnosing if NRE is presented
* PM-6706 Fixed UV attempts to be maximum 5 attempts and not 6 (#3103)
* PM-6793 Updated autofill settings copy (#3102)
* [PM-6655] Add username empty fallback on passkey (#3101)
* PM-6655 Added fallback "Unknown account" to passkey username and moved it so it can be shared with Android
* PM-6655 Improved code lines formatting
* PM-6844 Fix passkey creation cipher list empty label on small devices (#3104)
* [PM-6798] Fix account switch on autofill (#3106)
* PM-6798 Force state update when opening the Autofill extension
* PM-6798 Fix InitAppIfNeededAsync to be awaited and also ignored Fido2AuthenticatorException from logging them to AppCenter since they don't add much information and we're logging in other places what we need
* PM-6475 Fix dark theme on iOS Autofill extension (#3114)
* PM-6850 Removed duplicate MP Reprompt on passkey creation item selection (#3118)
* PM-6538 Removed non-discoverable passkeys filter for credentials that go to the ASStore (#3117)
* [PM-6655] Add null fallback cipher name on passkeys (#3116)
* PM-6655 Fixed fallback value on passkeys to take into account CipherView.Name. Also removed non-discoverable passkey filter on adding credentials to the ASStore and also added the fallback consideration on the passkeys list iOS extension
* PM-6655 Restored non-discoverable filter on credentials set for ASStore on this PR
* PM-6798 Fix account switch on iOS Autofill extension and also changed to Try... actions for TaskCompletionSource to avoid exceptions on some occasions. (#3121)
Co-authored-by: Álison Fernandes <vvolkgang@users.noreply.github.com>
* PM-6209 Removed MAUI label from environment and about pages (#2990)
* [PM-7186] Fallback to password list on exception (#3127)
* PM-7186 Added fallback in case of exception that loads password list
* PM-7186 Added back the error message removed in last commit.
* feat: add support for `credProps.rk` extension (#3132)
* PM-7186 Remove error message when showing password list as a fallback with user interaction (#3133)
* [PM-5153] Android Passkey Implementation (#3020)
* Initial WIP implementation for the app unlock flow when called from Passkey. Still needs code organization and to be finished.
Also added a new Window workaround in App.xaml.cs to allow CredentialProviderSelectionActivity to launch separately.
* Added missing IDeviceActionService.cs implementation for iOS to build.
* Added Async to ReturnToPasskeyAfterUnlockMethod
Changed i18n to AppResource.Unlock
Removed unecessary cast
* minor code change (added comment)
* Added back the case for loading a specific Window for CredentialProviverSelectionActivity
* Added fix for Intent not passing properly to CredentialProviderSelectionActivity
Added Activity cancellation on error during execution of ReturnToPasskeyAfterUnlockAsync()
* Added WIP code for Android passkey implementation. Currently returns a mostly complete response that is missing the ClientDataJson
* Added WIP code for creating passkeys on Android. Still missing unlock flow and response of passkey creation is still not correct.
Removed unused throw NotImplementedException from Fido2ClientService
Added CredentialCreationActivity for passkey creation
Added alternative code on CredentialProviderSelectionActivity to try to debug issue with response not being valid
* Started working on logic to adding unlock flow. It's already handling the unlock but not passing the PendingIntentHandler info for CredentialCreation to CredentialCreationActivity
* Changed "cross-platform" to "platform"
* Created CredentialHelpers.cs class to share code used for Populating Passkeys in Android.
* Added Passkey Credential Creation shared code to CredentialHelpers.
Unlock flow for Passkey creation should now be working also.
* Updated code for checking if the CredentialProviderService has been enabled by the user or not. Still WIP, somes notes in code due to Credential API not being complete.
Also changed the disable code to open the Credential Settings.
* Replaced the AndroidX.Credential helpers with custom JSON creation to fix the response for Credential Creation
* minor code cleanup on CredentialProviderSelectionActivity
* added todo comment
* Feature/maui migraton passkeys android unlock fix andreas (#3077)
* fix: bitwarden providing too many/wrong credentials
* feat: use authenticator instead of client
---------
Co-authored-by: Dinis Vieira <dinisvieira@outlook.com>
* Removed / commented some older Passkey Proof of concept code.
Auth and creation of passkey should still work both when device is unlocked (and not)
Added some initial code in AutofillCiphersPageViewModel and CipherAddEditPageViewModel for handling Passkey creation
* PM-6829 Implemented Fido2...UserInterfaces on Android and necessary logic to get/make a credential with those
* Added IFido2MediatorService registrations
Inverted two IsLockedAsync checks
* Added navigation to autofillCipher when creating passkey
* Updated LockPage to avoid multiple executions of SubmitAsync
* Added new flow for creating new passkey on Android with the Cipher page for editing details
* Changed the Credential Provider Switch to an external link control
* Added i18n for Passkey Settings
* Cleanup of older Credentials code used for Android Fido2 POC.
Removed CredentialCreationActivity as it's no longer needed
* fixed merge conflict/error and added error check to Fido2 navigation in App.xaml.cs
* Removed from MainActivity casts from DeviceActionService
Changed CredentialProviderServiceActivity to handle Fido errors and exceptions gracefully and show the user an error. Still not with the correct messages.
* Added some error messages. Still need to confirm the Text Resource to use and change.
* Changed some messages to use AppResources
* Cleanup of Credential Android code and added exception result if the clientCreateCredentialResult is null
* Updated Add new item button text when creating a new passkey
* Added AccountSwitchedException for the Fido Mediator Service
* Removed TODO that is no longer needed
* Updated some todo messages in Android AutofillHandler
* When authenticating a passkey on Android the "showDialog" callback can be called and there's no MainPage available so it was changed for that specific scenario to use _deviceActionService instead of MainPage.
---------
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-7369] Show passkey icon on android when the item has a Fido2 credential (#3148)
* PM-7369 Show passkey icon on android when the item has a Fido2 credential
* PM-7369 alternative way to show passkey icon only in scenarios where we are trying to create a passkey
* PM-7369 moved logic to show passkey icon to CipherItemViewModel
* Update src/Core/Utilities/IconGlyphConverter.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* PM-7379 Fix creating the PendingIntent for a passkey credential on Android so it has different request codes amongst each other so the extras are not overriden by the last credential entry created. (#3149)
* PM-7365 Fix setting HasUnlockedInThisTransaction on passkey creation on android (#3153)
* PM-7367 Fix empty items state placeholder on Android cipher selection page (#3160)
* [PM-7366] Select cipher on search on Fido2 creation (#3154)
* PM-7366 Implemented cipher selection on search on passkey creation
* PM-7366 Fix typo
* [PM-7385] Fix for allowing switching accounts while creating a passkey of Android (#3155)
* PM-7385 Fixed for allowing switching accounts while creating a passkey on Android.
This fixes also include scenarios where we need to unlock the vault after switching
Also fixed the issue where tapping on cipher won't do anything after switching.
* PM-7385 ensure the Options.Fido2CredentialAction and FromFido2Framework are reset when the Credential flow is started to avoid erratic behaviors when switching accounts, app is in background or other edge case scenarios.
These properties where replaced by calls to _fido2MakeCredentialConfirmationUserInterface.IsConfirmingNewCredential instead.
* Minor changes and added comments
* [PM-7385] Implemented several changes suggested in PR for better/cleaner code.
* PM-7385 Added several minor code improvemments.
* PM-7385 Fix IFido2MakeCredentialConfirmationUserInterface resolve and usage to be constrained to Android. (#3164)
* PM-7385 Fix unit tests for Fido2 service (#3167)
* PM-7518 Updated favicon placeholder color on iOS Autofill extension. (#3165)
* PM-7365 Fix UserVerification on Fido2 credential creation on Android by updating the HasUnlockedInThisTransaction flag when a new transaction starts. (#3168)
* PM-5154 Avoid logging Fido2AuthenticatorExceptions (#3169)
* PM-7258 Updated Android Credential creation details on description to be localized and passed the user email for further details. (#3162)
* [PM-7257] android add support for web authn resident key credential property in our net mobile app 2 (#3170)
* [PM-7257] feat: add ability to override `clientDataHash`
* [PM-7257] feat: add support for clientDataHash and extensions
* PM-7257 Updated the origin to be the correct one and not the android one to be passed to the Fido2Client
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-7365] Fix UV not being performed on Fido2 credential creation Android (#3171)
* PM-7365 Fix UV not being performed on Fido2 credential creation on Android
* PM-7365 Fix PublicKeyCredentialCreationOptions mapping from json on AuthenticatorSelection so mainly userVerification has correct value
* PM-7585 Show error message when Origin is null, given no support for passkeys from native apps yet (#3175)
* PM-7623 Fix proper implementation of IFido2GetAssertionUserInterface now that the Fido2ClientService is being used for passkey autofill (#3174)
* PM-7553 Fix native apps passkeys autofill and creation (#3188)
* [PM-7658] Implement Fido2 privileged apps verification (#3190)
* PM-7553 Fix native apps passkeys autofill and creation
* PM-7658 Implemented Fido2 priviliged apps verification
* [PM-7576] Implemented digital asset links verification on Fido2 flows (#3191)
* PM-7553 Fix native apps passkeys autofill and creation
* PM-7658 Implemented Fido2 priviliged apps verification
* PM-7576 Implemented digital asset links verification on Fido2 flows for native apps.
* PM-7576 Renamed to ValidateAssetLinksAndGetOriginAsync to go along with Google naming and also changed method to private given that public is not necessary
* PM-7576 Moved digital asset links verification to a Core service AssetLinksService and added unit tests for it.
---------
Co-authored-by: Dinis Vieira <dinisvieira@outlook.com>
Co-authored-by: Vince Grassia <593223+vgrassia@users.noreply.github.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: Álison Fernandes <vvolkgang@users.noreply.github.com>
2024-04-25 22:26:12 +02:00
<data name="PasskeyManagement" xml:space="preserve">
<value>Passkey management</value>
</data>
2020-11-17 15:37:57 +01:00
<data name="AutofillServices" xml:space="preserve">
2022-07-22 10:16:50 +02:00
<value>Auto-fill services</value>
2020-11-17 15:37:57 +01:00
</data>
<data name="InlineAutofill" xml:space="preserve">
2022-07-22 10:16:50 +02:00
<value>Use inline autofill</value>
2020-11-17 15:37:57 +01:00
</data>
<data name="InlineAutofillDescription" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Use inline autofill if your selected IME (keyboard) supports it. If your configuration is not supported (or this option is turned off), the default Autofill overlay will be used.</value>
2020-11-17 15:37:57 +01:00
</data>
<data name="Accessibility" xml:space="preserve">
2022-07-22 10:16:50 +02:00
<value>Use accessibility</value>
2020-11-17 15:37:57 +01:00
</data>
<data name="AccessibilityDescription" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Use the Bitwarden Accessibility Service to auto-fill your logins across apps and the web. When set up, we'll display a popup when login fields are selected.</value>
2020-11-17 15:37:57 +01:00
</data>
<data name="AccessibilityDescription2" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Use the Bitwarden Accessibility Service to auto-fill your logins across apps and the web. (Requires Draw-Over to be turned on as well)</value>
2020-11-17 15:37:57 +01:00
</data>
<data name="AccessibilityDescription3" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Use the Bitwarden Accessibility Service to use the Autofill Quick-Action Tile, and/or show a popup using Draw-Over (if turned on).</value>
2020-11-17 15:37:57 +01:00
</data>
<data name="AccessibilityDescription4" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Required to use the Autofill Quick-Action Tile, or to augment the Autofill Service by using Draw-Over (if turned on).</value>
2020-11-17 15:37:57 +01:00
</data>
<data name="DrawOver" xml:space="preserve">
2022-07-22 10:16:50 +02:00
<value>Use draw-over</value>
2020-11-17 15:37:57 +01:00
</data>
<data name="DrawOverDescription" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Allows the Bitwarden Accessibility Service to display a popup when login fields are selected.</value>
2020-11-17 15:37:57 +01:00
</data>
<data name="DrawOverDescription2" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>If turned on, the Bitwarden Accessibility Service will display a popup when login fields are selected to assist with auto-filling your logins.</value>
2020-11-17 15:37:57 +01:00
</data>
<data name="DrawOverDescription3" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>If turned on, accessibility will show a popup to augment the Autofill Service for older apps that don't support the Android Autofill Framework.</value>
2020-11-17 15:37:57 +01:00
</data>
2020-12-14 15:46:54 +01:00
<data name="PersonalOwnershipSubmitError" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Due to an enterprise policy, you are restricted from saving items to your individual vault. Change the ownership option to an organization and choose from available collections.</value>
2020-12-14 15:46:54 +01:00
</data>
2021-01-07 18:16:34 +01:00
<data name="PersonalOwnershipPolicyInEffect" xml:space="preserve">
<value>An organization policy is affecting your ownership options.</value>
</data>
2021-02-11 01:50:10 +01:00
<data name="Send" xml:space="preserve">
<value>Send</value>
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
<data name="AllSends" xml:space="preserve">
<value>All Sends</value>
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
<data name="Sends" xml:space="preserve">
<value>Sends</value>
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
2021-02-11 20:38:30 +01:00
<data name="NameInfo" xml:space="preserve">
<value>A friendly name to describe this Send.</value>
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
2022-05-25 18:20:51 +02:00
<data name="Text" xml:space="preserve">
<value>Text</value>
</data>
2021-02-11 01:50:10 +01:00
<data name="TypeText" xml:space="preserve">
<value>Text</value>
</data>
2021-02-11 20:38:30 +01:00
<data name="TypeTextInfo" xml:space="preserve">
<value>The text you want to send.</value>
</data>
2021-02-11 01:50:10 +01:00
<data name="HideTextByDefault" xml:space="preserve">
<value>When accessing the Send, hide the text by default</value>
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
<data name="TypeFile" xml:space="preserve">
<value>File</value>
</data>
2021-02-11 20:38:30 +01:00
<data name="TypeFileInfo" xml:space="preserve">
<value>The file you want to send.</value>
</data>
2022-05-25 18:20:51 +02:00
<data name="FileTypeIsSelected" xml:space="preserve">
<value>File type is selected.</value>
</data>
<data name="FileTypeIsNotSelected" xml:space="preserve">
<value>File type is not selected, tap to select.</value>
</data>
<data name="TextTypeIsSelected" xml:space="preserve">
<value>Text type is selected.</value>
</data>
<data name="TextTypeIsNotSelected" xml:space="preserve">
<value>Text type is not selected, tap to select.</value>
</data>
2021-02-11 01:50:10 +01:00
<data name="DeletionDate" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Deletion date</value>
2021-02-11 01:50:10 +01:00
</data>
<data name="DeletionTime" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Deletion time</value>
2021-02-11 01:50:10 +01:00
</data>
<data name="DeletionDateInfo" xml:space="preserve">
<value>The Send will be permanently deleted on the specified date and time.</value>
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
<data name="PendingDelete" xml:space="preserve">
<value>Pending deletion</value>
</data>
<data name="ExpirationDate" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Expiration date</value>
2021-02-11 01:50:10 +01:00
</data>
<data name="ExpirationTime" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Expiration time</value>
2021-02-11 01:50:10 +01:00
</data>
<data name="ExpirationDateInfo" xml:space="preserve">
<value>If set, access to this Send will expire on the specified date and time.</value>
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
<data name="Expired" xml:space="preserve">
<value>Expired</value>
</data>
<data name="MaximumAccessCount" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Maximum access count</value>
2021-02-11 01:50:10 +01:00
</data>
<data name="MaximumAccessCountInfo" xml:space="preserve">
2021-07-02 18:20:40 +02:00
<value>If set, users will no longer be able to access this Send once the maximum access count is reached.</value>
2021-02-11 01:50:10 +01:00
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
<data name="MaximumAccessCountReached" xml:space="preserve">
<value>Max access count reached</value>
</data>
<data name="CurrentAccessCount" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Current access count</value>
2021-02-11 01:50:10 +01:00
</data>
<data name="NewPassword" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>New password</value>
2021-02-11 01:50:10 +01:00
</data>
<data name="PasswordInfo" xml:space="preserve">
<value>Optionally require a password for users to access this Send.</value>
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
<data name="RemovePassword" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Remove password</value>
2021-02-11 01:50:10 +01:00
</data>
<data name="AreYouSureRemoveSendPassword" xml:space="preserve">
<value>Are you sure you want to remove the password?</value>
</data>
<data name="RemovingSendPassword" xml:space="preserve">
<value>Removing password</value>
</data>
<data name="SendPasswordRemoved" xml:space="preserve">
<value>Password has been removed.</value>
</data>
<data name="NotesInfo" xml:space="preserve">
<value>Private notes about this Send.</value>
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
<data name="DisableSend" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Deactivate this Send so that no one can access it</value>
2021-02-11 01:50:10 +01:00
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
<data name="NoSends" xml:space="preserve">
2021-03-12 02:52:35 +01:00
<value>There are no Sends in your account.</value>
2021-02-11 01:50:10 +01:00
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
2021-05-13 20:36:20 +02:00
<data name="AddASend" xml:space="preserve">
<value>Add a Send</value>
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
2021-02-11 01:50:10 +01:00
<data name="CopyLink" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Copy link</value>
2021-02-11 01:50:10 +01:00
</data>
<data name="ShareLink" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Share link</value>
2021-02-11 01:50:10 +01:00
</data>
2021-02-18 22:58:20 +01:00
<data name="SendLink" xml:space="preserve">
<value>Send link</value>
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
2021-02-11 01:50:10 +01:00
<data name="SearchSends" xml:space="preserve">
2021-02-18 22:58:20 +01:00
<value>Search Sends</value>
2021-02-11 01:50:10 +01:00
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
<data name="EditSend" xml:space="preserve">
<value>Edit Send</value>
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
<data name="AddSend" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>New Send</value>
2021-02-11 01:50:10 +01:00
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
<data name="AreYouSureDeleteSend" xml:space="preserve">
<value>Are you sure you want to delete this Send?</value>
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
<data name="SendDeleted" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Send deleted</value>
2021-02-11 01:50:10 +01:00
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
<data name="SendUpdated" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Send saved</value>
2021-02-11 01:50:10 +01:00
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
<data name="NewSendCreated" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Send created</value>
2021-02-11 01:50:10 +01:00
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
<data name="OneDay" xml:space="preserve">
<value>1 day</value>
</data>
<data name="TwoDays" xml:space="preserve">
<value>2 days</value>
</data>
<data name="ThreeDays" xml:space="preserve">
<value>3 days</value>
</data>
<data name="SevenDays" xml:space="preserve">
<value>7 days</value>
</data>
<data name="ThirtyDays" xml:space="preserve">
<value>30 days</value>
</data>
<data name="Custom" xml:space="preserve">
<value>Custom</value>
</data>
<data name="ShareOnSave" xml:space="preserve">
2022-02-02 20:07:58 +01:00
<value>Share this Send upon save</value>
2021-02-11 01:50:10 +01:00
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
2021-02-18 22:58:20 +01:00
<data name="SendDisabledWarning" xml:space="preserve">
<value>Due to an enterprise policy, you are only able to delete an existing Send.</value>
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
2021-03-06 00:57:57 +01:00
<data name="AboutSend" xml:space="preserve">
<value>About Send</value>
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
2021-03-29 18:01:42 +02:00
<data name="HideEmail" xml:space="preserve">
2022-02-02 20:07:58 +01:00
<value>Hide my email address from recipients</value>
2021-03-29 18:01:42 +02:00
</data>
<data name="SendOptionsPolicyInEffect" xml:space="preserve">
<value>One or more organization policies are affecting your Send options.</value>
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
2021-03-31 16:19:05 +02:00
<data name="SendFilePremiumRequired" xml:space="preserve">
<value>Free accounts are restricted to sharing text only. A premium membership is required to use files with Send.</value>
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
2021-04-07 22:42:00 +02:00
<data name="SendFileEmailVerificationRequired" xml:space="preserve">
2021-05-11 23:52:18 +02:00
<value>You must verify your email to use files with Send. You can verify your email in the web vault.</value>
2021-04-07 22:42:00 +02:00
<comment>'Send' is a noun and the name of a feature called 'Bitwarden Send'. It should not be translated.</comment>
</data>
2021-05-21 15:13:54 +02:00
<data name="PasswordPrompt" xml:space="preserve">
<value>Master password re-prompt</value>
</data>
<data name="PasswordConfirmation" xml:space="preserve">
<value>Master password confirmation</value>
</data>
<data name="PasswordConfirmationDesc" xml:space="preserve">
<value>This action is protected, to continue please re-enter your master password to verify your identity.</value>
</data>
2021-08-04 21:47:23 +02:00
<data name="CaptchaRequired" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Captcha required</value>
2021-08-04 21:47:23 +02:00
</data>
<data name="CaptchaFailed" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Captcha failed. Please try again.</value>
2021-08-04 21:47:23 +02:00
</data>
2021-09-24 20:14:26 +02:00
<data name="UpdatedMasterPassword" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Updated master password</value>
2021-09-24 20:14:26 +02:00
</data>
<data name="UpdateMasterPassword" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Update master password</value>
2021-09-24 20:14:26 +02:00
</data>
<data name="UpdateMasterPasswordWarning" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Your master password was recently changed by an administrator in your organization. In order to access the vault, you must update your master password now. Proceeding will log you out of your current session, requiring you to log back in. Active sessions on other devices may continue to remain active for up to one hour.</value>
2021-09-24 20:14:26 +02:00
</data>
<data name="UpdatingPassword" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Updating password</value>
2021-09-24 20:14:26 +02:00
</data>
<data name="UpdatePasswordError" xml:space="preserve">
<value>Currently unable to update password</value>
</data>
2021-11-11 02:46:48 +01:00
<data name="RemoveMasterPassword" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Remove master password</value>
2021-11-11 02:46:48 +01:00
</data>
<data name="RemoveMasterPasswordWarning" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>{0} is using SSO with customer-managed encryption. Continuing will remove your master password from your account and require SSO to login.</value>
2021-11-11 02:46:48 +01:00
</data>
<data name="RemoveMasterPasswordWarning2" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>If you do not want to remove your master password, you may leave this organization.</value>
2021-11-11 02:46:48 +01:00
</data>
<data name="LeaveOrganization" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Leave organization</value>
2021-11-11 02:46:48 +01:00
</data>
<data name="LeaveOrganizationName" xml:space="preserve">
<value>Leave {0}?</value>
</data>
2021-08-30 18:44:12 +02:00
<data name="Fido2Title" xml:space="preserve">
<value>FIDO2 WebAuthn</value>
</data>
<data name="Fido2Instruction" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>To continue, have your FIDO2 WebAuthn compatible security key ready, then follow the instructions after clicking 'Authenticate WebAuthn' on the next screen.</value>
2021-08-30 18:44:12 +02:00
</data>
<data name="Fido2Desc" xml:space="preserve">
<value>Authentication using FIDO2 WebAuthn, you can authenticate using an external security key.</value>
</data>
<data name="Fido2AuthenticateWebAuthn" xml:space="preserve">
<value>Authenticate WebAuthn</value>
</data>
2021-10-14 17:53:41 +02:00
<data name="Fido2ReturnToApp" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Return to app</value>
2021-10-14 17:53:41 +02:00
</data>
2021-09-09 16:04:49 +02:00
<data name="Fido2CheckBrowser" xml:space="preserve">
<value>Please make sure your default browser supports WebAuthn and try again.</value>
2021-08-30 18:44:12 +02:00
</data>
2021-09-08 19:43:24 +02:00
<data name="ResetPasswordAutoEnrollInviteWarning" xml:space="preserve">
<value>This organization has an enterprise policy that will automatically enroll you in password reset. Enrollment will allow organization administrators to change your master password.</value>
</data>
2021-09-23 15:42:38 +02:00
<data name="VaultTimeoutPolicyInEffect" xml:space="preserve">
2023-04-14 21:39:57 +02:00
<value>Your organization policies have set your maximum allowed vault timeout to {0} hour(s) and {1} minute(s).</value>
</data>
<data name="VaultTimeoutPolicyWithActionInEffect" xml:space="preserve">
<value>Your organization policies are affecting your vault timeout. Maximum allowed vault timeout is {0} hour(s) and {1} minute(s). Your vault timeout action is set to {2}.</value>
</data>
<data name="VaultTimeoutActionPolicyInEffect" xml:space="preserve">
<value>Your organization policies have set your vault timeout action to {0}.</value>
2021-09-23 15:42:38 +02:00
</data>
<data name="VaultTimeoutToLarge" xml:space="preserve">
<value>Your vault timeout exceeds the restrictions set by your organization.</value>
</data>
2023-02-16 19:15:40 +01:00
<data name="DisablePersonalVaultExportPolicyInEffect" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>One or more organization policies prevents your from exporting your individual vault.</value>
2021-09-23 18:30:20 +02:00
</data>
2022-02-23 18:40:17 +01:00
<data name="AddAccount" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Add account</value>
2022-02-23 18:40:17 +01:00
</data>
<data name="AccountUnlocked" xml:space="preserve">
<value>Unlocked</value>
</data>
<data name="AccountLocked" xml:space="preserve">
<value>Locked</value>
</data>
<data name="AccountLoggedOut" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Logged out</value>
2022-02-23 18:40:17 +01:00
</data>
<data name="AccountSwitchedAutomatically" xml:space="preserve">
<value>Switched to next available account</value>
</data>
2022-03-07 18:28:06 +01:00
<data name="AccountLockedSuccessfully" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Account locked</value>
2022-03-07 18:28:06 +01:00
</data>
<data name="AccountLoggedOutSuccessfully" xml:space="preserve">
<value>Account logged out successfully</value>
</data>
<data name="AccountRemovedSuccessfully" xml:space="preserve">
<value>Account removed successfully</value>
</data>
2021-11-24 20:09:39 +01:00
<data name="DeleteAccount" xml:space="preserve">
2022-07-11 08:45:42 +02:00
<value>Delete account</value>
2021-11-24 20:09:39 +01:00
</data>
<data name="DeletingYourAccountIsPermanent" xml:space="preserve">
<value>Deleting your account is permanent</value>
</data>
<data name="DeleteAccountExplanation" xml:space="preserve">
2022-07-08 10:28:23 +02:00
<value>Your account and all vault data will be erased and unrecoverable. Are you sure you want to continue?</value>
2021-11-24 20:09:39 +01:00
</data>
<data name="DeletingYourAccount" xml:space="preserve">
<value>Deleting your account</value>
</data>
<data name="YourAccountHasBeenPermanentlyDeleted" xml:space="preserve">
<value>Your account has been permanently deleted</value>
</data>
2021-11-11 02:46:48 +01:00
<data name="InvalidVerificationCode" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Invalid verification code</value>
2021-11-11 02:46:48 +01:00
</data>
2022-01-25 21:41:56 +01:00
<data name="RequestOTP" xml:space="preserve">
<value>Request one-time password</value>
</data>
2021-11-19 15:44:01 +01:00
<data name="SendCode" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Send code</value>
2021-11-19 15:44:01 +01:00
</data>
<data name="Sending" xml:space="preserve">
<value>Sending</value>
2021-11-11 02:46:48 +01:00
</data>
2022-01-25 21:41:56 +01:00
<data name="CopySendLinkOnSave" xml:space="preserve">
<value>Copy Send link on save</value>
</data>
2022-01-24 17:25:46 +01:00
<data name="SendingCode" xml:space="preserve">
<value>Sending code</value>
</data>
<data name="Verifying" xml:space="preserve">
<value>Verifying</value>
</data>
<data name="ResendCode" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Resend code</value>
2022-01-24 17:25:46 +01:00
</data>
<data name="AVerificationCodeWasSentToYourEmail" xml:space="preserve">
<value>A verification code was sent to your email</value>
</data>
<data name="AnErrorOccurredWhileSendingAVerificationCodeToYourEmailPleaseTryAgain" xml:space="preserve">
<value>An error occurred while sending a verification code to your email. Please try again</value>
</data>
<data name="EnterTheVerificationCodeThatWasSentToYourEmail" xml:space="preserve">
<value>Enter the verification code that was sent to your email</value>
</data>
2022-06-08 02:47:44 +02:00
<data name="SubmitCrashLogs" xml:space="preserve">
<value>Submit crash logs</value>
2022-05-18 18:59:19 +02:00
</data>
2022-06-08 02:47:44 +02:00
<data name="SubmitCrashLogsDescription" xml:space="preserve">
<value>Help Bitwarden improve app stability by submitting crash reports.</value>
2022-05-18 18:59:19 +02:00
</data>
2022-05-27 15:52:19 +02:00
<data name="OptionsExpanded" xml:space="preserve">
<value>Options are expanded, tap to collapse.</value>
</data>
<data name="OptionsCollapsed" xml:space="preserve">
<value>Options are collapsed, tap to expand.</value>
</data>
2022-05-25 18:25:21 +02:00
<data name="UppercaseAtoZ" xml:space="preserve">
<value>Uppercase (A to Z)</value>
</data>
<data name="LowercaseAtoZ" xml:space="preserve">
<value>Lowercase (A to Z)</value>
</data>
<data name="NumbersZeroToNine" xml:space="preserve">
<value>Numbers (0 to 9)</value>
</data>
<data name="SpecialCharacters" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Special characters (!@#$%^&*)</value>
2022-05-25 18:25:21 +02:00
</data>
2022-06-01 21:50:19 +02:00
<data name="TapToGoBack" xml:space="preserve">
<value>Tap to go back</value>
</data>
2022-06-01 17:02:28 +02:00
<data name="PasswordIsVisibleTapToHide" xml:space="preserve">
<value>Password is visible, tap to hide.</value>
</data>
<data name="PasswordIsNotVisibleTapToShow" xml:space="preserve">
<value>Password is not visible, tap to show.</value>
</data>
2022-05-31 19:34:54 +02:00
<data name="FilterByVault" xml:space="preserve">
<value>Filter items by vault</value>
</data>
<data name="AllVaults" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>All vaults</value>
2022-05-31 19:34:54 +02:00
</data>
<data name="Vaults" xml:space="preserve">
<value>Vaults</value>
</data>
<data name="VaultFilterDescription" xml:space="preserve">
<value>Vault: {0}</value>
</data>
<data name="All" xml:space="preserve">
<value>All</value>
</data>
2022-08-17 23:10:16 +02:00
<data name="Totp" xml:space="preserve">
<value>TOTP</value>
</data>
<data name="VerificationCodes" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Verification codes</value>
2022-08-17 23:10:16 +02:00
</data>
<data name="PremiumSubscriptionRequired" xml:space="preserve">
<value>Premium subscription required</value>
</data>
<data name="CannotAddAuthenticatorKey" xml:space="preserve">
<value>Cannot add authenticator key? </value>
</data>
<data name="ScanQRCode" xml:space="preserve">
<value>Scan QR Code</value>
</data>
<data name="CannotScanQRCode" xml:space="preserve">
<value>Cannot scan QR Code? </value>
</data>
<data name="AuthenticatorKeyScanner" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Authenticator key</value>
2022-08-17 23:10:16 +02:00
</data>
<data name="EnterKeyManually" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Enter key manually</value>
2022-08-17 23:10:16 +02:00
</data>
<data name="AddTotp" xml:space="preserve">
<value>Add TOTP</value>
</data>
<data name="SetupTotp" xml:space="preserve">
<value>Set up TOTP</value>
</data>
<data name="OnceTheKeyIsSuccessfullyEntered" xml:space="preserve">
<value>Once the key is successfully entered,
select Add TOTP to store the key safely</value>
</data>
2022-07-07 17:35:58 +02:00
<data name="NeverLockWarning" xml:space="preserve">
<value>Setting your lock options to “Never” keeps your vault available to anyone with access to your device. If you use this option, you should ensure that you keep your device properly protected.</value>
</data>
2022-07-11 19:02:11 +02:00
<data name="EnvironmentPageUrlsError" xml:space="preserve">
<value>One or more of the URLs entered are invalid. Please revise it and try to save again.</value>
</data>
<data name="GenericErrorMessage" xml:space="preserve">
<value>We were unable to process your request. Please try again or contact us.</value>
</data>
2022-07-15 17:13:10 +02:00
<data name="AllowScreenCapture" xml:space="preserve">
2022-07-22 10:16:50 +02:00
<value>Allow screen capture</value>
2022-07-15 17:13:10 +02:00
</data>
<data name="AreYouSureYouWantToEnableScreenCapture" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Are you sure you want to turn on screen capture?</value>
2022-07-15 17:13:10 +02:00
</data>
2022-09-26 19:27:57 +02:00
<data name="LogInRequested" xml:space="preserve">
<value>Login requested</value>
</data>
<data name="AreYouTryingToLogIn" xml:space="preserve">
<value>Are you trying to log in?</value>
</data>
<data name="LogInAttemptByXOnY" xml:space="preserve">
<value>Login attempt by {0} on {1}</value>
</data>
<data name="DeviceType" xml:space="preserve">
<value>Device type</value>
</data>
<data name="IpAddress" xml:space="preserve">
<value>IP address</value>
</data>
<data name="Time" xml:space="preserve">
<value>Time</value>
</data>
<data name="Near" xml:space="preserve">
<value>Near</value>
</data>
<data name="ConfirmLogIn" xml:space="preserve">
<value>Confirm login</value>
</data>
<data name="DenyLogIn" xml:space="preserve">
<value>Deny login</value>
</data>
<data name="JustNow" xml:space="preserve">
<value>Just now</value>
</data>
<data name="XMinutesAgo" xml:space="preserve">
<value>{0} minutes ago</value>
</data>
<data name="LogInAccepted" xml:space="preserve">
<value>Login confirmed</value>
</data>
<data name="LogInDenied" xml:space="preserve">
<value>Login denied</value>
</data>
<data name="ApproveLoginRequests" xml:space="preserve">
<value>Approve login requests</value>
</data>
<data name="UseThisDeviceToApproveLoginRequestsMadeFromOtherDevices" xml:space="preserve">
2023-09-27 21:26:12 +02:00
<value>Use this device to approve login requests made from other devices</value>
2022-09-26 19:27:57 +02:00
</data>
<data name="AllowNotifications" xml:space="preserve">
<value>Allow notifications</value>
</data>
<data name="ReceivePushNotificationsForNewLoginRequests" xml:space="preserve">
<value>Receive push notifications for new login requests</value>
</data>
<data name="NoThanks" xml:space="preserve">
<value>No thanks</value>
</data>
<data name="ConfimLogInAttempForX" xml:space="preserve">
<value>Confirm login attempt for {0}</value>
</data>
<data name="AllNotifications" xml:space="preserve">
<value>All notifications</value>
</data>
2022-08-26 20:32:02 +02:00
<data name="PasswordType" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Password type</value>
2022-08-26 20:32:02 +02:00
</data>
<data name="WhatWouldYouLikeToGenerate" xml:space="preserve">
<value>What would you like to generate?</value>
</data>
<data name="UsernameType" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Username type</value>
2022-08-26 20:32:02 +02:00
</data>
<data name="PlusAddressedEmail" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Plus addressed email</value>
2022-08-26 20:32:02 +02:00
</data>
<data name="CatchAllEmail" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Catch-all email</value>
2022-08-26 20:32:02 +02:00
</data>
<data name="ForwardedEmailAlias" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Forwarded email alias</value>
2022-08-26 20:32:02 +02:00
</data>
<data name="RandomWord" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Random word</value>
2022-08-26 20:32:02 +02:00
</data>
<data name="EmailRequiredParenthesis" xml:space="preserve">
<value>Email (required)</value>
</data>
<data name="DomainNameRequiredParenthesis" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Domain name (required)</value>
2022-08-26 20:32:02 +02:00
</data>
<data name="APIKeyRequiredParenthesis" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>API key (required)</value>
2022-08-26 20:32:02 +02:00
</data>
<data name="Service" xml:space="preserve">
<value>Service</value>
</data>
2023-09-08 16:23:51 +02:00
<data name="AddyIo" xml:space="preserve">
<value>addy.io</value>
<comment>"addy.io" is the product name and should not be translated.</comment>
2022-08-26 20:32:02 +02:00
</data>
<data name="FirefoxRelay" xml:space="preserve">
<value>Firefox Relay</value>
<comment>"Firefox Relay" is the product name and should not be translated.</comment>
</data>
<data name="SimpleLogin" xml:space="preserve">
<value>SimpleLogin</value>
<comment>"SimpleLogin" is the product name and should not be translated.</comment>
</data>
2023-01-26 14:53:48 +01:00
<data name="DuckDuckGo" xml:space="preserve">
<value>DuckDuckGo</value>
<comment>"DuckDuckGo" is the product name and should not be translated.</comment>
</data>
<data name="Fastmail" xml:space="preserve">
<value>Fastmail</value>
<comment>"Fastmail" is the product name and should not be translated.</comment>
</data>
2023-10-26 14:58:07 +02:00
<data name="ForwardEmail" xml:space="preserve">
<value>ForwardEmail</value>
<comment>"ForwardEmail" is the product name and should not be translated.</comment>
</data>
2022-08-26 20:32:02 +02:00
<data name="APIAccessToken" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>API access token</value>
2022-08-26 20:32:02 +02:00
</data>
<data name="AreYouSureYouWantToOverwriteTheCurrentUsername" xml:space="preserve">
<value>Are you sure you want to overwrite the current username?</value>
</data>
<data name="GenerateUsername" xml:space="preserve">
2022-10-13 21:31:03 +02:00
<value>Generate username</value>
2022-08-26 20:32:02 +02:00
</data>
<data name="EmailType" xml:space="preserve">
<value>Email Type</value>
</data>
<data name="WebsiteRequired" xml:space="preserve">
<value>Website (required)</value>
</data>
<data name="UnknownXErrorMessage" xml:space="preserve">
<value>Unknown {0} error occurred.</value>
</data>
<data name="PlusAddressedEmailDescription" xml:space="preserve">
<value>Use your email provider's subaddress capabilities</value>
</data>
<data name="CatchAllEmailDescription" xml:space="preserve">
<value>Use your domain's configured catch-all inbox.</value>
</data>
<data name="ForwardedEmailDescription" xml:space="preserve">
<value>Generate an email alias with an external forwarding service.</value>
</data>
<data name="Random" xml:space="preserve">
<value>Random</value>
</data>
2022-12-07 17:39:20 +01:00
<data name="ConnectToWatch" xml:space="preserve">
<value>Connect to Watch</value>
</data>
2022-09-27 20:03:06 +02:00
<data name="AccessibilityServiceDisclosure" xml:space="preserve">
<value>Accessibility Service Disclosure</value>
</data>
<data name="AccessibilityDisclosureText" xml:space="preserve">
<value>Bitwarden uses the Accessibility Service to search for login fields in apps and websites, then establish the appropriate field IDs for entering a username & password when a match for the app or site is found. We do not store any of the information presented to us by the service, nor do we make any attempt to control any on-screen elements beyond text entry of credentials.</value>
</data>
<data name="Accept" xml:space="preserve">
<value>Accept</value>
</data>
<data name="Decline" xml:space="preserve">
<value>Decline</value>
</data>
2022-09-30 21:44:56 +02:00
<data name="LoginRequestHasAlreadyExpired" xml:space="preserve">
<value>Login request has already expired.</value>
</data>
2022-10-18 18:21:45 +02:00
<data name="LoginAttemptFromXDoYouWantToSwitchToThisAccount" xml:space="preserve">
<value>Login attempt from:
{0}
Do you want to switch to this account?</value>
</data>
2022-10-29 00:10:41 +02:00
<data name="NewAroundHere" xml:space="preserve">
<value>New around here?</value>
</data>
<data name="GetMasterPasswordwordHint" xml:space="preserve">
<value>Get master password hint</value>
</data>
2023-05-19 13:42:41 +02:00
<data name="LoggingInAsXOnY" xml:space="preserve">
<value>Logging in as {0} on {1}</value>
2022-10-29 00:10:41 +02:00
</data>
<data name="NotYou" xml:space="preserve">
<value>Not you?</value>
</data>
<data name="LogInWithMasterPassword" xml:space="preserve">
2022-11-10 19:44:18 +01:00
<value>Log in with master password</value>
2022-10-29 00:10:41 +02:00
</data>
<data name="LogInWithAnotherDevice" xml:space="preserve">
2023-02-09 21:13:50 +01:00
<value>Log in with device</value>
2022-10-29 00:10:41 +02:00
</data>
2022-11-09 17:25:48 +01:00
<data name="LogInInitiated" xml:space="preserve">
2023-08-17 21:19:35 +02:00
<value>Login initiated</value>
2022-11-09 17:25:48 +01:00
</data>
<data name="ANotificationHasBeenSentToYourDevice" xml:space="preserve">
<value>A notification has been sent to your device.</value>
</data>
<data name="PleaseMakeSureYourVaultIsUnlockedAndTheFingerprintPhraseMatchesOnTheOtherDevice" xml:space="preserve">
<value>Please make sure your vault is unlocked and the Fingerprint phrase matches on the other device.</value>
</data>
<data name="ResendNotification" xml:space="preserve">
<value>Resend notification</value>
</data>
<data name="NeedAnotherOption" xml:space="preserve">
<value>Need another option?</value>
</data>
<data name="ViewAllLoginOptions" xml:space="preserve">
<value>View all log in options</value>
</data>
2022-11-15 15:17:26 +01:00
<data name="ThisRequestIsNoLongerValid" xml:space="preserve">
<value>This request is no longer valid</value>
</data>
2023-02-01 13:22:17 +01:00
<data name="PendingLogInRequests" xml:space="preserve">
<value>Pending login requests</value>
</data>
<data name="DeclineAllRequests" xml:space="preserve">
<value>Decline all requests</value>
</data>
<data name="AreYouSureYouWantToDeclineAllPendingLogInRequests" xml:space="preserve">
<value>Are you sure you want to decline all pending login requests?</value>
</data>
<data name="RequestsDeclined" xml:space="preserve">
<value>Requests declined</value>
</data>
<data name="NoPendingRequests" xml:space="preserve">
<value>No pending requests</value>
</data>
2022-12-06 17:30:46 +01:00
<data name="EnableCamerPermissionToUseTheScanner" xml:space="preserve">
<value>Enable camera permission to use the scanner</value>
</data>
2023-03-01 17:28:28 +01:00
<data name="Language" xml:space="preserve">
<value>Language</value>
</data>
<data name="LanguageChangeXDescription" xml:space="preserve">
<value>The language has been changed to {0}. Please restart the app to see the change</value>
</data>
<data name="LanguageChangeRequiresAppRestart" xml:space="preserve">
<value>Language change requires app restart</value>
</data>
<data name="DefaultSystem" xml:space="preserve">
<value>Default (System)</value>
</data>
2023-01-20 14:38:31 +01:00
<data name="Important" xml:space="preserve">
<value>Important</value>
</data>
<data name="YourMasterPasswordCannotBeRecoveredIfYouForgetItXCharactersMinimum" xml:space="preserve">
<value>Your master password cannot be recovered if you forget it! {0} characters minimum.</value>
</data>
<data name="WeakMasterPassword" xml:space="preserve">
<value>Weak Master Password</value>
</data>
<data name="WeakPasswordIdentifiedUseAStrongPasswordToProtectYourAccount" xml:space="preserve">
<value>Weak password identified. Use a strong password to protect your account. Are you sure you want to use a weak password?</value>
</data>
<data name="Weak" xml:space="preserve">
<value>Weak</value>
</data>
<data name="Good" xml:space="preserve">
<value>Good</value>
</data>
<data name="Strong" xml:space="preserve">
<value>Strong</value>
</data>
<data name="CheckKnownDataBreachesForThisPassword" xml:space="preserve">
<value>Check known data breaches for this password</value>
</data>
<data name="ExposedMasterPassword" xml:space="preserve">
<value>Exposed Master Password</value>
</data>
<data name="PasswordFoundInADataBreachAlertDescription" xml:space="preserve">
<value>Password found in a data breach. Use a unique password to protect your account. Are you sure you want to use an exposed password?</value>
</data>
<data name="WeakAndExposedMasterPassword" xml:space="preserve">
<value>Weak and Exposed Master Password</value>
</data>
<data name="WeakPasswordIdentifiedAndFoundInADataBreachAlertDescription" xml:space="preserve">
<value>Weak password identified and found in a data breach. Use a strong and unique password to protect your account. Are you sure you want to use this password?</value>
</data>
2023-02-20 15:49:20 +01:00
<data name="OrganizationSsoIdentifierRequired" xml:space="preserve">
<value>Organization SSO identifier required.</value>
</data>
2023-03-09 15:16:48 +01:00
<data name="AddTheKeyToAnExistingOrNewItem" xml:space="preserve">
<value>Add the key to an existing or new item</value>
</data>
<data name="ThereAreNoItemsInYourVaultThatMatchX" xml:space="preserve">
<value>There are no items in your vault that match "{0}"</value>
</data>
<data name="SearchForAnItemOrAddANewItem" xml:space="preserve">
<value>Search for an item or add a new item</value>
</data>
<data name="ThereAreNoItemsThatMatchTheSearch" xml:space="preserve">
<value>There are no items that match the search</value>
</data>
2023-05-19 13:42:41 +02:00
<data name="US" xml:space="preserve">
<value>US</value>
</data>
<data name="EU" xml:space="preserve">
<value>EU</value>
</data>
<data name="SelfHosted" xml:space="preserve">
<value>Self-hosted</value>
</data>
<data name="DataRegion" xml:space="preserve">
<value>Data region</value>
</data>
<data name="Region" xml:space="preserve">
<value>Region</value>
</data>
2023-04-17 16:35:50 +02:00
<data name="UpdateWeakMasterPasswordWarning" xml:space="preserve">
<value>Your master password does not meet one or more of your organization policies. In order to access the vault, you must update your master password now. Proceeding will log you out of your current session, requiring you to log back in. Active sessions on other devices may continue to remain active for up to one hour.</value>
</data>
<data name="CurrentMasterPassword" xml:space="preserve">
<value>Current master password</value>
</data>
2023-08-17 21:19:35 +02:00
<data name="LoggedIn" xml:space="preserve">
<value>Logged in!</value>
</data>
<data name="ApproveWithMyOtherDevice" xml:space="preserve">
<value>Approve with my other device</value>
</data>
<data name="RequestAdminApproval" xml:space="preserve">
<value>Request admin approval</value>
</data>
<data name="ApproveWithMasterPassword" xml:space="preserve">
<value>Approve with master password</value>
</data>
<data name="TurnOffUsingPublicDevice" xml:space="preserve">
<value>Turn off using a public device</value>
</data>
<data name="RememberThisDevice" xml:space="preserve">
<value>Remember this device</value>
</data>
2023-07-26 22:59:49 +02:00
<data name="Passkey" xml:space="preserve">
<value>Passkey</value>
</data>
<data name="Passkeys" xml:space="preserve">
<value>Passkeys</value>
</data>
<data name="Application" xml:space="preserve">
<value>Application</value>
</data>
<data name="YouCannotEditPasskeyApplicationBecauseItWouldInvalidateThePasskey" xml:space="preserve">
<value>You cannot edit passkey application because it would invalidate the passkey</value>
</data>
<data name="PasskeyWillNotBeCopied" xml:space="preserve">
<value>Passkey will not be copied</value>
</data>
<data name="ThePasskeyWillNotBeCopiedToTheClonedItemDoYouWantToContinueCloningThisItem" xml:space="preserve">
<value>The passkey will not be copied to the cloned item. Do you want to continue cloning this item?</value>
</data>
<data name="CopyApplication" xml:space="preserve">
<value>Copy application</value>
</data>
<data name="AvailableForTwoStepLogin" xml:space="preserve">
<value>Available for two-step login</value>
</data>
2023-06-05 18:58:38 +02:00
<data name="MasterPasswordRePromptHelp" xml:space="preserve">
<value>Master password re-prompt help</value>
</data>
2023-06-07 16:21:51 +02:00
<data name="UnlockingMayFailDueToInsufficientMemoryDecreaseYourKDFMemorySettingsToResolve" xml:space="preserve">
2023-08-07 16:41:40 +02:00
<value>Unlocking may fail due to insufficient memory. Decrease your KDF memory settings or set up biometric unlock to resolve.</value>
2023-06-07 16:21:51 +02:00
</data>
2023-06-27 23:49:38 +02:00
<data name="InvalidAPIKey" xml:space="preserve">
<value>Invalid API key</value>
</data>
<data name="InvalidAPIToken" xml:space="preserve">
<value>Invalid API token</value>
</data>
2023-08-17 21:19:35 +02:00
<data name="AdminApprovalRequested" xml:space="preserve">
<value>Admin approval requested</value>
</data>
<data name="YourRequestHasBeenSentToYourAdmin" xml:space="preserve">
<value>Your request has been sent to your admin.</value>
</data>
<data name="YouWillBeNotifiedOnceApproved" xml:space="preserve">
<value>You will be notified once approved. </value>
</data>
<data name="TroubleLoggingIn" xml:space="preserve">
<value>Trouble logging in?</value>
</data>
<data name="LoggingInAsX" xml:space="preserve">
<value>Logging in as {0}</value>
</data>
<data name="VaultTimeoutActionChangedToLogOut" xml:space="preserve">
<value>Vault timeout action changed to log out</value>
</data>
2023-07-18 16:25:38 +02:00
<data name="BlockAutoFill" xml:space="preserve">
<value>Block auto-fill</value>
</data>
<data name="AutoFillWillNotBeOfferedForTheseURIs" xml:space="preserve">
<value>Auto-fill will not be offered for these URIs.</value>
</data>
<data name="NewBlockedURI" xml:space="preserve">
<value>New blocked URI</value>
</data>
<data name="URISaved" xml:space="preserve">
<value>URI saved</value>
</data>
<data name="InvalidFormatUseHttpsHttpOrAndroidApp" xml:space="preserve">
<value>Invalid format. Use https://, http://, or androidapp://</value>
<comment>https://, http://, androidapp:// should not be translated</comment>
</data>
<data name="EditURI" xml:space="preserve">
<value>Edit URI</value>
</data>
<data name="EnterURI" xml:space="preserve">
<value>Enter URI</value>
</data>
<data name="FormatXSeparateMultipleURIsWithAComma" xml:space="preserve">
<value>Format: {0}. Separate multiple URIs with a comma.</value>
</data>
<data name="FormatX" xml:space="preserve">
<value>Format: {0}</value>
</data>
<data name="InvalidURI" xml:space="preserve">
<value>Invalid URI</value>
</data>
<data name="URIRemoved" xml:space="preserve">
<value>URI removed</value>
</data>
<data name="ThereAreNoBlockedURIs" xml:space="preserve">
<value>There are no blocked URIs</value>
</data>
<data name="TheURIXIsAlreadyBlocked" xml:space="preserve">
<value>The URI {0} is already blocked</value>
</data>
<data name="CannotEditMultipleURIsAtOnce" xml:space="preserve">
<value>Cannot edit multiple URIs at once</value>
</data>
2023-08-17 21:19:35 +02:00
<data name="LoginApproved" xml:space="preserve">
<value>Login approved</value>
</data>
<data name="LogInWithDeviceMustBeSetUpInTheSettingsOfTheBitwardenAppNeedAnotherOption" xml:space="preserve">
<value>Log in with device must be set up in the settings of the Bitwarden app. Need another option?</value>
</data>
<data name="LogInWithDevice" xml:space="preserve">
<value>Log in with device</value>
</data>
2023-08-04 16:44:39 +02:00
<data name="LoggingInOn" xml:space="preserve">
<value>Logging in on</value>
</data>
2023-09-27 21:26:12 +02:00
<data name="Vault" xml:space="preserve">
<value>Vault</value>
</data>
<data name="Appearance" xml:space="preserve">
<value>Appearance</value>
</data>
<data name="AccountSecurity" xml:space="preserve">
<value>Account security</value>
</data>
<data name="BitwardenHelpCenter" xml:space="preserve">
<value>Bitwarden Help Center</value>
</data>
<data name="ContactBitwardenSupport" xml:space="preserve">
<value>Contact Bitwarden support</value>
</data>
<data name="CopyAppInformation" xml:space="preserve">
<value>Copy app information</value>
</data>
<data name="SyncNow" xml:space="preserve">
<value>Sync now</value>
</data>
<data name="UnlockOptions" xml:space="preserve">
<value>Unlock options</value>
</data>
<data name="SessionTimeout" xml:space="preserve">
<value>Session timeout</value>
</data>
<data name="SessionTimeoutAction" xml:space="preserve">
<value>Session timeout action</value>
</data>
<data name="AccountFingerprintPhrase" xml:space="preserve">
<value>Account fingerprint phrase</value>
<comment>A 'fingerprint phrase' is a unique word phrase (similar to a passphrase) that a user can use to authenticate their public key with another user, for the purposes of sharing.</comment>
</data>
<data name="OneHourAndOneMinute" xml:space="preserve">
<value>One hour and one minute</value>
</data>
<data name="OneHourAndXMinute" xml:space="preserve">
<value>One hour and {0} minutes</value>
</data>
<data name="XHoursAndOneMinute" xml:space="preserve">
<value>{0} hours and one minute</value>
</data>
<data name="XHoursAndYMinutes" xml:space="preserve">
<value>{0} hours and {1} minutes</value>
</data>
<data name="XHours" xml:space="preserve">
<value>{0} hours</value>
</data>
[PM-5894] Implement Passkey Providers (#3173)
* PM-3349 PM-3350 Added the partial MAUI Community Toolkit implementation for TouchEffect. This is a temporary solution until they finalize this and add it to their nuget package.
This allows implementing the LongPressCommand in AccountSwitchingOverlay and also have the "Ripple effect" animation when touching an item in Android
* PM-3349 PM-3350 Changed SendViewCell and its binding to be directly against the ViewModel
* PM-3350 Fixed iOS Share extension lazy views loading and an issue with the avatar loading. Also discovered issue with TapGestureRecognizer not working on MAUI Embedding
* PM-3350 Fixed iOS Extensions navigation to several pages and improved avoiding duplicate calls to OnNavigatedTo
* PM-3350 Updated PCL Crypto to latest alpha version to fix "Dll not found NCrypt" issue
* PM-3350 Removed workaround for iOS issue with Avatar icon as it's now fixed in latest .Net8 release.
* PM-3349 PM-3350 Removed AsyncCommand "wrapper" and added AsyncRelayCommand directly in all ViewModels that were using the other one.
* PM-3350 Added watchOS app to main project and fixed some csproj conditions for runtime identifiers on iOS.
* PM-3350 Fixed/Updated all MAUI-Migration TODOs
* PM-3350 Fixed account toolbar item and TitleView on SendAddOnlyPage, also removed comments on AvatarImageSource given the workaround is not needed anymore to draw the image successfully.
* PM-3350 Updated AppCenter package to latest version 5.0.3 and updated some things into MAUI style
* PM-3350 Added workaround for iOS Avatar icon again.
* PM-3349 Added workaround for Android to avoid issues with setting MainPage when app is in background. They are now kept on a Queue to be executed after the app has resumed.
Updated some things on App.xaml.cs to the new MAUI style
* PM-3349 PM-3350 Fixed issue where creating an account with weak/exposed password would get stuck after the Captcha (if a captcha is shown)
Changed App.xaml.cs NavigateImpl to be private
* PM-3349 Started to configure build.yml for MAUI Android
* PM-3349 build.yml update paths for MAUI Android
* PM-3349 build.yml commented verify format and just set qa as variant on MAUI Android for faster checks on CI
* PM-3349 PM-3350 build.cake updated paths
* PM-3349 build.yml updated env helpers variables and set specific csproj to build on Android so not to build iOS extensions
* PM-3349 build.yml add Android "prod" variant
* PM-3350 build.yml updated iOS build and ignore Android build to try the CI faster
* PM-3350 build.yml changed nuget restore for dotnet restore on iOS build to fix issue on restoring due to msbuild
* PM-3350 build.yml Upgraded iOS build to run on macos-13 image which has XCode 15, and set the XCode 15 version as currently the default one is 14.x
* PM-3350 build.yml try to fix ILLINK warnings and changed image to be macos-13-arm64 to see if the build is faster
* PM-3350 build.yml changed image back to be macos-13 to see if the build is faster
* PM-3350 Added Document.Build.props to disable trimming on publish
* PM-3350 build.yml disable trimming on publish so it's faster
* PM-3350 added linkskip for iOS csprojs
* PM-3350 iOS projs disable linking and set Newstandkit as weak framework
* Update build.yml disabling iOS job to avoid long running process of publish until we can fix that
* PM-3349 PM-3350 Workaround to fix issues with text getting cropped/truncated when a Label has both Multiline and LinebreakMode set
* PM-3349 build.yml enabled android build workflow
* PM-3349 build.yml configured FDROID job for MAUI
* PM-3350 iOS extensions TapGestureRecognizer try Window workaround
* PM-3350 iOS applied workaround on the iOS Autofill and Share extension to maui embed the navigation page with its content page in the Window
* PM-3349 PM-3350 Added workaround for More Options to work on Search and Groupings Page
Updated some code to MAUI Style also
* PM-3349 PM-3350 Added the ability for users to press "Continue" button as a fallback when using the Yubikey if the "SubmitCommand" doesn't trigger automatically.
* PM-3349 PM-3350 Fix for text getting cut/truncated in both account switcher and ciphers/search lists
Issue is due to MAUI but can be avoided by using slightly different layout
* PM-3350 iOS updated CFBundlerShortVersionString to latest one 2023.10.1
* PM-3350 fix build.yml Bitwarden.ipa AppStore exported file
* PM-3350 build.yml added step to validate app for submitting into App Store and have better logs of it
* PM-3350 build.yml Added several fixes like not using MtouchUseLLVM on the iOS builds to fix they taking forever to build and some changes on the automation CI to do a debug build for the moment
* PM-3350 Improved MTouch linking and extra args on iOS related csprojs
* PM-3349 PM-3350 Added MAUI label on self-host settings and on about settings to differentiate from XF app
* PM-3349 PM-3350 build.yml uncommented jobs so we have a more complete workflow
* PM-3349 PM-3350 Minor change: removed unneeded HorizontalTextAlignment from Label.
* PM-3349 Replaced CrossCurrentActivity plugin with MAUI internal CurrentActivity
* PM-3350 Fix iOS extensions navigation and Window/RootViewController handling for TapGestureRecognizer to work
* PM-3350 Cleared left ClipLogger from the iOS extensions debug logging.
* PM-3349 PM-3350 Refactored cipher bindings to have a simpler approach reusing a new CipherItemViewModel to avoid unwanted issues in the app
* PM-3349 Added base structure for avoiding Android Autofill crash. This workaround works but it's not complete as it can't handle the entire workflow when showing CipherSelectionPAge (like checking if it should show LockPage)
* PM-3350 Bumped iOS version
* PM-3350 Changed linker to use default mode given that "Full" is presenting some problems as the linker is stripping things it shouldn't and we're trying to solve it. So for now we will use the mode "Link SDK assemblies only" so QA can test.
* PM-3349 Fix for app crashing on Android when Dark mode is enabled
Removed unused button style for android
* Proof of concept for having multiple window in Android for autofill support and navigating with the help of an Extended splash page.
* PM-3350 Fix crash on Release by adding Interpreter on iOS and also adding System.Security.Cryptography to be ignored by the linker
* PM-3350 Apply Cryptography TrimmerRootAssembly only to iOS
* PM-3350 Updated Plugin.Fingerprint so biometrics work
* Update .github/workflows/build.yml setup-xcode commit hash
Co-authored-by: Vince Grassia <593223+vgrassia@users.noreply.github.com>
* PM-3349 PM-3350 Enabled argon2id and fixed one issue with the Uris when getting the icon image
* PM-3349 Upgraded Android targetSdkVersion to 34
* minor change (public to private fields)
* minor improvemments on autofill-redirect
* PM-3349 Commented the Deploy step for Android job given that we're using the hotfix-rc branch for testing iOS on TestFlight
* PM-3349 Uncommented the Deploy step for Android job
* PM-3349 Ensure "_isResumed=true" is set on App.xaml.cs:Bootstrap
* Reusing App.xaml.cs Navigation for the Android RedirectPage
Some other cleanup and changes
* Improved autofill workaround to better handle switching between windows.
* PM-3349 minor fix to add space in HomePage between the region picker labels.
* Added some comments and improvemments.
* PM-3349 Added Window events unsubscription of events. Also changed code to avoid potentially having multiple autofillwindow
* PM-3349 Minor ui fix (space between buttons in delete account page)
* initial commit of android credential provider service (wip)
* Revert "initial commit of android credential provider service (wip)"
This reverts commit 6011b639586d081687d22d77352a024272ca6841.
* PM-3350 Fix for Delete Account buttons on iOS
* PM-3349 PM-3350 Changed search icon used in app to avoid issue with icon size on iOS
* PM-3349 Added custom window so that we can always get the current Active Window. This is used to support the Android Autofil and multi-window scenarios.
* PM-3349 Fix for icon and text spacing in some list items
* PM-3349 Minor aligment improvemment for region selection in HomePage
* PM-3349 Changed the "track color" for the Android switch so that the color is different from the "thumb"
* PM-3350 Updated version to 2024.1.0 on iOS
* PM-5154 Start implementing Passkeys Autofill in iOS
* PM-5154 Continue Passkeys Autofill in iOS
* initial commit of android credential provider service (wip)
* add cred manager project to build config
* PM-5154 Added Fido2AuthenticationService to provide us a wrapper for the actual implementation
* PM-3349 Fix Picker selection style by doing a custom PickerHandler for Android which uses SetSingleChoiceItems(...) to provide with the appropriate UI
* PM-3350 Updated MauiVersion to 8.0.4-nightly.* to have the TapGestureRecognizer fix applied. This is done on the Directory.Build.props so we don't have to change it on every csproj. Also removed the workaround of TapGestureHack and fix the Show environment picker to work on the extensions as well.
* PM-3350 Added nuget.config so we add the nuget package source for MAUI Nightly builds
* Bump main iOS version
* PM-3350 Removed "iOS" old folder project that has been moved into the MAUI Single app project.
* PM-3350 Improved code safety adding a lot of try...catch and logging throughout the app. Also made the invoking on main thread safer on several places of the app. Additionally, on the GroupingsPageViewModel changed the code removing the old Xamarin hack and just using Replace directly instead of Clearing first to see if that fixes the crash we're having sometimes on the app.
* PM-3350 PM-3349 Updated Unit Test projects to NET 8.0 and fixed it to work with Core project reference. Also fixed a test that was breaking due to CIpherKey creation being wrong. Added "UT" as a constant to add when building/running Core.Test project so we have something on the context that tells us that is for a UT. With this I had to remove FFImageLoading on UT context because it doesn't support NET 8.0
* PM-3350 PM-3349 Updated Readme with MAUI and main branch
* PM-3350 PM-3349 Enable running Core tests
* PM-3350 Fix build.yml format
* PM-3349 Fix navigation when coming from autofill with Accessibility Services enabled. The user was getting into Home page instead of where they were, with this workaround the app navigates as if the account has been switched, leaving the user as closely as possible to where they were, basically on the first screen for the current state of the user.
* PM-3350 PM-3349 Added property to Directory.Build.props to enable Unit Testing globally so Test runners work
* Improve TOTP scan performance on Android
* Move Android camera/scan changes to xaml
* PM-3350 Testing UseInterpreter false on CI build
* PM-3350 Enabled back UseInterpreter on iOS Release given that it crashes on startup without it.
* PM-3349 PM-3350 Improved code safety with try...catch, better invoke on main thread and better null handling.
* PM-3349 PM-3350 Updated XCode version on build.yml to 15.1
* PM-3350 Removed TapGesture Window MAUI hack from iOS.Extension and iOS.ShareExtension
* PM-3350 Fixed CancellationTokenSource proper disposal
* PM-3350 Fix Avatar toolbar icon on extensions to load properly and to take advantage of using directly SkiaSharp to do the native conversion to UIImage. Also improved the toolbar item so that size is set appropriately.
* PM-3349 PM-3350 Fix external link icon
* PM-3350 Added new style to prevent spell check and text prediction
* Fix merge from main
* PM-3350 Commented event collection upload on the timer and when sending the app to background to see if that prevents the app from crashing on release mode.
* PM-3350 Added check for state migration version before trying to migrate LiteDB values into Prefs when there's no need to and that may be inducing crashes on backgrounded iOS apps.
* PM-3350 Try to disable Interpreter to have better crash knowledge. This time testing if avoiding loading the argon2id lib we're able to not use the interpreter.
* PM-5928 Fix circle animation to be shown on verification codes list on each item
* PM-3350 Go back to use Interpreter and added some Directory.Build.props to easily change Codesign properties and also include/exclude iOS extensions / WatchOS from the build.
* PM-3350 Enabled iOS extensions and WatchOS app to be included based on the Directory.Build.props
* PM-3350 Go back to include argon2id and interpreter
* Removing error/loading placeholders of icons on the cells to see if that is causing the background crash on iOS; so we can test this in TestFlight
* [PM-5910] Workaround for for sliding elements in Duo 2FA flow (#2967)
* workaround for sliding elements in duo 2fa flow
* restrict workaround to Android
* restrict workaround to Android
* Revert "restrict workaround to Android"
This reverts commit c2753d5dc4960aeacdb4c798e7273ca86c08881d.
* Revert "restrict workaround to Android"
This reverts commit 69688cfb98e8e3e17812f126b4fd90ffd2ac3cf8.
* PM-5902 fix for account switcher not dismissing when tapping outside (#2974)
* PM-3350 Fix iossimulator-x64 argon2id load so we can test on simulators and also made easier to maintain loading the argon2id library on the iOS projects by setting a general Directory.Build.props that is shared.
* PM-5903 Changed App.xaml.cs SetOption to only update the needed properties instead of replacing the existing Options object which would cause the AccountSwitcher button bug (#2973)
* [PM-5896] Fix MAUI iOS Background crash due to lock files on suspension (#2969)
* PM-5896 Fix background crash on iOS due to lock files when app gets suspended. Changed loading and error placeholders of the CachedImage to not be used and use default icon of IconLabel instead changing visibility.
* PM-5896 Changed methods to be protected so that they don't get removed by the linker.
* PM-5896 Added stub class and references to it so to have stronger references to Icon_Success and Icon_Error so the linker doesn't remove them.
* PM-3349 Removed commented code from build.yml regarding FDroid that is not needed anymore.
* PM-3349 PM-3350 Fix crash on iOS AppGroup container URL because of sln config on AndroidX Credentials. Changed the project reference of Credentials to be a local NuGet.
* PM-6077 Separated Android and iOS HybridWebViewHandler so that it can be used on iOS.Core (#2983)
* [PM-5907] Fix for incorrect TOTP white text color on label when using light theme on iOS (#2982)
* PM-5907 workaround for incorrect textcolor when programmatically changing text on Entry
* Update src/Core/Pages/Vault/CipherAddEditPage.xaml.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-5906] Fix for incorrect Send MaxAccess white text color on label when using light theme on iOS (#2981)
* PM-5906 workaround for incorrect textcolor when programmatically changing text on Entry
* Update src/Core/Pages/Send/SendAddEditPage.xaml.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* PM-3349 PM-3350 Fixed Unit tests because of referencing FFImageLoading when it's not possible
* PM-3349 Added exception on gitignore so the nupkg for the AndroidX Credentials is added
* [PM-5731] Create C# WebAuthn authenticator to support maui apps (#2951)
* [PM-5731] feat: implement get assertion params object
* [PM-5731] feat: add first test
* [PM-5731] feat: add rp mismatch test
* [PM-5731] feat: ask for credentials when found
* [PM-5731] feat: find discoverable credentials
* [PM-5731] feat: add tests for successful UV requests
* [PM-5731] feat: add user does not consent test
* [PM-5731] feat: check for UV when reprompt is active
* [PM-5731] fix: tests a bit, needed some additional "arrange" steps
* [PM-5731] feat: add support for counter
* [PM-5731] feat: implement assertion without signature
* [PM-5732] feat: finish authenticator assertion implementation
note: CryptoFunctionService still needs Sign implemenation
* [PM-5731] chore: minor clean up
* [PM-5731] feat: scaffold make credential
* [PM-5731] feat: start implementing attestation
* [PM-5731] feat: implement credential exclusion
* [PM-5731] feat: add new credential confirmaiton
* [PM-5731] feat: implement credential creation
* [PM-5731] feat: add user verification checks
* [PM-5731] feat: add unknown error handling
* [PM-5731] chore: clean up unusued params
* [PM-5731] feat: partial attestation implementation
* [PM-5731] feat: implement key generation
* [PM-5731] feat: return public key in DER format
* [PM-5731] feat: implement signing
* [PM-5731] feat: remove logging
* [PM-5731] chore: use primary constructor
* [PM-5731] chore: add Async to method names
* [PM-5731] feat: add support for silent discoverability
* [PM-5731] feat: add support for specifying user presence requirement
* [PM-5731] feat: ensure unlocked vault
* [PM-5731] chore: clean up and refactor assertion tests
* [PM-5731] chore: clean up and refactor attestation tests
* [PM-5731] chore: add user presence todo comment
* [PM-5731] feat: scaffold fido2 client
* PM-5731 Fix build updating discoverable flag
* [PM-5731] fix: failing test
* [PM-5731] feat: add sameOriginWithAncestor and user id length checks
* [PM-5731] feat: add incomplete rpId verification
* [PM-5731] chore: document uri helpers
* [PM-5731] feat: implement fido2 client createCredential
* [PM-5731] feat: implement credential assertion in client
* fix wrong signature format
(cherry picked from commit a1c9ebf01fdcf7c64a0ca2533586b2647cc5cf3e)
* [PM-5731] fix: issues after cherry-pick
* Fix incompatible GUID conversions
(cherry picked from commit c801b2fc3aa4400032bb1bda74c034132cc677f1)
* [PM-5731] chore: remove default constructor
* [PM-5731] feat: refactor user interface to increase flexibility
* [PM-5731] feat: implement generic assertion user interface class
* [PM-5731] feat: remove ability to make user presence optional
* [PM-5731] chore: remove logging comments
* [PM-5731] feat: add native reprompt support to the authenticator
* [PM-5731] feat: allow pre and post UV
* [PM-5731] chore: add `Async` to method name. Remove `I` from struct
* [PM-5731] fix: discoverable string repr lowercase
* [PM-5731] chore: don't use C# 12 features
* [PM-5731] fix: replace magic strings and numbers with contants and enums
* [PM-5731] fix: use UTC creation date
* [PM-5731] fix: formatting
* [PM-5731] chore: use properties for public fields
* [PM-5731] chore: remove TODO
* [PM-5731] fix: IsValidRpId
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
* [PM-5154] Implement Passkeys on iOS (#3017)
* [PM-5731] feat: implement get assertion params object
* [PM-5731] feat: add first test
* [PM-5731] feat: add rp mismatch test
* [PM-5731] feat: ask for credentials when found
* [PM-5731] feat: find discoverable credentials
* [PM-5731] feat: add tests for successful UV requests
* [PM-5731] feat: add user does not consent test
* [PM-5731] feat: check for UV when reprompt is active
* [PM-5731] fix: tests a bit, needed some additional "arrange" steps
* [PM-5731] feat: add support for counter
* [PM-5731] feat: implement assertion without signature
* [PM-5732] feat: finish authenticator assertion implementation
note: CryptoFunctionService still needs Sign implemenation
* [PM-5731] chore: minor clean up
* [PM-5731] feat: scaffold make credential
* [PM-5731] feat: start implementing attestation
* [PM-5731] feat: implement credential exclusion
* [PM-5731] feat: add new credential confirmaiton
* [PM-5731] feat: implement credential creation
* [PM-5731] feat: add user verification checks
* [PM-5731] feat: add unknown error handling
* [PM-5731] chore: clean up unusued params
* [PM-5731] feat: partial attestation implementation
* [PM-5731] feat: implement key generation
* [PM-5731] feat: return public key in DER format
* [PM-5731] feat: implement signing
* [PM-5731] feat: remove logging
* [PM-5731] chore: use primary constructor
* [PM-5731] chore: add Async to method names
* [PM-5731] feat: add support for silent discoverability
* [PM-5731] feat: add support for specifying user presence requirement
* [PM-5731] feat: ensure unlocked vault
* [PM-5731] chore: clean up and refactor assertion tests
* [PM-5731] chore: clean up and refactor attestation tests
* [PM-5731] chore: add user presence todo comment
* [PM-5731] feat: scaffold fido2 client
* PM-5731 Fix build updating discoverable flag
* [PM-5731] fix: failing test
* [PM-5731] feat: add sameOriginWithAncestor and user id length checks
* [PM-5731] feat: add incomplete rpId verification
* [PM-5731] chore: document uri helpers
* [PM-5731] feat: implement fido2 client createCredential
* Added iOS passkeys integration, warning this branch has lots of logs to ease "debugging" extensions.
* [PM-5731] feat: implement credential assertion in client
* PM-5154 Fixed select passkey flow and started implementing create passkey on iOS
* fix wrong signature format
* PM-5154 [Passkeys iOS] Fix Credential ID handling on bytes and string formats. Fix Discoverable to be lowercase on set so it doesn't break parsing on clients. Added UserDisplayName on Fido2 entities. Extracted the Guid Standard/Raw format helpers to a extensions class.
* Fix incompatible GUID conversions
* PM-5154 [Passkeys iOS] Added custom UI flow for passkey creation
* PM-5154 [Passkeys iOS] Updated UI for passkey creation
* PM-5154 [Passkeys iOS] Refactored and added cipher selection for passkey creation on autofill search.
* PM-5154 [Passkeys iOS] Fixed empty top space on autofill password list
---------
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
* feat: optimize assertion network calls (#3021)
The server only needs to be updated if we have changed the counter. New passkeys that leave their counters at zero can therefore skip this step.
* [PM-5154] Implement iOS Passkey -> Add login item (#3019)
* PM-5154 Implement iOS passkey add login
* PM-5154 Added Username to Create new login for passkey, for this the param was changed to the Fido2ConfirmNewCredentialParams object so we have access to the proper values. Also added back RpId to the params to have access to it when creating the vault item. Finally added loading to saving the passkey as new login
* [PM-6513] Omit creating CredentialIdentity if it throws an exception (#3040)
* PM-6513 Omit creating CredentialIdentity if that throws, so it doesn't affect other ciphers. E.g. if a Passkey doesn't have a UserName it will throw here and it shouldn't break replacing all the other identities.
* PM-6513 Added fallback values to passkey username not being set
* Fix FIDO2 client bugs (#3056)
* fix: blockedUris null issue
* fix: trailing slash in origin breaking check
* [PM-6466] Implement passkeys User Verification (#3044)
* PM-6441 Implement passkeys User Verification
* PM-6441 Reorganized UserVerificationMediatorService so everything is not in the same file
* PM-6441 Fix Unit tests
* PM-6441 Refactor UserVerification on Fido2Authenticator and Client services to be of an enum type so we can see which specific preference the RP sent and to be passed into the user verification mediator service to perform the correct flow depending on that. Also updated Unit tests.
* PM-6441 Changed user verification logic a bit so if preference is Preferred and the app has the ability to verify the user then enforce required UV and fix issue on on Discouraged to take into account MP reprompt
* [PM-6474] Remove header on Save passkey as new login (#3054)
* PM-6474 Removed header on empty list view on iOS Autofill create passkey flow
* PM-6474 Fix TableView being hidden on Logins scene
* [PM-6496] Improved iOS extensions cipher cell UI (#3058)
* PM-6496 Improved iOS extensions cipher list to have an updated UI for each cell
* PM-6496 Improved UI on iOS extensions list cells
* [PM-5154] Implement combined view for passwords and passkeys on iOS Autofill extension (#3075)
* PM-5154 Implemented combined view of passwords and passkeys and improved search and items UI
* PM-5154 Code improvement from PR feedback
* PM-5154 Code improvement to log unknown exceptions
* PM-6685 Fix race condition issue where the biometrics check is being done before the iOS extension is being shown. So when we need the UI, we wait until ViewDidAppear happens. (#3078)
* PM-6468 Implemented copy TOTP if needed after using a Fido2 credential. Also added the Fido2MediatorService to have one point to interact with the authentication and also to add any new logic we need. (#3082)
* PM-6706 Add maximum attempts to UV with MP and with PIN (#3079)
* [PM-6848] Improved User verification on passkeys creation (#3099)
* PM-6848 Updated cancellation flow on passkey user verification and improved UV enforcement on creation
* PM-6848 Added null checks to help diagnosing if NRE is presented
* PM-6706 Fixed UV attempts to be maximum 5 attempts and not 6 (#3103)
* PM-6793 Updated autofill settings copy (#3102)
* [PM-6655] Add username empty fallback on passkey (#3101)
* PM-6655 Added fallback "Unknown account" to passkey username and moved it so it can be shared with Android
* PM-6655 Improved code lines formatting
* PM-6844 Fix passkey creation cipher list empty label on small devices (#3104)
* [PM-6798] Fix account switch on autofill (#3106)
* PM-6798 Force state update when opening the Autofill extension
* PM-6798 Fix InitAppIfNeededAsync to be awaited and also ignored Fido2AuthenticatorException from logging them to AppCenter since they don't add much information and we're logging in other places what we need
* PM-6475 Fix dark theme on iOS Autofill extension (#3114)
* PM-6850 Removed duplicate MP Reprompt on passkey creation item selection (#3118)
* PM-6538 Removed non-discoverable passkeys filter for credentials that go to the ASStore (#3117)
* [PM-6655] Add null fallback cipher name on passkeys (#3116)
* PM-6655 Fixed fallback value on passkeys to take into account CipherView.Name. Also removed non-discoverable passkey filter on adding credentials to the ASStore and also added the fallback consideration on the passkeys list iOS extension
* PM-6655 Restored non-discoverable filter on credentials set for ASStore on this PR
* PM-6798 Fix account switch on iOS Autofill extension and also changed to Try... actions for TaskCompletionSource to avoid exceptions on some occasions. (#3121)
Co-authored-by: Álison Fernandes <vvolkgang@users.noreply.github.com>
* PM-6209 Removed MAUI label from environment and about pages (#2990)
* [PM-7186] Fallback to password list on exception (#3127)
* PM-7186 Added fallback in case of exception that loads password list
* PM-7186 Added back the error message removed in last commit.
* feat: add support for `credProps.rk` extension (#3132)
* PM-7186 Remove error message when showing password list as a fallback with user interaction (#3133)
* [PM-5153] Android Passkey Implementation (#3020)
* Initial WIP implementation for the app unlock flow when called from Passkey. Still needs code organization and to be finished.
Also added a new Window workaround in App.xaml.cs to allow CredentialProviderSelectionActivity to launch separately.
* Added missing IDeviceActionService.cs implementation for iOS to build.
* Added Async to ReturnToPasskeyAfterUnlockMethod
Changed i18n to AppResource.Unlock
Removed unecessary cast
* minor code change (added comment)
* Added back the case for loading a specific Window for CredentialProviverSelectionActivity
* Added fix for Intent not passing properly to CredentialProviderSelectionActivity
Added Activity cancellation on error during execution of ReturnToPasskeyAfterUnlockAsync()
* Added WIP code for Android passkey implementation. Currently returns a mostly complete response that is missing the ClientDataJson
* Added WIP code for creating passkeys on Android. Still missing unlock flow and response of passkey creation is still not correct.
Removed unused throw NotImplementedException from Fido2ClientService
Added CredentialCreationActivity for passkey creation
Added alternative code on CredentialProviderSelectionActivity to try to debug issue with response not being valid
* Started working on logic to adding unlock flow. It's already handling the unlock but not passing the PendingIntentHandler info for CredentialCreation to CredentialCreationActivity
* Changed "cross-platform" to "platform"
* Created CredentialHelpers.cs class to share code used for Populating Passkeys in Android.
* Added Passkey Credential Creation shared code to CredentialHelpers.
Unlock flow for Passkey creation should now be working also.
* Updated code for checking if the CredentialProviderService has been enabled by the user or not. Still WIP, somes notes in code due to Credential API not being complete.
Also changed the disable code to open the Credential Settings.
* Replaced the AndroidX.Credential helpers with custom JSON creation to fix the response for Credential Creation
* minor code cleanup on CredentialProviderSelectionActivity
* added todo comment
* Feature/maui migraton passkeys android unlock fix andreas (#3077)
* fix: bitwarden providing too many/wrong credentials
* feat: use authenticator instead of client
---------
Co-authored-by: Dinis Vieira <dinisvieira@outlook.com>
* Removed / commented some older Passkey Proof of concept code.
Auth and creation of passkey should still work both when device is unlocked (and not)
Added some initial code in AutofillCiphersPageViewModel and CipherAddEditPageViewModel for handling Passkey creation
* PM-6829 Implemented Fido2...UserInterfaces on Android and necessary logic to get/make a credential with those
* Added IFido2MediatorService registrations
Inverted two IsLockedAsync checks
* Added navigation to autofillCipher when creating passkey
* Updated LockPage to avoid multiple executions of SubmitAsync
* Added new flow for creating new passkey on Android with the Cipher page for editing details
* Changed the Credential Provider Switch to an external link control
* Added i18n for Passkey Settings
* Cleanup of older Credentials code used for Android Fido2 POC.
Removed CredentialCreationActivity as it's no longer needed
* fixed merge conflict/error and added error check to Fido2 navigation in App.xaml.cs
* Removed from MainActivity casts from DeviceActionService
Changed CredentialProviderServiceActivity to handle Fido errors and exceptions gracefully and show the user an error. Still not with the correct messages.
* Added some error messages. Still need to confirm the Text Resource to use and change.
* Changed some messages to use AppResources
* Cleanup of Credential Android code and added exception result if the clientCreateCredentialResult is null
* Updated Add new item button text when creating a new passkey
* Added AccountSwitchedException for the Fido Mediator Service
* Removed TODO that is no longer needed
* Updated some todo messages in Android AutofillHandler
* When authenticating a passkey on Android the "showDialog" callback can be called and there's no MainPage available so it was changed for that specific scenario to use _deviceActionService instead of MainPage.
---------
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-7369] Show passkey icon on android when the item has a Fido2 credential (#3148)
* PM-7369 Show passkey icon on android when the item has a Fido2 credential
* PM-7369 alternative way to show passkey icon only in scenarios where we are trying to create a passkey
* PM-7369 moved logic to show passkey icon to CipherItemViewModel
* Update src/Core/Utilities/IconGlyphConverter.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* PM-7379 Fix creating the PendingIntent for a passkey credential on Android so it has different request codes amongst each other so the extras are not overriden by the last credential entry created. (#3149)
* PM-7365 Fix setting HasUnlockedInThisTransaction on passkey creation on android (#3153)
* PM-7367 Fix empty items state placeholder on Android cipher selection page (#3160)
* [PM-7366] Select cipher on search on Fido2 creation (#3154)
* PM-7366 Implemented cipher selection on search on passkey creation
* PM-7366 Fix typo
* [PM-7385] Fix for allowing switching accounts while creating a passkey of Android (#3155)
* PM-7385 Fixed for allowing switching accounts while creating a passkey on Android.
This fixes also include scenarios where we need to unlock the vault after switching
Also fixed the issue where tapping on cipher won't do anything after switching.
* PM-7385 ensure the Options.Fido2CredentialAction and FromFido2Framework are reset when the Credential flow is started to avoid erratic behaviors when switching accounts, app is in background or other edge case scenarios.
These properties where replaced by calls to _fido2MakeCredentialConfirmationUserInterface.IsConfirmingNewCredential instead.
* Minor changes and added comments
* [PM-7385] Implemented several changes suggested in PR for better/cleaner code.
* PM-7385 Added several minor code improvemments.
* PM-7385 Fix IFido2MakeCredentialConfirmationUserInterface resolve and usage to be constrained to Android. (#3164)
* PM-7385 Fix unit tests for Fido2 service (#3167)
* PM-7518 Updated favicon placeholder color on iOS Autofill extension. (#3165)
* PM-7365 Fix UserVerification on Fido2 credential creation on Android by updating the HasUnlockedInThisTransaction flag when a new transaction starts. (#3168)
* PM-5154 Avoid logging Fido2AuthenticatorExceptions (#3169)
* PM-7258 Updated Android Credential creation details on description to be localized and passed the user email for further details. (#3162)
* [PM-7257] android add support for web authn resident key credential property in our net mobile app 2 (#3170)
* [PM-7257] feat: add ability to override `clientDataHash`
* [PM-7257] feat: add support for clientDataHash and extensions
* PM-7257 Updated the origin to be the correct one and not the android one to be passed to the Fido2Client
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-7365] Fix UV not being performed on Fido2 credential creation Android (#3171)
* PM-7365 Fix UV not being performed on Fido2 credential creation on Android
* PM-7365 Fix PublicKeyCredentialCreationOptions mapping from json on AuthenticatorSelection so mainly userVerification has correct value
* PM-7585 Show error message when Origin is null, given no support for passkeys from native apps yet (#3175)
* PM-7623 Fix proper implementation of IFido2GetAssertionUserInterface now that the Fido2ClientService is being used for passkey autofill (#3174)
* PM-7553 Fix native apps passkeys autofill and creation (#3188)
* [PM-7658] Implement Fido2 privileged apps verification (#3190)
* PM-7553 Fix native apps passkeys autofill and creation
* PM-7658 Implemented Fido2 priviliged apps verification
* [PM-7576] Implemented digital asset links verification on Fido2 flows (#3191)
* PM-7553 Fix native apps passkeys autofill and creation
* PM-7658 Implemented Fido2 priviliged apps verification
* PM-7576 Implemented digital asset links verification on Fido2 flows for native apps.
* PM-7576 Renamed to ValidateAssetLinksAndGetOriginAsync to go along with Google naming and also changed method to private given that public is not necessary
* PM-7576 Moved digital asset links verification to a Core service AssetLinksService and added unit tests for it.
---------
Co-authored-by: Dinis Vieira <dinisvieira@outlook.com>
Co-authored-by: Vince Grassia <593223+vgrassia@users.noreply.github.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: Álison Fernandes <vvolkgang@users.noreply.github.com>
2024-04-25 22:26:12 +02:00
<data name="PasskeyManagementExplanationLong" xml:space="preserve">
<value>Use Bitwarden to save new passkeys and log in with passkeys stored in your vault.</value>
</data>
2023-09-27 21:26:12 +02:00
<data name="AutofillServicesExplanationLong" xml:space="preserve">
<value>The Android Autofill Framework is used to assist in filling login information into other apps on your device.</value>
</data>
<data name="UseInlineAutofillExplanationLong" xml:space="preserve">
<value>Use inline autofill if your selected keyboard supports it. Otherwise, use the default overlay.</value>
</data>
<data name="AdditionalOptions" xml:space="preserve">
<value>Additional options</value>
</data>
<data name="ContinueToWebApp" xml:space="preserve">
<value>Continue to web app?</value>
</data>
<data name="ContinueToX" xml:space="preserve">
<value>Continue to {0}?</value>
<comment>The parameter is an URL, like bitwarden.com.</comment>
</data>
<data name="ContinueToHelpCenter" xml:space="preserve">
<value>Continue to Help center?</value>
</data>
<data name="ContinueToContactSupport" xml:space="preserve">
<value>Continue to contact support?</value>
</data>
2024-01-24 21:07:39 +01:00
<data name="ContinueToPrivacyPolicy" xml:space="preserve">
<value>Continue to privacy policy?</value>
</data>
2023-09-27 21:26:12 +02:00
<data name="ContinueToAppStore" xml:space="preserve">
<value>Continue to app store?</value>
</data>
[PM-5894] Implement Passkey Providers (#3173)
* PM-3349 PM-3350 Added the partial MAUI Community Toolkit implementation for TouchEffect. This is a temporary solution until they finalize this and add it to their nuget package.
This allows implementing the LongPressCommand in AccountSwitchingOverlay and also have the "Ripple effect" animation when touching an item in Android
* PM-3349 PM-3350 Changed SendViewCell and its binding to be directly against the ViewModel
* PM-3350 Fixed iOS Share extension lazy views loading and an issue with the avatar loading. Also discovered issue with TapGestureRecognizer not working on MAUI Embedding
* PM-3350 Fixed iOS Extensions navigation to several pages and improved avoiding duplicate calls to OnNavigatedTo
* PM-3350 Updated PCL Crypto to latest alpha version to fix "Dll not found NCrypt" issue
* PM-3350 Removed workaround for iOS issue with Avatar icon as it's now fixed in latest .Net8 release.
* PM-3349 PM-3350 Removed AsyncCommand "wrapper" and added AsyncRelayCommand directly in all ViewModels that were using the other one.
* PM-3350 Added watchOS app to main project and fixed some csproj conditions for runtime identifiers on iOS.
* PM-3350 Fixed/Updated all MAUI-Migration TODOs
* PM-3350 Fixed account toolbar item and TitleView on SendAddOnlyPage, also removed comments on AvatarImageSource given the workaround is not needed anymore to draw the image successfully.
* PM-3350 Updated AppCenter package to latest version 5.0.3 and updated some things into MAUI style
* PM-3350 Added workaround for iOS Avatar icon again.
* PM-3349 Added workaround for Android to avoid issues with setting MainPage when app is in background. They are now kept on a Queue to be executed after the app has resumed.
Updated some things on App.xaml.cs to the new MAUI style
* PM-3349 PM-3350 Fixed issue where creating an account with weak/exposed password would get stuck after the Captcha (if a captcha is shown)
Changed App.xaml.cs NavigateImpl to be private
* PM-3349 Started to configure build.yml for MAUI Android
* PM-3349 build.yml update paths for MAUI Android
* PM-3349 build.yml commented verify format and just set qa as variant on MAUI Android for faster checks on CI
* PM-3349 PM-3350 build.cake updated paths
* PM-3349 build.yml updated env helpers variables and set specific csproj to build on Android so not to build iOS extensions
* PM-3349 build.yml add Android "prod" variant
* PM-3350 build.yml updated iOS build and ignore Android build to try the CI faster
* PM-3350 build.yml changed nuget restore for dotnet restore on iOS build to fix issue on restoring due to msbuild
* PM-3350 build.yml Upgraded iOS build to run on macos-13 image which has XCode 15, and set the XCode 15 version as currently the default one is 14.x
* PM-3350 build.yml try to fix ILLINK warnings and changed image to be macos-13-arm64 to see if the build is faster
* PM-3350 build.yml changed image back to be macos-13 to see if the build is faster
* PM-3350 Added Document.Build.props to disable trimming on publish
* PM-3350 build.yml disable trimming on publish so it's faster
* PM-3350 added linkskip for iOS csprojs
* PM-3350 iOS projs disable linking and set Newstandkit as weak framework
* Update build.yml disabling iOS job to avoid long running process of publish until we can fix that
* PM-3349 PM-3350 Workaround to fix issues with text getting cropped/truncated when a Label has both Multiline and LinebreakMode set
* PM-3349 build.yml enabled android build workflow
* PM-3349 build.yml configured FDROID job for MAUI
* PM-3350 iOS extensions TapGestureRecognizer try Window workaround
* PM-3350 iOS applied workaround on the iOS Autofill and Share extension to maui embed the navigation page with its content page in the Window
* PM-3349 PM-3350 Added workaround for More Options to work on Search and Groupings Page
Updated some code to MAUI Style also
* PM-3349 PM-3350 Added the ability for users to press "Continue" button as a fallback when using the Yubikey if the "SubmitCommand" doesn't trigger automatically.
* PM-3349 PM-3350 Fix for text getting cut/truncated in both account switcher and ciphers/search lists
Issue is due to MAUI but can be avoided by using slightly different layout
* PM-3350 iOS updated CFBundlerShortVersionString to latest one 2023.10.1
* PM-3350 fix build.yml Bitwarden.ipa AppStore exported file
* PM-3350 build.yml added step to validate app for submitting into App Store and have better logs of it
* PM-3350 build.yml Added several fixes like not using MtouchUseLLVM on the iOS builds to fix they taking forever to build and some changes on the automation CI to do a debug build for the moment
* PM-3350 Improved MTouch linking and extra args on iOS related csprojs
* PM-3349 PM-3350 Added MAUI label on self-host settings and on about settings to differentiate from XF app
* PM-3349 PM-3350 build.yml uncommented jobs so we have a more complete workflow
* PM-3349 PM-3350 Minor change: removed unneeded HorizontalTextAlignment from Label.
* PM-3349 Replaced CrossCurrentActivity plugin with MAUI internal CurrentActivity
* PM-3350 Fix iOS extensions navigation and Window/RootViewController handling for TapGestureRecognizer to work
* PM-3350 Cleared left ClipLogger from the iOS extensions debug logging.
* PM-3349 PM-3350 Refactored cipher bindings to have a simpler approach reusing a new CipherItemViewModel to avoid unwanted issues in the app
* PM-3349 Added base structure for avoiding Android Autofill crash. This workaround works but it's not complete as it can't handle the entire workflow when showing CipherSelectionPAge (like checking if it should show LockPage)
* PM-3350 Bumped iOS version
* PM-3350 Changed linker to use default mode given that "Full" is presenting some problems as the linker is stripping things it shouldn't and we're trying to solve it. So for now we will use the mode "Link SDK assemblies only" so QA can test.
* PM-3349 Fix for app crashing on Android when Dark mode is enabled
Removed unused button style for android
* Proof of concept for having multiple window in Android for autofill support and navigating with the help of an Extended splash page.
* PM-3350 Fix crash on Release by adding Interpreter on iOS and also adding System.Security.Cryptography to be ignored by the linker
* PM-3350 Apply Cryptography TrimmerRootAssembly only to iOS
* PM-3350 Updated Plugin.Fingerprint so biometrics work
* Update .github/workflows/build.yml setup-xcode commit hash
Co-authored-by: Vince Grassia <593223+vgrassia@users.noreply.github.com>
* PM-3349 PM-3350 Enabled argon2id and fixed one issue with the Uris when getting the icon image
* PM-3349 Upgraded Android targetSdkVersion to 34
* minor change (public to private fields)
* minor improvemments on autofill-redirect
* PM-3349 Commented the Deploy step for Android job given that we're using the hotfix-rc branch for testing iOS on TestFlight
* PM-3349 Uncommented the Deploy step for Android job
* PM-3349 Ensure "_isResumed=true" is set on App.xaml.cs:Bootstrap
* Reusing App.xaml.cs Navigation for the Android RedirectPage
Some other cleanup and changes
* Improved autofill workaround to better handle switching between windows.
* PM-3349 minor fix to add space in HomePage between the region picker labels.
* Added some comments and improvemments.
* PM-3349 Added Window events unsubscription of events. Also changed code to avoid potentially having multiple autofillwindow
* PM-3349 Minor ui fix (space between buttons in delete account page)
* initial commit of android credential provider service (wip)
* Revert "initial commit of android credential provider service (wip)"
This reverts commit 6011b639586d081687d22d77352a024272ca6841.
* PM-3350 Fix for Delete Account buttons on iOS
* PM-3349 PM-3350 Changed search icon used in app to avoid issue with icon size on iOS
* PM-3349 Added custom window so that we can always get the current Active Window. This is used to support the Android Autofil and multi-window scenarios.
* PM-3349 Fix for icon and text spacing in some list items
* PM-3349 Minor aligment improvemment for region selection in HomePage
* PM-3349 Changed the "track color" for the Android switch so that the color is different from the "thumb"
* PM-3350 Updated version to 2024.1.0 on iOS
* PM-5154 Start implementing Passkeys Autofill in iOS
* PM-5154 Continue Passkeys Autofill in iOS
* initial commit of android credential provider service (wip)
* add cred manager project to build config
* PM-5154 Added Fido2AuthenticationService to provide us a wrapper for the actual implementation
* PM-3349 Fix Picker selection style by doing a custom PickerHandler for Android which uses SetSingleChoiceItems(...) to provide with the appropriate UI
* PM-3350 Updated MauiVersion to 8.0.4-nightly.* to have the TapGestureRecognizer fix applied. This is done on the Directory.Build.props so we don't have to change it on every csproj. Also removed the workaround of TapGestureHack and fix the Show environment picker to work on the extensions as well.
* PM-3350 Added nuget.config so we add the nuget package source for MAUI Nightly builds
* Bump main iOS version
* PM-3350 Removed "iOS" old folder project that has been moved into the MAUI Single app project.
* PM-3350 Improved code safety adding a lot of try...catch and logging throughout the app. Also made the invoking on main thread safer on several places of the app. Additionally, on the GroupingsPageViewModel changed the code removing the old Xamarin hack and just using Replace directly instead of Clearing first to see if that fixes the crash we're having sometimes on the app.
* PM-3350 PM-3349 Updated Unit Test projects to NET 8.0 and fixed it to work with Core project reference. Also fixed a test that was breaking due to CIpherKey creation being wrong. Added "UT" as a constant to add when building/running Core.Test project so we have something on the context that tells us that is for a UT. With this I had to remove FFImageLoading on UT context because it doesn't support NET 8.0
* PM-3350 PM-3349 Updated Readme with MAUI and main branch
* PM-3350 PM-3349 Enable running Core tests
* PM-3350 Fix build.yml format
* PM-3349 Fix navigation when coming from autofill with Accessibility Services enabled. The user was getting into Home page instead of where they were, with this workaround the app navigates as if the account has been switched, leaving the user as closely as possible to where they were, basically on the first screen for the current state of the user.
* PM-3350 PM-3349 Added property to Directory.Build.props to enable Unit Testing globally so Test runners work
* Improve TOTP scan performance on Android
* Move Android camera/scan changes to xaml
* PM-3350 Testing UseInterpreter false on CI build
* PM-3350 Enabled back UseInterpreter on iOS Release given that it crashes on startup without it.
* PM-3349 PM-3350 Improved code safety with try...catch, better invoke on main thread and better null handling.
* PM-3349 PM-3350 Updated XCode version on build.yml to 15.1
* PM-3350 Removed TapGesture Window MAUI hack from iOS.Extension and iOS.ShareExtension
* PM-3350 Fixed CancellationTokenSource proper disposal
* PM-3350 Fix Avatar toolbar icon on extensions to load properly and to take advantage of using directly SkiaSharp to do the native conversion to UIImage. Also improved the toolbar item so that size is set appropriately.
* PM-3349 PM-3350 Fix external link icon
* PM-3350 Added new style to prevent spell check and text prediction
* Fix merge from main
* PM-3350 Commented event collection upload on the timer and when sending the app to background to see if that prevents the app from crashing on release mode.
* PM-3350 Added check for state migration version before trying to migrate LiteDB values into Prefs when there's no need to and that may be inducing crashes on backgrounded iOS apps.
* PM-3350 Try to disable Interpreter to have better crash knowledge. This time testing if avoiding loading the argon2id lib we're able to not use the interpreter.
* PM-5928 Fix circle animation to be shown on verification codes list on each item
* PM-3350 Go back to use Interpreter and added some Directory.Build.props to easily change Codesign properties and also include/exclude iOS extensions / WatchOS from the build.
* PM-3350 Enabled iOS extensions and WatchOS app to be included based on the Directory.Build.props
* PM-3350 Go back to include argon2id and interpreter
* Removing error/loading placeholders of icons on the cells to see if that is causing the background crash on iOS; so we can test this in TestFlight
* [PM-5910] Workaround for for sliding elements in Duo 2FA flow (#2967)
* workaround for sliding elements in duo 2fa flow
* restrict workaround to Android
* restrict workaround to Android
* Revert "restrict workaround to Android"
This reverts commit c2753d5dc4960aeacdb4c798e7273ca86c08881d.
* Revert "restrict workaround to Android"
This reverts commit 69688cfb98e8e3e17812f126b4fd90ffd2ac3cf8.
* PM-5902 fix for account switcher not dismissing when tapping outside (#2974)
* PM-3350 Fix iossimulator-x64 argon2id load so we can test on simulators and also made easier to maintain loading the argon2id library on the iOS projects by setting a general Directory.Build.props that is shared.
* PM-5903 Changed App.xaml.cs SetOption to only update the needed properties instead of replacing the existing Options object which would cause the AccountSwitcher button bug (#2973)
* [PM-5896] Fix MAUI iOS Background crash due to lock files on suspension (#2969)
* PM-5896 Fix background crash on iOS due to lock files when app gets suspended. Changed loading and error placeholders of the CachedImage to not be used and use default icon of IconLabel instead changing visibility.
* PM-5896 Changed methods to be protected so that they don't get removed by the linker.
* PM-5896 Added stub class and references to it so to have stronger references to Icon_Success and Icon_Error so the linker doesn't remove them.
* PM-3349 Removed commented code from build.yml regarding FDroid that is not needed anymore.
* PM-3349 PM-3350 Fix crash on iOS AppGroup container URL because of sln config on AndroidX Credentials. Changed the project reference of Credentials to be a local NuGet.
* PM-6077 Separated Android and iOS HybridWebViewHandler so that it can be used on iOS.Core (#2983)
* [PM-5907] Fix for incorrect TOTP white text color on label when using light theme on iOS (#2982)
* PM-5907 workaround for incorrect textcolor when programmatically changing text on Entry
* Update src/Core/Pages/Vault/CipherAddEditPage.xaml.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-5906] Fix for incorrect Send MaxAccess white text color on label when using light theme on iOS (#2981)
* PM-5906 workaround for incorrect textcolor when programmatically changing text on Entry
* Update src/Core/Pages/Send/SendAddEditPage.xaml.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* PM-3349 PM-3350 Fixed Unit tests because of referencing FFImageLoading when it's not possible
* PM-3349 Added exception on gitignore so the nupkg for the AndroidX Credentials is added
* [PM-5731] Create C# WebAuthn authenticator to support maui apps (#2951)
* [PM-5731] feat: implement get assertion params object
* [PM-5731] feat: add first test
* [PM-5731] feat: add rp mismatch test
* [PM-5731] feat: ask for credentials when found
* [PM-5731] feat: find discoverable credentials
* [PM-5731] feat: add tests for successful UV requests
* [PM-5731] feat: add user does not consent test
* [PM-5731] feat: check for UV when reprompt is active
* [PM-5731] fix: tests a bit, needed some additional "arrange" steps
* [PM-5731] feat: add support for counter
* [PM-5731] feat: implement assertion without signature
* [PM-5732] feat: finish authenticator assertion implementation
note: CryptoFunctionService still needs Sign implemenation
* [PM-5731] chore: minor clean up
* [PM-5731] feat: scaffold make credential
* [PM-5731] feat: start implementing attestation
* [PM-5731] feat: implement credential exclusion
* [PM-5731] feat: add new credential confirmaiton
* [PM-5731] feat: implement credential creation
* [PM-5731] feat: add user verification checks
* [PM-5731] feat: add unknown error handling
* [PM-5731] chore: clean up unusued params
* [PM-5731] feat: partial attestation implementation
* [PM-5731] feat: implement key generation
* [PM-5731] feat: return public key in DER format
* [PM-5731] feat: implement signing
* [PM-5731] feat: remove logging
* [PM-5731] chore: use primary constructor
* [PM-5731] chore: add Async to method names
* [PM-5731] feat: add support for silent discoverability
* [PM-5731] feat: add support for specifying user presence requirement
* [PM-5731] feat: ensure unlocked vault
* [PM-5731] chore: clean up and refactor assertion tests
* [PM-5731] chore: clean up and refactor attestation tests
* [PM-5731] chore: add user presence todo comment
* [PM-5731] feat: scaffold fido2 client
* PM-5731 Fix build updating discoverable flag
* [PM-5731] fix: failing test
* [PM-5731] feat: add sameOriginWithAncestor and user id length checks
* [PM-5731] feat: add incomplete rpId verification
* [PM-5731] chore: document uri helpers
* [PM-5731] feat: implement fido2 client createCredential
* [PM-5731] feat: implement credential assertion in client
* fix wrong signature format
(cherry picked from commit a1c9ebf01fdcf7c64a0ca2533586b2647cc5cf3e)
* [PM-5731] fix: issues after cherry-pick
* Fix incompatible GUID conversions
(cherry picked from commit c801b2fc3aa4400032bb1bda74c034132cc677f1)
* [PM-5731] chore: remove default constructor
* [PM-5731] feat: refactor user interface to increase flexibility
* [PM-5731] feat: implement generic assertion user interface class
* [PM-5731] feat: remove ability to make user presence optional
* [PM-5731] chore: remove logging comments
* [PM-5731] feat: add native reprompt support to the authenticator
* [PM-5731] feat: allow pre and post UV
* [PM-5731] chore: add `Async` to method name. Remove `I` from struct
* [PM-5731] fix: discoverable string repr lowercase
* [PM-5731] chore: don't use C# 12 features
* [PM-5731] fix: replace magic strings and numbers with contants and enums
* [PM-5731] fix: use UTC creation date
* [PM-5731] fix: formatting
* [PM-5731] chore: use properties for public fields
* [PM-5731] chore: remove TODO
* [PM-5731] fix: IsValidRpId
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
* [PM-5154] Implement Passkeys on iOS (#3017)
* [PM-5731] feat: implement get assertion params object
* [PM-5731] feat: add first test
* [PM-5731] feat: add rp mismatch test
* [PM-5731] feat: ask for credentials when found
* [PM-5731] feat: find discoverable credentials
* [PM-5731] feat: add tests for successful UV requests
* [PM-5731] feat: add user does not consent test
* [PM-5731] feat: check for UV when reprompt is active
* [PM-5731] fix: tests a bit, needed some additional "arrange" steps
* [PM-5731] feat: add support for counter
* [PM-5731] feat: implement assertion without signature
* [PM-5732] feat: finish authenticator assertion implementation
note: CryptoFunctionService still needs Sign implemenation
* [PM-5731] chore: minor clean up
* [PM-5731] feat: scaffold make credential
* [PM-5731] feat: start implementing attestation
* [PM-5731] feat: implement credential exclusion
* [PM-5731] feat: add new credential confirmaiton
* [PM-5731] feat: implement credential creation
* [PM-5731] feat: add user verification checks
* [PM-5731] feat: add unknown error handling
* [PM-5731] chore: clean up unusued params
* [PM-5731] feat: partial attestation implementation
* [PM-5731] feat: implement key generation
* [PM-5731] feat: return public key in DER format
* [PM-5731] feat: implement signing
* [PM-5731] feat: remove logging
* [PM-5731] chore: use primary constructor
* [PM-5731] chore: add Async to method names
* [PM-5731] feat: add support for silent discoverability
* [PM-5731] feat: add support for specifying user presence requirement
* [PM-5731] feat: ensure unlocked vault
* [PM-5731] chore: clean up and refactor assertion tests
* [PM-5731] chore: clean up and refactor attestation tests
* [PM-5731] chore: add user presence todo comment
* [PM-5731] feat: scaffold fido2 client
* PM-5731 Fix build updating discoverable flag
* [PM-5731] fix: failing test
* [PM-5731] feat: add sameOriginWithAncestor and user id length checks
* [PM-5731] feat: add incomplete rpId verification
* [PM-5731] chore: document uri helpers
* [PM-5731] feat: implement fido2 client createCredential
* Added iOS passkeys integration, warning this branch has lots of logs to ease "debugging" extensions.
* [PM-5731] feat: implement credential assertion in client
* PM-5154 Fixed select passkey flow and started implementing create passkey on iOS
* fix wrong signature format
* PM-5154 [Passkeys iOS] Fix Credential ID handling on bytes and string formats. Fix Discoverable to be lowercase on set so it doesn't break parsing on clients. Added UserDisplayName on Fido2 entities. Extracted the Guid Standard/Raw format helpers to a extensions class.
* Fix incompatible GUID conversions
* PM-5154 [Passkeys iOS] Added custom UI flow for passkey creation
* PM-5154 [Passkeys iOS] Updated UI for passkey creation
* PM-5154 [Passkeys iOS] Refactored and added cipher selection for passkey creation on autofill search.
* PM-5154 [Passkeys iOS] Fixed empty top space on autofill password list
---------
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
* feat: optimize assertion network calls (#3021)
The server only needs to be updated if we have changed the counter. New passkeys that leave their counters at zero can therefore skip this step.
* [PM-5154] Implement iOS Passkey -> Add login item (#3019)
* PM-5154 Implement iOS passkey add login
* PM-5154 Added Username to Create new login for passkey, for this the param was changed to the Fido2ConfirmNewCredentialParams object so we have access to the proper values. Also added back RpId to the params to have access to it when creating the vault item. Finally added loading to saving the passkey as new login
* [PM-6513] Omit creating CredentialIdentity if it throws an exception (#3040)
* PM-6513 Omit creating CredentialIdentity if that throws, so it doesn't affect other ciphers. E.g. if a Passkey doesn't have a UserName it will throw here and it shouldn't break replacing all the other identities.
* PM-6513 Added fallback values to passkey username not being set
* Fix FIDO2 client bugs (#3056)
* fix: blockedUris null issue
* fix: trailing slash in origin breaking check
* [PM-6466] Implement passkeys User Verification (#3044)
* PM-6441 Implement passkeys User Verification
* PM-6441 Reorganized UserVerificationMediatorService so everything is not in the same file
* PM-6441 Fix Unit tests
* PM-6441 Refactor UserVerification on Fido2Authenticator and Client services to be of an enum type so we can see which specific preference the RP sent and to be passed into the user verification mediator service to perform the correct flow depending on that. Also updated Unit tests.
* PM-6441 Changed user verification logic a bit so if preference is Preferred and the app has the ability to verify the user then enforce required UV and fix issue on on Discouraged to take into account MP reprompt
* [PM-6474] Remove header on Save passkey as new login (#3054)
* PM-6474 Removed header on empty list view on iOS Autofill create passkey flow
* PM-6474 Fix TableView being hidden on Logins scene
* [PM-6496] Improved iOS extensions cipher cell UI (#3058)
* PM-6496 Improved iOS extensions cipher list to have an updated UI for each cell
* PM-6496 Improved UI on iOS extensions list cells
* [PM-5154] Implement combined view for passwords and passkeys on iOS Autofill extension (#3075)
* PM-5154 Implemented combined view of passwords and passkeys and improved search and items UI
* PM-5154 Code improvement from PR feedback
* PM-5154 Code improvement to log unknown exceptions
* PM-6685 Fix race condition issue where the biometrics check is being done before the iOS extension is being shown. So when we need the UI, we wait until ViewDidAppear happens. (#3078)
* PM-6468 Implemented copy TOTP if needed after using a Fido2 credential. Also added the Fido2MediatorService to have one point to interact with the authentication and also to add any new logic we need. (#3082)
* PM-6706 Add maximum attempts to UV with MP and with PIN (#3079)
* [PM-6848] Improved User verification on passkeys creation (#3099)
* PM-6848 Updated cancellation flow on passkey user verification and improved UV enforcement on creation
* PM-6848 Added null checks to help diagnosing if NRE is presented
* PM-6706 Fixed UV attempts to be maximum 5 attempts and not 6 (#3103)
* PM-6793 Updated autofill settings copy (#3102)
* [PM-6655] Add username empty fallback on passkey (#3101)
* PM-6655 Added fallback "Unknown account" to passkey username and moved it so it can be shared with Android
* PM-6655 Improved code lines formatting
* PM-6844 Fix passkey creation cipher list empty label on small devices (#3104)
* [PM-6798] Fix account switch on autofill (#3106)
* PM-6798 Force state update when opening the Autofill extension
* PM-6798 Fix InitAppIfNeededAsync to be awaited and also ignored Fido2AuthenticatorException from logging them to AppCenter since they don't add much information and we're logging in other places what we need
* PM-6475 Fix dark theme on iOS Autofill extension (#3114)
* PM-6850 Removed duplicate MP Reprompt on passkey creation item selection (#3118)
* PM-6538 Removed non-discoverable passkeys filter for credentials that go to the ASStore (#3117)
* [PM-6655] Add null fallback cipher name on passkeys (#3116)
* PM-6655 Fixed fallback value on passkeys to take into account CipherView.Name. Also removed non-discoverable passkey filter on adding credentials to the ASStore and also added the fallback consideration on the passkeys list iOS extension
* PM-6655 Restored non-discoverable filter on credentials set for ASStore on this PR
* PM-6798 Fix account switch on iOS Autofill extension and also changed to Try... actions for TaskCompletionSource to avoid exceptions on some occasions. (#3121)
Co-authored-by: Álison Fernandes <vvolkgang@users.noreply.github.com>
* PM-6209 Removed MAUI label from environment and about pages (#2990)
* [PM-7186] Fallback to password list on exception (#3127)
* PM-7186 Added fallback in case of exception that loads password list
* PM-7186 Added back the error message removed in last commit.
* feat: add support for `credProps.rk` extension (#3132)
* PM-7186 Remove error message when showing password list as a fallback with user interaction (#3133)
* [PM-5153] Android Passkey Implementation (#3020)
* Initial WIP implementation for the app unlock flow when called from Passkey. Still needs code organization and to be finished.
Also added a new Window workaround in App.xaml.cs to allow CredentialProviderSelectionActivity to launch separately.
* Added missing IDeviceActionService.cs implementation for iOS to build.
* Added Async to ReturnToPasskeyAfterUnlockMethod
Changed i18n to AppResource.Unlock
Removed unecessary cast
* minor code change (added comment)
* Added back the case for loading a specific Window for CredentialProviverSelectionActivity
* Added fix for Intent not passing properly to CredentialProviderSelectionActivity
Added Activity cancellation on error during execution of ReturnToPasskeyAfterUnlockAsync()
* Added WIP code for Android passkey implementation. Currently returns a mostly complete response that is missing the ClientDataJson
* Added WIP code for creating passkeys on Android. Still missing unlock flow and response of passkey creation is still not correct.
Removed unused throw NotImplementedException from Fido2ClientService
Added CredentialCreationActivity for passkey creation
Added alternative code on CredentialProviderSelectionActivity to try to debug issue with response not being valid
* Started working on logic to adding unlock flow. It's already handling the unlock but not passing the PendingIntentHandler info for CredentialCreation to CredentialCreationActivity
* Changed "cross-platform" to "platform"
* Created CredentialHelpers.cs class to share code used for Populating Passkeys in Android.
* Added Passkey Credential Creation shared code to CredentialHelpers.
Unlock flow for Passkey creation should now be working also.
* Updated code for checking if the CredentialProviderService has been enabled by the user or not. Still WIP, somes notes in code due to Credential API not being complete.
Also changed the disable code to open the Credential Settings.
* Replaced the AndroidX.Credential helpers with custom JSON creation to fix the response for Credential Creation
* minor code cleanup on CredentialProviderSelectionActivity
* added todo comment
* Feature/maui migraton passkeys android unlock fix andreas (#3077)
* fix: bitwarden providing too many/wrong credentials
* feat: use authenticator instead of client
---------
Co-authored-by: Dinis Vieira <dinisvieira@outlook.com>
* Removed / commented some older Passkey Proof of concept code.
Auth and creation of passkey should still work both when device is unlocked (and not)
Added some initial code in AutofillCiphersPageViewModel and CipherAddEditPageViewModel for handling Passkey creation
* PM-6829 Implemented Fido2...UserInterfaces on Android and necessary logic to get/make a credential with those
* Added IFido2MediatorService registrations
Inverted two IsLockedAsync checks
* Added navigation to autofillCipher when creating passkey
* Updated LockPage to avoid multiple executions of SubmitAsync
* Added new flow for creating new passkey on Android with the Cipher page for editing details
* Changed the Credential Provider Switch to an external link control
* Added i18n for Passkey Settings
* Cleanup of older Credentials code used for Android Fido2 POC.
Removed CredentialCreationActivity as it's no longer needed
* fixed merge conflict/error and added error check to Fido2 navigation in App.xaml.cs
* Removed from MainActivity casts from DeviceActionService
Changed CredentialProviderServiceActivity to handle Fido errors and exceptions gracefully and show the user an error. Still not with the correct messages.
* Added some error messages. Still need to confirm the Text Resource to use and change.
* Changed some messages to use AppResources
* Cleanup of Credential Android code and added exception result if the clientCreateCredentialResult is null
* Updated Add new item button text when creating a new passkey
* Added AccountSwitchedException for the Fido Mediator Service
* Removed TODO that is no longer needed
* Updated some todo messages in Android AutofillHandler
* When authenticating a passkey on Android the "showDialog" callback can be called and there's no MainPage available so it was changed for that specific scenario to use _deviceActionService instead of MainPage.
---------
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-7369] Show passkey icon on android when the item has a Fido2 credential (#3148)
* PM-7369 Show passkey icon on android when the item has a Fido2 credential
* PM-7369 alternative way to show passkey icon only in scenarios where we are trying to create a passkey
* PM-7369 moved logic to show passkey icon to CipherItemViewModel
* Update src/Core/Utilities/IconGlyphConverter.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* PM-7379 Fix creating the PendingIntent for a passkey credential on Android so it has different request codes amongst each other so the extras are not overriden by the last credential entry created. (#3149)
* PM-7365 Fix setting HasUnlockedInThisTransaction on passkey creation on android (#3153)
* PM-7367 Fix empty items state placeholder on Android cipher selection page (#3160)
* [PM-7366] Select cipher on search on Fido2 creation (#3154)
* PM-7366 Implemented cipher selection on search on passkey creation
* PM-7366 Fix typo
* [PM-7385] Fix for allowing switching accounts while creating a passkey of Android (#3155)
* PM-7385 Fixed for allowing switching accounts while creating a passkey on Android.
This fixes also include scenarios where we need to unlock the vault after switching
Also fixed the issue where tapping on cipher won't do anything after switching.
* PM-7385 ensure the Options.Fido2CredentialAction and FromFido2Framework are reset when the Credential flow is started to avoid erratic behaviors when switching accounts, app is in background or other edge case scenarios.
These properties where replaced by calls to _fido2MakeCredentialConfirmationUserInterface.IsConfirmingNewCredential instead.
* Minor changes and added comments
* [PM-7385] Implemented several changes suggested in PR for better/cleaner code.
* PM-7385 Added several minor code improvemments.
* PM-7385 Fix IFido2MakeCredentialConfirmationUserInterface resolve and usage to be constrained to Android. (#3164)
* PM-7385 Fix unit tests for Fido2 service (#3167)
* PM-7518 Updated favicon placeholder color on iOS Autofill extension. (#3165)
* PM-7365 Fix UserVerification on Fido2 credential creation on Android by updating the HasUnlockedInThisTransaction flag when a new transaction starts. (#3168)
* PM-5154 Avoid logging Fido2AuthenticatorExceptions (#3169)
* PM-7258 Updated Android Credential creation details on description to be localized and passed the user email for further details. (#3162)
* [PM-7257] android add support for web authn resident key credential property in our net mobile app 2 (#3170)
* [PM-7257] feat: add ability to override `clientDataHash`
* [PM-7257] feat: add support for clientDataHash and extensions
* PM-7257 Updated the origin to be the correct one and not the android one to be passed to the Fido2Client
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-7365] Fix UV not being performed on Fido2 credential creation Android (#3171)
* PM-7365 Fix UV not being performed on Fido2 credential creation on Android
* PM-7365 Fix PublicKeyCredentialCreationOptions mapping from json on AuthenticatorSelection so mainly userVerification has correct value
* PM-7585 Show error message when Origin is null, given no support for passkeys from native apps yet (#3175)
* PM-7623 Fix proper implementation of IFido2GetAssertionUserInterface now that the Fido2ClientService is being used for passkey autofill (#3174)
* PM-7553 Fix native apps passkeys autofill and creation (#3188)
* [PM-7658] Implement Fido2 privileged apps verification (#3190)
* PM-7553 Fix native apps passkeys autofill and creation
* PM-7658 Implemented Fido2 priviliged apps verification
* [PM-7576] Implemented digital asset links verification on Fido2 flows (#3191)
* PM-7553 Fix native apps passkeys autofill and creation
* PM-7658 Implemented Fido2 priviliged apps verification
* PM-7576 Implemented digital asset links verification on Fido2 flows for native apps.
* PM-7576 Renamed to ValidateAssetLinksAndGetOriginAsync to go along with Google naming and also changed method to private given that public is not necessary
* PM-7576 Moved digital asset links verification to a Core service AssetLinksService and added unit tests for it.
---------
Co-authored-by: Dinis Vieira <dinisvieira@outlook.com>
Co-authored-by: Vince Grassia <593223+vgrassia@users.noreply.github.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: Álison Fernandes <vvolkgang@users.noreply.github.com>
2024-04-25 22:26:12 +02:00
<data name="ContinueToDeviceSettings" xml:space="preserve">
<value>Continue to device Settings?</value>
</data>
2023-09-27 21:26:12 +02:00
<data name="TwoStepLoginDescriptionLong" xml:space="preserve">
<value>Make your account more secure by setting up two-step login in the Bitwarden web app.</value>
</data>
<data name="ChangeMasterPasswordDescriptionLong" xml:space="preserve">
<value>You can change your master password on the Bitwarden web app.</value>
</data>
<data name="YouCanImportDataToYourVaultOnX" xml:space="preserve">
<value>You can import data to your vault on {0}.</value>
<comment>The parameter is an URL, like vault.bitwarden.com.</comment>
</data>
<data name="LearnMoreAboutHowToUseBitwardenOnTheHelpCenter" xml:space="preserve">
<value>Learn more about how to use Bitwarden on the Help center.</value>
</data>
<data name="ContactSupportDescriptionLong" xml:space="preserve">
<value>Can’ t find what you are looking for? Reach out to Bitwarden support on bitwarden.com.</value>
</data>
2024-01-24 21:07:39 +01:00
<data name="PrivacyPolicyDescriptionLong" xml:space="preserve">
<value>Check out our privacy policy on bitwarden.com.</value>
</data>
2023-09-27 21:26:12 +02:00
<data name="ExploreMoreFeaturesOfYourBitwardenAccountOnTheWebApp" xml:space="preserve">
<value>Explore more features of your Bitwarden account on the web app.</value>
</data>
<data name="LearnAboutOrganizationsDescriptionLong" xml:space="preserve">
<value>Bitwarden allows you to share your vault items with others by using an organization. Learn more on the bitwarden.com website.</value>
</data>
<data name="RateAppDescriptionLong" xml:space="preserve">
<value>Help others find out if Bitwarden is right for them. Visit the app store and leave a rating now.</value>
</data>
<data name="DefaultDarkThemeDescriptionLong" xml:space="preserve">
<value>Choose the dark theme to use when your device’ s dark mode is in use</value>
</data>
2023-09-22 16:55:35 +02:00
<data name="CreatedXY" xml:space="preserve">
<value>Created {0}, {1}</value>
<comment>To state the date/time in which the cipher was created: Created 03/21/2023, 09:25 AM. First parameter is the date and the second parameter is the time.</comment>
</data>
2023-09-19 11:32:23 +02:00
<data name="TooManyAttempts" xml:space="preserve">
<value>Too many attempts</value>
</data>
<data name="AccountLoggedOutBiometricExceeded" xml:space="preserve">
<value>Account logged out.</value>
</data>
2023-11-09 18:21:00 +01:00
<data name="YourOrganizationPermissionsWereUpdatedRequeringYouToSetAMasterPassword" xml:space="preserve">
<value>Your organization permissions were updated, requiring you to set a master password.</value>
</data>
<data name="YourOrganizationRequiresYouToSetAMasterPassword" xml:space="preserve">
<value>Your organization requires you to set a master password.</value>
</data>
2023-11-06 16:28:54 +01:00
<data name="SetUpAnUnlockOptionToChangeYourVaultTimeoutAction" xml:space="preserve">
<value>Set up an unlock option to change your vault timeout action.</value>
</data>
[PM-5894] Implement Passkey Providers (#3173)
* PM-3349 PM-3350 Added the partial MAUI Community Toolkit implementation for TouchEffect. This is a temporary solution until they finalize this and add it to their nuget package.
This allows implementing the LongPressCommand in AccountSwitchingOverlay and also have the "Ripple effect" animation when touching an item in Android
* PM-3349 PM-3350 Changed SendViewCell and its binding to be directly against the ViewModel
* PM-3350 Fixed iOS Share extension lazy views loading and an issue with the avatar loading. Also discovered issue with TapGestureRecognizer not working on MAUI Embedding
* PM-3350 Fixed iOS Extensions navigation to several pages and improved avoiding duplicate calls to OnNavigatedTo
* PM-3350 Updated PCL Crypto to latest alpha version to fix "Dll not found NCrypt" issue
* PM-3350 Removed workaround for iOS issue with Avatar icon as it's now fixed in latest .Net8 release.
* PM-3349 PM-3350 Removed AsyncCommand "wrapper" and added AsyncRelayCommand directly in all ViewModels that were using the other one.
* PM-3350 Added watchOS app to main project and fixed some csproj conditions for runtime identifiers on iOS.
* PM-3350 Fixed/Updated all MAUI-Migration TODOs
* PM-3350 Fixed account toolbar item and TitleView on SendAddOnlyPage, also removed comments on AvatarImageSource given the workaround is not needed anymore to draw the image successfully.
* PM-3350 Updated AppCenter package to latest version 5.0.3 and updated some things into MAUI style
* PM-3350 Added workaround for iOS Avatar icon again.
* PM-3349 Added workaround for Android to avoid issues with setting MainPage when app is in background. They are now kept on a Queue to be executed after the app has resumed.
Updated some things on App.xaml.cs to the new MAUI style
* PM-3349 PM-3350 Fixed issue where creating an account with weak/exposed password would get stuck after the Captcha (if a captcha is shown)
Changed App.xaml.cs NavigateImpl to be private
* PM-3349 Started to configure build.yml for MAUI Android
* PM-3349 build.yml update paths for MAUI Android
* PM-3349 build.yml commented verify format and just set qa as variant on MAUI Android for faster checks on CI
* PM-3349 PM-3350 build.cake updated paths
* PM-3349 build.yml updated env helpers variables and set specific csproj to build on Android so not to build iOS extensions
* PM-3349 build.yml add Android "prod" variant
* PM-3350 build.yml updated iOS build and ignore Android build to try the CI faster
* PM-3350 build.yml changed nuget restore for dotnet restore on iOS build to fix issue on restoring due to msbuild
* PM-3350 build.yml Upgraded iOS build to run on macos-13 image which has XCode 15, and set the XCode 15 version as currently the default one is 14.x
* PM-3350 build.yml try to fix ILLINK warnings and changed image to be macos-13-arm64 to see if the build is faster
* PM-3350 build.yml changed image back to be macos-13 to see if the build is faster
* PM-3350 Added Document.Build.props to disable trimming on publish
* PM-3350 build.yml disable trimming on publish so it's faster
* PM-3350 added linkskip for iOS csprojs
* PM-3350 iOS projs disable linking and set Newstandkit as weak framework
* Update build.yml disabling iOS job to avoid long running process of publish until we can fix that
* PM-3349 PM-3350 Workaround to fix issues with text getting cropped/truncated when a Label has both Multiline and LinebreakMode set
* PM-3349 build.yml enabled android build workflow
* PM-3349 build.yml configured FDROID job for MAUI
* PM-3350 iOS extensions TapGestureRecognizer try Window workaround
* PM-3350 iOS applied workaround on the iOS Autofill and Share extension to maui embed the navigation page with its content page in the Window
* PM-3349 PM-3350 Added workaround for More Options to work on Search and Groupings Page
Updated some code to MAUI Style also
* PM-3349 PM-3350 Added the ability for users to press "Continue" button as a fallback when using the Yubikey if the "SubmitCommand" doesn't trigger automatically.
* PM-3349 PM-3350 Fix for text getting cut/truncated in both account switcher and ciphers/search lists
Issue is due to MAUI but can be avoided by using slightly different layout
* PM-3350 iOS updated CFBundlerShortVersionString to latest one 2023.10.1
* PM-3350 fix build.yml Bitwarden.ipa AppStore exported file
* PM-3350 build.yml added step to validate app for submitting into App Store and have better logs of it
* PM-3350 build.yml Added several fixes like not using MtouchUseLLVM on the iOS builds to fix they taking forever to build and some changes on the automation CI to do a debug build for the moment
* PM-3350 Improved MTouch linking and extra args on iOS related csprojs
* PM-3349 PM-3350 Added MAUI label on self-host settings and on about settings to differentiate from XF app
* PM-3349 PM-3350 build.yml uncommented jobs so we have a more complete workflow
* PM-3349 PM-3350 Minor change: removed unneeded HorizontalTextAlignment from Label.
* PM-3349 Replaced CrossCurrentActivity plugin with MAUI internal CurrentActivity
* PM-3350 Fix iOS extensions navigation and Window/RootViewController handling for TapGestureRecognizer to work
* PM-3350 Cleared left ClipLogger from the iOS extensions debug logging.
* PM-3349 PM-3350 Refactored cipher bindings to have a simpler approach reusing a new CipherItemViewModel to avoid unwanted issues in the app
* PM-3349 Added base structure for avoiding Android Autofill crash. This workaround works but it's not complete as it can't handle the entire workflow when showing CipherSelectionPAge (like checking if it should show LockPage)
* PM-3350 Bumped iOS version
* PM-3350 Changed linker to use default mode given that "Full" is presenting some problems as the linker is stripping things it shouldn't and we're trying to solve it. So for now we will use the mode "Link SDK assemblies only" so QA can test.
* PM-3349 Fix for app crashing on Android when Dark mode is enabled
Removed unused button style for android
* Proof of concept for having multiple window in Android for autofill support and navigating with the help of an Extended splash page.
* PM-3350 Fix crash on Release by adding Interpreter on iOS and also adding System.Security.Cryptography to be ignored by the linker
* PM-3350 Apply Cryptography TrimmerRootAssembly only to iOS
* PM-3350 Updated Plugin.Fingerprint so biometrics work
* Update .github/workflows/build.yml setup-xcode commit hash
Co-authored-by: Vince Grassia <593223+vgrassia@users.noreply.github.com>
* PM-3349 PM-3350 Enabled argon2id and fixed one issue with the Uris when getting the icon image
* PM-3349 Upgraded Android targetSdkVersion to 34
* minor change (public to private fields)
* minor improvemments on autofill-redirect
* PM-3349 Commented the Deploy step for Android job given that we're using the hotfix-rc branch for testing iOS on TestFlight
* PM-3349 Uncommented the Deploy step for Android job
* PM-3349 Ensure "_isResumed=true" is set on App.xaml.cs:Bootstrap
* Reusing App.xaml.cs Navigation for the Android RedirectPage
Some other cleanup and changes
* Improved autofill workaround to better handle switching between windows.
* PM-3349 minor fix to add space in HomePage between the region picker labels.
* Added some comments and improvemments.
* PM-3349 Added Window events unsubscription of events. Also changed code to avoid potentially having multiple autofillwindow
* PM-3349 Minor ui fix (space between buttons in delete account page)
* initial commit of android credential provider service (wip)
* Revert "initial commit of android credential provider service (wip)"
This reverts commit 6011b639586d081687d22d77352a024272ca6841.
* PM-3350 Fix for Delete Account buttons on iOS
* PM-3349 PM-3350 Changed search icon used in app to avoid issue with icon size on iOS
* PM-3349 Added custom window so that we can always get the current Active Window. This is used to support the Android Autofil and multi-window scenarios.
* PM-3349 Fix for icon and text spacing in some list items
* PM-3349 Minor aligment improvemment for region selection in HomePage
* PM-3349 Changed the "track color" for the Android switch so that the color is different from the "thumb"
* PM-3350 Updated version to 2024.1.0 on iOS
* PM-5154 Start implementing Passkeys Autofill in iOS
* PM-5154 Continue Passkeys Autofill in iOS
* initial commit of android credential provider service (wip)
* add cred manager project to build config
* PM-5154 Added Fido2AuthenticationService to provide us a wrapper for the actual implementation
* PM-3349 Fix Picker selection style by doing a custom PickerHandler for Android which uses SetSingleChoiceItems(...) to provide with the appropriate UI
* PM-3350 Updated MauiVersion to 8.0.4-nightly.* to have the TapGestureRecognizer fix applied. This is done on the Directory.Build.props so we don't have to change it on every csproj. Also removed the workaround of TapGestureHack and fix the Show environment picker to work on the extensions as well.
* PM-3350 Added nuget.config so we add the nuget package source for MAUI Nightly builds
* Bump main iOS version
* PM-3350 Removed "iOS" old folder project that has been moved into the MAUI Single app project.
* PM-3350 Improved code safety adding a lot of try...catch and logging throughout the app. Also made the invoking on main thread safer on several places of the app. Additionally, on the GroupingsPageViewModel changed the code removing the old Xamarin hack and just using Replace directly instead of Clearing first to see if that fixes the crash we're having sometimes on the app.
* PM-3350 PM-3349 Updated Unit Test projects to NET 8.0 and fixed it to work with Core project reference. Also fixed a test that was breaking due to CIpherKey creation being wrong. Added "UT" as a constant to add when building/running Core.Test project so we have something on the context that tells us that is for a UT. With this I had to remove FFImageLoading on UT context because it doesn't support NET 8.0
* PM-3350 PM-3349 Updated Readme with MAUI and main branch
* PM-3350 PM-3349 Enable running Core tests
* PM-3350 Fix build.yml format
* PM-3349 Fix navigation when coming from autofill with Accessibility Services enabled. The user was getting into Home page instead of where they were, with this workaround the app navigates as if the account has been switched, leaving the user as closely as possible to where they were, basically on the first screen for the current state of the user.
* PM-3350 PM-3349 Added property to Directory.Build.props to enable Unit Testing globally so Test runners work
* Improve TOTP scan performance on Android
* Move Android camera/scan changes to xaml
* PM-3350 Testing UseInterpreter false on CI build
* PM-3350 Enabled back UseInterpreter on iOS Release given that it crashes on startup without it.
* PM-3349 PM-3350 Improved code safety with try...catch, better invoke on main thread and better null handling.
* PM-3349 PM-3350 Updated XCode version on build.yml to 15.1
* PM-3350 Removed TapGesture Window MAUI hack from iOS.Extension and iOS.ShareExtension
* PM-3350 Fixed CancellationTokenSource proper disposal
* PM-3350 Fix Avatar toolbar icon on extensions to load properly and to take advantage of using directly SkiaSharp to do the native conversion to UIImage. Also improved the toolbar item so that size is set appropriately.
* PM-3349 PM-3350 Fix external link icon
* PM-3350 Added new style to prevent spell check and text prediction
* Fix merge from main
* PM-3350 Commented event collection upload on the timer and when sending the app to background to see if that prevents the app from crashing on release mode.
* PM-3350 Added check for state migration version before trying to migrate LiteDB values into Prefs when there's no need to and that may be inducing crashes on backgrounded iOS apps.
* PM-3350 Try to disable Interpreter to have better crash knowledge. This time testing if avoiding loading the argon2id lib we're able to not use the interpreter.
* PM-5928 Fix circle animation to be shown on verification codes list on each item
* PM-3350 Go back to use Interpreter and added some Directory.Build.props to easily change Codesign properties and also include/exclude iOS extensions / WatchOS from the build.
* PM-3350 Enabled iOS extensions and WatchOS app to be included based on the Directory.Build.props
* PM-3350 Go back to include argon2id and interpreter
* Removing error/loading placeholders of icons on the cells to see if that is causing the background crash on iOS; so we can test this in TestFlight
* [PM-5910] Workaround for for sliding elements in Duo 2FA flow (#2967)
* workaround for sliding elements in duo 2fa flow
* restrict workaround to Android
* restrict workaround to Android
* Revert "restrict workaround to Android"
This reverts commit c2753d5dc4960aeacdb4c798e7273ca86c08881d.
* Revert "restrict workaround to Android"
This reverts commit 69688cfb98e8e3e17812f126b4fd90ffd2ac3cf8.
* PM-5902 fix for account switcher not dismissing when tapping outside (#2974)
* PM-3350 Fix iossimulator-x64 argon2id load so we can test on simulators and also made easier to maintain loading the argon2id library on the iOS projects by setting a general Directory.Build.props that is shared.
* PM-5903 Changed App.xaml.cs SetOption to only update the needed properties instead of replacing the existing Options object which would cause the AccountSwitcher button bug (#2973)
* [PM-5896] Fix MAUI iOS Background crash due to lock files on suspension (#2969)
* PM-5896 Fix background crash on iOS due to lock files when app gets suspended. Changed loading and error placeholders of the CachedImage to not be used and use default icon of IconLabel instead changing visibility.
* PM-5896 Changed methods to be protected so that they don't get removed by the linker.
* PM-5896 Added stub class and references to it so to have stronger references to Icon_Success and Icon_Error so the linker doesn't remove them.
* PM-3349 Removed commented code from build.yml regarding FDroid that is not needed anymore.
* PM-3349 PM-3350 Fix crash on iOS AppGroup container URL because of sln config on AndroidX Credentials. Changed the project reference of Credentials to be a local NuGet.
* PM-6077 Separated Android and iOS HybridWebViewHandler so that it can be used on iOS.Core (#2983)
* [PM-5907] Fix for incorrect TOTP white text color on label when using light theme on iOS (#2982)
* PM-5907 workaround for incorrect textcolor when programmatically changing text on Entry
* Update src/Core/Pages/Vault/CipherAddEditPage.xaml.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-5906] Fix for incorrect Send MaxAccess white text color on label when using light theme on iOS (#2981)
* PM-5906 workaround for incorrect textcolor when programmatically changing text on Entry
* Update src/Core/Pages/Send/SendAddEditPage.xaml.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* PM-3349 PM-3350 Fixed Unit tests because of referencing FFImageLoading when it's not possible
* PM-3349 Added exception on gitignore so the nupkg for the AndroidX Credentials is added
* [PM-5731] Create C# WebAuthn authenticator to support maui apps (#2951)
* [PM-5731] feat: implement get assertion params object
* [PM-5731] feat: add first test
* [PM-5731] feat: add rp mismatch test
* [PM-5731] feat: ask for credentials when found
* [PM-5731] feat: find discoverable credentials
* [PM-5731] feat: add tests for successful UV requests
* [PM-5731] feat: add user does not consent test
* [PM-5731] feat: check for UV when reprompt is active
* [PM-5731] fix: tests a bit, needed some additional "arrange" steps
* [PM-5731] feat: add support for counter
* [PM-5731] feat: implement assertion without signature
* [PM-5732] feat: finish authenticator assertion implementation
note: CryptoFunctionService still needs Sign implemenation
* [PM-5731] chore: minor clean up
* [PM-5731] feat: scaffold make credential
* [PM-5731] feat: start implementing attestation
* [PM-5731] feat: implement credential exclusion
* [PM-5731] feat: add new credential confirmaiton
* [PM-5731] feat: implement credential creation
* [PM-5731] feat: add user verification checks
* [PM-5731] feat: add unknown error handling
* [PM-5731] chore: clean up unusued params
* [PM-5731] feat: partial attestation implementation
* [PM-5731] feat: implement key generation
* [PM-5731] feat: return public key in DER format
* [PM-5731] feat: implement signing
* [PM-5731] feat: remove logging
* [PM-5731] chore: use primary constructor
* [PM-5731] chore: add Async to method names
* [PM-5731] feat: add support for silent discoverability
* [PM-5731] feat: add support for specifying user presence requirement
* [PM-5731] feat: ensure unlocked vault
* [PM-5731] chore: clean up and refactor assertion tests
* [PM-5731] chore: clean up and refactor attestation tests
* [PM-5731] chore: add user presence todo comment
* [PM-5731] feat: scaffold fido2 client
* PM-5731 Fix build updating discoverable flag
* [PM-5731] fix: failing test
* [PM-5731] feat: add sameOriginWithAncestor and user id length checks
* [PM-5731] feat: add incomplete rpId verification
* [PM-5731] chore: document uri helpers
* [PM-5731] feat: implement fido2 client createCredential
* [PM-5731] feat: implement credential assertion in client
* fix wrong signature format
(cherry picked from commit a1c9ebf01fdcf7c64a0ca2533586b2647cc5cf3e)
* [PM-5731] fix: issues after cherry-pick
* Fix incompatible GUID conversions
(cherry picked from commit c801b2fc3aa4400032bb1bda74c034132cc677f1)
* [PM-5731] chore: remove default constructor
* [PM-5731] feat: refactor user interface to increase flexibility
* [PM-5731] feat: implement generic assertion user interface class
* [PM-5731] feat: remove ability to make user presence optional
* [PM-5731] chore: remove logging comments
* [PM-5731] feat: add native reprompt support to the authenticator
* [PM-5731] feat: allow pre and post UV
* [PM-5731] chore: add `Async` to method name. Remove `I` from struct
* [PM-5731] fix: discoverable string repr lowercase
* [PM-5731] chore: don't use C# 12 features
* [PM-5731] fix: replace magic strings and numbers with contants and enums
* [PM-5731] fix: use UTC creation date
* [PM-5731] fix: formatting
* [PM-5731] chore: use properties for public fields
* [PM-5731] chore: remove TODO
* [PM-5731] fix: IsValidRpId
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
* [PM-5154] Implement Passkeys on iOS (#3017)
* [PM-5731] feat: implement get assertion params object
* [PM-5731] feat: add first test
* [PM-5731] feat: add rp mismatch test
* [PM-5731] feat: ask for credentials when found
* [PM-5731] feat: find discoverable credentials
* [PM-5731] feat: add tests for successful UV requests
* [PM-5731] feat: add user does not consent test
* [PM-5731] feat: check for UV when reprompt is active
* [PM-5731] fix: tests a bit, needed some additional "arrange" steps
* [PM-5731] feat: add support for counter
* [PM-5731] feat: implement assertion without signature
* [PM-5732] feat: finish authenticator assertion implementation
note: CryptoFunctionService still needs Sign implemenation
* [PM-5731] chore: minor clean up
* [PM-5731] feat: scaffold make credential
* [PM-5731] feat: start implementing attestation
* [PM-5731] feat: implement credential exclusion
* [PM-5731] feat: add new credential confirmaiton
* [PM-5731] feat: implement credential creation
* [PM-5731] feat: add user verification checks
* [PM-5731] feat: add unknown error handling
* [PM-5731] chore: clean up unusued params
* [PM-5731] feat: partial attestation implementation
* [PM-5731] feat: implement key generation
* [PM-5731] feat: return public key in DER format
* [PM-5731] feat: implement signing
* [PM-5731] feat: remove logging
* [PM-5731] chore: use primary constructor
* [PM-5731] chore: add Async to method names
* [PM-5731] feat: add support for silent discoverability
* [PM-5731] feat: add support for specifying user presence requirement
* [PM-5731] feat: ensure unlocked vault
* [PM-5731] chore: clean up and refactor assertion tests
* [PM-5731] chore: clean up and refactor attestation tests
* [PM-5731] chore: add user presence todo comment
* [PM-5731] feat: scaffold fido2 client
* PM-5731 Fix build updating discoverable flag
* [PM-5731] fix: failing test
* [PM-5731] feat: add sameOriginWithAncestor and user id length checks
* [PM-5731] feat: add incomplete rpId verification
* [PM-5731] chore: document uri helpers
* [PM-5731] feat: implement fido2 client createCredential
* Added iOS passkeys integration, warning this branch has lots of logs to ease "debugging" extensions.
* [PM-5731] feat: implement credential assertion in client
* PM-5154 Fixed select passkey flow and started implementing create passkey on iOS
* fix wrong signature format
* PM-5154 [Passkeys iOS] Fix Credential ID handling on bytes and string formats. Fix Discoverable to be lowercase on set so it doesn't break parsing on clients. Added UserDisplayName on Fido2 entities. Extracted the Guid Standard/Raw format helpers to a extensions class.
* Fix incompatible GUID conversions
* PM-5154 [Passkeys iOS] Added custom UI flow for passkey creation
* PM-5154 [Passkeys iOS] Updated UI for passkey creation
* PM-5154 [Passkeys iOS] Refactored and added cipher selection for passkey creation on autofill search.
* PM-5154 [Passkeys iOS] Fixed empty top space on autofill password list
---------
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
* feat: optimize assertion network calls (#3021)
The server only needs to be updated if we have changed the counter. New passkeys that leave their counters at zero can therefore skip this step.
* [PM-5154] Implement iOS Passkey -> Add login item (#3019)
* PM-5154 Implement iOS passkey add login
* PM-5154 Added Username to Create new login for passkey, for this the param was changed to the Fido2ConfirmNewCredentialParams object so we have access to the proper values. Also added back RpId to the params to have access to it when creating the vault item. Finally added loading to saving the passkey as new login
* [PM-6513] Omit creating CredentialIdentity if it throws an exception (#3040)
* PM-6513 Omit creating CredentialIdentity if that throws, so it doesn't affect other ciphers. E.g. if a Passkey doesn't have a UserName it will throw here and it shouldn't break replacing all the other identities.
* PM-6513 Added fallback values to passkey username not being set
* Fix FIDO2 client bugs (#3056)
* fix: blockedUris null issue
* fix: trailing slash in origin breaking check
* [PM-6466] Implement passkeys User Verification (#3044)
* PM-6441 Implement passkeys User Verification
* PM-6441 Reorganized UserVerificationMediatorService so everything is not in the same file
* PM-6441 Fix Unit tests
* PM-6441 Refactor UserVerification on Fido2Authenticator and Client services to be of an enum type so we can see which specific preference the RP sent and to be passed into the user verification mediator service to perform the correct flow depending on that. Also updated Unit tests.
* PM-6441 Changed user verification logic a bit so if preference is Preferred and the app has the ability to verify the user then enforce required UV and fix issue on on Discouraged to take into account MP reprompt
* [PM-6474] Remove header on Save passkey as new login (#3054)
* PM-6474 Removed header on empty list view on iOS Autofill create passkey flow
* PM-6474 Fix TableView being hidden on Logins scene
* [PM-6496] Improved iOS extensions cipher cell UI (#3058)
* PM-6496 Improved iOS extensions cipher list to have an updated UI for each cell
* PM-6496 Improved UI on iOS extensions list cells
* [PM-5154] Implement combined view for passwords and passkeys on iOS Autofill extension (#3075)
* PM-5154 Implemented combined view of passwords and passkeys and improved search and items UI
* PM-5154 Code improvement from PR feedback
* PM-5154 Code improvement to log unknown exceptions
* PM-6685 Fix race condition issue where the biometrics check is being done before the iOS extension is being shown. So when we need the UI, we wait until ViewDidAppear happens. (#3078)
* PM-6468 Implemented copy TOTP if needed after using a Fido2 credential. Also added the Fido2MediatorService to have one point to interact with the authentication and also to add any new logic we need. (#3082)
* PM-6706 Add maximum attempts to UV with MP and with PIN (#3079)
* [PM-6848] Improved User verification on passkeys creation (#3099)
* PM-6848 Updated cancellation flow on passkey user verification and improved UV enforcement on creation
* PM-6848 Added null checks to help diagnosing if NRE is presented
* PM-6706 Fixed UV attempts to be maximum 5 attempts and not 6 (#3103)
* PM-6793 Updated autofill settings copy (#3102)
* [PM-6655] Add username empty fallback on passkey (#3101)
* PM-6655 Added fallback "Unknown account" to passkey username and moved it so it can be shared with Android
* PM-6655 Improved code lines formatting
* PM-6844 Fix passkey creation cipher list empty label on small devices (#3104)
* [PM-6798] Fix account switch on autofill (#3106)
* PM-6798 Force state update when opening the Autofill extension
* PM-6798 Fix InitAppIfNeededAsync to be awaited and also ignored Fido2AuthenticatorException from logging them to AppCenter since they don't add much information and we're logging in other places what we need
* PM-6475 Fix dark theme on iOS Autofill extension (#3114)
* PM-6850 Removed duplicate MP Reprompt on passkey creation item selection (#3118)
* PM-6538 Removed non-discoverable passkeys filter for credentials that go to the ASStore (#3117)
* [PM-6655] Add null fallback cipher name on passkeys (#3116)
* PM-6655 Fixed fallback value on passkeys to take into account CipherView.Name. Also removed non-discoverable passkey filter on adding credentials to the ASStore and also added the fallback consideration on the passkeys list iOS extension
* PM-6655 Restored non-discoverable filter on credentials set for ASStore on this PR
* PM-6798 Fix account switch on iOS Autofill extension and also changed to Try... actions for TaskCompletionSource to avoid exceptions on some occasions. (#3121)
Co-authored-by: Álison Fernandes <vvolkgang@users.noreply.github.com>
* PM-6209 Removed MAUI label from environment and about pages (#2990)
* [PM-7186] Fallback to password list on exception (#3127)
* PM-7186 Added fallback in case of exception that loads password list
* PM-7186 Added back the error message removed in last commit.
* feat: add support for `credProps.rk` extension (#3132)
* PM-7186 Remove error message when showing password list as a fallback with user interaction (#3133)
* [PM-5153] Android Passkey Implementation (#3020)
* Initial WIP implementation for the app unlock flow when called from Passkey. Still needs code organization and to be finished.
Also added a new Window workaround in App.xaml.cs to allow CredentialProviderSelectionActivity to launch separately.
* Added missing IDeviceActionService.cs implementation for iOS to build.
* Added Async to ReturnToPasskeyAfterUnlockMethod
Changed i18n to AppResource.Unlock
Removed unecessary cast
* minor code change (added comment)
* Added back the case for loading a specific Window for CredentialProviverSelectionActivity
* Added fix for Intent not passing properly to CredentialProviderSelectionActivity
Added Activity cancellation on error during execution of ReturnToPasskeyAfterUnlockAsync()
* Added WIP code for Android passkey implementation. Currently returns a mostly complete response that is missing the ClientDataJson
* Added WIP code for creating passkeys on Android. Still missing unlock flow and response of passkey creation is still not correct.
Removed unused throw NotImplementedException from Fido2ClientService
Added CredentialCreationActivity for passkey creation
Added alternative code on CredentialProviderSelectionActivity to try to debug issue with response not being valid
* Started working on logic to adding unlock flow. It's already handling the unlock but not passing the PendingIntentHandler info for CredentialCreation to CredentialCreationActivity
* Changed "cross-platform" to "platform"
* Created CredentialHelpers.cs class to share code used for Populating Passkeys in Android.
* Added Passkey Credential Creation shared code to CredentialHelpers.
Unlock flow for Passkey creation should now be working also.
* Updated code for checking if the CredentialProviderService has been enabled by the user or not. Still WIP, somes notes in code due to Credential API not being complete.
Also changed the disable code to open the Credential Settings.
* Replaced the AndroidX.Credential helpers with custom JSON creation to fix the response for Credential Creation
* minor code cleanup on CredentialProviderSelectionActivity
* added todo comment
* Feature/maui migraton passkeys android unlock fix andreas (#3077)
* fix: bitwarden providing too many/wrong credentials
* feat: use authenticator instead of client
---------
Co-authored-by: Dinis Vieira <dinisvieira@outlook.com>
* Removed / commented some older Passkey Proof of concept code.
Auth and creation of passkey should still work both when device is unlocked (and not)
Added some initial code in AutofillCiphersPageViewModel and CipherAddEditPageViewModel for handling Passkey creation
* PM-6829 Implemented Fido2...UserInterfaces on Android and necessary logic to get/make a credential with those
* Added IFido2MediatorService registrations
Inverted two IsLockedAsync checks
* Added navigation to autofillCipher when creating passkey
* Updated LockPage to avoid multiple executions of SubmitAsync
* Added new flow for creating new passkey on Android with the Cipher page for editing details
* Changed the Credential Provider Switch to an external link control
* Added i18n for Passkey Settings
* Cleanup of older Credentials code used for Android Fido2 POC.
Removed CredentialCreationActivity as it's no longer needed
* fixed merge conflict/error and added error check to Fido2 navigation in App.xaml.cs
* Removed from MainActivity casts from DeviceActionService
Changed CredentialProviderServiceActivity to handle Fido errors and exceptions gracefully and show the user an error. Still not with the correct messages.
* Added some error messages. Still need to confirm the Text Resource to use and change.
* Changed some messages to use AppResources
* Cleanup of Credential Android code and added exception result if the clientCreateCredentialResult is null
* Updated Add new item button text when creating a new passkey
* Added AccountSwitchedException for the Fido Mediator Service
* Removed TODO that is no longer needed
* Updated some todo messages in Android AutofillHandler
* When authenticating a passkey on Android the "showDialog" callback can be called and there's no MainPage available so it was changed for that specific scenario to use _deviceActionService instead of MainPage.
---------
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-7369] Show passkey icon on android when the item has a Fido2 credential (#3148)
* PM-7369 Show passkey icon on android when the item has a Fido2 credential
* PM-7369 alternative way to show passkey icon only in scenarios where we are trying to create a passkey
* PM-7369 moved logic to show passkey icon to CipherItemViewModel
* Update src/Core/Utilities/IconGlyphConverter.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* PM-7379 Fix creating the PendingIntent for a passkey credential on Android so it has different request codes amongst each other so the extras are not overriden by the last credential entry created. (#3149)
* PM-7365 Fix setting HasUnlockedInThisTransaction on passkey creation on android (#3153)
* PM-7367 Fix empty items state placeholder on Android cipher selection page (#3160)
* [PM-7366] Select cipher on search on Fido2 creation (#3154)
* PM-7366 Implemented cipher selection on search on passkey creation
* PM-7366 Fix typo
* [PM-7385] Fix for allowing switching accounts while creating a passkey of Android (#3155)
* PM-7385 Fixed for allowing switching accounts while creating a passkey on Android.
This fixes also include scenarios where we need to unlock the vault after switching
Also fixed the issue where tapping on cipher won't do anything after switching.
* PM-7385 ensure the Options.Fido2CredentialAction and FromFido2Framework are reset when the Credential flow is started to avoid erratic behaviors when switching accounts, app is in background or other edge case scenarios.
These properties where replaced by calls to _fido2MakeCredentialConfirmationUserInterface.IsConfirmingNewCredential instead.
* Minor changes and added comments
* [PM-7385] Implemented several changes suggested in PR for better/cleaner code.
* PM-7385 Added several minor code improvemments.
* PM-7385 Fix IFido2MakeCredentialConfirmationUserInterface resolve and usage to be constrained to Android. (#3164)
* PM-7385 Fix unit tests for Fido2 service (#3167)
* PM-7518 Updated favicon placeholder color on iOS Autofill extension. (#3165)
* PM-7365 Fix UserVerification on Fido2 credential creation on Android by updating the HasUnlockedInThisTransaction flag when a new transaction starts. (#3168)
* PM-5154 Avoid logging Fido2AuthenticatorExceptions (#3169)
* PM-7258 Updated Android Credential creation details on description to be localized and passed the user email for further details. (#3162)
* [PM-7257] android add support for web authn resident key credential property in our net mobile app 2 (#3170)
* [PM-7257] feat: add ability to override `clientDataHash`
* [PM-7257] feat: add support for clientDataHash and extensions
* PM-7257 Updated the origin to be the correct one and not the android one to be passed to the Fido2Client
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-7365] Fix UV not being performed on Fido2 credential creation Android (#3171)
* PM-7365 Fix UV not being performed on Fido2 credential creation on Android
* PM-7365 Fix PublicKeyCredentialCreationOptions mapping from json on AuthenticatorSelection so mainly userVerification has correct value
* PM-7585 Show error message when Origin is null, given no support for passkeys from native apps yet (#3175)
* PM-7623 Fix proper implementation of IFido2GetAssertionUserInterface now that the Fido2ClientService is being used for passkey autofill (#3174)
* PM-7553 Fix native apps passkeys autofill and creation (#3188)
* [PM-7658] Implement Fido2 privileged apps verification (#3190)
* PM-7553 Fix native apps passkeys autofill and creation
* PM-7658 Implemented Fido2 priviliged apps verification
* [PM-7576] Implemented digital asset links verification on Fido2 flows (#3191)
* PM-7553 Fix native apps passkeys autofill and creation
* PM-7658 Implemented Fido2 priviliged apps verification
* PM-7576 Implemented digital asset links verification on Fido2 flows for native apps.
* PM-7576 Renamed to ValidateAssetLinksAndGetOriginAsync to go along with Google naming and also changed method to private given that public is not necessary
* PM-7576 Moved digital asset links verification to a Core service AssetLinksService and added unit tests for it.
---------
Co-authored-by: Dinis Vieira <dinisvieira@outlook.com>
Co-authored-by: Vince Grassia <593223+vgrassia@users.noreply.github.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: Álison Fernandes <vvolkgang@users.noreply.github.com>
2024-04-25 22:26:12 +02:00
<data name="ChooseALoginToSaveThisPasskeyTo" xml:space="preserve">
<value>Choose a login to save this passkey to</value>
</data>
<data name="SavePasskeyAsNewLogin" xml:space="preserve">
<value>Save passkey as new login</value>
</data>
<data name="SavePasskey" xml:space="preserve">
<value>Save passkey</value>
</data>
<data name="PasskeysForX" xml:space="preserve">
<value>Passkeys for {0}</value>
</data>
<data name="PasswordsForX" xml:space="preserve">
<value>Passwords for {0}</value>
</data>
<data name="OverwritePasskey" xml:space="preserve">
<value>Overwrite passkey?</value>
</data>
<data name="ThisItemAlreadyContainsAPasskeyAreYouSureYouWantToOverwriteTheCurrentPasskey" xml:space="preserve">
<value>This item already contains a passkey. Are you sure you want to overwrite the current passkey?</value>
</data>
2024-02-20 19:46:47 +01:00
<data name="DuoTwoStepLoginIsRequiredForYourAccount" xml:space="preserve">
<value>Duo two-step login is required for your account. </value>
</data>
<data name="FollowTheStepsFromDuoToFinishLoggingIn" xml:space="preserve">
<value>Follow the steps from Duo to finish logging in.</value>
</data>
<data name="LaunchDuo" xml:space="preserve">
<value>Launch Duo</value>
</data>
[PM-5894] Implement Passkey Providers (#3173)
* PM-3349 PM-3350 Added the partial MAUI Community Toolkit implementation for TouchEffect. This is a temporary solution until they finalize this and add it to their nuget package.
This allows implementing the LongPressCommand in AccountSwitchingOverlay and also have the "Ripple effect" animation when touching an item in Android
* PM-3349 PM-3350 Changed SendViewCell and its binding to be directly against the ViewModel
* PM-3350 Fixed iOS Share extension lazy views loading and an issue with the avatar loading. Also discovered issue with TapGestureRecognizer not working on MAUI Embedding
* PM-3350 Fixed iOS Extensions navigation to several pages and improved avoiding duplicate calls to OnNavigatedTo
* PM-3350 Updated PCL Crypto to latest alpha version to fix "Dll not found NCrypt" issue
* PM-3350 Removed workaround for iOS issue with Avatar icon as it's now fixed in latest .Net8 release.
* PM-3349 PM-3350 Removed AsyncCommand "wrapper" and added AsyncRelayCommand directly in all ViewModels that were using the other one.
* PM-3350 Added watchOS app to main project and fixed some csproj conditions for runtime identifiers on iOS.
* PM-3350 Fixed/Updated all MAUI-Migration TODOs
* PM-3350 Fixed account toolbar item and TitleView on SendAddOnlyPage, also removed comments on AvatarImageSource given the workaround is not needed anymore to draw the image successfully.
* PM-3350 Updated AppCenter package to latest version 5.0.3 and updated some things into MAUI style
* PM-3350 Added workaround for iOS Avatar icon again.
* PM-3349 Added workaround for Android to avoid issues with setting MainPage when app is in background. They are now kept on a Queue to be executed after the app has resumed.
Updated some things on App.xaml.cs to the new MAUI style
* PM-3349 PM-3350 Fixed issue where creating an account with weak/exposed password would get stuck after the Captcha (if a captcha is shown)
Changed App.xaml.cs NavigateImpl to be private
* PM-3349 Started to configure build.yml for MAUI Android
* PM-3349 build.yml update paths for MAUI Android
* PM-3349 build.yml commented verify format and just set qa as variant on MAUI Android for faster checks on CI
* PM-3349 PM-3350 build.cake updated paths
* PM-3349 build.yml updated env helpers variables and set specific csproj to build on Android so not to build iOS extensions
* PM-3349 build.yml add Android "prod" variant
* PM-3350 build.yml updated iOS build and ignore Android build to try the CI faster
* PM-3350 build.yml changed nuget restore for dotnet restore on iOS build to fix issue on restoring due to msbuild
* PM-3350 build.yml Upgraded iOS build to run on macos-13 image which has XCode 15, and set the XCode 15 version as currently the default one is 14.x
* PM-3350 build.yml try to fix ILLINK warnings and changed image to be macos-13-arm64 to see if the build is faster
* PM-3350 build.yml changed image back to be macos-13 to see if the build is faster
* PM-3350 Added Document.Build.props to disable trimming on publish
* PM-3350 build.yml disable trimming on publish so it's faster
* PM-3350 added linkskip for iOS csprojs
* PM-3350 iOS projs disable linking and set Newstandkit as weak framework
* Update build.yml disabling iOS job to avoid long running process of publish until we can fix that
* PM-3349 PM-3350 Workaround to fix issues with text getting cropped/truncated when a Label has both Multiline and LinebreakMode set
* PM-3349 build.yml enabled android build workflow
* PM-3349 build.yml configured FDROID job for MAUI
* PM-3350 iOS extensions TapGestureRecognizer try Window workaround
* PM-3350 iOS applied workaround on the iOS Autofill and Share extension to maui embed the navigation page with its content page in the Window
* PM-3349 PM-3350 Added workaround for More Options to work on Search and Groupings Page
Updated some code to MAUI Style also
* PM-3349 PM-3350 Added the ability for users to press "Continue" button as a fallback when using the Yubikey if the "SubmitCommand" doesn't trigger automatically.
* PM-3349 PM-3350 Fix for text getting cut/truncated in both account switcher and ciphers/search lists
Issue is due to MAUI but can be avoided by using slightly different layout
* PM-3350 iOS updated CFBundlerShortVersionString to latest one 2023.10.1
* PM-3350 fix build.yml Bitwarden.ipa AppStore exported file
* PM-3350 build.yml added step to validate app for submitting into App Store and have better logs of it
* PM-3350 build.yml Added several fixes like not using MtouchUseLLVM on the iOS builds to fix they taking forever to build and some changes on the automation CI to do a debug build for the moment
* PM-3350 Improved MTouch linking and extra args on iOS related csprojs
* PM-3349 PM-3350 Added MAUI label on self-host settings and on about settings to differentiate from XF app
* PM-3349 PM-3350 build.yml uncommented jobs so we have a more complete workflow
* PM-3349 PM-3350 Minor change: removed unneeded HorizontalTextAlignment from Label.
* PM-3349 Replaced CrossCurrentActivity plugin with MAUI internal CurrentActivity
* PM-3350 Fix iOS extensions navigation and Window/RootViewController handling for TapGestureRecognizer to work
* PM-3350 Cleared left ClipLogger from the iOS extensions debug logging.
* PM-3349 PM-3350 Refactored cipher bindings to have a simpler approach reusing a new CipherItemViewModel to avoid unwanted issues in the app
* PM-3349 Added base structure for avoiding Android Autofill crash. This workaround works but it's not complete as it can't handle the entire workflow when showing CipherSelectionPAge (like checking if it should show LockPage)
* PM-3350 Bumped iOS version
* PM-3350 Changed linker to use default mode given that "Full" is presenting some problems as the linker is stripping things it shouldn't and we're trying to solve it. So for now we will use the mode "Link SDK assemblies only" so QA can test.
* PM-3349 Fix for app crashing on Android when Dark mode is enabled
Removed unused button style for android
* Proof of concept for having multiple window in Android for autofill support and navigating with the help of an Extended splash page.
* PM-3350 Fix crash on Release by adding Interpreter on iOS and also adding System.Security.Cryptography to be ignored by the linker
* PM-3350 Apply Cryptography TrimmerRootAssembly only to iOS
* PM-3350 Updated Plugin.Fingerprint so biometrics work
* Update .github/workflows/build.yml setup-xcode commit hash
Co-authored-by: Vince Grassia <593223+vgrassia@users.noreply.github.com>
* PM-3349 PM-3350 Enabled argon2id and fixed one issue with the Uris when getting the icon image
* PM-3349 Upgraded Android targetSdkVersion to 34
* minor change (public to private fields)
* minor improvemments on autofill-redirect
* PM-3349 Commented the Deploy step for Android job given that we're using the hotfix-rc branch for testing iOS on TestFlight
* PM-3349 Uncommented the Deploy step for Android job
* PM-3349 Ensure "_isResumed=true" is set on App.xaml.cs:Bootstrap
* Reusing App.xaml.cs Navigation for the Android RedirectPage
Some other cleanup and changes
* Improved autofill workaround to better handle switching between windows.
* PM-3349 minor fix to add space in HomePage between the region picker labels.
* Added some comments and improvemments.
* PM-3349 Added Window events unsubscription of events. Also changed code to avoid potentially having multiple autofillwindow
* PM-3349 Minor ui fix (space between buttons in delete account page)
* initial commit of android credential provider service (wip)
* Revert "initial commit of android credential provider service (wip)"
This reverts commit 6011b639586d081687d22d77352a024272ca6841.
* PM-3350 Fix for Delete Account buttons on iOS
* PM-3349 PM-3350 Changed search icon used in app to avoid issue with icon size on iOS
* PM-3349 Added custom window so that we can always get the current Active Window. This is used to support the Android Autofil and multi-window scenarios.
* PM-3349 Fix for icon and text spacing in some list items
* PM-3349 Minor aligment improvemment for region selection in HomePage
* PM-3349 Changed the "track color" for the Android switch so that the color is different from the "thumb"
* PM-3350 Updated version to 2024.1.0 on iOS
* PM-5154 Start implementing Passkeys Autofill in iOS
* PM-5154 Continue Passkeys Autofill in iOS
* initial commit of android credential provider service (wip)
* add cred manager project to build config
* PM-5154 Added Fido2AuthenticationService to provide us a wrapper for the actual implementation
* PM-3349 Fix Picker selection style by doing a custom PickerHandler for Android which uses SetSingleChoiceItems(...) to provide with the appropriate UI
* PM-3350 Updated MauiVersion to 8.0.4-nightly.* to have the TapGestureRecognizer fix applied. This is done on the Directory.Build.props so we don't have to change it on every csproj. Also removed the workaround of TapGestureHack and fix the Show environment picker to work on the extensions as well.
* PM-3350 Added nuget.config so we add the nuget package source for MAUI Nightly builds
* Bump main iOS version
* PM-3350 Removed "iOS" old folder project that has been moved into the MAUI Single app project.
* PM-3350 Improved code safety adding a lot of try...catch and logging throughout the app. Also made the invoking on main thread safer on several places of the app. Additionally, on the GroupingsPageViewModel changed the code removing the old Xamarin hack and just using Replace directly instead of Clearing first to see if that fixes the crash we're having sometimes on the app.
* PM-3350 PM-3349 Updated Unit Test projects to NET 8.0 and fixed it to work with Core project reference. Also fixed a test that was breaking due to CIpherKey creation being wrong. Added "UT" as a constant to add when building/running Core.Test project so we have something on the context that tells us that is for a UT. With this I had to remove FFImageLoading on UT context because it doesn't support NET 8.0
* PM-3350 PM-3349 Updated Readme with MAUI and main branch
* PM-3350 PM-3349 Enable running Core tests
* PM-3350 Fix build.yml format
* PM-3349 Fix navigation when coming from autofill with Accessibility Services enabled. The user was getting into Home page instead of where they were, with this workaround the app navigates as if the account has been switched, leaving the user as closely as possible to where they were, basically on the first screen for the current state of the user.
* PM-3350 PM-3349 Added property to Directory.Build.props to enable Unit Testing globally so Test runners work
* Improve TOTP scan performance on Android
* Move Android camera/scan changes to xaml
* PM-3350 Testing UseInterpreter false on CI build
* PM-3350 Enabled back UseInterpreter on iOS Release given that it crashes on startup without it.
* PM-3349 PM-3350 Improved code safety with try...catch, better invoke on main thread and better null handling.
* PM-3349 PM-3350 Updated XCode version on build.yml to 15.1
* PM-3350 Removed TapGesture Window MAUI hack from iOS.Extension and iOS.ShareExtension
* PM-3350 Fixed CancellationTokenSource proper disposal
* PM-3350 Fix Avatar toolbar icon on extensions to load properly and to take advantage of using directly SkiaSharp to do the native conversion to UIImage. Also improved the toolbar item so that size is set appropriately.
* PM-3349 PM-3350 Fix external link icon
* PM-3350 Added new style to prevent spell check and text prediction
* Fix merge from main
* PM-3350 Commented event collection upload on the timer and when sending the app to background to see if that prevents the app from crashing on release mode.
* PM-3350 Added check for state migration version before trying to migrate LiteDB values into Prefs when there's no need to and that may be inducing crashes on backgrounded iOS apps.
* PM-3350 Try to disable Interpreter to have better crash knowledge. This time testing if avoiding loading the argon2id lib we're able to not use the interpreter.
* PM-5928 Fix circle animation to be shown on verification codes list on each item
* PM-3350 Go back to use Interpreter and added some Directory.Build.props to easily change Codesign properties and also include/exclude iOS extensions / WatchOS from the build.
* PM-3350 Enabled iOS extensions and WatchOS app to be included based on the Directory.Build.props
* PM-3350 Go back to include argon2id and interpreter
* Removing error/loading placeholders of icons on the cells to see if that is causing the background crash on iOS; so we can test this in TestFlight
* [PM-5910] Workaround for for sliding elements in Duo 2FA flow (#2967)
* workaround for sliding elements in duo 2fa flow
* restrict workaround to Android
* restrict workaround to Android
* Revert "restrict workaround to Android"
This reverts commit c2753d5dc4960aeacdb4c798e7273ca86c08881d.
* Revert "restrict workaround to Android"
This reverts commit 69688cfb98e8e3e17812f126b4fd90ffd2ac3cf8.
* PM-5902 fix for account switcher not dismissing when tapping outside (#2974)
* PM-3350 Fix iossimulator-x64 argon2id load so we can test on simulators and also made easier to maintain loading the argon2id library on the iOS projects by setting a general Directory.Build.props that is shared.
* PM-5903 Changed App.xaml.cs SetOption to only update the needed properties instead of replacing the existing Options object which would cause the AccountSwitcher button bug (#2973)
* [PM-5896] Fix MAUI iOS Background crash due to lock files on suspension (#2969)
* PM-5896 Fix background crash on iOS due to lock files when app gets suspended. Changed loading and error placeholders of the CachedImage to not be used and use default icon of IconLabel instead changing visibility.
* PM-5896 Changed methods to be protected so that they don't get removed by the linker.
* PM-5896 Added stub class and references to it so to have stronger references to Icon_Success and Icon_Error so the linker doesn't remove them.
* PM-3349 Removed commented code from build.yml regarding FDroid that is not needed anymore.
* PM-3349 PM-3350 Fix crash on iOS AppGroup container URL because of sln config on AndroidX Credentials. Changed the project reference of Credentials to be a local NuGet.
* PM-6077 Separated Android and iOS HybridWebViewHandler so that it can be used on iOS.Core (#2983)
* [PM-5907] Fix for incorrect TOTP white text color on label when using light theme on iOS (#2982)
* PM-5907 workaround for incorrect textcolor when programmatically changing text on Entry
* Update src/Core/Pages/Vault/CipherAddEditPage.xaml.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-5906] Fix for incorrect Send MaxAccess white text color on label when using light theme on iOS (#2981)
* PM-5906 workaround for incorrect textcolor when programmatically changing text on Entry
* Update src/Core/Pages/Send/SendAddEditPage.xaml.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* PM-3349 PM-3350 Fixed Unit tests because of referencing FFImageLoading when it's not possible
* PM-3349 Added exception on gitignore so the nupkg for the AndroidX Credentials is added
* [PM-5731] Create C# WebAuthn authenticator to support maui apps (#2951)
* [PM-5731] feat: implement get assertion params object
* [PM-5731] feat: add first test
* [PM-5731] feat: add rp mismatch test
* [PM-5731] feat: ask for credentials when found
* [PM-5731] feat: find discoverable credentials
* [PM-5731] feat: add tests for successful UV requests
* [PM-5731] feat: add user does not consent test
* [PM-5731] feat: check for UV when reprompt is active
* [PM-5731] fix: tests a bit, needed some additional "arrange" steps
* [PM-5731] feat: add support for counter
* [PM-5731] feat: implement assertion without signature
* [PM-5732] feat: finish authenticator assertion implementation
note: CryptoFunctionService still needs Sign implemenation
* [PM-5731] chore: minor clean up
* [PM-5731] feat: scaffold make credential
* [PM-5731] feat: start implementing attestation
* [PM-5731] feat: implement credential exclusion
* [PM-5731] feat: add new credential confirmaiton
* [PM-5731] feat: implement credential creation
* [PM-5731] feat: add user verification checks
* [PM-5731] feat: add unknown error handling
* [PM-5731] chore: clean up unusued params
* [PM-5731] feat: partial attestation implementation
* [PM-5731] feat: implement key generation
* [PM-5731] feat: return public key in DER format
* [PM-5731] feat: implement signing
* [PM-5731] feat: remove logging
* [PM-5731] chore: use primary constructor
* [PM-5731] chore: add Async to method names
* [PM-5731] feat: add support for silent discoverability
* [PM-5731] feat: add support for specifying user presence requirement
* [PM-5731] feat: ensure unlocked vault
* [PM-5731] chore: clean up and refactor assertion tests
* [PM-5731] chore: clean up and refactor attestation tests
* [PM-5731] chore: add user presence todo comment
* [PM-5731] feat: scaffold fido2 client
* PM-5731 Fix build updating discoverable flag
* [PM-5731] fix: failing test
* [PM-5731] feat: add sameOriginWithAncestor and user id length checks
* [PM-5731] feat: add incomplete rpId verification
* [PM-5731] chore: document uri helpers
* [PM-5731] feat: implement fido2 client createCredential
* [PM-5731] feat: implement credential assertion in client
* fix wrong signature format
(cherry picked from commit a1c9ebf01fdcf7c64a0ca2533586b2647cc5cf3e)
* [PM-5731] fix: issues after cherry-pick
* Fix incompatible GUID conversions
(cherry picked from commit c801b2fc3aa4400032bb1bda74c034132cc677f1)
* [PM-5731] chore: remove default constructor
* [PM-5731] feat: refactor user interface to increase flexibility
* [PM-5731] feat: implement generic assertion user interface class
* [PM-5731] feat: remove ability to make user presence optional
* [PM-5731] chore: remove logging comments
* [PM-5731] feat: add native reprompt support to the authenticator
* [PM-5731] feat: allow pre and post UV
* [PM-5731] chore: add `Async` to method name. Remove `I` from struct
* [PM-5731] fix: discoverable string repr lowercase
* [PM-5731] chore: don't use C# 12 features
* [PM-5731] fix: replace magic strings and numbers with contants and enums
* [PM-5731] fix: use UTC creation date
* [PM-5731] fix: formatting
* [PM-5731] chore: use properties for public fields
* [PM-5731] chore: remove TODO
* [PM-5731] fix: IsValidRpId
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
* [PM-5154] Implement Passkeys on iOS (#3017)
* [PM-5731] feat: implement get assertion params object
* [PM-5731] feat: add first test
* [PM-5731] feat: add rp mismatch test
* [PM-5731] feat: ask for credentials when found
* [PM-5731] feat: find discoverable credentials
* [PM-5731] feat: add tests for successful UV requests
* [PM-5731] feat: add user does not consent test
* [PM-5731] feat: check for UV when reprompt is active
* [PM-5731] fix: tests a bit, needed some additional "arrange" steps
* [PM-5731] feat: add support for counter
* [PM-5731] feat: implement assertion without signature
* [PM-5732] feat: finish authenticator assertion implementation
note: CryptoFunctionService still needs Sign implemenation
* [PM-5731] chore: minor clean up
* [PM-5731] feat: scaffold make credential
* [PM-5731] feat: start implementing attestation
* [PM-5731] feat: implement credential exclusion
* [PM-5731] feat: add new credential confirmaiton
* [PM-5731] feat: implement credential creation
* [PM-5731] feat: add user verification checks
* [PM-5731] feat: add unknown error handling
* [PM-5731] chore: clean up unusued params
* [PM-5731] feat: partial attestation implementation
* [PM-5731] feat: implement key generation
* [PM-5731] feat: return public key in DER format
* [PM-5731] feat: implement signing
* [PM-5731] feat: remove logging
* [PM-5731] chore: use primary constructor
* [PM-5731] chore: add Async to method names
* [PM-5731] feat: add support for silent discoverability
* [PM-5731] feat: add support for specifying user presence requirement
* [PM-5731] feat: ensure unlocked vault
* [PM-5731] chore: clean up and refactor assertion tests
* [PM-5731] chore: clean up and refactor attestation tests
* [PM-5731] chore: add user presence todo comment
* [PM-5731] feat: scaffold fido2 client
* PM-5731 Fix build updating discoverable flag
* [PM-5731] fix: failing test
* [PM-5731] feat: add sameOriginWithAncestor and user id length checks
* [PM-5731] feat: add incomplete rpId verification
* [PM-5731] chore: document uri helpers
* [PM-5731] feat: implement fido2 client createCredential
* Added iOS passkeys integration, warning this branch has lots of logs to ease "debugging" extensions.
* [PM-5731] feat: implement credential assertion in client
* PM-5154 Fixed select passkey flow and started implementing create passkey on iOS
* fix wrong signature format
* PM-5154 [Passkeys iOS] Fix Credential ID handling on bytes and string formats. Fix Discoverable to be lowercase on set so it doesn't break parsing on clients. Added UserDisplayName on Fido2 entities. Extracted the Guid Standard/Raw format helpers to a extensions class.
* Fix incompatible GUID conversions
* PM-5154 [Passkeys iOS] Added custom UI flow for passkey creation
* PM-5154 [Passkeys iOS] Updated UI for passkey creation
* PM-5154 [Passkeys iOS] Refactored and added cipher selection for passkey creation on autofill search.
* PM-5154 [Passkeys iOS] Fixed empty top space on autofill password list
---------
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
* feat: optimize assertion network calls (#3021)
The server only needs to be updated if we have changed the counter. New passkeys that leave their counters at zero can therefore skip this step.
* [PM-5154] Implement iOS Passkey -> Add login item (#3019)
* PM-5154 Implement iOS passkey add login
* PM-5154 Added Username to Create new login for passkey, for this the param was changed to the Fido2ConfirmNewCredentialParams object so we have access to the proper values. Also added back RpId to the params to have access to it when creating the vault item. Finally added loading to saving the passkey as new login
* [PM-6513] Omit creating CredentialIdentity if it throws an exception (#3040)
* PM-6513 Omit creating CredentialIdentity if that throws, so it doesn't affect other ciphers. E.g. if a Passkey doesn't have a UserName it will throw here and it shouldn't break replacing all the other identities.
* PM-6513 Added fallback values to passkey username not being set
* Fix FIDO2 client bugs (#3056)
* fix: blockedUris null issue
* fix: trailing slash in origin breaking check
* [PM-6466] Implement passkeys User Verification (#3044)
* PM-6441 Implement passkeys User Verification
* PM-6441 Reorganized UserVerificationMediatorService so everything is not in the same file
* PM-6441 Fix Unit tests
* PM-6441 Refactor UserVerification on Fido2Authenticator and Client services to be of an enum type so we can see which specific preference the RP sent and to be passed into the user verification mediator service to perform the correct flow depending on that. Also updated Unit tests.
* PM-6441 Changed user verification logic a bit so if preference is Preferred and the app has the ability to verify the user then enforce required UV and fix issue on on Discouraged to take into account MP reprompt
* [PM-6474] Remove header on Save passkey as new login (#3054)
* PM-6474 Removed header on empty list view on iOS Autofill create passkey flow
* PM-6474 Fix TableView being hidden on Logins scene
* [PM-6496] Improved iOS extensions cipher cell UI (#3058)
* PM-6496 Improved iOS extensions cipher list to have an updated UI for each cell
* PM-6496 Improved UI on iOS extensions list cells
* [PM-5154] Implement combined view for passwords and passkeys on iOS Autofill extension (#3075)
* PM-5154 Implemented combined view of passwords and passkeys and improved search and items UI
* PM-5154 Code improvement from PR feedback
* PM-5154 Code improvement to log unknown exceptions
* PM-6685 Fix race condition issue where the biometrics check is being done before the iOS extension is being shown. So when we need the UI, we wait until ViewDidAppear happens. (#3078)
* PM-6468 Implemented copy TOTP if needed after using a Fido2 credential. Also added the Fido2MediatorService to have one point to interact with the authentication and also to add any new logic we need. (#3082)
* PM-6706 Add maximum attempts to UV with MP and with PIN (#3079)
* [PM-6848] Improved User verification on passkeys creation (#3099)
* PM-6848 Updated cancellation flow on passkey user verification and improved UV enforcement on creation
* PM-6848 Added null checks to help diagnosing if NRE is presented
* PM-6706 Fixed UV attempts to be maximum 5 attempts and not 6 (#3103)
* PM-6793 Updated autofill settings copy (#3102)
* [PM-6655] Add username empty fallback on passkey (#3101)
* PM-6655 Added fallback "Unknown account" to passkey username and moved it so it can be shared with Android
* PM-6655 Improved code lines formatting
* PM-6844 Fix passkey creation cipher list empty label on small devices (#3104)
* [PM-6798] Fix account switch on autofill (#3106)
* PM-6798 Force state update when opening the Autofill extension
* PM-6798 Fix InitAppIfNeededAsync to be awaited and also ignored Fido2AuthenticatorException from logging them to AppCenter since they don't add much information and we're logging in other places what we need
* PM-6475 Fix dark theme on iOS Autofill extension (#3114)
* PM-6850 Removed duplicate MP Reprompt on passkey creation item selection (#3118)
* PM-6538 Removed non-discoverable passkeys filter for credentials that go to the ASStore (#3117)
* [PM-6655] Add null fallback cipher name on passkeys (#3116)
* PM-6655 Fixed fallback value on passkeys to take into account CipherView.Name. Also removed non-discoverable passkey filter on adding credentials to the ASStore and also added the fallback consideration on the passkeys list iOS extension
* PM-6655 Restored non-discoverable filter on credentials set for ASStore on this PR
* PM-6798 Fix account switch on iOS Autofill extension and also changed to Try... actions for TaskCompletionSource to avoid exceptions on some occasions. (#3121)
Co-authored-by: Álison Fernandes <vvolkgang@users.noreply.github.com>
* PM-6209 Removed MAUI label from environment and about pages (#2990)
* [PM-7186] Fallback to password list on exception (#3127)
* PM-7186 Added fallback in case of exception that loads password list
* PM-7186 Added back the error message removed in last commit.
* feat: add support for `credProps.rk` extension (#3132)
* PM-7186 Remove error message when showing password list as a fallback with user interaction (#3133)
* [PM-5153] Android Passkey Implementation (#3020)
* Initial WIP implementation for the app unlock flow when called from Passkey. Still needs code organization and to be finished.
Also added a new Window workaround in App.xaml.cs to allow CredentialProviderSelectionActivity to launch separately.
* Added missing IDeviceActionService.cs implementation for iOS to build.
* Added Async to ReturnToPasskeyAfterUnlockMethod
Changed i18n to AppResource.Unlock
Removed unecessary cast
* minor code change (added comment)
* Added back the case for loading a specific Window for CredentialProviverSelectionActivity
* Added fix for Intent not passing properly to CredentialProviderSelectionActivity
Added Activity cancellation on error during execution of ReturnToPasskeyAfterUnlockAsync()
* Added WIP code for Android passkey implementation. Currently returns a mostly complete response that is missing the ClientDataJson
* Added WIP code for creating passkeys on Android. Still missing unlock flow and response of passkey creation is still not correct.
Removed unused throw NotImplementedException from Fido2ClientService
Added CredentialCreationActivity for passkey creation
Added alternative code on CredentialProviderSelectionActivity to try to debug issue with response not being valid
* Started working on logic to adding unlock flow. It's already handling the unlock but not passing the PendingIntentHandler info for CredentialCreation to CredentialCreationActivity
* Changed "cross-platform" to "platform"
* Created CredentialHelpers.cs class to share code used for Populating Passkeys in Android.
* Added Passkey Credential Creation shared code to CredentialHelpers.
Unlock flow for Passkey creation should now be working also.
* Updated code for checking if the CredentialProviderService has been enabled by the user or not. Still WIP, somes notes in code due to Credential API not being complete.
Also changed the disable code to open the Credential Settings.
* Replaced the AndroidX.Credential helpers with custom JSON creation to fix the response for Credential Creation
* minor code cleanup on CredentialProviderSelectionActivity
* added todo comment
* Feature/maui migraton passkeys android unlock fix andreas (#3077)
* fix: bitwarden providing too many/wrong credentials
* feat: use authenticator instead of client
---------
Co-authored-by: Dinis Vieira <dinisvieira@outlook.com>
* Removed / commented some older Passkey Proof of concept code.
Auth and creation of passkey should still work both when device is unlocked (and not)
Added some initial code in AutofillCiphersPageViewModel and CipherAddEditPageViewModel for handling Passkey creation
* PM-6829 Implemented Fido2...UserInterfaces on Android and necessary logic to get/make a credential with those
* Added IFido2MediatorService registrations
Inverted two IsLockedAsync checks
* Added navigation to autofillCipher when creating passkey
* Updated LockPage to avoid multiple executions of SubmitAsync
* Added new flow for creating new passkey on Android with the Cipher page for editing details
* Changed the Credential Provider Switch to an external link control
* Added i18n for Passkey Settings
* Cleanup of older Credentials code used for Android Fido2 POC.
Removed CredentialCreationActivity as it's no longer needed
* fixed merge conflict/error and added error check to Fido2 navigation in App.xaml.cs
* Removed from MainActivity casts from DeviceActionService
Changed CredentialProviderServiceActivity to handle Fido errors and exceptions gracefully and show the user an error. Still not with the correct messages.
* Added some error messages. Still need to confirm the Text Resource to use and change.
* Changed some messages to use AppResources
* Cleanup of Credential Android code and added exception result if the clientCreateCredentialResult is null
* Updated Add new item button text when creating a new passkey
* Added AccountSwitchedException for the Fido Mediator Service
* Removed TODO that is no longer needed
* Updated some todo messages in Android AutofillHandler
* When authenticating a passkey on Android the "showDialog" callback can be called and there's no MainPage available so it was changed for that specific scenario to use _deviceActionService instead of MainPage.
---------
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-7369] Show passkey icon on android when the item has a Fido2 credential (#3148)
* PM-7369 Show passkey icon on android when the item has a Fido2 credential
* PM-7369 alternative way to show passkey icon only in scenarios where we are trying to create a passkey
* PM-7369 moved logic to show passkey icon to CipherItemViewModel
* Update src/Core/Utilities/IconGlyphConverter.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* PM-7379 Fix creating the PendingIntent for a passkey credential on Android so it has different request codes amongst each other so the extras are not overriden by the last credential entry created. (#3149)
* PM-7365 Fix setting HasUnlockedInThisTransaction on passkey creation on android (#3153)
* PM-7367 Fix empty items state placeholder on Android cipher selection page (#3160)
* [PM-7366] Select cipher on search on Fido2 creation (#3154)
* PM-7366 Implemented cipher selection on search on passkey creation
* PM-7366 Fix typo
* [PM-7385] Fix for allowing switching accounts while creating a passkey of Android (#3155)
* PM-7385 Fixed for allowing switching accounts while creating a passkey on Android.
This fixes also include scenarios where we need to unlock the vault after switching
Also fixed the issue where tapping on cipher won't do anything after switching.
* PM-7385 ensure the Options.Fido2CredentialAction and FromFido2Framework are reset when the Credential flow is started to avoid erratic behaviors when switching accounts, app is in background or other edge case scenarios.
These properties where replaced by calls to _fido2MakeCredentialConfirmationUserInterface.IsConfirmingNewCredential instead.
* Minor changes and added comments
* [PM-7385] Implemented several changes suggested in PR for better/cleaner code.
* PM-7385 Added several minor code improvemments.
* PM-7385 Fix IFido2MakeCredentialConfirmationUserInterface resolve and usage to be constrained to Android. (#3164)
* PM-7385 Fix unit tests for Fido2 service (#3167)
* PM-7518 Updated favicon placeholder color on iOS Autofill extension. (#3165)
* PM-7365 Fix UserVerification on Fido2 credential creation on Android by updating the HasUnlockedInThisTransaction flag when a new transaction starts. (#3168)
* PM-5154 Avoid logging Fido2AuthenticatorExceptions (#3169)
* PM-7258 Updated Android Credential creation details on description to be localized and passed the user email for further details. (#3162)
* [PM-7257] android add support for web authn resident key credential property in our net mobile app 2 (#3170)
* [PM-7257] feat: add ability to override `clientDataHash`
* [PM-7257] feat: add support for clientDataHash and extensions
* PM-7257 Updated the origin to be the correct one and not the android one to be passed to the Fido2Client
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-7365] Fix UV not being performed on Fido2 credential creation Android (#3171)
* PM-7365 Fix UV not being performed on Fido2 credential creation on Android
* PM-7365 Fix PublicKeyCredentialCreationOptions mapping from json on AuthenticatorSelection so mainly userVerification has correct value
* PM-7585 Show error message when Origin is null, given no support for passkeys from native apps yet (#3175)
* PM-7623 Fix proper implementation of IFido2GetAssertionUserInterface now that the Fido2ClientService is being used for passkey autofill (#3174)
* PM-7553 Fix native apps passkeys autofill and creation (#3188)
* [PM-7658] Implement Fido2 privileged apps verification (#3190)
* PM-7553 Fix native apps passkeys autofill and creation
* PM-7658 Implemented Fido2 priviliged apps verification
* [PM-7576] Implemented digital asset links verification on Fido2 flows (#3191)
* PM-7553 Fix native apps passkeys autofill and creation
* PM-7658 Implemented Fido2 priviliged apps verification
* PM-7576 Implemented digital asset links verification on Fido2 flows for native apps.
* PM-7576 Renamed to ValidateAssetLinksAndGetOriginAsync to go along with Google naming and also changed method to private given that public is not necessary
* PM-7576 Moved digital asset links verification to a Core service AssetLinksService and added unit tests for it.
---------
Co-authored-by: Dinis Vieira <dinisvieira@outlook.com>
Co-authored-by: Vince Grassia <593223+vgrassia@users.noreply.github.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: Álison Fernandes <vvolkgang@users.noreply.github.com>
2024-04-25 22:26:12 +02:00
<data name="VerificationRequiredByX" xml:space="preserve">
<value>Verification required by {0}</value>
</data>
<data name="VerificationRequiredForThisActionSetUpAnUnlockMethodInBitwardenToContinue" xml:space="preserve">
<value>Verification required for this action. Set up an unlock method in Bitwarden to continue.</value>
</data>
<data name="ErrorCreatingPasskey" xml:space="preserve">
<value>Error creating passkey</value>
</data>
<data name="ErrorReadingPasskey" xml:space="preserve">
<value>Error reading passkey</value>
</data>
<data name="ThereWasAProblemCreatingAPasskeyForXTryAgainLater" xml:space="preserve">
<value>There was a problem creating a passkey for {0}. Try again later.</value>
<comment>The parameter is the RpId</comment>
</data>
<data name="ThereWasAProblemReadingAPasskeyForXTryAgainLater" xml:space="preserve">
<value>There was a problem reading your passkey for {0}. Try again later.</value>
<comment>The parameter is the RpId</comment>
</data>
<data name="VerifyingIdentityEllipsis" xml:space="preserve">
<value>Verifying identity...</value>
</data>
<data name="Passwords" xml:space="preserve">
<value>Passwords</value>
</data>
<data name="UnknownAccount" xml:space="preserve">
<value>Unknown account</value>
</data>
<data name="SetUpAutofill" xml:space="preserve">
<value>Set up auto-fill</value>
</data>
<data name="GetInstantAccessToYourPasswordsAndPasskeys" xml:space="preserve">
<value>Get instant access to your passwords and passkeys!</value>
</data>
<data name="SetUpAutoFillDescriptionLong" xml:space="preserve">
<value>To set up password auto-fill and passkey management, set Bitwarden as your preferred provider in the iOS Settings.</value>
</data>
<data name="FirstDotGoToYourDeviceSettingsPasswordsPasswordOptions" xml:space="preserve">
<value>1. Go to your device's Settings > Passwords > Password Options</value>
</data>
<data name="SecondDotTurnOnAutoFill" xml:space="preserve">
<value>2. Turn on AutoFill</value>
</data>
<data name="ThirdDotSelectBitwardenToUseForPasswordsAndPasskeys" xml:space="preserve">
<value>3. Select "Bitwarden" to use for passwords and passkeys</value>
</data>
<data name="YourPasskeyWillBeSavedToYourBitwardenVault" xml:space="preserve">
<value>Your passkey will be saved to your Bitwarden vault</value>
</data>
<data name="YourPasskeyWillBeSavedToYourBitwardenVaultForX" xml:space="preserve">
<value>Your passkey will be saved to your Bitwarden vault for {0}</value>
</data>
2024-04-12 20:52:39 +02:00
<data name="OrganizationUnassignedItemsMessageUSEUDescriptionLong" xml:space="preserve">
<value>Unassigned organization items are no longer visible in the All Vaults view and only accessible via the Admin Console. Assign these items to a collection from the Admin Console to make them visible.</value>
</data>
2024-04-15 15:58:56 +02:00
<data name="OrganizationUnassignedItemsMessageSelfHost041624DescriptionLong" xml:space="preserve">
<value>On May 16, 2024, unassigned organization items will no longer be visible in the All Vaults view and only accessible via the Admin Console. Assign these items to a collection from the Admin Console to make them visible.</value>
2024-04-12 20:52:39 +02:00
</data>
<data name="RemindMeLater" xml:space="preserve">
<value>Remind me later</value>
</data>
<data name="Notice" xml:space="preserve">
<value>Notice</value>
</data>
[PM-5894] Implement Passkey Providers (#3173)
* PM-3349 PM-3350 Added the partial MAUI Community Toolkit implementation for TouchEffect. This is a temporary solution until they finalize this and add it to their nuget package.
This allows implementing the LongPressCommand in AccountSwitchingOverlay and also have the "Ripple effect" animation when touching an item in Android
* PM-3349 PM-3350 Changed SendViewCell and its binding to be directly against the ViewModel
* PM-3350 Fixed iOS Share extension lazy views loading and an issue with the avatar loading. Also discovered issue with TapGestureRecognizer not working on MAUI Embedding
* PM-3350 Fixed iOS Extensions navigation to several pages and improved avoiding duplicate calls to OnNavigatedTo
* PM-3350 Updated PCL Crypto to latest alpha version to fix "Dll not found NCrypt" issue
* PM-3350 Removed workaround for iOS issue with Avatar icon as it's now fixed in latest .Net8 release.
* PM-3349 PM-3350 Removed AsyncCommand "wrapper" and added AsyncRelayCommand directly in all ViewModels that were using the other one.
* PM-3350 Added watchOS app to main project and fixed some csproj conditions for runtime identifiers on iOS.
* PM-3350 Fixed/Updated all MAUI-Migration TODOs
* PM-3350 Fixed account toolbar item and TitleView on SendAddOnlyPage, also removed comments on AvatarImageSource given the workaround is not needed anymore to draw the image successfully.
* PM-3350 Updated AppCenter package to latest version 5.0.3 and updated some things into MAUI style
* PM-3350 Added workaround for iOS Avatar icon again.
* PM-3349 Added workaround for Android to avoid issues with setting MainPage when app is in background. They are now kept on a Queue to be executed after the app has resumed.
Updated some things on App.xaml.cs to the new MAUI style
* PM-3349 PM-3350 Fixed issue where creating an account with weak/exposed password would get stuck after the Captcha (if a captcha is shown)
Changed App.xaml.cs NavigateImpl to be private
* PM-3349 Started to configure build.yml for MAUI Android
* PM-3349 build.yml update paths for MAUI Android
* PM-3349 build.yml commented verify format and just set qa as variant on MAUI Android for faster checks on CI
* PM-3349 PM-3350 build.cake updated paths
* PM-3349 build.yml updated env helpers variables and set specific csproj to build on Android so not to build iOS extensions
* PM-3349 build.yml add Android "prod" variant
* PM-3350 build.yml updated iOS build and ignore Android build to try the CI faster
* PM-3350 build.yml changed nuget restore for dotnet restore on iOS build to fix issue on restoring due to msbuild
* PM-3350 build.yml Upgraded iOS build to run on macos-13 image which has XCode 15, and set the XCode 15 version as currently the default one is 14.x
* PM-3350 build.yml try to fix ILLINK warnings and changed image to be macos-13-arm64 to see if the build is faster
* PM-3350 build.yml changed image back to be macos-13 to see if the build is faster
* PM-3350 Added Document.Build.props to disable trimming on publish
* PM-3350 build.yml disable trimming on publish so it's faster
* PM-3350 added linkskip for iOS csprojs
* PM-3350 iOS projs disable linking and set Newstandkit as weak framework
* Update build.yml disabling iOS job to avoid long running process of publish until we can fix that
* PM-3349 PM-3350 Workaround to fix issues with text getting cropped/truncated when a Label has both Multiline and LinebreakMode set
* PM-3349 build.yml enabled android build workflow
* PM-3349 build.yml configured FDROID job for MAUI
* PM-3350 iOS extensions TapGestureRecognizer try Window workaround
* PM-3350 iOS applied workaround on the iOS Autofill and Share extension to maui embed the navigation page with its content page in the Window
* PM-3349 PM-3350 Added workaround for More Options to work on Search and Groupings Page
Updated some code to MAUI Style also
* PM-3349 PM-3350 Added the ability for users to press "Continue" button as a fallback when using the Yubikey if the "SubmitCommand" doesn't trigger automatically.
* PM-3349 PM-3350 Fix for text getting cut/truncated in both account switcher and ciphers/search lists
Issue is due to MAUI but can be avoided by using slightly different layout
* PM-3350 iOS updated CFBundlerShortVersionString to latest one 2023.10.1
* PM-3350 fix build.yml Bitwarden.ipa AppStore exported file
* PM-3350 build.yml added step to validate app for submitting into App Store and have better logs of it
* PM-3350 build.yml Added several fixes like not using MtouchUseLLVM on the iOS builds to fix they taking forever to build and some changes on the automation CI to do a debug build for the moment
* PM-3350 Improved MTouch linking and extra args on iOS related csprojs
* PM-3349 PM-3350 Added MAUI label on self-host settings and on about settings to differentiate from XF app
* PM-3349 PM-3350 build.yml uncommented jobs so we have a more complete workflow
* PM-3349 PM-3350 Minor change: removed unneeded HorizontalTextAlignment from Label.
* PM-3349 Replaced CrossCurrentActivity plugin with MAUI internal CurrentActivity
* PM-3350 Fix iOS extensions navigation and Window/RootViewController handling for TapGestureRecognizer to work
* PM-3350 Cleared left ClipLogger from the iOS extensions debug logging.
* PM-3349 PM-3350 Refactored cipher bindings to have a simpler approach reusing a new CipherItemViewModel to avoid unwanted issues in the app
* PM-3349 Added base structure for avoiding Android Autofill crash. This workaround works but it's not complete as it can't handle the entire workflow when showing CipherSelectionPAge (like checking if it should show LockPage)
* PM-3350 Bumped iOS version
* PM-3350 Changed linker to use default mode given that "Full" is presenting some problems as the linker is stripping things it shouldn't and we're trying to solve it. So for now we will use the mode "Link SDK assemblies only" so QA can test.
* PM-3349 Fix for app crashing on Android when Dark mode is enabled
Removed unused button style for android
* Proof of concept for having multiple window in Android for autofill support and navigating with the help of an Extended splash page.
* PM-3350 Fix crash on Release by adding Interpreter on iOS and also adding System.Security.Cryptography to be ignored by the linker
* PM-3350 Apply Cryptography TrimmerRootAssembly only to iOS
* PM-3350 Updated Plugin.Fingerprint so biometrics work
* Update .github/workflows/build.yml setup-xcode commit hash
Co-authored-by: Vince Grassia <593223+vgrassia@users.noreply.github.com>
* PM-3349 PM-3350 Enabled argon2id and fixed one issue with the Uris when getting the icon image
* PM-3349 Upgraded Android targetSdkVersion to 34
* minor change (public to private fields)
* minor improvemments on autofill-redirect
* PM-3349 Commented the Deploy step for Android job given that we're using the hotfix-rc branch for testing iOS on TestFlight
* PM-3349 Uncommented the Deploy step for Android job
* PM-3349 Ensure "_isResumed=true" is set on App.xaml.cs:Bootstrap
* Reusing App.xaml.cs Navigation for the Android RedirectPage
Some other cleanup and changes
* Improved autofill workaround to better handle switching between windows.
* PM-3349 minor fix to add space in HomePage between the region picker labels.
* Added some comments and improvemments.
* PM-3349 Added Window events unsubscription of events. Also changed code to avoid potentially having multiple autofillwindow
* PM-3349 Minor ui fix (space between buttons in delete account page)
* initial commit of android credential provider service (wip)
* Revert "initial commit of android credential provider service (wip)"
This reverts commit 6011b639586d081687d22d77352a024272ca6841.
* PM-3350 Fix for Delete Account buttons on iOS
* PM-3349 PM-3350 Changed search icon used in app to avoid issue with icon size on iOS
* PM-3349 Added custom window so that we can always get the current Active Window. This is used to support the Android Autofil and multi-window scenarios.
* PM-3349 Fix for icon and text spacing in some list items
* PM-3349 Minor aligment improvemment for region selection in HomePage
* PM-3349 Changed the "track color" for the Android switch so that the color is different from the "thumb"
* PM-3350 Updated version to 2024.1.0 on iOS
* PM-5154 Start implementing Passkeys Autofill in iOS
* PM-5154 Continue Passkeys Autofill in iOS
* initial commit of android credential provider service (wip)
* add cred manager project to build config
* PM-5154 Added Fido2AuthenticationService to provide us a wrapper for the actual implementation
* PM-3349 Fix Picker selection style by doing a custom PickerHandler for Android which uses SetSingleChoiceItems(...) to provide with the appropriate UI
* PM-3350 Updated MauiVersion to 8.0.4-nightly.* to have the TapGestureRecognizer fix applied. This is done on the Directory.Build.props so we don't have to change it on every csproj. Also removed the workaround of TapGestureHack and fix the Show environment picker to work on the extensions as well.
* PM-3350 Added nuget.config so we add the nuget package source for MAUI Nightly builds
* Bump main iOS version
* PM-3350 Removed "iOS" old folder project that has been moved into the MAUI Single app project.
* PM-3350 Improved code safety adding a lot of try...catch and logging throughout the app. Also made the invoking on main thread safer on several places of the app. Additionally, on the GroupingsPageViewModel changed the code removing the old Xamarin hack and just using Replace directly instead of Clearing first to see if that fixes the crash we're having sometimes on the app.
* PM-3350 PM-3349 Updated Unit Test projects to NET 8.0 and fixed it to work with Core project reference. Also fixed a test that was breaking due to CIpherKey creation being wrong. Added "UT" as a constant to add when building/running Core.Test project so we have something on the context that tells us that is for a UT. With this I had to remove FFImageLoading on UT context because it doesn't support NET 8.0
* PM-3350 PM-3349 Updated Readme with MAUI and main branch
* PM-3350 PM-3349 Enable running Core tests
* PM-3350 Fix build.yml format
* PM-3349 Fix navigation when coming from autofill with Accessibility Services enabled. The user was getting into Home page instead of where they were, with this workaround the app navigates as if the account has been switched, leaving the user as closely as possible to where they were, basically on the first screen for the current state of the user.
* PM-3350 PM-3349 Added property to Directory.Build.props to enable Unit Testing globally so Test runners work
* Improve TOTP scan performance on Android
* Move Android camera/scan changes to xaml
* PM-3350 Testing UseInterpreter false on CI build
* PM-3350 Enabled back UseInterpreter on iOS Release given that it crashes on startup without it.
* PM-3349 PM-3350 Improved code safety with try...catch, better invoke on main thread and better null handling.
* PM-3349 PM-3350 Updated XCode version on build.yml to 15.1
* PM-3350 Removed TapGesture Window MAUI hack from iOS.Extension and iOS.ShareExtension
* PM-3350 Fixed CancellationTokenSource proper disposal
* PM-3350 Fix Avatar toolbar icon on extensions to load properly and to take advantage of using directly SkiaSharp to do the native conversion to UIImage. Also improved the toolbar item so that size is set appropriately.
* PM-3349 PM-3350 Fix external link icon
* PM-3350 Added new style to prevent spell check and text prediction
* Fix merge from main
* PM-3350 Commented event collection upload on the timer and when sending the app to background to see if that prevents the app from crashing on release mode.
* PM-3350 Added check for state migration version before trying to migrate LiteDB values into Prefs when there's no need to and that may be inducing crashes on backgrounded iOS apps.
* PM-3350 Try to disable Interpreter to have better crash knowledge. This time testing if avoiding loading the argon2id lib we're able to not use the interpreter.
* PM-5928 Fix circle animation to be shown on verification codes list on each item
* PM-3350 Go back to use Interpreter and added some Directory.Build.props to easily change Codesign properties and also include/exclude iOS extensions / WatchOS from the build.
* PM-3350 Enabled iOS extensions and WatchOS app to be included based on the Directory.Build.props
* PM-3350 Go back to include argon2id and interpreter
* Removing error/loading placeholders of icons on the cells to see if that is causing the background crash on iOS; so we can test this in TestFlight
* [PM-5910] Workaround for for sliding elements in Duo 2FA flow (#2967)
* workaround for sliding elements in duo 2fa flow
* restrict workaround to Android
* restrict workaround to Android
* Revert "restrict workaround to Android"
This reverts commit c2753d5dc4960aeacdb4c798e7273ca86c08881d.
* Revert "restrict workaround to Android"
This reverts commit 69688cfb98e8e3e17812f126b4fd90ffd2ac3cf8.
* PM-5902 fix for account switcher not dismissing when tapping outside (#2974)
* PM-3350 Fix iossimulator-x64 argon2id load so we can test on simulators and also made easier to maintain loading the argon2id library on the iOS projects by setting a general Directory.Build.props that is shared.
* PM-5903 Changed App.xaml.cs SetOption to only update the needed properties instead of replacing the existing Options object which would cause the AccountSwitcher button bug (#2973)
* [PM-5896] Fix MAUI iOS Background crash due to lock files on suspension (#2969)
* PM-5896 Fix background crash on iOS due to lock files when app gets suspended. Changed loading and error placeholders of the CachedImage to not be used and use default icon of IconLabel instead changing visibility.
* PM-5896 Changed methods to be protected so that they don't get removed by the linker.
* PM-5896 Added stub class and references to it so to have stronger references to Icon_Success and Icon_Error so the linker doesn't remove them.
* PM-3349 Removed commented code from build.yml regarding FDroid that is not needed anymore.
* PM-3349 PM-3350 Fix crash on iOS AppGroup container URL because of sln config on AndroidX Credentials. Changed the project reference of Credentials to be a local NuGet.
* PM-6077 Separated Android and iOS HybridWebViewHandler so that it can be used on iOS.Core (#2983)
* [PM-5907] Fix for incorrect TOTP white text color on label when using light theme on iOS (#2982)
* PM-5907 workaround for incorrect textcolor when programmatically changing text on Entry
* Update src/Core/Pages/Vault/CipherAddEditPage.xaml.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-5906] Fix for incorrect Send MaxAccess white text color on label when using light theme on iOS (#2981)
* PM-5906 workaround for incorrect textcolor when programmatically changing text on Entry
* Update src/Core/Pages/Send/SendAddEditPage.xaml.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* PM-3349 PM-3350 Fixed Unit tests because of referencing FFImageLoading when it's not possible
* PM-3349 Added exception on gitignore so the nupkg for the AndroidX Credentials is added
* [PM-5731] Create C# WebAuthn authenticator to support maui apps (#2951)
* [PM-5731] feat: implement get assertion params object
* [PM-5731] feat: add first test
* [PM-5731] feat: add rp mismatch test
* [PM-5731] feat: ask for credentials when found
* [PM-5731] feat: find discoverable credentials
* [PM-5731] feat: add tests for successful UV requests
* [PM-5731] feat: add user does not consent test
* [PM-5731] feat: check for UV when reprompt is active
* [PM-5731] fix: tests a bit, needed some additional "arrange" steps
* [PM-5731] feat: add support for counter
* [PM-5731] feat: implement assertion without signature
* [PM-5732] feat: finish authenticator assertion implementation
note: CryptoFunctionService still needs Sign implemenation
* [PM-5731] chore: minor clean up
* [PM-5731] feat: scaffold make credential
* [PM-5731] feat: start implementing attestation
* [PM-5731] feat: implement credential exclusion
* [PM-5731] feat: add new credential confirmaiton
* [PM-5731] feat: implement credential creation
* [PM-5731] feat: add user verification checks
* [PM-5731] feat: add unknown error handling
* [PM-5731] chore: clean up unusued params
* [PM-5731] feat: partial attestation implementation
* [PM-5731] feat: implement key generation
* [PM-5731] feat: return public key in DER format
* [PM-5731] feat: implement signing
* [PM-5731] feat: remove logging
* [PM-5731] chore: use primary constructor
* [PM-5731] chore: add Async to method names
* [PM-5731] feat: add support for silent discoverability
* [PM-5731] feat: add support for specifying user presence requirement
* [PM-5731] feat: ensure unlocked vault
* [PM-5731] chore: clean up and refactor assertion tests
* [PM-5731] chore: clean up and refactor attestation tests
* [PM-5731] chore: add user presence todo comment
* [PM-5731] feat: scaffold fido2 client
* PM-5731 Fix build updating discoverable flag
* [PM-5731] fix: failing test
* [PM-5731] feat: add sameOriginWithAncestor and user id length checks
* [PM-5731] feat: add incomplete rpId verification
* [PM-5731] chore: document uri helpers
* [PM-5731] feat: implement fido2 client createCredential
* [PM-5731] feat: implement credential assertion in client
* fix wrong signature format
(cherry picked from commit a1c9ebf01fdcf7c64a0ca2533586b2647cc5cf3e)
* [PM-5731] fix: issues after cherry-pick
* Fix incompatible GUID conversions
(cherry picked from commit c801b2fc3aa4400032bb1bda74c034132cc677f1)
* [PM-5731] chore: remove default constructor
* [PM-5731] feat: refactor user interface to increase flexibility
* [PM-5731] feat: implement generic assertion user interface class
* [PM-5731] feat: remove ability to make user presence optional
* [PM-5731] chore: remove logging comments
* [PM-5731] feat: add native reprompt support to the authenticator
* [PM-5731] feat: allow pre and post UV
* [PM-5731] chore: add `Async` to method name. Remove `I` from struct
* [PM-5731] fix: discoverable string repr lowercase
* [PM-5731] chore: don't use C# 12 features
* [PM-5731] fix: replace magic strings and numbers with contants and enums
* [PM-5731] fix: use UTC creation date
* [PM-5731] fix: formatting
* [PM-5731] chore: use properties for public fields
* [PM-5731] chore: remove TODO
* [PM-5731] fix: IsValidRpId
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
* [PM-5154] Implement Passkeys on iOS (#3017)
* [PM-5731] feat: implement get assertion params object
* [PM-5731] feat: add first test
* [PM-5731] feat: add rp mismatch test
* [PM-5731] feat: ask for credentials when found
* [PM-5731] feat: find discoverable credentials
* [PM-5731] feat: add tests for successful UV requests
* [PM-5731] feat: add user does not consent test
* [PM-5731] feat: check for UV when reprompt is active
* [PM-5731] fix: tests a bit, needed some additional "arrange" steps
* [PM-5731] feat: add support for counter
* [PM-5731] feat: implement assertion without signature
* [PM-5732] feat: finish authenticator assertion implementation
note: CryptoFunctionService still needs Sign implemenation
* [PM-5731] chore: minor clean up
* [PM-5731] feat: scaffold make credential
* [PM-5731] feat: start implementing attestation
* [PM-5731] feat: implement credential exclusion
* [PM-5731] feat: add new credential confirmaiton
* [PM-5731] feat: implement credential creation
* [PM-5731] feat: add user verification checks
* [PM-5731] feat: add unknown error handling
* [PM-5731] chore: clean up unusued params
* [PM-5731] feat: partial attestation implementation
* [PM-5731] feat: implement key generation
* [PM-5731] feat: return public key in DER format
* [PM-5731] feat: implement signing
* [PM-5731] feat: remove logging
* [PM-5731] chore: use primary constructor
* [PM-5731] chore: add Async to method names
* [PM-5731] feat: add support for silent discoverability
* [PM-5731] feat: add support for specifying user presence requirement
* [PM-5731] feat: ensure unlocked vault
* [PM-5731] chore: clean up and refactor assertion tests
* [PM-5731] chore: clean up and refactor attestation tests
* [PM-5731] chore: add user presence todo comment
* [PM-5731] feat: scaffold fido2 client
* PM-5731 Fix build updating discoverable flag
* [PM-5731] fix: failing test
* [PM-5731] feat: add sameOriginWithAncestor and user id length checks
* [PM-5731] feat: add incomplete rpId verification
* [PM-5731] chore: document uri helpers
* [PM-5731] feat: implement fido2 client createCredential
* Added iOS passkeys integration, warning this branch has lots of logs to ease "debugging" extensions.
* [PM-5731] feat: implement credential assertion in client
* PM-5154 Fixed select passkey flow and started implementing create passkey on iOS
* fix wrong signature format
* PM-5154 [Passkeys iOS] Fix Credential ID handling on bytes and string formats. Fix Discoverable to be lowercase on set so it doesn't break parsing on clients. Added UserDisplayName on Fido2 entities. Extracted the Guid Standard/Raw format helpers to a extensions class.
* Fix incompatible GUID conversions
* PM-5154 [Passkeys iOS] Added custom UI flow for passkey creation
* PM-5154 [Passkeys iOS] Updated UI for passkey creation
* PM-5154 [Passkeys iOS] Refactored and added cipher selection for passkey creation on autofill search.
* PM-5154 [Passkeys iOS] Fixed empty top space on autofill password list
---------
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
* feat: optimize assertion network calls (#3021)
The server only needs to be updated if we have changed the counter. New passkeys that leave their counters at zero can therefore skip this step.
* [PM-5154] Implement iOS Passkey -> Add login item (#3019)
* PM-5154 Implement iOS passkey add login
* PM-5154 Added Username to Create new login for passkey, for this the param was changed to the Fido2ConfirmNewCredentialParams object so we have access to the proper values. Also added back RpId to the params to have access to it when creating the vault item. Finally added loading to saving the passkey as new login
* [PM-6513] Omit creating CredentialIdentity if it throws an exception (#3040)
* PM-6513 Omit creating CredentialIdentity if that throws, so it doesn't affect other ciphers. E.g. if a Passkey doesn't have a UserName it will throw here and it shouldn't break replacing all the other identities.
* PM-6513 Added fallback values to passkey username not being set
* Fix FIDO2 client bugs (#3056)
* fix: blockedUris null issue
* fix: trailing slash in origin breaking check
* [PM-6466] Implement passkeys User Verification (#3044)
* PM-6441 Implement passkeys User Verification
* PM-6441 Reorganized UserVerificationMediatorService so everything is not in the same file
* PM-6441 Fix Unit tests
* PM-6441 Refactor UserVerification on Fido2Authenticator and Client services to be of an enum type so we can see which specific preference the RP sent and to be passed into the user verification mediator service to perform the correct flow depending on that. Also updated Unit tests.
* PM-6441 Changed user verification logic a bit so if preference is Preferred and the app has the ability to verify the user then enforce required UV and fix issue on on Discouraged to take into account MP reprompt
* [PM-6474] Remove header on Save passkey as new login (#3054)
* PM-6474 Removed header on empty list view on iOS Autofill create passkey flow
* PM-6474 Fix TableView being hidden on Logins scene
* [PM-6496] Improved iOS extensions cipher cell UI (#3058)
* PM-6496 Improved iOS extensions cipher list to have an updated UI for each cell
* PM-6496 Improved UI on iOS extensions list cells
* [PM-5154] Implement combined view for passwords and passkeys on iOS Autofill extension (#3075)
* PM-5154 Implemented combined view of passwords and passkeys and improved search and items UI
* PM-5154 Code improvement from PR feedback
* PM-5154 Code improvement to log unknown exceptions
* PM-6685 Fix race condition issue where the biometrics check is being done before the iOS extension is being shown. So when we need the UI, we wait until ViewDidAppear happens. (#3078)
* PM-6468 Implemented copy TOTP if needed after using a Fido2 credential. Also added the Fido2MediatorService to have one point to interact with the authentication and also to add any new logic we need. (#3082)
* PM-6706 Add maximum attempts to UV with MP and with PIN (#3079)
* [PM-6848] Improved User verification on passkeys creation (#3099)
* PM-6848 Updated cancellation flow on passkey user verification and improved UV enforcement on creation
* PM-6848 Added null checks to help diagnosing if NRE is presented
* PM-6706 Fixed UV attempts to be maximum 5 attempts and not 6 (#3103)
* PM-6793 Updated autofill settings copy (#3102)
* [PM-6655] Add username empty fallback on passkey (#3101)
* PM-6655 Added fallback "Unknown account" to passkey username and moved it so it can be shared with Android
* PM-6655 Improved code lines formatting
* PM-6844 Fix passkey creation cipher list empty label on small devices (#3104)
* [PM-6798] Fix account switch on autofill (#3106)
* PM-6798 Force state update when opening the Autofill extension
* PM-6798 Fix InitAppIfNeededAsync to be awaited and also ignored Fido2AuthenticatorException from logging them to AppCenter since they don't add much information and we're logging in other places what we need
* PM-6475 Fix dark theme on iOS Autofill extension (#3114)
* PM-6850 Removed duplicate MP Reprompt on passkey creation item selection (#3118)
* PM-6538 Removed non-discoverable passkeys filter for credentials that go to the ASStore (#3117)
* [PM-6655] Add null fallback cipher name on passkeys (#3116)
* PM-6655 Fixed fallback value on passkeys to take into account CipherView.Name. Also removed non-discoverable passkey filter on adding credentials to the ASStore and also added the fallback consideration on the passkeys list iOS extension
* PM-6655 Restored non-discoverable filter on credentials set for ASStore on this PR
* PM-6798 Fix account switch on iOS Autofill extension and also changed to Try... actions for TaskCompletionSource to avoid exceptions on some occasions. (#3121)
Co-authored-by: Álison Fernandes <vvolkgang@users.noreply.github.com>
* PM-6209 Removed MAUI label from environment and about pages (#2990)
* [PM-7186] Fallback to password list on exception (#3127)
* PM-7186 Added fallback in case of exception that loads password list
* PM-7186 Added back the error message removed in last commit.
* feat: add support for `credProps.rk` extension (#3132)
* PM-7186 Remove error message when showing password list as a fallback with user interaction (#3133)
* [PM-5153] Android Passkey Implementation (#3020)
* Initial WIP implementation for the app unlock flow when called from Passkey. Still needs code organization and to be finished.
Also added a new Window workaround in App.xaml.cs to allow CredentialProviderSelectionActivity to launch separately.
* Added missing IDeviceActionService.cs implementation for iOS to build.
* Added Async to ReturnToPasskeyAfterUnlockMethod
Changed i18n to AppResource.Unlock
Removed unecessary cast
* minor code change (added comment)
* Added back the case for loading a specific Window for CredentialProviverSelectionActivity
* Added fix for Intent not passing properly to CredentialProviderSelectionActivity
Added Activity cancellation on error during execution of ReturnToPasskeyAfterUnlockAsync()
* Added WIP code for Android passkey implementation. Currently returns a mostly complete response that is missing the ClientDataJson
* Added WIP code for creating passkeys on Android. Still missing unlock flow and response of passkey creation is still not correct.
Removed unused throw NotImplementedException from Fido2ClientService
Added CredentialCreationActivity for passkey creation
Added alternative code on CredentialProviderSelectionActivity to try to debug issue with response not being valid
* Started working on logic to adding unlock flow. It's already handling the unlock but not passing the PendingIntentHandler info for CredentialCreation to CredentialCreationActivity
* Changed "cross-platform" to "platform"
* Created CredentialHelpers.cs class to share code used for Populating Passkeys in Android.
* Added Passkey Credential Creation shared code to CredentialHelpers.
Unlock flow for Passkey creation should now be working also.
* Updated code for checking if the CredentialProviderService has been enabled by the user or not. Still WIP, somes notes in code due to Credential API not being complete.
Also changed the disable code to open the Credential Settings.
* Replaced the AndroidX.Credential helpers with custom JSON creation to fix the response for Credential Creation
* minor code cleanup on CredentialProviderSelectionActivity
* added todo comment
* Feature/maui migraton passkeys android unlock fix andreas (#3077)
* fix: bitwarden providing too many/wrong credentials
* feat: use authenticator instead of client
---------
Co-authored-by: Dinis Vieira <dinisvieira@outlook.com>
* Removed / commented some older Passkey Proof of concept code.
Auth and creation of passkey should still work both when device is unlocked (and not)
Added some initial code in AutofillCiphersPageViewModel and CipherAddEditPageViewModel for handling Passkey creation
* PM-6829 Implemented Fido2...UserInterfaces on Android and necessary logic to get/make a credential with those
* Added IFido2MediatorService registrations
Inverted two IsLockedAsync checks
* Added navigation to autofillCipher when creating passkey
* Updated LockPage to avoid multiple executions of SubmitAsync
* Added new flow for creating new passkey on Android with the Cipher page for editing details
* Changed the Credential Provider Switch to an external link control
* Added i18n for Passkey Settings
* Cleanup of older Credentials code used for Android Fido2 POC.
Removed CredentialCreationActivity as it's no longer needed
* fixed merge conflict/error and added error check to Fido2 navigation in App.xaml.cs
* Removed from MainActivity casts from DeviceActionService
Changed CredentialProviderServiceActivity to handle Fido errors and exceptions gracefully and show the user an error. Still not with the correct messages.
* Added some error messages. Still need to confirm the Text Resource to use and change.
* Changed some messages to use AppResources
* Cleanup of Credential Android code and added exception result if the clientCreateCredentialResult is null
* Updated Add new item button text when creating a new passkey
* Added AccountSwitchedException for the Fido Mediator Service
* Removed TODO that is no longer needed
* Updated some todo messages in Android AutofillHandler
* When authenticating a passkey on Android the "showDialog" callback can be called and there's no MainPage available so it was changed for that specific scenario to use _deviceActionService instead of MainPage.
---------
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-7369] Show passkey icon on android when the item has a Fido2 credential (#3148)
* PM-7369 Show passkey icon on android when the item has a Fido2 credential
* PM-7369 alternative way to show passkey icon only in scenarios where we are trying to create a passkey
* PM-7369 moved logic to show passkey icon to CipherItemViewModel
* Update src/Core/Utilities/IconGlyphConverter.cs
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* PM-7379 Fix creating the PendingIntent for a passkey credential on Android so it has different request codes amongst each other so the extras are not overriden by the last credential entry created. (#3149)
* PM-7365 Fix setting HasUnlockedInThisTransaction on passkey creation on android (#3153)
* PM-7367 Fix empty items state placeholder on Android cipher selection page (#3160)
* [PM-7366] Select cipher on search on Fido2 creation (#3154)
* PM-7366 Implemented cipher selection on search on passkey creation
* PM-7366 Fix typo
* [PM-7385] Fix for allowing switching accounts while creating a passkey of Android (#3155)
* PM-7385 Fixed for allowing switching accounts while creating a passkey on Android.
This fixes also include scenarios where we need to unlock the vault after switching
Also fixed the issue where tapping on cipher won't do anything after switching.
* PM-7385 ensure the Options.Fido2CredentialAction and FromFido2Framework are reset when the Credential flow is started to avoid erratic behaviors when switching accounts, app is in background or other edge case scenarios.
These properties where replaced by calls to _fido2MakeCredentialConfirmationUserInterface.IsConfirmingNewCredential instead.
* Minor changes and added comments
* [PM-7385] Implemented several changes suggested in PR for better/cleaner code.
* PM-7385 Added several minor code improvemments.
* PM-7385 Fix IFido2MakeCredentialConfirmationUserInterface resolve and usage to be constrained to Android. (#3164)
* PM-7385 Fix unit tests for Fido2 service (#3167)
* PM-7518 Updated favicon placeholder color on iOS Autofill extension. (#3165)
* PM-7365 Fix UserVerification on Fido2 credential creation on Android by updating the HasUnlockedInThisTransaction flag when a new transaction starts. (#3168)
* PM-5154 Avoid logging Fido2AuthenticatorExceptions (#3169)
* PM-7258 Updated Android Credential creation details on description to be localized and passed the user email for further details. (#3162)
* [PM-7257] android add support for web authn resident key credential property in our net mobile app 2 (#3170)
* [PM-7257] feat: add ability to override `clientDataHash`
* [PM-7257] feat: add support for clientDataHash and extensions
* PM-7257 Updated the origin to be the correct one and not the android one to be passed to the Fido2Client
---------
Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
* [PM-7365] Fix UV not being performed on Fido2 credential creation Android (#3171)
* PM-7365 Fix UV not being performed on Fido2 credential creation on Android
* PM-7365 Fix PublicKeyCredentialCreationOptions mapping from json on AuthenticatorSelection so mainly userVerification has correct value
* PM-7585 Show error message when Origin is null, given no support for passkeys from native apps yet (#3175)
* PM-7623 Fix proper implementation of IFido2GetAssertionUserInterface now that the Fido2ClientService is being used for passkey autofill (#3174)
* PM-7553 Fix native apps passkeys autofill and creation (#3188)
* [PM-7658] Implement Fido2 privileged apps verification (#3190)
* PM-7553 Fix native apps passkeys autofill and creation
* PM-7658 Implemented Fido2 priviliged apps verification
* [PM-7576] Implemented digital asset links verification on Fido2 flows (#3191)
* PM-7553 Fix native apps passkeys autofill and creation
* PM-7658 Implemented Fido2 priviliged apps verification
* PM-7576 Implemented digital asset links verification on Fido2 flows for native apps.
* PM-7576 Renamed to ValidateAssetLinksAndGetOriginAsync to go along with Google naming and also changed method to private given that public is not necessary
* PM-7576 Moved digital asset links verification to a Core service AssetLinksService and added unit tests for it.
---------
Co-authored-by: Dinis Vieira <dinisvieira@outlook.com>
Co-authored-by: Vince Grassia <593223+vgrassia@users.noreply.github.com>
Co-authored-by: mpbw2 <59324545+mpbw2@users.noreply.github.com>
Co-authored-by: Andreas Coroiu <andreas.coroiu@gmail.com>
Co-authored-by: Álison Fernandes <vvolkgang@users.noreply.github.com>
2024-04-25 22:26:12 +02:00
<data name="PasskeysNotSupportedForThisApp" xml:space="preserve">
<value>Passkeys not supported for this app</value>
</data>
2020-12-18 23:47:34 +01:00
</root>