Skip to content

Commit

Permalink
feat(keychain-touch-id): add KeychainTouchId plugin (#1837)
Browse files Browse the repository at this point in the history
  • Loading branch information
MoemenMostafa authored and ihadeed committed Aug 23, 2017
1 parent 1c6a3a3 commit a2cc187
Showing 1 changed file with 106 additions and 0 deletions.
106 changes: 106 additions & 0 deletions src/@ionic-native/plugins/keychain-touch-id/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,106 @@
import { Injectable } from '@angular/core';
import { Plugin, Cordova, IonicNativePlugin } from '@ionic-native/core';

/**
* @name Keychain Touch Id
* @description
* A cordova plugin adding the iOS TouchID / Android fingerprint to your
* app and allowing you to store a password securely in the device keychain.
*
* @usage
* ```typescript
* import { KeychainTouchId } from '@ionic-native/keychain-touch-id';
*
*
* constructor(private keychainTouchId: KeychainTouchId) { }
*
* ...
*
*
* this.keychainTouchId.isAvailable()
* .then((res: any) => console.log(res))
* .catch((error: any) => console.error(error));
*
* ```
*/
@Plugin({
pluginName: 'KeychainTouchId',
plugin: 'cordova-plugin-keychain-touch-id',
pluginRef: 'plugins.touchid',
repo: 'https://github.com/sjhoeksma/cordova-plugin-keychain-touch-id',
platforms: ['Android', 'iOS']
})
@Injectable()
export class KeychainTouchId extends IonicNativePlugin {

/**
* Check if Touch ID / Fingerprint is supported by the device
*
* @return {Promise<any>} Returns a promise that resolves when there is hardware support
*/
@Cordova()
isAvailable(): Promise<any> {
return;
}

/**
* Encrypts and Saves a password under the key in the device keychain, which can be retrieved after
* successful authentication using fingerprint
*
* @param key {string} the key you want to store
* @param password {string} the password you want to encrypt and store
* @return {Promise<any>} Returns a promise that resolves when there is a result
*/
@Cordova()
save(key: string, passwrod: string): Promise<any> {
return;
}

/**
* Opens the fingerprint dialog, for the given key, showing an additional message. Promise will resolve
* with the password stored in keychain or will resolve an error code, where -1 indicated not available.
*
* @param key {string} the key you want to retrieve from keychain
* @param message {string} a message to the user
* @return {Promise<any>} Returns a promise that resolves when the key value is successfully retrieved or an error
*/
@Cordova()
verify(key: string, message: string): Promise<any> {
return;
}

/**
* Checks if there is a password stored within the keychain for the given key.
*
* @param key {string} the key you want to check from keychain
* @return {Promise<any>} Returns a promise that resolves with success if the key
* is available or failure if key is not
*/
@Cordova()
has(key: string): Promise<any> {
return;
}

/**
* Deletes the password stored under given key from the keychain.
*
* @param key {string} the key you want to delete from keychain
* @return {Promise<any>} Returns a promise that resolves with success if the key
* is deleted or failure if key is not
*/
@Cordova()
delete(key: string): Promise<any> {
return;
}

/**
* Sets the language of the fingerprint dialog
*
* @param locale {string} locale subtag from this list
* https://www.iana.org/assignments/language-subtag-registry/language-subtag-registry
*
*/
@Cordova()
setLocale(locale: string): void { }

}

0 comments on commit a2cc187

Please sign in to comment.