1
0
mirror of https://gitlab.com/comunic/comunicmobile synced 2025-01-28 04:33:00 +00:00
comunicmobile/lib/helpers/api_helper.dart

96 lines
3.0 KiB
Dart
Raw Normal View History

2019-04-22 19:16:26 +02:00
import 'dart:io';
import 'package:comunic/helpers/events_helper.dart';
2019-11-01 09:59:05 +01:00
import 'package:comunic/helpers/preferences_helper.dart';
2019-04-22 19:16:26 +02:00
import 'package:comunic/models/api_request.dart';
import 'package:comunic/models/api_response.dart';
import 'package:comunic/models/config.dart';
2019-04-25 20:14:19 +02:00
import 'package:dio/dio.dart';
2019-04-22 19:16:26 +02:00
/// API Helper
///
/// @author Pierre HUBERT
class APIHelper {
/// Execute a [request] on the server and returns a [APIResponse]
///
/// This method should never throw but the response code of the [APIResponse]
/// should be verified before accessing response content
2019-04-25 20:14:19 +02:00
Future<APIResponse> exec(APIRequest request, {bool multipart = false}) async {
2019-04-22 19:16:26 +02:00
try {
//Add API tokens
request.addString("serviceName", config().serviceName);
request.addString("serviceToken", config().serviceToken);
//Add user tokens (if required)
2019-04-23 14:35:41 +02:00
if (request.needLogin) {
2019-11-01 09:59:05 +01:00
final tokens = (await PreferencesHelper.getInstance()).getLoginTokens();
2019-04-23 14:35:41 +02:00
assert(tokens != null);
request.addString("userToken1", tokens.tokenOne);
request.addString("userToken2", tokens.tokenTwo);
}
2019-04-22 19:16:26 +02:00
// Determine server URL
final path = config().apiServerUri + request.uri;
Uri url;
if (!config().apiServerSecure)
url = Uri.http(config().apiServerName, path);
else
url = Uri.https(config().apiServerName, path);
2020-03-24 15:01:34 +01:00
final data = FormData.fromMap(request.args);
2019-04-25 20:14:19 +02:00
// Process files (if required)
2020-04-17 08:44:57 +02:00
if (multipart) {
// Process filesystem files
for (final key in request.files.keys) {
2020-03-24 15:01:34 +01:00
var v = request.files[key];
data.files.add(MapEntry(
key,
await MultipartFile.fromFile(v.path,
filename: v.path.split("/").last)));
}
2019-04-25 20:14:19 +02:00
2020-04-17 08:44:57 +02:00
// Process in-memory files
for (final key in request.bytesFiles.keys) {
var v = request.bytesFiles[key];
data.files.add(MapEntry(
key,
MultipartFile.fromBytes(v.bytes,
filename: v.filename.split("/").last)));
}
}
2019-04-25 20:14:19 +02:00
// Execute the request
final response = await Dio().post(
2019-04-25 11:44:58 +02:00
url.toString(),
2019-04-25 20:14:19 +02:00
data: data,
options: Options(
receiveDataWhenStatusError: true,
validateStatus: (s) => true,
responseType: ResponseType.plain,
),
2019-04-25 11:44:58 +02:00
);
2019-04-22 19:16:26 +02:00
// Check if login token is rejected by server
if (response.statusCode == 412)
EventsHelper.emit(InvalidLoginTokensEvent());
2019-04-22 19:16:26 +02:00
if (response.statusCode != HttpStatus.ok)
return APIResponse(response.statusCode, null);
2019-04-25 20:14:19 +02:00
return APIResponse(response.statusCode, response.data);
2020-04-17 08:44:57 +02:00
} catch (e, stack) {
2019-04-22 19:16:26 +02:00
print(e.toString());
print("Could not execute a request!");
2020-04-17 08:44:57 +02:00
print(stack);
2019-04-22 19:16:26 +02:00
return APIResponse(-1, null);
}
}
2019-04-25 20:14:19 +02:00
/// Same as exec, but also allows to send files
Future<APIResponse> execWithFiles(APIRequest request) async {
return await exec(request, multipart: true);
}
2019-04-22 19:16:26 +02:00
}