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