import 'dart:convert'; import 'package:logging/logging.dart'; import 'package:nc_photos/account.dart'; import 'package:nc_photos/api/api.dart'; import 'package:nc_photos/entity/face.dart'; import 'package:nc_photos/entity/person.dart'; import 'package:nc_photos/exception.dart'; import 'package:nc_photos/type.dart'; class FaceRemoteDataSource implements FaceDataSource { const FaceRemoteDataSource(); @override list(Account account, Person person) async { _log.info("[list] $person"); final response = await Api(account) .ocs() .facerecognition() .person(person.name) .faces() .get(); if (!response.isGood) { _log.severe("[list] Failed requesting server: $response"); throw ApiException( response: response, message: "Server responed with an error: HTTP ${response.statusCode}"); } final json = jsonDecode(response.body); final List dataJson = json["ocs"]["data"].cast(); return _FaceParser().parseList(dataJson); } static final _log = Logger("entity.face.data_source.FaceRemoteDataSource"); } class _FaceParser { List parseList(List jsons) { final product = []; for (final j in jsons) { try { product.add(parseSingle(j)); } catch (e) { _log.severe("[parseList] Failed parsing json: ${jsonEncode(j)}", e); } } return product; } Face parseSingle(JsonObj json) { return Face( id: json["id"], fileId: json["fileId"], ); } static final _log = Logger("entity.face.data_source._FaceParser"); }