Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

  1. Request camera access.

  2. Configure the capture feature using the CaptureConfiguration.

  3. Register an activity result handler with the CaptureFlowContract().

  4. Launch the SDK with GiniBank.startCaptureFlow().

  5. Handle the extraction results.

  6. Send the final transfer summary values to Gini by calling GiniBank.sendTransferSummary()method which will be used to improve the future extraction accuracy

  7. Clean up the SDK by calling GiniBank.releaseCapture() while also providing the required extraction feedback to improve future extraction accuracy. which will release the resources used by SDK.

Follow these recommendations:

Note
  • Provide values for all necessary fields, including those that were not extracted.

  • Provide the final data approved by the user (and not the initially extracted only).

  • Do cleanup only after TAN verification.

...

Drawio
mVer2
zoom1
simple0
inComment0
custContentId2884089
pageId2949214
lbox1
diagramDisplayNameUntitled Diagram-1675761818164.drawio
contentVer6
revision6
baseUrlhttps://gini.atlassian.net/wiki
diagramNameUntitled Diagram-1675761818164.drawio
pCenter0
width860
links
tbstyle
height379.5
Info

Check out an example app to see how an integration can look like.

...

Code Block
languagekotlin
// Use the androidx's Activity Result API to register a handler for the capture result.
val captureLauncher = registerForActivityResult(CaptureFlowContract()) { result: CaptureResult ->
    when (result) {
        is CaptureResult.Success -> {
            handleExtractions(result.specificExtractions)
        }
        is CaptureResult.Error -> {
            when (result.value) {
                is ResultError.Capture -> {
                    val captureError: GiniCaptureError = (result.value as ResultError.Capture).giniCaptureError
                    handleCaptureError(captureError)
                }
                is ResultError.FileImport -> {
                    // See the File Import section on the Capture Features page for more details.
                    val fileImportError = result.value as ResultError.FileImport
                    handleFileImportError(fileImportError)
                }
            }
            GiniBank.releaseCapturesendTransferSummary(
                "", "", "", this"", "", Amount.EMPTY
            )
  "", "", "", "", Amount.EMPTY          GiniBank.releaseCapture(
                this
            )
        }
        CaptureResult.Empty -> {
            handleNoExtractions()
            GiniBank.releaseCapturesendTransferSummary(
                "", "", "", this"", "", Amount.EMPTY
            )
        "", "", "", "", Amount.EMPTYGiniBank.releaseCapture(
                this
            )
        }
        CaptureResult.Cancel -> {
            handleCancellation()
            GiniBank.releaseCapturesendTransferSummary(
                this"", "", "", "", "", Amount.EMPTY
            )
        "", "", "", "", Amount.EMPTYGiniBank.releaseCapture(
                this
            )
        }
        CaptureResult.EnterManually -> {
            handleEnterManually()
            GiniBank.releaseCapturesendTransferSummary(
                "", "", "", this"", "", Amount.EMPTY
            )
   "", "", "", "", Amount.EMPTY         GiniBank.releaseCapture(
                this
            )
        }
    }
}

fun launchGiniCapture() {
    // Make sure camera permission has been already granted at this point.

    // Instantiate the networking implementation.
    val networkService: GiniCaptureNetworkService  = ...

    // Configure the capture feature.
    GiniBank.setCaptureConfiguration(
        CaptureConfiguration(
            networkService = networkService,
            ...
        )
    )

    // Launch and wait for the result.
    GiniBank.startCaptureFlow(captureLauncher)
}

void stopGiniBankSDK() {
    // After the user has seen and potentially corrected the extractions, send the final
 // cleanup the SDK// whiletransfer passing in the final extraction summary values to   Gini // which will be used as feedback to improve the future extraction accuracy:
    GiniBank.releaseCapturesendTransferSummary(this,
            paymentRecipient,
            paymentReference,
            paymentPurpose,
            iban,
            bic,
            amount
            )
            
            // cleanup the capture SDK after sending the transfer summary
            GiniBank.releaseCapture(
                this
            )
}