Authentication
This is an add-on feature of the Notificare library. You will need to subscribe to the Users & Authentication add-on and configure this service as described here. With this feature your application can provide creation, authentication and management of user accounts.
In this page we will dive deeper into this functionality. This functionality is built based on the OAuth2 standard, providing your application with the means to create accounts, authenticate users, send email activations, recover and change passwords and refresh access tokens when needed.
First, make sure you declare the following URL Schemes in your app's AndroidManifest.xml file:
<activity
android:name=".MainActivity"
android:label="@string/app_name"
android:launchMode="singleTop"
android:configChanges="keyboard|keyboardHidden|orientation|screenSize">
// ... more
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<data
android:host="${notificareHost}"
android:pathPrefix="/oauth/resetpassword/${notificareAppId}"
android:scheme="https" />
</intent-filter>
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<data
android:host="${notificareHost}"
android:pathPrefix="/oauth/validate/${notificareAppId}"
android:scheme="https" />
</intent-filter>
</activity>
Make sure you replace ${notificareAppId} with your app's own ID, e.g., by including it in your build.gradle as a build variable. You can find the ID in your app's configuration page, as described here.
This allow you to handle the reset password and account activation process after users click validation links from an automated email message.
Create an Account
You are able to create an account by simply invoking the method below and providing three required parameters: email, name and password.
Notificare.createAccount(email, name, password).then((result) => {
//Handle success
}).catch((e) => {
//Handle error
});
Validate an Account
By default, a newly created account will receive a validation email. This will contain a link to validate the email address. When users click in that email, it will open your app and trigger the following event which you should use to validate the account:
DeviceEventEmitter.addListener('activationTokenReceived', (data) => {
Notificare.validateAccount(data.token).then((result) => {
//Handle success
}).catch((e) => {
//Handle error
});
});
Recover an Account
Provide your users with a way of requesting a new password when they forget it. You will have to request the email address from your user and call the following method:
Notificare.sendPassword(email).then((result) => {
//Handle success
}).catch((e) => {
//Handle error
});
Upon success, an email with instructions will be sent to your user containing a link that allows the user to complete the password reset process. When a user clicks in that link, your app will open and a token will be passed to your code via the following event:
DeviceEventEmitter.addListener('resetPasswordTokenReceived', (data) => {
//Keep a reference of the data.token
});
Keep a reference to that token and build UI to be able to capture the new password. Then, with the token received previously and the new password provided by the user, you can use the following method to complete this operation:
Notificare.resetPassword(password, token).then((result) => {
//Handle success
}).catch((e) => {
//Handle error
});
After this point, you user will be able to sign in using the new password.
Authenticate an Account
To authenticate the user invoke the following method:
Notificare.login(email, password).then((result) => {
//Handle success
}).catch((e) => {
//Handle error
});
If authentication fails or the user session is for some reason terminated, you should use the following delegate to handle your app's UI accordingly:
DeviceEventEmitter.addListener('accountSessionFailedToRenewWithError', (data) => {
//Handle revoke or expired session. You might want to show the login screen in response to this event
});
User Details
When a user is authenticated, you can easily get their data by calling the following method. On success it will return the user object.
Notificare.fetchAccountDetails().then((user) => {
//Handle success
}).catch((e) => {
//Handle error
});
Access Token
At any time after the user is signed in you can generate a access token. This will also create a Push Mail address. Once you generate an access token, you can send push remote notifications to your users via email. Every time this method is invoked a new token/email will be generated.
Notificare.generateAccessToken().then((result) => {
//Handle success
}).catch((e) => {
//Handle error
});
Change a Password
To provide your authenticated in users with the means to change their password you could build UI that requires the user to insert a new password and then invoke the following method:
Notificare.changePassword(password).then((result) => {
//Handle success
}).catch((e) => {
//Handle error
});
Sign out
To end a user session invoke the following method:
Notificare.logout().then((result) => {
//Handle success
}).catch((e) => {
//Handle error
});