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:
permissions
New permissions.password
New password.sendPasswordByTalk
New condition if the password should be send over Talk.publicUpload
New condition if public uploading is allowed.expireDate
New expiry date.note
New note.label
New label.hideDownload
New condition if the download should be hidden.attributes
New additional attributes.id
ID of the share.oCSAPIRequest
Required 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
DynamiteResponse
with 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,
);
}