Sample code for 30+ languages & platforms
Tcl

Get the Photos for a User

See more Facebook Examples

Demonstrates how to get the photos that the user has uploaded.

Chilkat Tcl Downloads

Tcl

load ./chilkat.dll

set success 0

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

# This example assumes a previously obtained an access token
set oauth2 [new_CkOAuth2]

CkOAuth2_put_AccessToken $oauth2 "FACEBOOK-ACCESS-TOKEN"

set rest [new_CkRest]

# Connect to Facebook.
set success [CkRest_Connect $rest "graph.facebook.com" 443 1 1]
if {$success == 0} then {
    puts [CkRest_lastErrorText $rest]
    delete_CkOAuth2 $oauth2
    delete_CkRest $rest
    exit
}

# Provide the authentication credentials (i.e. the access key)
CkRest_SetAuthOAuth2 $rest $oauth2

# Indicate that we only want the photos the user has personally uploaded.
CkRest_AddQueryParam $rest "type" "uploaded"

# We could limit the number of photos by setting a limit.
CkRest_AddQueryParam $rest "limit" "5"

# Gets the 1st page of photos. (Not the actual image data, but the information about each photo.)
# See https://developers.facebook.com/docs/graph-api/reference/user/photos/ for more information.
set responseJson [CkRest_fullRequestNoBody $rest "GET" "/v2.7/me/photos"]
if {[CkRest_get_LastMethodSuccess $rest] == 0} then {
    puts [CkRest_lastErrorText $rest]
    delete_CkOAuth2 $oauth2
    delete_CkRest $rest
    exit
}

set json [new_CkJsonObject]

CkJsonObject_put_EmitCompact $json 0
CkJsonObject_Load $json $responseJson
puts [CkJsonObject_emit $json]

# A sample JSON response is shown below.  
# This is the code to parse the JSON response.

set dtime [new_CkDateTime]

set bLocalTime 1

set dt [new_CkDtObj]

set i 0
set numItems [CkJsonObject_SizeOfArray $json "data"]
while {$i < $numItems} {
    CkJsonObject_put_I $json $i
    puts "--- $i"
    set name [CkJsonObject_stringOf $json "data[i].name"]
    if {[CkJsonObject_get_LastMethodSuccess $json] == 1} then {
        puts "name: $name"
    }

    puts "id: [CkJsonObject_stringOf $json {data[i].id}]"

    # We can load the created_time into a CkDateTime...
    CkDateTime_SetFromTimestamp $dtime [CkJsonObject_stringOf $json "data[i].created_time"]
    CkDateTime_ToDtObj $dtime $bLocalTime $dt

    puts [CkDtObj_get_Month $dt]/[CkDtObj_get_Day $dt]/[CkDtObj_get_Year $dt]  [CkDtObj_get_Hour $dt]:[CkDtObj_get_Minute $dt]
    set i [expr $i + 1]
}

# We can get the paging information as follows:
puts "URL for next page: [CkJsonObject_stringOf $json paging.next]"
puts "before cursor: [CkJsonObject_stringOf $json paging.cursors.before]"
puts "after cursor: [CkJsonObject_stringOf $json paging.cursors.after]"

# This is a sample JSON response:
# { 
#   "data": [
#     {
#       "created_time": "2016-09-29T20:46:18+0000",
#       "name": "Ignore my posts -- I'm doing some testing for Facebook related programming...",
#       "id": "10210199026347451"
#     },
#     { 
#       "created_time": "2016-09-19T02:00:42+0000",
#       "id": "10210091531240138"
#     },
#     { 
#       "created_time": "2016-09-19T02:00:42+0000",
#       "id": "10210091520620125"
#     },
#     { 
#       "created_time": "2016-09-19T01:59:46+0000",
#       "name": "I would've went for a swim had it not been for the sign",
#       "id": "10210091522299917"
#     },
#     { 
#       "created_time": "2016-09-12T00:37:35+0000",
#       "id": "10210023316834798"
#     }
#   ],
#   "paging": { 
#     "cursors": { 
#       "before": "MTAyMTAxOTkwMjYzNDc0NTEZD",
#       "after": "MTAyMTAwMjMzMTU4MzQ3OTgZD"
#     },
#     "next": "https:\/\/graph.facebook.com\/v2.7\/10224048320139890\/photos?type=uploaded&limit=5&after=MTAyMTAwMjMzMTU4MzQ3OTgZD"
#   }
# }
# 

delete_CkOAuth2 $oauth2
delete_CkRest $rest
delete_CkJsonObject $json
delete_CkDateTime $dtime
delete_CkDtObj $dt