init method
Initialize the Amwal Card SDK with merchant configuration.
This method sets up the SDK with all necessary credentials and configuration parameters required for card payment processing.
Parameters
- token- Authentication token for API access
- merchantId- Unique identifier for the merchant
- terminalIds- List of terminal IDs for payment processing
- secureHashValue- Optional secure hash for additional validation
- transactionRefNo- Reference number for the transaction
- service- Network service instance for API communication
- merchantName- Optional display name for the merchant
- isMocked- Enable mock mode for testing (default: false)
- is3DS- Enable 3D Secure authentication (default: false)
- locale- Locale for internationalization
Returns
Returns the initialized AmwalCardSdk instance.
Example
final sdk = await AmwalCardSdk.instance.init(
  token: 'auth_token_123',
  merchantId: 'merchant_456',
  terminalIds: ['term_1', 'term_2'],
  transactionRefNo: 'txn_789',
  service: networkService,
  is3DS: true,
);
Implementation
Future<AmwalCardSdk> init({
  required String token,
  required String merchantId,
  required List<String> terminalIds,
  String? secureHashValue,
  required String transactionRefNo,
  required NetworkService service,
  String? merchantName,
  bool isMocked = false,
  bool is3DS = false,
  Locale? locale,
}) async {
  await CardInjector.instance.onSdkInit(
    () async => await _sdkInitialization(
      token,
      terminalIds,
      secureHashValue,
      merchantId,
      isMocked,
      service,
      locale: locale,
      merchantName: merchantName,
    ),
  );
  return this;
}