updateShareRaw method
- @experimental
Update a share.
This method and the response it returns is experimental. The API might change without a major version bump.
Returns a Future containing a DynamiteRawResponse with the raw HttpClientResponse and serialization helpers.
Throws a DynamiteApiException if the API call does not return an expected status code.
Parameters:
permissionsNew permissions.passwordNew password.sendPasswordByTalkNew condition if the password should be send over Talk.publicUploadNew condition if public uploading is allowed.expireDateNew expiry date.noteNew note.labelNew label.hideDownloadNew condition if the download should be hidden.attributesNew additional attributes.idID of the share.oCSAPIRequestRequired to be true for the API request to pass. Defaults totrue.
Status codes:
- 200: Share updated successfully
- 400: Share could not be updated because the requested changes are invalid
- 403: Missing permissions to update the share
- 404: Share not found
See:
- updateShare for an operation that returns a
DynamiteResponsewith a stable API.
Implementation
@_i4.experimental
_i1.DynamiteRawResponse<ShareapiUpdateShareResponseApplicationJson, void> updateShareRaw({
required String id,
int? permissions,
String? password,
String? sendPasswordByTalk,
String? publicUpload,
String? expireDate,
String? note,
String? label,
String? hideDownload,
String? attributes,
bool? oCSAPIRequest,
}) {
final _parameters = <String, dynamic>{};
final _headers = <String, String>{'Accept': 'application/json'};
// coverage:ignore-start
final authentication = _rootClient.authentications?.firstWhereOrNull(
(auth) => switch (auth) {
_i1.DynamiteHttpBearerAuthentication() || _i1.DynamiteHttpBasicAuthentication() => true,
_ => false,
},
);
if (authentication != null) {
_headers.addAll(
authentication.headers,
);
} else {
throw Exception('Missing authentication for bearer_auth or basic_auth');
}
// coverage:ignore-end
final $id = _$jsonSerializers.serialize(id, specifiedType: const FullType(String));
_parameters['id'] = $id;
final $permissions = _$jsonSerializers.serialize(permissions, specifiedType: const FullType(int));
_parameters['permissions'] = $permissions;
final $password = _$jsonSerializers.serialize(password, specifiedType: const FullType(String));
_parameters['password'] = $password;
final $sendPasswordByTalk = _$jsonSerializers.serialize(sendPasswordByTalk, specifiedType: const FullType(String));
_parameters['sendPasswordByTalk'] = $sendPasswordByTalk;
final $publicUpload = _$jsonSerializers.serialize(publicUpload, specifiedType: const FullType(String));
_parameters['publicUpload'] = $publicUpload;
final $expireDate = _$jsonSerializers.serialize(expireDate, specifiedType: const FullType(String));
_parameters['expireDate'] = $expireDate;
final $note = _$jsonSerializers.serialize(note, specifiedType: const FullType(String));
_parameters['note'] = $note;
final $label = _$jsonSerializers.serialize(label, specifiedType: const FullType(String));
_parameters['label'] = $label;
final $hideDownload = _$jsonSerializers.serialize(hideDownload, specifiedType: const FullType(String));
_parameters['hideDownload'] = $hideDownload;
final $attributes = _$jsonSerializers.serialize(attributes, specifiedType: const FullType(String));
_parameters['attributes'] = $attributes;
var $oCSAPIRequest = _$jsonSerializers.serialize(oCSAPIRequest, specifiedType: const FullType(bool));
$oCSAPIRequest ??= true;
_headers['OCS-APIRequest'] = const _i2.HeaderEncoder().convert($oCSAPIRequest);
final _path = _i3.UriTemplate(
'/ocs/v2.php/apps/files_sharing/api/v1/shares/{id}{?permissions*,password*,sendPasswordByTalk*,publicUpload*,expireDate*,note*,label*,hideDownload*,attributes*}',
).expand(_parameters);
return _i1.DynamiteRawResponse<ShareapiUpdateShareResponseApplicationJson, void>(
response: _rootClient.executeRequest(
'put',
_path,
headers: _headers,
validStatuses: const {200},
),
bodyType: const FullType(ShareapiUpdateShareResponseApplicationJson),
headersType: null,
serializers: _$jsonSerializers,
);
}