D1APP-22 request service bug fixed
This commit is contained in:
parent
0ec05f1764
commit
9fcd2e0a16
|
|
@ -4,11 +4,16 @@ import 'dart:io';
|
||||||
import 'package:http/http.dart' as http;
|
import 'package:http/http.dart' as http;
|
||||||
|
|
||||||
class RequestService {
|
class RequestService {
|
||||||
static late String token;
|
static late String _token;
|
||||||
|
|
||||||
|
static set token(value) => _token = value;
|
||||||
|
|
||||||
|
Map get result => _body['result'] ?? const {};
|
||||||
|
Map get errors => _body['errors'] ?? const {};
|
||||||
|
|
||||||
String? errorMessage;
|
String? errorMessage;
|
||||||
|
|
||||||
dynamic body;
|
dynamic _body;
|
||||||
final Map<String, String> _headers = {
|
final Map<String, String> _headers = {
|
||||||
"accept": "*/*",
|
"accept": "*/*",
|
||||||
"Content-Type": "application/json; charset=UTF-8",
|
"Content-Type": "application/json; charset=UTF-8",
|
||||||
|
|
@ -26,7 +31,7 @@ class RequestService {
|
||||||
}) {
|
}) {
|
||||||
if (body != null) _requestBody = body;
|
if (body != null) _requestBody = body;
|
||||||
if (requestHeaders != null) _headers.addAll(requestHeaders);
|
if (requestHeaders != null) _headers.addAll(requestHeaders);
|
||||||
if (useAutherization) _headers.addAll({'Authorization': 'Bearer $token'});
|
if (useAutherization) _headers.addAll({'Authorization': 'Bearer $_token'});
|
||||||
if (body != null) _requestBody = body;
|
if (body != null) _requestBody = body;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -61,8 +66,10 @@ class RequestService {
|
||||||
const Duration(seconds: 10),
|
const Duration(seconds: 10),
|
||||||
)
|
)
|
||||||
.catchError(
|
.catchError(
|
||||||
(e) => throw e,
|
(e) {
|
||||||
);
|
throw e;
|
||||||
|
},
|
||||||
|
);
|
||||||
_handleResponse(response);
|
_handleResponse(response);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
_handleError(null);
|
_handleError(null);
|
||||||
|
|
@ -140,7 +147,7 @@ class RequestService {
|
||||||
void _handleResponse(http.Response? response) {
|
void _handleResponse(http.Response? response) {
|
||||||
if (_handleError(response)) {
|
if (_handleError(response)) {
|
||||||
if (response!.body.isNotEmpty) {
|
if (response!.body.isNotEmpty) {
|
||||||
body = json.decode(response.body);
|
_body = json.decode(response.body);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -156,8 +163,16 @@ class RequestService {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (response.statusCode != 200 && response.statusCode != 204) {
|
if (response.statusCode != 200 && response.statusCode != 204) {
|
||||||
|
String data;
|
||||||
|
if (response.body.isEmpty) {
|
||||||
|
data = 'No results!';
|
||||||
|
} else if (response.body.contains('<!DOCTYPE html>')) {
|
||||||
|
data = response.body;
|
||||||
|
} else {
|
||||||
|
data = jsonDecode(response.body);
|
||||||
|
}
|
||||||
log(
|
log(
|
||||||
'Request to [$url] failed with status code ${response.statusCode} & result : \n ${response.body.isNotEmpty ? json.decode(response.body) : 'No result.'}',
|
'Request to [$url] failed with status code ${response.statusCode} & result : \n $data',
|
||||||
name: 'Request fail error',
|
name: 'Request fail error',
|
||||||
);
|
);
|
||||||
isSuccess = false;
|
isSuccess = false;
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue