PureBasic / Support API / Show Self
Back to Collection Items
IncludeFile "CkJsonObject.pb"
IncludeFile "CkStringBuilder.pb"
IncludeFile "CkHttp.pb"
Procedure ChilkatExample()
; This example assumes the Chilkat API to have been previously unlocked.
; See Global Unlock Sample for sample code.
http.i = CkHttp::ckCreate()
If http.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
success.i
CkHttp::setCkBasicAuth(http, 1)
CkHttp::setCkLogin(http, "login")
CkHttp::setCkPassword(http, "password")
CkHttp::ckSetRequestHeader(http,"Accept","application/json")
sbResponseBody.i = CkStringBuilder::ckCreate()
If sbResponseBody.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
success = CkHttp::ckQuickGetSb(http,"https://example.zendesk.com/api/v2/users/me",sbResponseBody)
If success = 0
Debug CkHttp::ckLastErrorText(http)
CkHttp::ckDispose(http)
CkStringBuilder::ckDispose(sbResponseBody)
ProcedureReturn
EndIf
jResp.i = CkJsonObject::ckCreate()
If jResp.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
CkJsonObject::ckLoadSb(jResp,sbResponseBody)
CkJsonObject::setCkEmitCompact(jResp, 0)
Debug "Response Body:"
Debug CkJsonObject::ckEmit(jResp)
respStatusCode.i = CkHttp::ckLastStatus(http)
Debug "Response Status Code = " + Str(respStatusCode)
If respStatusCode >= 400
Debug "Response Header:"
Debug CkHttp::ckLastHeader(http)
Debug "Failed."
CkHttp::ckDispose(http)
CkStringBuilder::ckDispose(sbResponseBody)
CkJsonObject::ckDispose(jResp)
ProcedureReturn
EndIf
; Sample JSON response:
; (Sample code for parsing the JSON response is shown below)
; {
; "user": {
; "name": "<string>",
; "active": "<boolean>",
; "alias": "<string>",
; "chat_only": "<boolean>",
; "created_at": "<string>",
; "custom_role_id": "<integer>",
; "default_group_id": "<integer>",
; "details": "<string>",
; "email": "<string>",
; "external_id": "<string>",
; "iana_time_zone": "<string>",
; "id": "<integer>",
; "last_login_at": "<string>",
; "locale": "<string>",
; "locale_id": "<integer>",
; "moderator": "<boolean>",
; "notes": "<string>",
; "only_private_comments": "<boolean>",
; "organization_id": "<integer>",
; "phone": "<string>",
; "photo": {
; "dolore50": -51881550.25541992
; },
; "remote_photo_url": "<string>",
; "report_csv": "<boolean>",
; "restricted_agent": "<boolean>",
; "role": "<string>",
; "role_type": "<integer>",
; "shared": "<boolean>",
; "shared_agent": "<boolean>",
; "shared_phone_number": "<boolean>",
; "signature": "<string>",
; "suspended": "<boolean>",
; "tags": "<array>",
; "ticket_restriction": "<string>",
; "time_zone": "<string>",
; "two_factor_auth_enabled": "<boolean>",
; "updated_at": "<string>",
; "url": "<string>",
; "user_fields": {
; "deserunt_c4": -61141403
; },
; "verified": "<boolean>",
; "authenticity_token": "<string>"
; }
; }
; Sample code for parsing the JSON response...
; Use this online tool to generate parsing code from sample JSON: Generate JSON Parsing Code
Name.s = CkJsonObject::ckStringOf(jResp,"user.name")
Active.s = CkJsonObject::ckStringOf(jResp,"user.active")
Alias.s = CkJsonObject::ckStringOf(jResp,"user.alias")
Chat_only.s = CkJsonObject::ckStringOf(jResp,"user.chat_only")
Created_at.s = CkJsonObject::ckStringOf(jResp,"user.created_at")
Custom_role_id.s = CkJsonObject::ckStringOf(jResp,"user.custom_role_id")
Default_group_id.s = CkJsonObject::ckStringOf(jResp,"user.default_group_id")
Details.s = CkJsonObject::ckStringOf(jResp,"user.details")
v_Email.s = CkJsonObject::ckStringOf(jResp,"user.email")
External_id.s = CkJsonObject::ckStringOf(jResp,"user.external_id")
Iana_time_zone.s = CkJsonObject::ckStringOf(jResp,"user.iana_time_zone")
Id.s = CkJsonObject::ckStringOf(jResp,"user.id")
Last_login_at.s = CkJsonObject::ckStringOf(jResp,"user.last_login_at")
Locale.s = CkJsonObject::ckStringOf(jResp,"user.locale")
Locale_id.s = CkJsonObject::ckStringOf(jResp,"user.locale_id")
Moderator.s = CkJsonObject::ckStringOf(jResp,"user.moderator")
Notes.s = CkJsonObject::ckStringOf(jResp,"user.notes")
Only_private_comments.s = CkJsonObject::ckStringOf(jResp,"user.only_private_comments")
Organization_id.s = CkJsonObject::ckStringOf(jResp,"user.organization_id")
Phone.s = CkJsonObject::ckStringOf(jResp,"user.phone")
Dolore50.s = CkJsonObject::ckStringOf(jResp,"user.photo.dolore50")
Remote_photo_url.s = CkJsonObject::ckStringOf(jResp,"user.remote_photo_url")
Report_csv.s = CkJsonObject::ckStringOf(jResp,"user.report_csv")
Restricted_agent.s = CkJsonObject::ckStringOf(jResp,"user.restricted_agent")
Role.s = CkJsonObject::ckStringOf(jResp,"user.role")
Role_type.s = CkJsonObject::ckStringOf(jResp,"user.role_type")
v_Shared.s = CkJsonObject::ckStringOf(jResp,"user.shared")
Shared_agent.s = CkJsonObject::ckStringOf(jResp,"user.shared_agent")
Shared_phone_number.s = CkJsonObject::ckStringOf(jResp,"user.shared_phone_number")
Signature.s = CkJsonObject::ckStringOf(jResp,"user.signature")
Suspended.s = CkJsonObject::ckStringOf(jResp,"user.suspended")
Tags.s = CkJsonObject::ckStringOf(jResp,"user.tags")
Ticket_restriction.s = CkJsonObject::ckStringOf(jResp,"user.ticket_restriction")
Time_zone.s = CkJsonObject::ckStringOf(jResp,"user.time_zone")
Two_factor_auth_enabled.s = CkJsonObject::ckStringOf(jResp,"user.two_factor_auth_enabled")
Updated_at.s = CkJsonObject::ckStringOf(jResp,"user.updated_at")
v_Url.s = CkJsonObject::ckStringOf(jResp,"user.url")
Deserunt_c4.i = CkJsonObject::ckIntOf(jResp,"user.user_fields.deserunt_c4")
Verified.s = CkJsonObject::ckStringOf(jResp,"user.verified")
Authenticity_token.s = CkJsonObject::ckStringOf(jResp,"user.authenticity_token")
CkHttp::ckDispose(http)
CkStringBuilder::ckDispose(sbResponseBody)
CkJsonObject::ckDispose(jResp)
ProcedureReturn
EndProcedure
Curl Command
curl -u login:password -X GET
-H "Accept: application/json"
https://example.zendesk.com/api/v2/users/me
Postman Collection Item JSON
{
"name": "Show Self",
"request": {
"method": "GET",
"header": [
{
"key": "Accept",
"value": "application/json"
}
],
"url": {
"raw": "{{baseUrl}}/api/v2/users/me",
"host": [
"{{baseUrl}}"
],
"path": [
"api",
"v2",
"users",
"me"
]
},
"description": "#### Allowed For\n\n* Anonymous users\n\n#### Authenticity Token\n\nThe endpoint returns an `authenticity_token`. Zendesk API calls made by end users from a Zendesk help center must include this token in the `X-CSRF-Token` HTTP header. This helps prevent [cross-site request forgery (CSRF)](https://en.wikipedia.org/wiki/Cross-site_request_forgery) attacks.\n\nFor an example using an authenticity token, see the AJAX request in the [Upgrading from Templating API v1](https://developer.zendesk.com/documentation/help_center/help-center-templates/v1#jquery) documentation.\n"
},
"response": [
{
"name": "Success response",
"originalRequest": {
"method": "GET",
"header": [
{
"description": "Added as a part of security scheme: basic",
"key": "Authorization",
"value": "Basic <credentials>"
}
],
"url": {
"raw": "{{baseUrl}}/api/v2/users/me",
"host": [
"{{baseUrl}}"
],
"path": [
"api",
"v2",
"users",
"me"
]
}
},
"status": "OK",
"code": 200,
"_postman_previewlanguage": "json",
"header": [
{
"key": "Content-Type",
"value": "application/json"
}
],
"cookie": [
],
"body": "{\n \"user\": {\n \"name\": \"<string>\",\n \"active\": \"<boolean>\",\n \"alias\": \"<string>\",\n \"chat_only\": \"<boolean>\",\n \"created_at\": \"<string>\",\n \"custom_role_id\": \"<integer>\",\n \"default_group_id\": \"<integer>\",\n \"details\": \"<string>\",\n \"email\": \"<string>\",\n \"external_id\": \"<string>\",\n \"iana_time_zone\": \"<string>\",\n \"id\": \"<integer>\",\n \"last_login_at\": \"<string>\",\n \"locale\": \"<string>\",\n \"locale_id\": \"<integer>\",\n \"moderator\": \"<boolean>\",\n \"notes\": \"<string>\",\n \"only_private_comments\": \"<boolean>\",\n \"organization_id\": \"<integer>\",\n \"phone\": \"<string>\",\n \"photo\": {\n \"dolore50\": -51881550.25541992\n },\n \"remote_photo_url\": \"<string>\",\n \"report_csv\": \"<boolean>\",\n \"restricted_agent\": \"<boolean>\",\n \"role\": \"<string>\",\n \"role_type\": \"<integer>\",\n \"shared\": \"<boolean>\",\n \"shared_agent\": \"<boolean>\",\n \"shared_phone_number\": \"<boolean>\",\n \"signature\": \"<string>\",\n \"suspended\": \"<boolean>\",\n \"tags\": \"<array>\",\n \"ticket_restriction\": \"<string>\",\n \"time_zone\": \"<string>\",\n \"two_factor_auth_enabled\": \"<boolean>\",\n \"updated_at\": \"<string>\",\n \"url\": \"<string>\",\n \"user_fields\": {\n \"deserunt_c4\": -61141403\n },\n \"verified\": \"<boolean>\",\n \"authenticity_token\": \"<string>\"\n }\n}"
}
]
}