Browser-based Android integration tutorial
If you have an Android app built with Kotlin, here's a tutorial on how to add Ramp to it in just a few steps.
You can see the full code sample at https://github.com/RampNetwork/integration-example-android.
We recommend using the Ramp Android SDK to integrate Ramp into your Android app natively. See its documentation here.
What do we need to do?
- compose a URL for the Ramp widget with parameters of your choice
- create an intent and send it to the system to handle it
- [OPTIONAL] prepare the app for handle a return intent after a successful purchase
In detail
Composing the widget URL
To compose widget URL you can simply create uri with 'https://app.ramp.network' address.
private fun composeUrl(): String {
return Uri.Builder()
.scheme("https")
.authority("app.ramp.network")
.build()
.toString()
}
This has one big caveat - the user has to copy-paste their information like their crypto address in the widget.
To avoid that, the Ramp widget allows you to provide some parameters before displaying it. You can set options such as wallet address, cryptocurrency and crypto amount, etc. In order to do so, we need to create a URL with proper query parameters as showcased in the snippet below. You can find the description of all available parameters in our documentation.
Let's declare some parameters then.
class MainActivity : AppCompatActivity() {
/**
* TODO() Fill parameters below with your values
*/
private val userAddress = "0x0000000000000000000000000000000000000000" // wallet address
private val swapAsset = "ETH_ETH" // parameter that sets available crypto assets (comma-separated)
private val fiatCurrency = "EUR"
private val fiatValue = "1000" // initial total fiat value of the purchase that will be suggested to the user
private val hostApiKey = "YOUR VALUE"
private val hostAppName = "YOUR VALUE"
private val hostLogoUrl = "YOUR VALUE"
Now, you need to compose the URL using these parameters.
private fun composeUrl(): String {
return Uri.Builder()
.scheme("https")
.authority(rampHost)
.appendQueryParameter("variant", "webview-mobile") // Mandatory QueryParameter for webview integrations
.appendQueryParameter("swapAsset", swapAsset)
.appendQueryParameter("userAddress", userAddress)
.appendQueryParameter("hostApiKey", hostApiKey)
.appendQueryParameter("hostAppName", hostAppName)
.appendQueryParameter("hostLogoUrl", hostLogoUrl)
.build()
.toString()
}
Create an intent and send it
In order to open Ramp in a browser, we need to create an intent with the action parameter set to Intent.ACTION_VIEW
and add the previously created URL as data
. Then, we'll start an activity with this intent. From now on, the system will handle it on its own and it'll open the browser with our URL loaded.
val intent = Intent(Intent.ACTION_VIEW).apply { data = Uri.parse(composeUrl()) }
startActivity(intent)
[OPTIONAL] Handling a URL callback
One of the query parameters you can pass to Ramp widget URL is finalUrl
. If you do this, Ramp will redirect your users to this URL after the purchase is completed. You can use this mechanism for your app to detect purchase completion and perform some actions like notifying your user about the purchase status.
Step 1 - Define a redirection URL
Now, we need to register a URL scheme that's unique for our app. Usually the best way is to simply use the app's name. If your app's name is Ramp-Example, the scheme may be ramp-example
. Next, append a host that is unique for completing Ramp Purchase, for example ramp.purchase.complete
.
Having these two, you can now define a value for the finalUrl
parameter - it will be ramp-example://ramp.purchase.complete
.
Add this parameter to the URL you created earlier.
val finalUrl = "ramp-example://ramp.purchase.complete"
private fun composeUrl(): String {
return Uri.Builder()
.scheme("https")
.authority("app.ramp.network")
...
.appendQueryParameter("finalUrl", finalUrl)
...
.build()
.toString()
}
Step 2 - Register deep link to app content
To create a link to your app content, we need to add an intent filter with action
, data
and category
elements in the AndroidManifest.xml
file. Intent filter should contain action
with ACTION_VIEW
value, two categories with the values DEFAULT
and BROWSABLE
, and data
with scheme
and host
that you defined in step 1. You can find more details on how to add a custom URL scheme in the Android documentation.
<activity android:name=".YourActivity">
<intent-filter android:autoVerify="true">
<data
android:host="ramp.purchase.complete"
android:scheme="ramp-example" />
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
</intent-filter>
</activity>
To prevent multiple instances, add singleTask
value in the launchMode
attribute
<application
...
android:launchMode="singleTask"
...
>
Step 3 - Handle final callback in your activity
Now it's time to handle the URL callback inside your app by overriding the onNewIntent
method in your Activity
just like in the snippets below.
override fun onNewIntent(intent: Intent) {
super.onNewIntent(intent)
processIntent(intent)
}
private fun processIntent(intent: Intent) {
val uri = intent.data?.toString()
if (uri == RAMP_FINAL_URL) {
// show your user that the purchase is complete here
}
}
We also need to ensure that incoming intents will be processed properly in the onCreate
method by using processIntent(it)
in case our activity was killed or is newly created.
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
...
intent?.let { processIntent(it) }
...
}
That's it - your app can now use Ramp to allow your users to buy crypto easily.
If you want to provide the best off-ramping (selling crypto) experience to your users, we recommend to take advantage of the Native Flow. Implementation of the native flow may be required in some native mobile apps. You can see more details here.