callPatchApi static method

Future callPatchApi(
  1. String endPoint,
  2. Map params, {
  3. bool hasAuth = true,
  4. bool hasEncoded = true,
  5. required String token,
  6. bool? defaultResponse,
  7. bool? withStream,
  8. bool? utf8Convert,
  9. String? paramAsBody,
  10. bool isTypeJson = true,
  11. Map<String, String>? customHeader,
  12. String? changeLocalization,
  13. String tokenKey = 'Bearer ',
  14. bool? useDefaultURl,
  15. bool? showLogs,
  16. int? callTimeoutInSec,
  17. bool? usePreCheckFn,
})

Implementation

static Future<dynamic> callPatchApi(
  String endPoint,
  Map params, {
  bool hasAuth = true,
  bool hasEncoded = true,
  required String token,
  bool? defaultResponse,
  bool? withStream,
  bool? utf8Convert,
  String? paramAsBody,
  bool isTypeJson = true,
  Map<String, String>? customHeader,
  String? changeLocalization,
  String tokenKey = 'Bearer ',
  bool? useDefaultURl,
  bool? showLogs,
  int? callTimeoutInSec,
      bool? usePreCheckFn,
}) async {
  dynamic response;
  try {
  await callPreCheckFn(usePreCheckFn);
  showLog((params), showLog: showLogs, logName: endPoint);
  Uri url = HttpCalls.getRequestURL(endPoint, useDefaultURl: useDefaultURl);

  final Map<String, String> header = {
    'X-localization': '',
    'content-type': 'application/json'
  };
  if ((localization ?? changeLocalization) != null) {
    header['X-localization'] = localization ?? changeLocalization ?? '';
    header['Accept-Language'] = localization ?? changeLocalization ?? '';
  }
  if (isTypeJson) {
    header[HttpHeaders.contentTypeHeader] = 'application/json';
  }

  if (hasAuth) {
    header[Static.httpCallTokenKey??HttpHeaders.authorizationHeader] = '${Static.canHttpCallAddBearerAsPreToken?tokenKey:''}$token';
  }
  if (headerAddOns != null) {
    header.addAll(headerAddOns!);
  }
  showLog((customHeader ?? httpHeader ?? header),
      showLog: showLogs, logName: endPoint);
    if (withStream ?? httpCallsWithStream) {
      var request = http.Request('PATCH', url);
      request.body = paramAsBody ?? json.encode(params);
      request.headers.addAll(customHeader ?? httpHeader ?? header);
      var streamedResponse = await request.send().timeout(
          Duration(seconds: callTimeoutInSec ?? httpCallTimeoutInSec));
      var result = await Response.fromStream(streamedResponse);
      if (result.statusCode < Static.stopDecodingFromErrorCode) {
        if (utf8Convert ?? httpResponseUtf8Convert) {
          response = HttpCalls.getDataObject(
              Response(utf8.decoder.convert(result.bodyBytes),
                  streamedResponse.statusCode),
              defaultResponse: defaultResponse);
          showLog(utf8.decoder.convert(result.bodyBytes),
              enableJsonEncode: false, showLog: showLogs, logName: endPoint);
        } else {
          response = HttpCalls.getDataObject(result,
              defaultResponse: defaultResponse);
          showLog(result.body.toString(),
              enableJsonEncode: false, showLog: showLogs, logName: endPoint);
        }
      } else {
        throw Exception(result);
      }
    } else {
      var result = await http
          .patch(url,
              headers: customHeader ?? httpHeader ?? header,
              body: paramAsBody ?? utf8.encode(json.encode(params)))
          .timeout(
              Duration(seconds: callTimeoutInSec ?? httpCallTimeoutInSec));
      if (result.statusCode < Static.stopDecodingFromErrorCode) {
        response =
            HttpCalls.getDataObject(result, defaultResponse: defaultResponse);
        showLog(result.body.toString(),
            enableJsonEncode: false, showLog: showLogs, logName: endPoint);
      } else {
        throw Exception(result);
      }
    }
  } catch (e) {
    response = errorHandler(e, response, defaultResponse);
  }
  return response;
}