This is a React Native native module inspired by wayneholis/react-native-humanapi library.
The Human API SDK has been updated to the latest build. We will be constantly updating this package for our own project.
$ npm install react-native-human-api --save
$ react-native link react-native-human-api
Even with the automatic installation there are remaining steps to finishing the Android import
- Add the following lines to
android/settings.gradle
:
include ':humanapi-sdk'
project(':humanapi-sdk').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-human-api/android/humanapi-sdk')
- In XCode, in the project navigator, right click
Libraries
➜Add Files to [your project's name]
- Go to
node_modules
➜react-native-react-native-human-api
and addRNReactNativeHumanApi.xcodeproj
- In XCode, in the project navigator, select your project. Add
libRNReactNativeHumanApi.a
to your project'sBuild Phases
➜Link Binary With Libraries
- Run your project (
Cmd+R
)<
- Open up
android/app/src/main/java/[...]/MainApplication.java
- Add
import io.citizenhealth.humanapi.RNReactNativeHumanApiPackage;
to the imports at the top of the file - Add
new RNReactNativeHumanApiPackage()
to the list returned by thegetPackages()
method
- Append the following lines to
android/settings.gradle
:include ':react-native-human-api' project(':react-native-human-api').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-human-api/android') include ':humanapi-sdk' project(':humanapi-sdk').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-human-api/android/humanapi-sdk')
- Insert the following lines inside the dependencies block in
android/app/build.gradle
:compile project(':react-native-human-api')
Go to https://developer.humanapi.co/signup and register for an account.
First import the component and render a button to open it.
import RNHumanAPI from 'react-native-human-api';
// Call the API with a connect function
render() {
...
<TouchableOpacity style={styles.button} onPress={this.connectHumanAPI}>
<Text style={styles.instructions}>
Connect HumanAPI
</Text>
</TouchableOpacity>
...
}
Add your client id, secret and app key. You can get those from https://developer.humanapi.co under the settings tab in your Human API account. Also add the Human API redirect URLs.
const baseURL = 'https://connect.humanapi.co/embed?';
const clientID = 'xxxx'; //Add your clientId here
const clientSecret = 'xxx'; //Add your client secret here
const appKey = 'xxx'; // Add your App Key here
const finishURL = 'https://connect.humanapi.co/blank/hc-finish';
const closeURL = 'https://connect.humanapi.co/blank/hc-close';
const authURL = 'https://xxx' // Add your backend auth endpoint
Then implement the call. Here, you need to store and retrieve the user public token to either create a user account or if the token exists, just login to the user Human API data. I am assuming in the example below that the public_token and the client_user_id are a component property. This should be part of your user account saved data. public_token = null if the user has not connected for the first time yet.
connectHumanAPI = () => {
const {
public_token,
client_user_id
} = this.props.user;
const humanAPI = new RNHumanAPI()
const options = (public_token) ? {
client_id: clientID,
client_user_id: client_user_id,
public_token: public_token,
auth: (data) => this.sendAuth(data),
auth_url: authURL,
success: (data) => {
console.log(`Human API Callback: ${data}`);
// save publicToken in your user account
this._savePublicToken(data.public_token);
}, // callback when success with auth_url
cancel: () =>
console.log('cancel') // callback when cancel
} : {
client_id: clientID,
client_user_id: client_user_id,
auth: (data) => this.sendAuth(data),
auth_url: authURL,
success: (data) => {
// save publicToken
this._savePublicToken(data.public_token);
}, // callback when success with auth_url
cancel: () =>
console.log('cancel') // callback when cancel
}
humanAPI.onConnect(options)
}
}
A backend endpoint is required to handle the auth redirect and handshake with the Human API server.
Here is a Google Firebase example of a simple Node.js microservice to deploy for this purpose:
// Human API auth handler service on Google Firebase
const request = require('request');
exports.humanAPIHandshake = function(req, res, database, callback) {
var sessionTokenObject = req.body;
sessionTokenObject.clientSecret = 'xxx'; // Your Human API account client secret
request({
method: 'POST',
uri: 'https://user.humanapi.co/v1/connect/tokens',
json: sessionTokenObject
}, (err, resp, body) => {
if(err) {
console.log(`error = ${err}`);
callback(false);
return;
}
// This is the response from the Human API server after authentication
console.log("clientId ="+ body.clientId);
console.log("humanId = " + body.humanId);
console.log("accessToken = "+ body.accessToken);
console.log("publicToken = "+ body.publicToken);
//Send back publicToken to app
var responseJSON = {
humanId: body.humanId,
accessToken: body.accessToken,
publicToken: body.publicToken
};
callback(true, responseJSON);
return;
});
}
Please send any bug or comment to dev@citizenhealth.io
- See LICENSE