In this tutorial we will publish images to a conversation.
Prerequisites
See Prerequisites.
Step 1 — Enable Image Sharing
In order to publish images in your account, you should first enable the feature. Insert your account admin username and password and type the following:
LP_USER=__AGENT_USERNAME__
LP_PASS=__AGENT_PASSWORD__
LP_BEARER=`curl -c cookies -X POST -H "Content-Type: application/json" -H "Accept: application/json" -H "Cache-Control: no-cache" -d '{"username": "'$LP_USER'","password":"'$LP_PASS'"}' "https://$LP_AGENTVEP/api/account/$LP_ACCOUNT/login?v=1.1" jq -r .bearer`
./set_site_property.sh $LP_BEARER true messaging.file.sharing.enabled
Now download an example image file to your shell:
wget https://static.liveperson.com/static-assets/2022/02/10094247/logo-light-large.png
We will further publish this image to the messaging service.
Step 2 — Create a Conversation
Open a connection to the messaging service.
wscat -k 60 -H "Authorization:jwt $LP_JWT" -c "wss://$LP_ASYNCMESSAGINGENT/ws_api/account/$LP_ACCOUNT/messaging/consumer?v=3"
Then ask to create a new conversation:
{"kind":"req","id":1,"type":"cm.ConsumerRequestConversation"}
In response, you will get a conversation ID that will be used in the next steps.
Step 3 — Upload an image
Now, ask the service to create an upload URL.
{"kind":"req","id":"3","body":{"fileSize":1000,"fileType":"PNG"},"type":"ms.GenerateURLForUploadFile" }
In response you will get the following message:
{"kind":"resp","reqId":"3","code":200,"body":{"relativePath":"/v1/AUTH_async-images/qa57221676/8a66a22f-81ee-4447-b92f-78e9c3ecc819.PNG","queryParams":{"temp_url_sig":"6f52625b7f148325071c2518c714109134acd7a3","temp_url_expires":"1474973420"}},"type":"ms.BaseGenerateURLResponse"}
We will extract the relativePath
, temp_url_sig
and temp_url_expires
from this response, and use this value in the upload call. Close the WebSocket connection using Ctrl+C
and type the following commands with the values you extracted from the previous response.
LP_REL_PATH=__relativePath__
LP_TUS=__temp_url_sig__
LP_TUE=___temp_url_expires__
curl -i "https://${LP_SWIFT}$LP_REL_PATH?temp_url_sig=$LP_TUS&temp_url_expires=$LP_TUE" --upload-file LP_LOGO_1.png
This call should upload the image file you have on your disk to LivePerson object storage.
Step 4 — Publish the Conversation
Reestablish the connection using:
wscat -k 60 -H "Authorization:jwt $LP_JWT" -c "wss://$LP_ASYNCMESSAGINGENT/ws_api/account/$LP_ACCOUNT/messaging/consumer?v=3"
Then publish the image with the conversationId
from Step 2, and the relativePath
from Step 3.
{"kind":"req","id":"22","body":{"dialogId":"__CONVERSATION_ID__","event":{"type":"ContentEvent","message":{"caption":"LivePerson logo","relativePath":"__relative_path__","fileType":"PNG","preview":""},"contentType":"hosted/file"}},"type":"ms.PublishEvent"}
(Not Available yet in production): Now log into the Agent Workspace, accept the open conversation, and you should see the image that has been published by the consumer.
Step 5 — Download the image from the Conversation
In order to download an image that was published to the conversation, follow these steps.
Paste the following message to the open connection using the relative_path
from Step 4:
{"kind":"req","id":"33","body":{"relativePath":"__relative_path__"},"type":"ms.GenerateURLForDownloadFile"}
In response, you will get the URL details:
{"kind":"resp","reqId":"3","code":200,"body":{"relativePath":"/v1/AUTH_async-images/qa57221676/8a66a22f-81ee-4447-b92f-78e9c3ecc819.PNG","queryParams":{"temp_url_sig":"6f52625b7f148325071c2518c714109134acd7a3","temp_url_expires":"1474973420"}},"type":"ms.BaseGenerateURLResponse"}
We will extract the relativePath
, temp_url_sig
and temp_url_expires
from this response and use this value in the upload call. Close the WebSocket connection using Ctrl+c
and type the following commands with the values you extracted from the previous response.
LP_REL_PATH=__relativePath__
LP_TUS=__temp_url_sig__
LP_TUE=___temp_url_expires__
curl -i "https://${LP_SWIFT}$LP_REL_PATH?temp_url_sig=$LP_TUS&temp_url_expires=$LP_TUE" --output my.png