nc-photos/app/lib/entity/share/data_source.dart

181 lines
5.5 KiB
Dart
Raw Normal View History

2021-08-07 22:34:44 +02:00
import 'dart:convert';
import 'package:logging/logging.dart';
import 'package:nc_photos/account.dart';
import 'package:nc_photos/api/api.dart';
2021-11-12 22:13:02 +01:00
import 'package:nc_photos/ci_string.dart';
2021-08-07 22:34:44 +02:00
import 'package:nc_photos/entity/file.dart';
import 'package:nc_photos/entity/file_descriptor.dart';
2021-08-07 22:34:44 +02:00
import 'package:nc_photos/entity/share.dart';
import 'package:nc_photos/exception.dart';
import 'package:nc_photos/type.dart';
2022-12-16 16:01:04 +01:00
import 'package:np_codegen/np_codegen.dart';
2021-08-07 22:34:44 +02:00
2022-12-16 16:01:04 +01:00
part 'data_source.g.dart';
@npLog
2021-08-07 22:34:44 +02:00
class ShareRemoteDataSource implements ShareDataSource {
@override
list(
Account account,
File file, {
bool? isIncludeReshare,
}) async {
2021-08-07 22:34:44 +02:00
_log.info("[list] ${file.path}");
final response = await Api(account).ocs().filesSharing().shares().get(
path: file.strippedPath,
reshares: isIncludeReshare,
2021-08-07 22:34:44 +02:00
);
2021-08-13 12:42:31 +02:00
return _onListResult(response);
}
2021-08-07 22:34:44 +02:00
2021-08-13 12:42:31 +02:00
@override
listDir(Account account, File dir) async {
_log.info("[listDir] ${dir.path}");
final response = await Api(account).ocs().filesSharing().shares().get(
path: dir.strippedPath,
subfiles: true,
);
return _onListResult(response);
2021-08-07 22:34:44 +02:00
}
2021-10-06 22:32:36 +02:00
@override
listAll(Account account) async {
_log.info("[listAll] $account");
final response = await Api(account).ocs().filesSharing().shares().get();
return _onListResult(response);
}
@override
reverseList(Account account, File file) async {
_log.info("[reverseList] ${file.path}");
final response = await Api(account).ocs().filesSharing().shares().get(
path: file.strippedPath,
sharedWithMe: true,
);
return _onListResult(response);
}
2021-10-11 19:03:37 +02:00
@override
reverseListAll(Account account) async {
_log.info("[reverseListAll] $account");
final response = await Api(account).ocs().filesSharing().shares().get(
sharedWithMe: true,
);
return _onListResult(response);
}
2021-08-07 22:34:44 +02:00
@override
create(Account account, File file, String shareWith) async {
_log.info("[create] Share '${file.path}' with '$shareWith'");
final response = await Api(account).ocs().filesSharing().shares().post(
path: file.strippedPath,
shareType: ShareType.user.toValue(),
2021-08-07 22:34:44 +02:00
shareWith: shareWith,
);
if (!response.isGood) {
_log.severe("[create] Failed requesting server: $response");
throw ApiException(
response: response,
2022-07-21 07:45:49 +02:00
message:
"Server responed with an error: HTTP ${response.statusCode}");
2021-08-07 22:34:44 +02:00
}
final json = jsonDecode(response.body);
final JsonObj dataJson = json["ocs"]["data"];
return _ShareParser().parseSingle(dataJson);
}
@override
createLink(
Account account,
File file, {
String? password,
}) async {
_log.info("[createLink] Share '${file.path}' with a share link");
final response = await Api(account).ocs().filesSharing().shares().post(
path: file.strippedPath,
shareType: ShareType.publicLink.toValue(),
password: password,
);
if (!response.isGood) {
_log.severe("[create] Failed requesting server: $response");
throw ApiException(
response: response,
2022-07-21 07:45:49 +02:00
message:
"Server responed with an error: HTTP ${response.statusCode}");
}
final json = jsonDecode(response.body);
final JsonObj dataJson = json["ocs"]["data"];
return _ShareParser().parseSingle(dataJson);
}
2021-08-07 22:34:44 +02:00
@override
delete(Account account, Share share) async {
_log.info("[delete] $share");
final response =
await Api(account).ocs().filesSharing().share(share.id).delete();
if (!response.isGood) {
_log.severe("[delete] Failed requesting server: $response");
throw ApiException(
response: response,
2022-07-21 07:45:49 +02:00
message:
"Server responed with an error: HTTP ${response.statusCode}");
2021-08-07 22:34:44 +02:00
}
}
2021-08-13 12:42:31 +02:00
List<Share> _onListResult(Response response) {
if (!response.isGood) {
_log.severe("[_onListResult] Failed requesting server: $response");
throw ApiException(
response: response,
2022-07-21 07:45:49 +02:00
message:
"Server responed with an error: HTTP ${response.statusCode}");
2021-08-13 12:42:31 +02:00
}
final json = jsonDecode(response.body);
final List<JsonObj> dataJson = json["ocs"]["data"].cast<JsonObj>();
return _ShareParser().parseList(dataJson);
}
2021-08-07 22:34:44 +02:00
}
2022-12-16 16:01:04 +01:00
@npLog
2021-08-07 22:34:44 +02:00
class _ShareParser {
List<Share> parseList(List<JsonObj> jsons) {
final product = <Share>[];
for (final j in jsons) {
try {
product.add(parseSingle(j));
} catch (e) {
_log.severe("[parseList] Failed parsing json: ${jsonEncode(j)}", e);
}
}
return product;
}
Share parseSingle(JsonObj json) {
final shareType = ShareTypeExtension.fromValue(json["share_type"]);
2021-10-06 22:32:36 +02:00
final itemType = ShareItemTypeExtension.fromValue(json["item_type"]);
2021-08-07 22:34:44 +02:00
return Share(
id: json["id"],
shareType: shareType,
2021-10-11 19:03:37 +02:00
stime: DateTime.fromMillisecondsSinceEpoch(json["stime"] * 1000),
2021-11-12 22:13:02 +01:00
uidOwner: CiString(json["uid_owner"]),
2021-10-11 19:03:37 +02:00
displaynameOwner: json["displayname_owner"],
uidFileOwner: CiString(json["uid_file_owner"]),
2021-10-06 22:32:36 +02:00
path: json["path"],
itemType: itemType,
mimeType: json["mimetype"],
itemSource: json["item_source"],
// when shared with a password protected link, shareWith somehow contains
// the password, which doesn't make sense. We set it to null instead
2021-11-12 22:13:02 +01:00
shareWith: shareType == ShareType.publicLink
? null
: (json["share_with"] as String?)?.toCi(),
2021-08-07 22:34:44 +02:00
shareWithDisplayName: json["share_with_displayname"],
url: json["url"],
2021-08-07 22:34:44 +02:00
);
}
}