Chilkat Online Tools

VBScript / Salesforce Platform APIs / Comment

Back to Collection Items

Dim fso, outFile
Set fso = CreateObject("Scripting.FileSystemObject")
'Create a Unicode (utf-16) output text file.
Set outFile = fso.CreateTextFile("output.txt", True, True)

' This example assumes the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.

' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Http")
set http = CreateObject("Chilkat.Http")

' Use this online tool to generate code from sample JSON: Generate Code to Create JSON

' The following JSON is sent in the request body.

' {
'   "body": {
'     "messageSegments": [
'       {
'         "type": "Text",
'         "text": "Editing a comment"
'       }
'     ]
'   }
' }

' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.JsonObject")
set json = CreateObject("Chilkat.JsonObject")
success = json.UpdateString("body.messageSegments[0].type","Text")
success = json.UpdateString("body.messageSegments[0].text","Editing a comment")

' Adds the "Authorization: Bearer <access_token>" header.
http.AuthToken = "<access_token>"
http.SetRequestHeader "Content-Type","application/json"

' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.StringBuilder")
set sbRequestBody = CreateObject("Chilkat.StringBuilder")
success = json.EmitSb(sbRequestBody)

' resp is a Chilkat.HttpResponse
Set resp = http.PTextSb("GET","https://domain.com/services/data/v{{version}}/chatter/comments/:COMMENT_ID",sbRequestBody,"utf-8","application/json",0,0)
If (http.LastMethodSuccess = 0) Then
    outFile.WriteLine(http.LastErrorText)
    WScript.Quit
End If

' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.StringBuilder")
set sbResponseBody = CreateObject("Chilkat.StringBuilder")
success = resp.GetBodySb(sbResponseBody)

' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.JsonObject")
set jResp = CreateObject("Chilkat.JsonObject")
success = jResp.LoadSb(sbResponseBody)
jResp.EmitCompact = 0

outFile.WriteLine("Response Body:")
outFile.WriteLine(jResp.Emit())

respStatusCode = resp.StatusCode
outFile.WriteLine("Response Status Code = " & respStatusCode)
If (respStatusCode >= 400) Then
    outFile.WriteLine("Response Header:")
    outFile.WriteLine(resp.Header)
    outFile.WriteLine("Failed.")

    WScript.Quit
End If

' Sample JSON response:
' (Sample code for parsing the JSON response is shown below)

' {
'   "body": {
'     "isRichText": true,
'     "messageSegments": [
'       {
'         "altText": null,
'         "htmlTag": "p",
'         "markupType": "Paragraph",
'         "text": "",
'         "type": "MarkupBegin",
'         "url": null
'       },
'       {
'         "text": "Comment",
'         "type": "Text"
'       },
'       {
'         "htmlTag": "p",
'         "markupType": "Paragraph",
'         "text": "\n",
'         "type": "MarkupEnd"
'       }
'     ],
'     "text": "Comment\n"
'   },
'   "capabilities": {
'     "edit": {
'       "isEditRestricted": false,
'       "isEditableByMeUrl": "/services/data/v58.0/chatter/comments/0D7.../capabilities/edit/is-editable-by-me",
'       "lastEditedBy": null,
'       "lastEditedDate": null,
'       "latestRevision": 1,
'       "relativeLastEditedDate": null
'     },
'     "status": {
'       "feedEntityStatus": "Published",
'       "isApprovableByMe": true
'     },
'     "upDownVote": {
'       "downVoteCount": 0,
'       "myVote": "None",
'       "upVoteCount": 0
'     },
'     "verified": {
'       "isVerifiableByMe": false,
'       "isVerified": false,
'       "isVerifiedByAnonymized": null,
'       "lastVerifiedByUser": null,
'       "lastVerifiedDate": null
'     }
'   },
'   "clientInfo": null,
'   "createdDate": "2023-11-22T11:19:50.000Z",
'   "feedElement": {
'     "id": "0D5...",
'     "url": "/services/data/v58.0/chatter/feed-elements/0D5..."
'   },
'   "id": "0D7...",
'   "isDeleteRestricted": false,
'   "likes": {
'     "currentPageToken": null,
'     "currentPageUrl": "/services/data/v58.0/chatter/comments/0D7.../likes",
'     "items": [
'     ],
'     "nextPageToken": null,
'     "nextPageUrl": null,
'     "previousPageToken": null,
'     "previousPageUrl": null,
'     "total": 0
'   },
'   "likesMessage": null,
'   "moderationFlags": null,
'   "myLike": null,
'   "parent": {
'     "id": "005...",
'     "url": "/services/data/v58.0/chatter/users/005..."
'   },
'   "relativeCreatedDate": "Just now",
'   "threadLevel": 0,
'   "threadParentId": null,
'   "type": "TextComment",
'   "url": "/services/data/v58.0/chatter/comments/0D7...",
'   "user": {
'     "additionalLabel": null,
'     "communityNickname": "User1696423780773910041",
'     "companyName": "Salesforce",
'     "displayName": "Name",
'     "firstName": "Firstname",
'     "id": "005...",
'     "isActive": true,
'     "isInThisCommunity": true,
'     "lastName": "Name",
'     "motif": {
'       "color": "1B96FF",
'       "largeIconUrl": "/img/icon/profile64.png",
'       "mediumIconUrl": "/img/icon/profile32.png",
'       "smallIconUrl": "/img/icon/profile16.png",
'       "svgIconUrl": null
'     },
'     "mySubscription": null,
'     "name": "Name",
'     "outOfOffice": {
'       "message": ""
'     },
'     "photo": {
'       "fullEmailPhotoUrl": "https://<my_domain>/ncsphoto/1wsMlOd3tVC7boygqBO8wMT9KzA0D6tqzpbs-Uw0IogXzXAXaYKJnuWCNQmXymRq?fromEmail=1",
'       "largePhotoUrl": "https://<my_domain>/profilephoto/729.../F",
'       "mediumPhotoUrl": "https://<my_domain>/profilephoto/729.../M",
'       "photoVersionId": "729...",
'       "smallPhotoUrl": "https://<my_domain>/profilephoto/729.../T",
'       "standardEmailPhotoUrl": "https://<my_domain>/ncsphoto/1wsMlOd3tVC7boygqBO8wMT9KzA0D6tqzpbs-Uw0Ioi-dtynkoFWsl46as__TDFU?fromEmail=1",
'       "url": "/services/data/v58.0/connect/user-profiles/005.../photo"
'     },
'     "reputation": null,
'     "title": null,
'     "type": "User",
'     "url": "/services/data/v58.0/chatter/users/005...",
'     "userType": "Internal"
'   }
' }

' Sample code for parsing the JSON response...
' Use this online tool to generate parsing code from sample JSON: Generate JSON Parsing Code

IsRichText = jResp.BoolOf("body.isRichText")
Text = jResp.StringOf("body.text")
IsEditRestricted = jResp.BoolOf("capabilities.edit.isEditRestricted")
IsEditableByMeUrl = jResp.StringOf("capabilities.edit.isEditableByMeUrl")
LastEditedBy = jResp.StringOf("capabilities.edit.lastEditedBy")
LastEditedDate = jResp.StringOf("capabilities.edit.lastEditedDate")
LatestRevision = jResp.IntOf("capabilities.edit.latestRevision")
RelativeLastEditedDate = jResp.StringOf("capabilities.edit.relativeLastEditedDate")
FeedEntityStatus = jResp.StringOf("capabilities.status.feedEntityStatus")
IsApprovableByMe = jResp.BoolOf("capabilities.status.isApprovableByMe")
DownVoteCount = jResp.IntOf("capabilities.upDownVote.downVoteCount")
MyVote = jResp.StringOf("capabilities.upDownVote.myVote")
UpVoteCount = jResp.IntOf("capabilities.upDownVote.upVoteCount")
IsVerifiableByMe = jResp.BoolOf("capabilities.verified.isVerifiableByMe")
IsVerified = jResp.BoolOf("capabilities.verified.isVerified")
IsVerifiedByAnonymized = jResp.StringOf("capabilities.verified.isVerifiedByAnonymized")
LastVerifiedByUser = jResp.StringOf("capabilities.verified.lastVerifiedByUser")
LastVerifiedDate = jResp.StringOf("capabilities.verified.lastVerifiedDate")
clientInfo = jResp.StringOf("clientInfo")
createdDate = jResp.StringOf("createdDate")
Id = jResp.StringOf("feedElement.id")
v_Url = jResp.StringOf("feedElement.url")
id = jResp.StringOf("id")
isDeleteRestricted = jResp.BoolOf("isDeleteRestricted")
CurrentPageToken = jResp.StringOf("likes.currentPageToken")
CurrentPageUrl = jResp.StringOf("likes.currentPageUrl")
NextPageToken = jResp.StringOf("likes.nextPageToken")
NextPageUrl = jResp.StringOf("likes.nextPageUrl")
PreviousPageToken = jResp.StringOf("likes.previousPageToken")
PreviousPageUrl = jResp.StringOf("likes.previousPageUrl")
Total = jResp.IntOf("likes.total")
likesMessage = jResp.StringOf("likesMessage")
moderationFlags = jResp.StringOf("moderationFlags")
myLike = jResp.StringOf("myLike")
parentId = jResp.StringOf("parent.id")
parentUrl = jResp.StringOf("parent.url")
relativeCreatedDate = jResp.StringOf("relativeCreatedDate")
threadLevel = jResp.IntOf("threadLevel")
threadParentId = jResp.StringOf("threadParentId")
v_type = jResp.StringOf("type")
url = jResp.StringOf("url")
AdditionalLabel = jResp.StringOf("user.additionalLabel")
CommunityNickname = jResp.StringOf("user.communityNickname")
CompanyName = jResp.StringOf("user.companyName")
DisplayName = jResp.StringOf("user.displayName")
FirstName = jResp.StringOf("user.firstName")
userId = jResp.StringOf("user.id")
IsActive = jResp.BoolOf("user.isActive")
IsInThisCommunity = jResp.BoolOf("user.isInThisCommunity")
LastName = jResp.StringOf("user.lastName")
Color = jResp.StringOf("user.motif.color")
LargeIconUrl = jResp.StringOf("user.motif.largeIconUrl")
MediumIconUrl = jResp.StringOf("user.motif.mediumIconUrl")
SmallIconUrl = jResp.StringOf("user.motif.smallIconUrl")
SvgIconUrl = jResp.StringOf("user.motif.svgIconUrl")
MySubscription = jResp.StringOf("user.mySubscription")
Name = jResp.StringOf("user.name")
Message = jResp.StringOf("user.outOfOffice.message")
FullEmailPhotoUrl = jResp.StringOf("user.photo.fullEmailPhotoUrl")
LargePhotoUrl = jResp.StringOf("user.photo.largePhotoUrl")
MediumPhotoUrl = jResp.StringOf("user.photo.mediumPhotoUrl")
PhotoVersionId = jResp.StringOf("user.photo.photoVersionId")
SmallPhotoUrl = jResp.StringOf("user.photo.smallPhotoUrl")
StandardEmailPhotoUrl = jResp.StringOf("user.photo.standardEmailPhotoUrl")
PhotoUrl = jResp.StringOf("user.photo.url")
Reputation = jResp.StringOf("user.reputation")
Title = jResp.StringOf("user.title")
v_Type = jResp.StringOf("user.type")
userUrl = jResp.StringOf("user.url")
UserType = jResp.StringOf("user.userType")
i = 0
count_i = jResp.SizeOfArray("body.messageSegments")
Do While i < count_i
    jResp.I = i
    altText = jResp.StringOf("body.messageSegments[i].altText")
    htmlTag = jResp.StringOf("body.messageSegments[i].htmlTag")
    markupType = jResp.StringOf("body.messageSegments[i].markupType")
    text = jResp.StringOf("body.messageSegments[i].text")
    v_type = jResp.StringOf("body.messageSegments[i].type")
    url = jResp.StringOf("body.messageSegments[i].url")
    i = i + 1
Loop
i = 0
count_i = jResp.SizeOfArray("likes.items")
Do While i < count_i
    jResp.I = i
    i = i + 1
Loop

outFile.Close

Curl Command

curl -X GET
	-H "Authorization: Bearer <access_token>"
	-H "Content-Type: application/json"
	-d '{
    "body": {
        "messageSegments": [
            {
                "type": "Text",
                "text": "Editing a comment"
            }
        ]
    }
}'
https://domain.com/services/data/v{{version}}/chatter/comments/:COMMENT_ID

Postman Collection Item JSON

{
  "name": "Comment",
  "event": [
    {
      "listen": "prerequest",
      "script": {
        "exec": [
          ""
        ],
        "type": "text/javascript"
      }
    },
    {
      "listen": "test",
      "script": {
        "exec": [
          ""
        ],
        "type": "text/javascript"
      }
    }
  ],
  "protocolProfileBehavior": {
    "disabledSystemHeaders": {},
    "disableBodyPruning": true
  },
  "request": {
    "method": "GET",
    "header": [
      {
        "key": "Content-Type",
        "value": "application/json",
        "type": "text"
      }
    ],
    "body": {
      "mode": "raw",
      "raw": "{\n    \"body\": {\n        \"messageSegments\": [\n            {\n                \"type\": \"Text\",\n                \"text\": \"Editing a comment\"\n            }\n        ]\n    }\n}",
      "options": {
        "raw": {
          "language": "json"
        }
      }
    },
    "url": {
      "raw": "{{_endpoint}}/services/data/v{{version}}/chatter/comments/:COMMENT_ID",
      "host": [
        "{{_endpoint}}"
      ],
      "path": [
        "services",
        "data",
        "v{{version}}",
        "chatter",
        "comments",
        ":COMMENT_ID"
      ],
      "variable": [
        {
          "key": "COMMENT_ID",
          "value": "0D7..."
        }
      ]
    },
    "description": "Get information about, edit, or delete a comment.\nTo post a comment, use Feed Elements Capability, Comments Items.\n\nhttps://developer.salesforce.com/docs/atlas.en-us.chatterapi.meta/chatterapi/connect_resources_comments_specific.htm#connect_resources_comments_specific"
  },
  "response": [
    {
      "name": "Successful Comment",
      "originalRequest": {
        "method": "GET",
        "header": [
          {
            "key": "Content-Type",
            "value": "application/json"
          }
        ],
        "body": {
          "mode": "raw",
          "raw": "{\n    \"body\": {\n        \"messageSegments\": [\n            {\n                \"type\": \"Text\",\n                \"text\": \"Editing a comment\"\n            }\n        ]\n    }\n}",
          "options": {
            "raw": {
              "language": "json"
            }
          }
        },
        "url": {
          "raw": "{{_endpoint}}/services/data/v{{version}}/chatter/comments/:COMMENT_ID",
          "host": [
            "{{_endpoint}}"
          ],
          "path": [
            "services",
            "data",
            "v{{version}}",
            "chatter",
            "comments",
            ":COMMENT_ID"
          ],
          "variable": [
            {
              "key": "COMMENT_ID",
              "value": "0D72o00000E8dNiCAJ"
            }
          ]
        }
      },
      "status": "OK",
      "code": 200,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "Date",
          "value": "Wed, 22 Nov 2023 11:20:42 GMT"
        },
        {
          "key": "Strict-Transport-Security",
          "value": "max-age=63072000; includeSubDomains"
        },
        {
          "key": "X-Content-Type-Options",
          "value": "nosniff"
        },
        {
          "key": "X-XSS-Protection",
          "value": "1; mode=block"
        },
        {
          "key": "X-Robots-Tag",
          "value": "none"
        },
        {
          "key": "Cache-Control",
          "value": "no-cache,must-revalidate,max-age=0,no-store,private"
        },
        {
          "key": "Content-Type",
          "value": "application/json;charset=UTF-8"
        },
        {
          "key": "Vary",
          "value": "Accept-Encoding"
        },
        {
          "key": "Content-Encoding",
          "value": "gzip"
        },
        {
          "key": "Transfer-Encoding",
          "value": "chunked"
        }
      ],
      "cookie": [
      ],
      "body": "{\n    \"body\": {\n        \"isRichText\": true,\n        \"messageSegments\": [\n            {\n                \"altText\": null,\n                \"htmlTag\": \"p\",\n                \"markupType\": \"Paragraph\",\n                \"text\": \"\",\n                \"type\": \"MarkupBegin\",\n                \"url\": null\n            },\n            {\n                \"text\": \"Comment\",\n                \"type\": \"Text\"\n            },\n            {\n                \"htmlTag\": \"p\",\n                \"markupType\": \"Paragraph\",\n                \"text\": \"\\n\",\n                \"type\": \"MarkupEnd\"\n            }\n        ],\n        \"text\": \"Comment\\n\"\n    },\n    \"capabilities\": {\n        \"edit\": {\n            \"isEditRestricted\": false,\n            \"isEditableByMeUrl\": \"/services/data/v58.0/chatter/comments/0D7.../capabilities/edit/is-editable-by-me\",\n            \"lastEditedBy\": null,\n            \"lastEditedDate\": null,\n            \"latestRevision\": 1,\n            \"relativeLastEditedDate\": null\n        },\n        \"status\": {\n            \"feedEntityStatus\": \"Published\",\n            \"isApprovableByMe\": true\n        },\n        \"upDownVote\": {\n            \"downVoteCount\": 0,\n            \"myVote\": \"None\",\n            \"upVoteCount\": 0\n        },\n        \"verified\": {\n            \"isVerifiableByMe\": false,\n            \"isVerified\": false,\n            \"isVerifiedByAnonymized\": null,\n            \"lastVerifiedByUser\": null,\n            \"lastVerifiedDate\": null\n        }\n    },\n    \"clientInfo\": null,\n    \"createdDate\": \"2023-11-22T11:19:50.000Z\",\n    \"feedElement\": {\n        \"id\": \"0D5...\",\n        \"url\": \"/services/data/v58.0/chatter/feed-elements/0D5...\"\n    },\n    \"id\": \"0D7...\",\n    \"isDeleteRestricted\": false,\n    \"likes\": {\n        \"currentPageToken\": null,\n        \"currentPageUrl\": \"/services/data/v58.0/chatter/comments/0D7.../likes\",\n        \"items\": [],\n        \"nextPageToken\": null,\n        \"nextPageUrl\": null,\n        \"previousPageToken\": null,\n        \"previousPageUrl\": null,\n        \"total\": 0\n    },\n    \"likesMessage\": null,\n    \"moderationFlags\": null,\n    \"myLike\": null,\n    \"parent\": {\n        \"id\": \"005...\",\n        \"url\": \"/services/data/v58.0/chatter/users/005...\"\n    },\n    \"relativeCreatedDate\": \"Just now\",\n    \"threadLevel\": 0,\n    \"threadParentId\": null,\n    \"type\": \"TextComment\",\n    \"url\": \"/services/data/v58.0/chatter/comments/0D7...\",\n    \"user\": {\n        \"additionalLabel\": null,\n        \"communityNickname\": \"User1696423780773910041\",\n        \"companyName\": \"Salesforce\",\n        \"displayName\": \"Name\",\n        \"firstName\": \"Firstname\",\n        \"id\": \"005...\",\n        \"isActive\": true,\n        \"isInThisCommunity\": true,\n        \"lastName\": \"Name\",\n        \"motif\": {\n            \"color\": \"1B96FF\",\n            \"largeIconUrl\": \"/img/icon/profile64.png\",\n            \"mediumIconUrl\": \"/img/icon/profile32.png\",\n            \"smallIconUrl\": \"/img/icon/profile16.png\",\n            \"svgIconUrl\": null\n        },\n        \"mySubscription\": null,\n        \"name\": \"Name\",\n        \"outOfOffice\": {\n            \"message\": \"\"\n        },\n        \"photo\": {\n            \"fullEmailPhotoUrl\": \"https://<my_domain>/ncsphoto/1wsMlOd3tVC7boygqBO8wMT9KzA0D6tqzpbs-Uw0IogXzXAXaYKJnuWCNQmXymRq?fromEmail=1\",\n            \"largePhotoUrl\": \"https://<my_domain>/profilephoto/729.../F\",\n            \"mediumPhotoUrl\": \"https://<my_domain>/profilephoto/729.../M\",\n            \"photoVersionId\": \"729...\",\n            \"smallPhotoUrl\": \"https://<my_domain>/profilephoto/729.../T\",\n            \"standardEmailPhotoUrl\": \"https://<my_domain>/ncsphoto/1wsMlOd3tVC7boygqBO8wMT9KzA0D6tqzpbs-Uw0Ioi-dtynkoFWsl46as__TDFU?fromEmail=1\",\n            \"url\": \"/services/data/v58.0/connect/user-profiles/005.../photo\"\n        },\n        \"reputation\": null,\n        \"title\": null,\n        \"type\": \"User\",\n        \"url\": \"/services/data/v58.0/chatter/users/005...\",\n        \"userType\": \"Internal\"\n    }\n}"
    }
  ]
}