sendMessageRaw method
- @experimental
- required String message,
- required String token,
- String? referenceId,
- int? replyTo,
- BotSendMessageSilent? silent,
- BotSendMessageApiVersion? 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.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.tokenConversation token.oCSAPIRequestRequired to be true for the API request to pass. Defaults totrue.
Status codes:
- 201: Message sent successfully
- 400: When the replyTo is invalid or message is empty
- 401: Sending message is not allowed
- 413: Message too long
See:
- sendMessage for an operation that returns a
DynamiteResponsewith a stable API.
Implementation
@_i4.experimental
_i1.DynamiteRawResponse<BotSendMessageResponseApplicationJson, void> sendMessageRaw({
required String message,
required String token,
String? referenceId,
int? replyTo,
BotSendMessageSilent? silent,
BotSendMessageApiVersion? 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 $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(BotSendMessageSilent));
$silent ??= 0;
_parameters['silent'] = $silent;
var $apiVersion = _$jsonSerializers.serialize(apiVersion, specifiedType: const FullType(BotSendMessageApiVersion));
$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}/bot/{token}/message{?message*,referenceId*,replyTo*,silent*}',
).expand(_parameters);
return _i1.DynamiteRawResponse<BotSendMessageResponseApplicationJson, void>(
response: _rootClient.executeRequest(
'post',
_path,
headers: _headers,
validStatuses: const {
201,
400,
401,
413,
},
),
bodyType: const FullType(BotSendMessageResponseApplicationJson),
headersType: null,
serializers: _$jsonSerializers,
);
}