mirror of
https://github.com/danielsogl/awesome-cordova-plugins.git
synced 2025-02-14 04:05:23 +08:00
138 lines
3.3 KiB
TypeScript
138 lines
3.3 KiB
TypeScript
import { Injectable } from '@angular/core';
|
|
import { CordovaCheck, CordovaInstance, IonicNativePlugin, Plugin } from '@ionic-native/core';
|
|
|
|
/**
|
|
* @hidden
|
|
*/
|
|
export class SecureStorageObject {
|
|
|
|
constructor(private _objectInstance: any) { }
|
|
|
|
/**
|
|
* Gets a stored item
|
|
* @param key {string}
|
|
* @returns {Promise<string>}
|
|
*/
|
|
@CordovaInstance({
|
|
callbackOrder: 'reverse'
|
|
})
|
|
get(key: string): Promise<string> { return; }
|
|
|
|
/**
|
|
* Stores a value
|
|
* @param key {string}
|
|
* @param value {string}
|
|
* @returns {Promise<any>}
|
|
*/
|
|
@CordovaInstance({
|
|
callbackOrder: 'reverse'
|
|
})
|
|
set(key: string, value: string): Promise<any> { return; }
|
|
|
|
/**
|
|
* Removes a single stored item
|
|
* @param key {string}
|
|
* @returns {Promise<string>} returns a promise that resolves with the key that was removed
|
|
*/
|
|
@CordovaInstance({
|
|
callbackOrder: 'reverse'
|
|
})
|
|
remove(key: string): Promise<string> { return; }
|
|
|
|
/**
|
|
* Get all references from the storage.
|
|
* @returns {Promise<string[]>} returns a promise that resolves with array of keys storage
|
|
*/
|
|
@CordovaInstance({
|
|
callbackOrder: 'reverse'
|
|
})
|
|
keys(): Promise<string[]> { return; }
|
|
|
|
/**
|
|
* Clear all references from the storage.
|
|
* @returns {Promise<any>}
|
|
*/
|
|
@CordovaInstance({
|
|
callbackOrder: 'reverse'
|
|
})
|
|
clear(): Promise<any> { return; }
|
|
|
|
/**
|
|
* Brings up the screen-lock settings
|
|
* @returns {Promise<any>}
|
|
*/
|
|
@CordovaInstance()
|
|
secureDevice(): Promise<any> { return; }
|
|
|
|
}
|
|
|
|
/**
|
|
* @name Secure Storage
|
|
* @description
|
|
* This plugin gets, sets and removes key,value pairs from a device's secure storage.
|
|
*
|
|
* Requires Cordova plugin: `cordova-plugin-secure-storage`. For more info, please see the [Cordova Secure Storage docs](https://github.com/Crypho/cordova-plugin-secure-storage).
|
|
*
|
|
* The browser platform is supported as a mock only. Key/values are stored unencrypted in localStorage.
|
|
*
|
|
* @usage
|
|
*
|
|
* ```typescript
|
|
* import { SecureStorage, SecureStorageObject } from '@ionic-native/secure-storage';
|
|
*
|
|
* constructor(private secureStorage: SecureStorage) { }
|
|
*
|
|
* ...
|
|
*
|
|
* this.secureStorage.create('my_store_name')
|
|
* .then((storage: SecureStorageObject) => {
|
|
*
|
|
* storage.get('key')
|
|
* .then(
|
|
* data => console.log(data),
|
|
* error => console.log(error)
|
|
* );
|
|
*
|
|
* storage.set('key', 'value')
|
|
* .then(
|
|
* data => console.log(data),
|
|
* error => console.log(error)
|
|
* );
|
|
*
|
|
* storage.remove('key')
|
|
* .then(
|
|
* data => console.log(data),
|
|
* error => console.log(error)
|
|
* );
|
|
*
|
|
* });
|
|
*
|
|
*
|
|
* ```
|
|
* @classes
|
|
* SecureStorageObject
|
|
*/
|
|
@Plugin({
|
|
pluginName: 'SecureStorage',
|
|
plugin: 'cordova-plugin-secure-storage',
|
|
pluginRef: 'cordova.plugins.SecureStorage',
|
|
repo: 'https://github.com/Crypho/cordova-plugin-secure-storage',
|
|
platforms: ['Android', 'Browser', 'iOS', 'Windows']
|
|
})
|
|
@Injectable()
|
|
export class SecureStorage extends IonicNativePlugin {
|
|
|
|
/**
|
|
* Creates a namespaced storage.
|
|
* @param store {string}
|
|
* @returns {Promise<SecureStorageObject>}
|
|
*/
|
|
@CordovaCheck()
|
|
create(store: string): Promise<SecureStorageObject> {
|
|
return new Promise((res: Function, rej: Function) => {
|
|
const instance = new (SecureStorage.getPlugin())(() => res(new SecureStorageObject(instance)), rej, store);
|
|
});
|
|
}
|
|
|
|
}
|