light-mode-image
Learn
SDKs

MATTR Pi mDocs Holder SDKs Overview

Overview

The mDocs Holder SDKs are based on the ISO/IEC 18013-5 standard which establishes an interoperable digital representation of mobile-based credentials such as mobile drivers licenses (mDL). However, these SDKs can extend the same technology and architecture to more than just mDLs, but rather any conforming mobile document (mDoc) - a term defined in ISO/IEC 18013-5.

The mDocs Holder SDKs are available for React Native, iOS, and Android. They help developers add mDocs holding features to their apps, allowing users to securely claim and present mDocs in various interoperable workflows.

To get started with any of our mDocs Holder SDKs, please contact us.

SDK Capabilities

The mDocs Holder SDKs offer tools to assist developers integrating the following capabilities into their applications:

Supported features

ISO/IEC 18013-5

Below is a summary of ISO/IEC 18013-5:2021 features supported by the mDocs Holder SDKs:

FeatureSupported optionsDefault
Device engagementQR codeQR code
Device retrieval data transportBLE with either mDoc peripheral server or mDoc central client modeBLE with mDoc central client
Ephemeral session key curveAny NIST P-* keysP-256 key using secure enclave
Device authentication modeDigital Signature or ECDH-agreed MACDigital Signature with a P-256 key using secure enclave
FeatureSupported optionsDefault
Device engagementQR code or NFCNo default; explicit selection required
Device retrieval data transportBLE with either mDoc peripheral server or mDoc central client modeBLE with mDoc central client
Ephemeral session key curveAny NIST P-* keysP-256 key using Keystore
Device authentication modeDigital Signature or ECDH-agreed MACDigital Signature with a P-256 key using Keystore
FeatureSupported optionsDefault
Device engagementQR codeQR code
Device retrieval data transportBLE with either mDoc peripheral server or mDoc central client modeBLE with mDoc peripheral server
Ephemeral session key curveAny NIST P-* keysP-256 key using secure enclave (iOS) / Keystore (Android)
Device authentication modeDigital Signature or ECDH-agreed MACDigital Signature with a P-256 key using secure enclave (iOS) / Keystore (Android)

ISO/IEC 18013-7

Below is a summary of ISO/IEC 18013-7:2025 features supported by the mDocs Holder SDKs:

FeatureOptions SupportedDefault Option Selected
Data Retrieval methodsOID4VPOID4VP
Wallet InvocationCustom URL and QR Code-basedBoth
MDoc Reader validationStored verifier certificates, client Metadata retrievalBoth
Authorization Response EncryptionECDH in Direct Key Agreement modeECDH in Direct Key Agreement mode
FeatureOptions SupportedDefault Option Selected
Data Retrieval methodsOID4VPOID4VP
Wallet InvocationCustom URL and QR Code-basedBoth
MDoc Reader validationStored verifier certificates, client Metadata retrievalBoth
Authorization Response EncryptionECDH in Direct Key Agreement modeECDH in Direct Key Agreement mode
FeatureOptions SupportedDefault Option Selected
Data Retrieval methodsOID4VPOID4VP
Wallet InvocationCustom URL and QR Code-basedBoth
MDoc Reader validationStored verifier certificates, client Metadata retrievalBoth
Authorization Response EncryptionECDH in Direct Key Agreement modeECDH in Direct Key Agreement mode

System requirements

The iOS mDocs Holder SDK is developed in the Swift programming language and is meant for integration into iOS applications developed in Swift and/or Objective-C. Specifically it currently only supports applications developed in iOS 15 and above.

Digital Credentials API support (iOS 26+): The SDK supports the Digital Credentials API for presenting credentials via an OS-native overlay without launching your app. This feature requires iOS 26 or later.

This SDK is developed in the Kotlin programming language and is meant for integration into Android applications. It currently supports Android 7 (API level 24) and above.

This SDK is meant for integration into React Native applications using React Native 0.78 and above. Supported operating systems are:

  • iOS 15 or higher.
  • Android 7 or higher.

Dependencies

This section lists all dependencies for using mDocs Holder SDKs.

Third party dependencies

Apple frameworks

Toolchain dependencies

  • Swift 5.10.
  • iOS support: The SDK functionality is only available for devices from iOS 15 onwards.
  • Xcode: The SDK requires Xcode 26.0.0 (17A324) or later. Our CI builds use the latest stable Xcode available in GitHub Actions (setup-xcode action with the latest-stable label). Ensure that your development environment and CI pipelines meet or exceed this minimum to avoid build failures.
  • macOS 15.

Kotlin, AGP, Gradle, and Android Studio

The Android Holder SDK is built using Kotlin 2.0. This adds some intrinsic dependencies into your build tools.

  • Kotlin 2.0 is supported from AGP version 8.5.
  • AGP 8.5 is supported from Gradle version 8.7 and Android Studio Koala 2024.1.1.

Runtime

A list of runtime dependencies and licenses is generated at build time and packaged in res/raw/dependencies_licenses.html. The majority are Kotlin and Android, the rest are listed below:

Standard libraries

Third-party libraries

  • None.

Versions

Below are the available versions of the mDocs Holder SDKs, including the current active version, supported versions, and those that have reached end-of-life (EOL).

Major versionStatusLatest releaseEnd of Life dateDocumentation
v5Active5.0.0-SDK Docs
v4Maintenance4.4.013-05-2026SDK Docs
v3End of Life3.0.07-10-2025-
v2End of Life2.0.026-08-2025-
v1End of Life1.0.005-05-2025-
Major versionStatusLatest releaseEnd of Life dateDocumentation
v6Active6.0.0-SDK Docs
v5Maintenance5.3.213-05-2026SDK Docs
v4End of Life4.1.130-12-2025-
v3End of Life3.0.07-10-2025-
v2End of Life2.0.026-08-2025-
v1End of Life1.1.005-05-2025-
Major versionStatusLatest releaseEnd of Life dateDocumentation
v8Active8.1.2-SDK Docs
v7End of Life7.0.012-12-2025-
v6End of Life6.0.019-11-2025-

Release candidates (RC) are pre-release versions that may contain new features or changes that are not yet fully tested. They are intended for testing purposes, are not subject to our SLA and should not be used in production environments.

How would you rate this page?

Last updated on

On this page