react-native-keychain/index.ios.js

161 lines
4.7 KiB
JavaScript
Raw Normal View History

2015-05-20 16:23:04 +00:00
/**
2015-05-20 18:39:52 +00:00
* @providesModule Keychain
2015-05-20 16:23:04 +00:00
*/
'use strict';
2015-07-06 10:49:20 +00:00
var { NativeModules } = require('react-native');
2015-05-20 18:39:52 +00:00
var RNKeychainManager = NativeModules.RNKeychainManager;
2015-05-20 16:23:04 +00:00
var Keychain = {
2015-05-20 18:39:52 +00:00
/**
* Saves the `username` and `password` combination for `server`
* and calls `callback` with an `Error` if there is any.
* Returns a `Promise` object.
*/
setInternetCredentials: function(
server: string,
username: string,
password: string,
callback?: ?(error: ?Error) => void
): Promise {
return new Promise((resolve, reject) => {
RNKeychainManager.setInternetCredentialsForServer(server, username, password, function(err) {
callback && callback((err && convertError(err)) || null);
if (err) {
reject(convertError(err));
} else {
resolve();
}
});
});
},
/**
* Fetches login combination for `server` as an object with the format `{ username, password }`
* and passes the result to `callback`, along with an `Error` if there is any.
* Returns a `Promise` object.
*/
getInternetCredentials: function(
server: string,
callback?: ?(error: ?Error, result: ?string) => void
): Promise {
return new Promise((resolve, reject) => {
RNKeychainManager.getInternetCredentialsForServer(server, function(err, username, password) {
err = convertError(err);
if(!err && arguments.length === 1) {
err = new Error('No keychain entry found for server "' + server + '"');
}
callback && callback((err && convertError(err)) || null, username, password);
if (err) {
reject(convertError(err));
} else {
resolve({ username, password });
}
});
});
},
/**
2015-05-29 16:25:56 +00:00
* Deletes all internet password keychain entries for `server` and calls `callback` with an
* `Error` if there is any.
2015-05-20 18:39:52 +00:00
* Returns a `Promise` object.
*/
resetInternetCredentials: function(
server: string,
callback?: ?(error: ?Error) => void
): Promise {
return new Promise((resolve, reject) => {
RNKeychainManager.resetInternetCredentialsForServer(server, function(err) {
callback && callback((err && convertError(err)) || null);
if (err) {
reject(convertError(err));
} else {
resolve();
}
});
});
},
2015-05-20 16:23:04 +00:00
2015-05-29 16:25:56 +00:00
/**
* Saves the `username` and `password` combination for `service` (defaults to `bundleId`)
* and calls `callback` with an `Error` if there is any.
* Returns a `Promise` object.
*/
setGenericPassword: function(
username: string,
password: string,
service?: string,
callback?: ?(error: ?Error) => void
): Promise {
return new Promise((resolve, reject) => {
RNKeychainManager.setGenericPasswordForService(service, username, password, function(err) {
callback && callback((err && convertError(err)) || null);
if (err) {
reject(convertError(err));
} else {
resolve();
}
});
});
},
/**
* Fetches login combination for `service` (defaults to `bundleId`) as an object with the format
* `{ username, password }` and passes the result to `callback`, along with an `Error` if
* there is any.
* Returns a `Promise` object.
*/
getGenericPassword: function(
service?: string,
callback?: ?(error: ?Error, result: ?string) => void
): Promise {
return new Promise((resolve, reject) => {
RNKeychainManager.getGenericPasswordForService(service, function(err, username, password) {
err = convertError(err);
if(!err && arguments.length === 1) {
err = new Error('No keychain entry found' + (service ? ' for service "' + service + '"' : ''));
}
callback && callback((err && convertError(err)) || null, username, password);
if (err) {
reject(convertError(err));
} else {
resolve({ username, password });
}
});
});
},
/**
* Deletes all generic password keychain entries for `service` (defaults to `bundleId`) and calls
* `callback` with an `Error` if there is any.
* Returns a `Promise` object.
*/
resetGenericPassword: function(
service?: string,
callback?: ?(error: ?Error) => void
): Promise {
return new Promise((resolve, reject) => {
RNKeychainManager.resetGenericPasswordForService(service, function(err) {
callback && callback((err && convertError(err)) || null);
if (err) {
reject(convertError(err));
} else {
resolve();
}
});
});
},
2015-05-20 16:23:04 +00:00
};
2015-05-20 18:39:52 +00:00
function convertError(err) {
if (!err) {
return null;
}
var out = new Error(err.message);
out.key = err.key;
return out;
}
2015-05-20 16:23:04 +00:00
module.exports = Keychain;