7.1.0 • Published 5 months ago

@capgo/capacitor-autofill-save-password v7.1.0

Weekly downloads
-
License
MIT
Repository
github
Last release
5 months ago

@capgo/capacitor-autofill-save-password

Prompt to display dialog for saving password to keychain from webview app

Fork of original plugin to work with Capacitor 7

IOS work for old versions and 18.3

Android still WIP

Install

npm install @capgo/capacitor-autofill-save-password
npx cap sync

Prerequisite

You must set up your app’s associated domains. To learn how to set up your app’s associated domains, see Supporting Associated Domains in Apple Developer document.

Then add in your App.entitlements

	<key>com.apple.developer.associated-domains</key>
	<array>
		<string>webcredentials:YOURDOMAIN</string>
	</array>

To associate your domain to your app.

How to use

import { Capacitor } from '@capacitor/core';
import { SavePassword } from '@capgo/capacitor-autofill-save-password';
    
login(username: string, password: string) {
    // your login logic here
        
        SavePassword.promptDialog({
            username: username,
            password: password,
        })
        .then(() => console.log('promptDialog success'))
        .catch((err) => console.error('promptDialog failure', err));
}

Android

Add apply plugin: 'com.google.gms.google-services' beneath apply plugin: 'com.android.application' in android/app/build.gradle

this will allow the plugin to import the proper lib.

Then you need to make sure you did set properly your domain and did add google-services.json.

guide here https://developer.android.com/identity/sign-in/credential-manager

You need to have the file at this path android/google-services.json set, if you dont use firebase add empty json

then add your domain in example-app/android/app/src/main/res/values/strings.xml

with

    <string name="asset_statements" translatable="false">
    [{
    \"include\": \"https://YOURDOMAIN/.well-known/assetlinks.json\"
    }]
    </string>

API

promptDialog(...)

promptDialog(options: Options) => Promise<void>

Save a password to the keychain.

ParamTypeDescription
optionsOptions- The options for the password.

readPassword()

readPassword() => Promise<ReadPasswordResult>

Read a password from the keychain. Requires the developer to setup associated domain for the app for iOS.

Returns: Promise<ReadPasswordResult>


Interfaces

Options

PropTypeDescription
usernamestringThe username to save.
passwordstringThe password to save.
urlstringThe url to save the password for. (For example: "web.capgo.app") iOS only.

ReadPasswordResult

PropTypeDescription
usernamestringThe username of the password.
passwordstringThe password of the password.
7.1.0

5 months ago

6.0.1

6 months ago

6.0.0

6 months ago

7.0.4

6 months ago

7.0.3

6 months ago

7.0.2

6 months ago

7.0.1

6 months ago