Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Page Properties
hiddentrue

Status

Status
colourGreen
titleapproved

Approver

Alpar Szotyori (Unlicensed)

Info

We recommend using Capture Flow with Fragments instead of activities.

In order to use the capture flow , you need towith activities, follow these steps:

  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 (e.g. in the registerForActivityResult).

  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. Follow the recommendations below 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 Send transfer summary only after TAN verification.

You don’t need to implement any extra steps.

...

The diagram below shows the interaction between your app and the SDK:

Drawio
mVer2
zoom1
simple0
zoominComment10
inCommentcustContentId02884089
pageId2949214
custContentIdlbox28840891
diagramDisplayNameUntitled Diagram-1675761818164.drawio
lbox1
contentVer57
revision57
baseUrlhttps://gini.atlassian.net/wiki
diagramNameUntitled Diagram-1675761818164.drawio
pCenter0
width860
links
tbstyle
height379.5
Info

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

The Gini Bank SDK can return with returns one of the following results:

  • CaptureResult.Success

A document was

...

analysed and the extractions are available in the properties of the CaptureResult.Success object.

  • CaptureResult.Cancel

The user

...

canceled Gini Bank SDK.

  • CaptureResult.Error

An error occurred and the details are available in the value property of the CaptureResult.Error object.

  • CaptureResult.EmptyThe

Gini Bank SDK was able to extract information, but they were not payment related. Your app should proceed with

...

enabling your user to enter the payment information manually.

  • CaptureResult.EnterManually

The document analysis finished with no results or an error and the user clicked the Enter manually button on either the No Results Screen or the Error Screen.

...

To enable manual entry of payment information, let your app prompt users for manual input.

...

Learn how to launch the capture flow and how to handle the results from the example:

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 -> {
            handleExtractionsshowExtractions(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.releaseCapture(this)
        }
       this, "",
  CaptureResult.Empty -> {
            handleNoExtractions()
 "", "", "", "", Amount.EMPTY             GiniBank.releaseCapture(this)
        }
        CaptureResult.EmptyCancel -> {
            handleNoExtractionshandleCancellation()
            GiniBank.releaseCapture(this)
        }
       this, "",
  CaptureResult.EnterManually -> {
              "", "", "", "", Amount.EMPTYhandleEnterManually()
              GiniBank.releaseCapture(this)
        }
    }
}

 CaptureResult.Cancel -> fun startGiniBankSDK() {
    // Make sure camera permission has been already handleCancellation()granted at this point.

    // Instantiate the networking GiniBankimplementation.releaseCapture(
    val networkService: GiniCaptureNetworkService  = ...

    // this, "",
 Configure the capture feature.
    GiniBank.setCaptureConfiguration(
         "", "", "", "", Amount.EMPTYCaptureConfiguration(
            networkService = networkService,
)         }   ...
     CaptureResult.EnterManually -> { )
    )

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

fun              this, "",
stopGiniBankSDKWithTransferSummary(paymentRecipient: String, 
              "", "", "", "", Amount.EMPTY             )         }  paymentReference: String,
 } }  fun launchGiniCapture() {     // Make sure camera permission has been already granted at this point.      // Check that the device fulfills the requirements.    paymentPurpose: valString, report
= GiniCaptureRequirements.checkRequirements((Context) this)     if (!report.isFulfilled()) {         handleUnfulfilledRequirements(report)         return     }      // Instantiate the networking implementation.
    val networkService: GiniCaptureNetworkService  = ... iban: String,
        // Configure the capture feature.     GiniBank.setCaptureConfiguration(         CaptureConfiguration(             networkService =bic: networkServiceString,
            ...         )     )      // Launch and wait for the result. amount: Amount
  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)
}