To include the Datadog integration for Glide in your project, simply add the
following to your application's build.gradle
file.
dependencies {
implementation "com.datadoghq:dd-sdk-android:<latest-version>"
implementation "com.datadoghq:dd-sdk-android-glide:<latest-version>"
}
Before you can use the SDK, you need to setup the library with your application context, your Client token and your Application ID. To generate a Client token and an Application ID please check UX Monitoring > RUM Applications > New Application in the Datadog dashboard.
class SampleApplication : Application() {
override fun onCreate() {
super.onCreate()
val configuration = Configuration.Builder().build()
val credentials = Credentials(
<CLIENT_TOKEN>,
<ENV_NAME>,
<APP_VARIANT_NAME>,
<APPLICATION_ID>
)
Datadog.initialize(this, credentials, configuration, trackingConsent)
val monitor = RumMonitor.Builder().build()
GlobalRum.registerIfAbsent(monitor)
}
}
Following Glide's Generated API documentation, you then need to create your own GlideAppModule
with Datadog integrations by extending the DatadogGlideModule
, as follow.
Doing so will automatically track Glide's network requests (creating both APM Traces and RUM Resource events), and will also listen for disk cache and image transformation errors (creating RUM Error events).
@GlideModule
class CustomGlideModule :
DatadogGlideModule(
listOf("example.com", "example.eu"), traceSamplingRate = 20f
)
Network requests are sampled with an adjustable sampling rate. A sampling of 20% is applied by default.
Pull requests are welcome, but please open an issue first to discuss what you would like to change. For more information, read the Contributing Guide.