sendMessageRaw method
- @experimental
- required String message,
- required String token,
- String? actorDisplayName,
- String? referenceId,
- int? replyTo,
- ChatSendMessageSilent? silent,
- ChatSendMessageApiVersion? apiVersion,
- bool? oCSAPIRequest,
Sends a new chat message to the given room.
The author and timestamp are automatically set to the current user/guest and time.
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:
messagethe message to send.actorDisplayNamefor guests. Defaults to''.referenceIdfor the message to be able to later identify it again. Defaults to''.replyToParent id which this message is a reply to. Defaults to0.silentIf sent silent the chat message will not create any notifications. Defaults to0.apiVersionDefaults tov1.tokenoCSAPIRequestRequired to be true for the API request to pass. Defaults totrue.
Status codes:
- 201: Message sent successfully
- 400: Sending message is not possible
- 404: Actor not found
- 413: Message too long
See:
- sendMessage for an operation that returns a
DynamiteResponsewith a stable API.
Implementation
@_i4.experimental
_i1.DynamiteRawResponse<ChatSendMessageResponseApplicationJson, ChatChatSendMessageHeaders> sendMessageRaw({
required String message,
required String token,
String? actorDisplayName,
String? referenceId,
int? replyTo,
ChatSendMessageSilent? silent,
ChatSendMessageApiVersion? apiVersion,
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,
);
}
// coverage:ignore-end
final $message = _$jsonSerializers.serialize(message, specifiedType: const FullType(String));
_parameters['message'] = $message;
final $token = _$jsonSerializers.serialize(token, specifiedType: const FullType(String));
_i2.checkPattern(
$token as String?,
RegExp(r'^[a-z0-9]{4,30}$'),
'token',
);
_parameters['token'] = $token;
var $actorDisplayName = _$jsonSerializers.serialize(actorDisplayName, specifiedType: const FullType(String));
$actorDisplayName ??= '';
_parameters['actorDisplayName'] = $actorDisplayName;
var $referenceId = _$jsonSerializers.serialize(referenceId, specifiedType: const FullType(String));
$referenceId ??= '';
_parameters['referenceId'] = $referenceId;
var $replyTo = _$jsonSerializers.serialize(replyTo, specifiedType: const FullType(int));
$replyTo ??= 0;
_parameters['replyTo'] = $replyTo;
var $silent = _$jsonSerializers.serialize(silent, specifiedType: const FullType(ChatSendMessageSilent));
$silent ??= 0;
_parameters['silent'] = $silent;
var $apiVersion = _$jsonSerializers.serialize(apiVersion, specifiedType: const FullType(ChatSendMessageApiVersion));
$apiVersion ??= 'v1';
_parameters['apiVersion'] = $apiVersion;
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/spreed/api/{apiVersion}/chat/{token}{?message*,actorDisplayName*,referenceId*,replyTo*,silent*}',
).expand(_parameters);
return _i1.DynamiteRawResponse<ChatSendMessageResponseApplicationJson, ChatChatSendMessageHeaders>(
response: _rootClient.executeRequest(
'post',
_path,
headers: _headers,
validStatuses: const {201},
),
bodyType: const FullType(ChatSendMessageResponseApplicationJson),
headersType: const FullType(ChatChatSendMessageHeaders),
serializers: _$jsonSerializers,
);
}