File Uploads
When you upload a file, Wildix CDN becomes the host for your file, taking charge of its safe storage. Uploading files is by far the easiest way to use files in x-bees.
- Files are stored in company storage and could be removed due to data retention policy configured in WMS (documentation: https://wildix.atlassian.net/wiki/x/hQAMEw).
- Files are attached to a specific channel, and access to the file is available only to members of the channel.
- Each message can have up to 10 attachments.
- Once a file is uploaded, it cannot be removed, but the access to the file can be restricted if you remove the message where the file is attached.
- If a service token is used, it is necessary to specify the ID of the user on whose behalf the operation is performed.
Commands
Retrieves a presigned URL for downloading a specific file from a message in a specified channel.
Retrieves information about an uploaded file in a specified channel.
Create a presigned URL for file upload in the channel.
Upload files or images
import {
ConversationsClient,
GetUploadedFileInfoCommand,
SendMessageCommand,
UploadFileCommand
} from '@wildix/xbees-conversations-client';
import fs from 'fs';
// Initialize the client with the desired configuration
const client = new ConversationsClient({...});
const channelId = '<channel-id>';
const fileName = 'example.jpg';
const fileContent = fs.readFileSync(`./${fileName}`);
// Create a file resource to get an upload URL for the file
const fileUploadResponse = await client.send(
new UploadFileCommand({
channelId,
name: fileName,
// Specify user ID in case of service authorization
options: {
userId: '<user-id>',
},
}),
);
// Upload content to the file storage service
await fetch(fileUploadResponse.presignedUploadUrl, {
method: 'PUT',
body: fileContent,
});
// Get the uploaded file info
const fileUploadInfoResponse = await client.send(
new GetUploadedFileInfoCommand({
channelId,
fileId: fileUploadResponse.fileId,
}),
);
// Prepare attachments for the message
const attachments = [];
if (fileUploadInfoResponse.file) {
attachments.push(fileUploadInfoResponse.file);
}
// Send a message with the uploaded file attached
const sendMessageResponse = await client.send(
new SendMessageCommand({
channelId,
userId: '<user-id>', // Specify user ID in case of service authorization
text: "File example",
attachments,
}),
);
console.log('Message sent successfully', sendMessageResponse);
Download files
import {
ConversationsClient,
GetFilePresignedDownloadUrlCommand
} from '@wildix/xbees-conversations-client';
// Initialize the client with the desired configuration
const client = new ConversationsClient({...});
const channelId = '<channel-id>';
const messageId = '<message-id>';
const fileId = '<file-id>';
// Get the presigned download URL for the file
const fileDownloadUrlResponse = await client.send(
new GetFilePresignedDownloadUrlCommand({
channelId,
messageId,
fileId,
}),
);
// Fetch the file content from the presigned URL
const fileDownloadResponse = await fetch(fileDownloadUrlResponse.presignedDownloadUrl);
const fileDownloadBuffer = await fileDownloadResponse.arrayBuffer();
console.log('File downloaded successfully', fileDownloadBuffer);