diff --git a/examples/simple-examples/src/conversation/messages/send.ts b/examples/simple-examples/src/conversation/messages/send.ts index c5922b02..fa148f09 100644 --- a/examples/simple-examples/src/conversation/messages/send.ts +++ b/examples/simple-examples/src/conversation/messages/send.ts @@ -24,7 +24,7 @@ import { getAppIdFromConfig, getContactIdFromConfig, initConversationService, pr queue: 'HIGH_PRIORITY', processing_strategy: 'DEFAULT', channel_priority_order: ['MESSENGER'], - ttl_seconds: 60, + ttl: 60, }, }; diff --git a/examples/webhooks/src/services/conversation-event.service.ts b/examples/webhooks/src/services/conversation-event.service.ts index 34daea1f..c88bb5cd 100644 --- a/examples/webhooks/src/services/conversation-event.service.ts +++ b/examples/webhooks/src/services/conversation-event.service.ts @@ -61,7 +61,7 @@ export class ConversationEventService { contact_id: message.contact_id!, }, message: this.buildContactMessage(contactMessage), - ttl_seconds: 5, + ttl: 5, channel_properties: { MESSENGER_NOTIFICATION_TYPE: 'NO_PUSH', } diff --git a/packages/conversation/src/models/v1/send-message-request/send-message-request.ts b/packages/conversation/src/models/v1/send-message-request/send-message-request.ts index 3d09ee04..32ca82d4 100644 --- a/packages/conversation/src/models/v1/send-message-request/send-message-request.ts +++ b/packages/conversation/src/models/v1/send-message-request/send-message-request.ts @@ -36,7 +36,7 @@ export interface SendMessageRequestBase { /** @see Recipient */ recipient: T; /** The timeout allotted for sending the message, expressed in seconds. Passed to channels which support it and emulated by the Conversation API for channels without ttl support but with message retract/unsend functionality. Channel failover will not be performed for messages with an expired TTL. The format is an integer with the suffix `s` (for seconds). Valid integer range is 3 to 315,576,000,000 (inclusive). Example values include `10s` (10 seconds) and `86400s` (24 hours). */ - ttl_seconds?: number; + ttl?: string | number; /** Overrides the app\'s [Processing Mode](../../../../../conversation/processing-modes/). Default value is `DEFAULT`. */ processing_strategy?: ProcessingStrategy; /** An arbitrary identifier that will be propagated to callbacks related to this message, including MO replies. Only applicable to messages sent with the `CONVERSATION` processing mode. Up to 128 characters long. */ diff --git a/packages/conversation/src/rest/v1/messages/messages-api.ts b/packages/conversation/src/rest/v1/messages/messages-api.ts index 2f066461..0c21b40d 100644 --- a/packages/conversation/src/rest/v1/messages/messages-api.ts +++ b/packages/conversation/src/rest/v1/messages/messages-api.ts @@ -361,14 +361,11 @@ export class MessagesApi extends ConversationDomainApi { 'Accept': 'application/json', }; - // Special fields handling: ttl_seconds: number => ttl: string - if (data.sendMessageRequestBody.ttl_seconds !== undefined) { - (data as any).sendMessageRequestBody.ttl = data.sendMessageRequestBody.ttl_seconds + 's'; - delete data.sendMessageRequestBody.ttl_seconds; - } + // Special fields handling: see method for details + const requestDataBody = this.performSendMessageRequestBodyTransformation(data.sendMessageRequestBody); - const body: RequestBody = data['sendMessageRequestBody'] - ? JSON.stringify(data['sendMessageRequestBody']) + const body: RequestBody = requestDataBody + ? JSON.stringify(requestDataBody) : '{}'; const basePathUrl = `${this.client.apiClientOptions.hostname}/v1/projects/${this.client.apiClientOptions.projectId}/messages:send`; @@ -383,6 +380,20 @@ export class MessagesApi extends ConversationDomainApi { }); } + performSendMessageRequestBodyTransformation( + body: SendMessageRequest + ): SendMessageRequest { + const requestDataBody = { ...body }; + // 'ttl' field can be a number or a string and needs to be formatted as for instance "10s" to be accepted by the server + if (typeof requestDataBody.ttl === 'number') { + requestDataBody.ttl = requestDataBody.ttl.toString(); + } + if (typeof requestDataBody.ttl === 'string' && !requestDataBody.ttl.endsWith('s')) { + requestDataBody.ttl = requestDataBody.ttl + 's'; + } + return requestDataBody; + } + /** * Update message metadata * Update a specific message metadata by its ID. diff --git a/packages/conversation/tests/rest/v1/messages/messages-api.test.ts b/packages/conversation/tests/rest/v1/messages/messages-api.test.ts index 7663b6d4..14d558b0 100644 --- a/packages/conversation/tests/rest/v1/messages/messages-api.test.ts +++ b/packages/conversation/tests/rest/v1/messages/messages-api.test.ts @@ -191,7 +191,6 @@ describe('MessagesApi', () => { message: { ...messageBuilder.text(textMessageItem), }, - ttl_seconds: 20, }; const requestDataWithContactId: SendMessageRequestData = { sendMessageRequestBody: { @@ -226,6 +225,22 @@ describe('MessagesApi', () => { expect(response).toEqual(expectedResponse); expect(fixture.send).toHaveBeenCalledWith(requestData); }); + + it('should format the ttl field', () => { + const requestBody: SendMessageRequest = { + ...sendMessageRequest, + ...recipientContactId, + }; + requestBody.ttl = 20; + let formattedBody = messagesApi.performSendMessageRequestBodyTransformation(requestBody); + expect(formattedBody.ttl).toBe('20s'); + requestBody.ttl = '20'; + formattedBody = messagesApi.performSendMessageRequestBodyTransformation(requestBody); + expect(formattedBody.ttl).toBe('20s'); + requestBody.ttl = '20s'; + formattedBody = messagesApi.performSendMessageRequestBodyTransformation(requestBody); + expect(formattedBody.ttl).toBe('20s'); + }); }); describe ('sendCardMessage', () => {