createPaymentConsent method

  1. @override
Future<Map> createPaymentConsent(
  1. String token,
  2. String? connectedAccountId,
  3. String customerId,
  4. String? merchantTriggerReason,
  5. Map<String, dynamic>? metadata,
  6. String nextTriggerReason,
  7. Map<String, dynamic>? paymentMethod,
  8. String requestId,
  9. bool? requiresCVC,
)
override

Implementation

@override
Future<Map> createPaymentConsent(
    String token,
    String? connectedAccountId,
    String customerId,
    String? merchantTriggerReason,
    Map<String, dynamic>? metadata,
    String nextTriggerReason,
    Map<String, dynamic>? paymentMethod,
    String requestId,
    bool? requiresCVC) async {
  final baseUrl = await getBaseUrl;
  var url = Uri.parse("$baseUrl/api/v1/pa/payment_consents/create");

  Map<String, dynamic> bodyData = {
    "customer_id": customerId,
    "next_triggered_by": nextTriggerReason,
    "request_id": requestId
  };
  if (connectedAccountId != null) {
    bodyData.addAll({"connected_account_id": connectedAccountId});
  }
  if (merchantTriggerReason != null) {
    bodyData.addAll({"merchant_trigger_reason": merchantTriggerReason});
  }
  if (metadata != null) {
    bodyData.addAll({"metadata": metadata});
  }
  if (paymentMethod != null) {
    bodyData.addAll({"payment_method": paymentMethod});
  }
  if (requiresCVC != null) {
    bodyData.addAll({"requires_cvc": requiresCVC});
  }
  var jsonBody = jsonEncode(bodyData);
  var response = await http.post(
    url,
    headers: {
      "Content-Type": "application/json",
      "Authorization": "Bearer $token"
    },
    body: jsonBody,
  );
  var data = jsonDecode(response.body);
  return data;
}