Chilkat Online Tools

Ruby / Atlassian Confluence Cloud / Get current user

Back to Collection Items

require 'chilkat'

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

http = Chilkat::CkHttp.new()

queryParams = Chilkat::CkJsonObject.new()
queryParams.UpdateString("expand","<string>")
queryParams.UpdateString("expand","<string>")

# Adds the "Authorization: Bearer <access_token>" header.
http.put_AuthToken("<access_token>")

# resp is a CkHttpResponse
resp = http.QuickRequestParams("GET","https://your-domain.atlassian.net/wiki/rest/api/user/current",queryParams)
if (http.get_LastMethodSuccess() == false)
    print http.lastErrorText() + "\n";
    exit
end

sbResponseBody = Chilkat::CkStringBuilder.new()
resp.GetBodySb(sbResponseBody)

jResp = Chilkat::CkJsonObject.new()
jResp.LoadSb(sbResponseBody)
jResp.put_EmitCompact(false)

print "Response Body:" + "\n";
print jResp.emit() + "\n";

respStatusCode = resp.get_StatusCode()
print "Response Status Code = " + respStatusCode.to_s() + "\n";
if (respStatusCode >= 400)
    print "Response Header:" + "\n";
    print resp.header() + "\n";
    print "Failed." + "\n";

    exit
end

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

# {
#   "type": "unknown",
#   "accountId": "sit consectetur",
#   "accountType": "atlassian",
#   "email": "do",
#   "publicName": "et nostrud mollit id",
#   "profilePicture": {
#     "path": "eiusmod Excepteur",
#     "width": 61811707,
#     "height": -27758421,
#     "isDefault": true
#   },
#   "displayName": "eiusmod pariatur aliqua cupidatat",
#   "_expandable": {
#     "operations": "officia nu",
#     "details": "exercitation ipsum elit tempor laborum",
#     "personalSpace": "exercitation re"
#   },
#   "_links": {},
#   "username": "sed velit Ut",
#   "userKey": "labore anim",
#   "operations": [
#     {
#       "operation": "use",
#       "targetType": "application"
#     },
#     {
#       "operation": "restore",
#       "targetType": "space"
#     }
#   ],
#   "details": {
#     "business": {
#       "value": "<Error: Too many levels of nesting to fake this schema>"
#     },
#     "personal": {
#       "value": "<Error: Too many levels of nesting to fake this schema>"
#     }
#   },
#   "personalSpace": {
#     "id": -69293677,
#     "key": "minim",
#     "name": "adipisicing minim nulla nisi consequat",
#     "type": "reprehenderit",
#     "status": "amet officia pariatur sed",
#     "_expandable": {
#       "settings": "deserunt dolore velit laborum",
#       "metadata": "ullamco quis non sunt",
#       "operations": "qui aliquip",
#       "lookAndFeel": "eiusmod cillum ex",
#       "permissions": "in ullamco",
#       "icon": "veniam quis",
#       "description": "officia adip",
#       "theme": "ea nisi",
#       "history": "aliquip est irure",
#       "homepage": "aliqua est deserunt"
#     },
#     "_links": {},
#     "icon": {
#       "path": "adipisicing sed officia",
#       "width": 33631448,
#       "height": -10767970,
#       "isDefault": true
#     },
#     "description": {
#       "plain": {
#         "value": "cupidatat nulla",
#         "representation": "view",
#         "embeddedContent": [
#           {
#             "value": "<Error: Too many levels of nesting to fake this schema>"
#           },
#           {
#             "value": "<Error: Too many levels of nesting to fake this schema>"
#           }
#         ]
#       },
#       "view": {
#         "value": "magna aliquip ea",
#         "representation": "plain",
#         "embeddedContent": [
#           {
#             "value": "<Error: Too many levels of nesting to fake this schema>"
#           },
#           {
#             "value": "<Error: Too many levels of nesting to fake this schema>"
#           }
#         ]
#       }
#     },
#     "homepage": {
#       "value": "<Circular reference to #/components/schemas/Content detected>"
#     },
#     "metadata": {
#       "labels": {
#         "results": [
#           {
#             "value": "<Error: Too many levels of nesting to fake this schema>"
#           },
#           {
#             "value": "<Error: Too many levels of nesting to fake this schema>"
#           }
#         ],
#         "start": 58105433,
#         "limit": 10735114,
#         "size": -29792214,
#         "_links": {}
#       }
#     },
#     "operations": [
#       {
#         "operation": "delete",
#         "targetType": "blogpost"
#       },
#       {
#         "operation": "restore",
#         "targetType": "blogpost"
#       }
#     ],
#     "permissions": [
#       {
#         "subjects": {
#           "_expandable": {
#             "value": "<Error: Too many levels of nesting to fake this schema>"
#           },
#           "user": {
#             "value": "<Error: Too many levels of nesting to fake this schema>"
#           },
#           "group": {
#             "value": "<Error: Too many levels of nesting to fake this schema>"
#           }
#         },
#         "operation": {
#           "operation": "create",
#           "targetType": "page"
#         },
#         "anonymousAccess": false,
#         "unlicensedAccess": false
#       },
#       {
#         "subjects": {
#           "_expandable": {
#             "value": "<Error: Too many levels of nesting to fake this schema>"
#           },
#           "user": {
#             "value": "<Error: Too many levels of nesting to fake this schema>"
#           },
#           "group": {
#             "value": "<Error: Too many levels of nesting to fake this schema>"
#           }
#         },
#         "operation": {
#           "operation": "restore",
#           "targetType": "blogpost"
#         },
#         "anonymousAccess": false,
#         "unlicensedAccess": false
#       }
#     ],
#     "settings": {
#       "routeOverrideEnabled": false,
#       "_links": {}
#     },
#     "theme": {},
#     "lookAndFeel": {
#       "headings": {
#         "color": "<string>"
#       },
#       "links": {
#         "color": "<string>"
#       },
#       "menus": {
#         "hoverOrFocus": {
#           "value": "<Error: Too many levels of nesting to fake this schema>"
#         },
#         "color": {
#           "value": "<Error: Too many levels of nesting to fake this schema>"
#         }
#       },
#       "header": {
#         "backgroundColor": {
#           "value": "<Error: Too many levels of nesting to fake this schema>"
#         },
#         "button": {
#           "value": "<Error: Too many levels of nesting to fake this schema>"
#         },
#         "primaryNavigation": {
#           "value": "<Error: Too many levels of nesting to fake this schema>"
#         },
#         "secondaryNavigation": {
#           "value": "<Error: Too many levels of nesting to fake this schema>"
#         },
#         "search": {
#           "value": "<Error: Too many levels of nesting to fake this schema>"
#         }
#       },
#       "content": {
#         "screen": {
#           "value": "<Error: Too many levels of nesting to fake this schema>"
#         },
#         "container": {
#           "value": "<Error: Too many levels of nesting to fake this schema>"
#         },
#         "header": {
#           "value": "<Error: Too many levels of nesting to fake this schema>"
#         },
#         "body": {
#           "value": "<Error: Too many levels of nesting to fake this schema>"
#         }
#       },
#       "bordersAndDividers": {
#         "color": "<string>"
#       }
#     },
#     "history": {
#       "createdDate": "2014-12-12T23:08:45.947Z"
#     }
#   }
# }

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

v_type = jResp.stringOf("type")
accountId = jResp.stringOf("accountId")
accountType = jResp.stringOf("accountType")
email = jResp.stringOf("email")
publicName = jResp.stringOf("publicName")
Path = jResp.stringOf("profilePicture.path")
Width = jResp.IntOf("profilePicture.width")
Height = jResp.IntOf("profilePicture.height")
IsDefault = jResp.BoolOf("profilePicture.isDefault")
displayName = jResp.stringOf("displayName")
Operations = jResp.stringOf("_expandable.operations")
Details = jResp.stringOf("_expandable.details")
PersonalSpace = jResp.stringOf("_expandable.personalSpace")
username = jResp.stringOf("username")
userKey = jResp.stringOf("userKey")
Value = jResp.stringOf("details.business.value")
PersonalValue = jResp.stringOf("details.personal.value")
Id = jResp.IntOf("personalSpace.id")
Key = jResp.stringOf("personalSpace.key")
Name = jResp.stringOf("personalSpace.name")
v_Type = jResp.stringOf("personalSpace.type")
Status = jResp.stringOf("personalSpace.status")
Settings = jResp.stringOf("personalSpace._expandable.settings")
Metadata = jResp.stringOf("personalSpace._expandable.metadata")
v_expandableOperations = jResp.stringOf("personalSpace._expandable.operations")
LookAndFeel = jResp.stringOf("personalSpace._expandable.lookAndFeel")
Permissions = jResp.stringOf("personalSpace._expandable.permissions")
Icon = jResp.stringOf("personalSpace._expandable.icon")
Description = jResp.stringOf("personalSpace._expandable.description")
Theme = jResp.stringOf("personalSpace._expandable.theme")
History = jResp.stringOf("personalSpace._expandable.history")
Homepage = jResp.stringOf("personalSpace._expandable.homepage")
IconPath = jResp.stringOf("personalSpace.icon.path")
IconWidth = jResp.IntOf("personalSpace.icon.width")
IconHeight = jResp.IntOf("personalSpace.icon.height")
IconIsDefault = jResp.BoolOf("personalSpace.icon.isDefault")
PlainValue = jResp.stringOf("personalSpace.description.plain.value")
Representation = jResp.stringOf("personalSpace.description.plain.representation")
ViewValue = jResp.stringOf("personalSpace.description.view.value")
ViewRepresentation = jResp.stringOf("personalSpace.description.view.representation")
HomepageValue = jResp.stringOf("personalSpace.homepage.value")
Start = jResp.IntOf("personalSpace.metadata.labels.start")
Limit = jResp.IntOf("personalSpace.metadata.labels.limit")
Size = jResp.IntOf("personalSpace.metadata.labels.size")
RouteOverrideEnabled = jResp.BoolOf("personalSpace.settings.routeOverrideEnabled")
Color = jResp.stringOf("personalSpace.lookAndFeel.headings.color")
LinksColor = jResp.stringOf("personalSpace.lookAndFeel.links.color")
HoverOrFocusValue = jResp.stringOf("personalSpace.lookAndFeel.menus.hoverOrFocus.value")
ColorValue = jResp.stringOf("personalSpace.lookAndFeel.menus.color.value")
BackgroundColorValue = jResp.stringOf("personalSpace.lookAndFeel.header.backgroundColor.value")
ButtonValue = jResp.stringOf("personalSpace.lookAndFeel.header.button.value")
PrimaryNavigationValue = jResp.stringOf("personalSpace.lookAndFeel.header.primaryNavigation.value")
SecondaryNavigationValue = jResp.stringOf("personalSpace.lookAndFeel.header.secondaryNavigation.value")
SearchValue = jResp.stringOf("personalSpace.lookAndFeel.header.search.value")
ScreenValue = jResp.stringOf("personalSpace.lookAndFeel.content.screen.value")
ContainerValue = jResp.stringOf("personalSpace.lookAndFeel.content.container.value")
HeaderValue = jResp.stringOf("personalSpace.lookAndFeel.content.header.value")
BodyValue = jResp.stringOf("personalSpace.lookAndFeel.content.body.value")
BordersAndDividersColor = jResp.stringOf("personalSpace.lookAndFeel.bordersAndDividers.color")
CreatedDate = jResp.stringOf("personalSpace.history.createdDate")
i = 0
count_i = jResp.SizeOfArray("operations")
while i < count_i
    jResp.put_I(i)
    operation = jResp.stringOf("operations[i].operation")
    targetType = jResp.stringOf("operations[i].targetType")
    i = i + 1
end
i = 0
count_i = jResp.SizeOfArray("personalSpace.description.plain.embeddedContent")
while i < count_i
    jResp.put_I(i)
    value = jResp.stringOf("personalSpace.description.plain.embeddedContent[i].value")
    i = i + 1
end
i = 0
count_i = jResp.SizeOfArray("personalSpace.description.view.embeddedContent")
while i < count_i
    jResp.put_I(i)
    value = jResp.stringOf("personalSpace.description.view.embeddedContent[i].value")
    i = i + 1
end
i = 0
count_i = jResp.SizeOfArray("personalSpace.metadata.labels.results")
while i < count_i
    jResp.put_I(i)
    value = jResp.stringOf("personalSpace.metadata.labels.results[i].value")
    i = i + 1
end
i = 0
count_i = jResp.SizeOfArray("personalSpace.operations")
while i < count_i
    jResp.put_I(i)
    operation = jResp.stringOf("personalSpace.operations[i].operation")
    targetType = jResp.stringOf("personalSpace.operations[i].targetType")
    i = i + 1
end
i = 0
count_i = jResp.SizeOfArray("personalSpace.permissions")
while i < count_i
    jResp.put_I(i)
    v_expandableValue = jResp.stringOf("personalSpace.permissions[i].subjects._expandable.value")
    UserValue = jResp.stringOf("personalSpace.permissions[i].subjects.user.value")
    GroupValue = jResp.stringOf("personalSpace.permissions[i].subjects.group.value")
    Operation = jResp.stringOf("personalSpace.permissions[i].operation.operation")
    TargetType = jResp.stringOf("personalSpace.permissions[i].operation.targetType")
    anonymousAccess = jResp.BoolOf("personalSpace.permissions[i].anonymousAccess")
    unlicensedAccess = jResp.BoolOf("personalSpace.permissions[i].unlicensedAccess")
    i = i + 1
end

Curl Command

curl -G -d "expand=%3Cstring%3E"
	-d "expand=%3Cstring%3E"
	-H "Authorization: Bearer <access_token>"
https://your-domain.atlassian.net/wiki/rest/api/user/current

Postman Collection Item JSON

{
  "name": "Get current user",
  "request": {
    "auth": {
      "type": "oauth2"
    },
    "method": "GET",
    "header": [
    ],
    "url": {
      "raw": "{{baseUrl}}/api/user/current?expand=<string>&expand=<string>",
      "host": [
        "{{baseUrl}}"
      ],
      "path": [
        "api",
        "user",
        "current"
      ],
      "query": [
        {
          "key": "expand",
          "value": "<string>",
          "description": "A multi-value parameter indicating which properties of the user to\nexpand.\n\n  - `operations` returns the operations that the user is allowed to do.\n  - `details.personal` returns the 'Personal' details in the user's profile, like the 'Email' and 'Phone'.\n  Note that these fields have been deprecated due to privacy changes. See the\n  [migration guide](https://developer.atlassian.com/cloud/confluence/deprecation-notice-user-privacy-api-migration-guide/)\n  for details.\n  - `details.business` returns the 'Company' details in the user's profile, like the 'Position' and 'Department'.\n  Note that these fields have been deprecated due to privacy changes. See the\n  [migration guide](https://developer.atlassian.com/cloud/confluence/deprecation-notice-user-privacy-api-migration-guide/)\n  for details.\n  - personalSpace returns the user's personal space, if it exists."
        },
        {
          "key": "expand",
          "value": "<string>",
          "description": "A multi-value parameter indicating which properties of the user to\nexpand.\n\n  - `operations` returns the operations that the user is allowed to do.\n  - `details.personal` returns the 'Personal' details in the user's profile, like the 'Email' and 'Phone'.\n  Note that these fields have been deprecated due to privacy changes. See the\n  [migration guide](https://developer.atlassian.com/cloud/confluence/deprecation-notice-user-privacy-api-migration-guide/)\n  for details.\n  - `details.business` returns the 'Company' details in the user's profile, like the 'Position' and 'Department'.\n  Note that these fields have been deprecated due to privacy changes. See the\n  [migration guide](https://developer.atlassian.com/cloud/confluence/deprecation-notice-user-privacy-api-migration-guide/)\n  for details.\n  - personalSpace returns the user's personal space, if it exists."
        }
      ]
    },
    "description": "Returns the currently logged-in user. This includes information about\nthe user, like the display name, userKey, account ID, profile picture,\nand more.\n\n**[Permissions](https://confluence.atlassian.com/x/_AozKw) required**:\nPermission to access the Confluence site ('Can use' global permission)."
  },
  "response": [
    {
      "name": "Returned if the current user is returned.",
      "originalRequest": {
        "method": "GET",
        "header": [
          {
            "description": {
              "content": "Added as a part of security scheme: oauth2",
              "type": "text/plain"
            },
            "key": "Authorization",
            "value": "<token>"
          }
        ],
        "url": {
          "raw": "{{baseUrl}}/api/user/current?expand=<string>&expand=<string>",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "api",
            "user",
            "current"
          ],
          "query": [
            {
              "key": "expand",
              "value": "<string>"
            },
            {
              "key": "expand",
              "value": "<string>"
            }
          ]
        }
      },
      "status": "OK",
      "code": 200,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n \"type\": \"unknown\",\n \"accountId\": \"sit consectetur\",\n \"accountType\": \"atlassian\",\n \"email\": \"do\",\n \"publicName\": \"et nostrud mollit id\",\n \"profilePicture\": {\n  \"path\": \"eiusmod Excepteur\",\n  \"width\": 61811707,\n  \"height\": -27758421,\n  \"isDefault\": true\n },\n \"displayName\": \"eiusmod pariatur aliqua cupidatat\",\n \"_expandable\": {\n  \"operations\": \"officia nu\",\n  \"details\": \"exercitation ipsum elit tempor laborum\",\n  \"personalSpace\": \"exercitation re\"\n },\n \"_links\": {},\n \"username\": \"sed velit Ut\",\n \"userKey\": \"labore anim\",\n \"operations\": [\n  {\n   \"operation\": \"use\",\n   \"targetType\": \"application\"\n  },\n  {\n   \"operation\": \"restore\",\n   \"targetType\": \"space\"\n  }\n ],\n \"details\": {\n  \"business\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  },\n  \"personal\": {\n   \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n  }\n },\n \"personalSpace\": {\n  \"id\": -69293677,\n  \"key\": \"minim\",\n  \"name\": \"adipisicing minim nulla nisi consequat\",\n  \"type\": \"reprehenderit\",\n  \"status\": \"amet officia pariatur sed\",\n  \"_expandable\": {\n   \"settings\": \"deserunt dolore velit laborum\",\n   \"metadata\": \"ullamco quis non sunt\",\n   \"operations\": \"qui aliquip\",\n   \"lookAndFeel\": \"eiusmod cillum ex\",\n   \"permissions\": \"in ullamco\",\n   \"icon\": \"veniam quis\",\n   \"description\": \"officia adip\",\n   \"theme\": \"ea nisi\",\n   \"history\": \"aliquip est irure\",\n   \"homepage\": \"aliqua est deserunt\"\n  },\n  \"_links\": {},\n  \"icon\": {\n   \"path\": \"adipisicing sed officia\",\n   \"width\": 33631448,\n   \"height\": -10767970,\n   \"isDefault\": true\n  },\n  \"description\": {\n   \"plain\": {\n    \"value\": \"cupidatat nulla\",\n    \"representation\": \"view\",\n    \"embeddedContent\": [\n     {\n      \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n     },\n     {\n      \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n     }\n    ]\n   },\n   \"view\": {\n    \"value\": \"magna aliquip ea\",\n    \"representation\": \"plain\",\n    \"embeddedContent\": [\n     {\n      \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n     },\n     {\n      \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n     }\n    ]\n   }\n  },\n  \"homepage\": {\n   \"value\": \"<Circular reference to #/components/schemas/Content detected>\"\n  },\n  \"metadata\": {\n   \"labels\": {\n    \"results\": [\n     {\n      \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n     },\n     {\n      \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n     }\n    ],\n    \"start\": 58105433,\n    \"limit\": 10735114,\n    \"size\": -29792214,\n    \"_links\": {}\n   }\n  },\n  \"operations\": [\n   {\n    \"operation\": \"delete\",\n    \"targetType\": \"blogpost\"\n   },\n   {\n    \"operation\": \"restore\",\n    \"targetType\": \"blogpost\"\n   }\n  ],\n  \"permissions\": [\n   {\n    \"subjects\": {\n     \"_expandable\": {\n      \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n     },\n     \"user\": {\n      \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n     },\n     \"group\": {\n      \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n     }\n    },\n    \"operation\": {\n     \"operation\": \"create\",\n     \"targetType\": \"page\"\n    },\n    \"anonymousAccess\": false,\n    \"unlicensedAccess\": false\n   },\n   {\n    \"subjects\": {\n     \"_expandable\": {\n      \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n     },\n     \"user\": {\n      \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n     },\n     \"group\": {\n      \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n     }\n    },\n    \"operation\": {\n     \"operation\": \"restore\",\n     \"targetType\": \"blogpost\"\n    },\n    \"anonymousAccess\": false,\n    \"unlicensedAccess\": false\n   }\n  ],\n  \"settings\": {\n   \"routeOverrideEnabled\": false,\n   \"_links\": {}\n  },\n  \"theme\": {},\n  \"lookAndFeel\": {\n   \"headings\": {\n    \"color\": \"<string>\"\n   },\n   \"links\": {\n    \"color\": \"<string>\"\n   },\n   \"menus\": {\n    \"hoverOrFocus\": {\n     \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n    },\n    \"color\": {\n     \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n    }\n   },\n   \"header\": {\n    \"backgroundColor\": {\n     \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n    },\n    \"button\": {\n     \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n    },\n    \"primaryNavigation\": {\n     \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n    },\n    \"secondaryNavigation\": {\n     \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n    },\n    \"search\": {\n     \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n    }\n   },\n   \"content\": {\n    \"screen\": {\n     \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n    },\n    \"container\": {\n     \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n    },\n    \"header\": {\n     \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n    },\n    \"body\": {\n     \"value\": \"<Error: Too many levels of nesting to fake this schema>\"\n    }\n   },\n   \"bordersAndDividers\": {\n    \"color\": \"<string>\"\n   }\n  },\n  \"history\": {\n   \"createdDate\": \"2014-12-12T23:08:45.947Z\"\n  }\n }\n}"
    },
    {
      "name": "Returned if the calling user does not have permission to use\nConfluence.",
      "originalRequest": {
        "method": "GET",
        "header": [
          {
            "description": {
              "content": "Added as a part of security scheme: oauth2",
              "type": "text/plain"
            },
            "key": "Authorization",
            "value": "<token>"
          }
        ],
        "url": {
          "raw": "{{baseUrl}}/api/user/current?expand=<string>&expand=<string>",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "api",
            "user",
            "current"
          ],
          "query": [
            {
              "key": "expand",
              "value": "<string>"
            },
            {
              "key": "expand",
              "value": "<string>"
            }
          ]
        }
      },
      "status": "Forbidden",
      "code": 403,
      "_postman_previewlanguage": "text",
      "header": [
        {
          "key": "Content-Type",
          "value": "text/plain"
        }
      ],
      "cookie": [
      ],
      "body": ""
    }
  ]
}