Sample code for 30+ languages & platforms
DataFlex

GeoOp - Export Clients to CSV

See more GeoOp Examples

Export client data to a CSV.

Chilkat DataFlex Downloads

DataFlex
Use ChilkatAx-win32.pkg

Procedure Test
    Boolean iSuccess
Token    Handle hoJsonToken
    Variant vOauth2
    Handle hoOauth2
    Handle hoRest
    Boolean iBAutoReconnect
    String sResponseBody
    Handle hoJson
    Handle hoCsv
    Integer iNumRecords
    Integer i
    String sTemp1
    Integer iTemp1
    Boolean bTemp1

    Move False To iSuccess

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

    // This example also assumes an OAuth2 access token was previously fetched.
    // and saved in a JSON file.  

    // First get our previously obtained access token.
    // {"access_token":"e6dqdG....mzjpT04w==","token_type":"Bearer","expires_in":2592000,"owner_id":999236}
    Get Create (RefClass(cComChilkatJsonObject)) To hoJsonToken
    If (Not(IsComObjectCreated(hoJsonToken))) Begin
        Send CreateComObject of hoJsonToken
    End
    Get ComLoadFile Of hoJsonToken "qa_data/tokens/geoop.json" To iSuccess

    // This example assumes we previously obtained an access token
    Get Create (RefClass(cComChilkatOAuth2)) To hoOauth2
    If (Not(IsComObjectCreated(hoOauth2))) Begin
        Send CreateComObject of hoOauth2
    End
    Get ComStringOf Of hoJsonToken "access_token" To sTemp1
    Set ComAccessToken Of hoOauth2 To sTemp1

    Get Create (RefClass(cComChilkatRest)) To hoRest
    If (Not(IsComObjectCreated(hoRest))) Begin
        Send CreateComObject of hoRest
    End

    // Connect to GeoOp and send the following GET request:

    // GET /users HTTP/1.1
    // Host: api.geoop.com
    Move True To iBAutoReconnect
    Get ComConnect Of hoRest "api.geoop.com" 443 True iBAutoReconnect To iSuccess
    If (iSuccess <> True) Begin
        Get ComLastErrorText Of hoRest To sTemp1
        Showln sTemp1
        Procedure_Return
    End

    // Provide the authentication credentials (i.e. the access token)
    Get pvComObject of hoOauth2 to vOauth2
    Get ComSetAuthOAuth2 Of hoRest vOauth2 To iSuccess

    // Set the X-Version header.
    Get ComAddHeader Of hoRest "X-Version" "1.0" To iSuccess

    Get ComFullRequestNoBody Of hoRest "GET" "/clients" To sResponseBody
    Get ComLastMethodSuccess Of hoRest To bTemp1
    If (bTemp1 <> True) Begin
        Get ComLastErrorText Of hoRest To sTemp1
        Showln sTemp1
        Procedure_Return
    End

    Get Create (RefClass(cComChilkatJsonObject)) To hoJson
    If (Not(IsComObjectCreated(hoJson))) Begin
        Send CreateComObject of hoJson
    End
    Set ComEmitCompact Of hoJson To False

    // If the response status code did not indicate success, then see what happened..
    Get ComResponseStatusCode Of hoRest To iTemp1
    If (iTemp1 <> 200) Begin
        Showln "Request Header: "
        Get ComLastRequestHeader Of hoRest To sTemp1
        Showln sTemp1
        Showln "----"
        Get ComResponseStatusCode Of hoRest To iTemp1
        Showln "Response StatusCode = " iTemp1
        Get ComResponseStatusText Of hoRest To sTemp1
        Showln "Response StatusLine: " sTemp1
        Showln "Response Header:"
        Get ComResponseHeader Of hoRest To sTemp1
        Showln sTemp1
        Get ComLoad Of hoJson sResponseBody To iSuccess
        Get ComEmit Of hoJson To sTemp1
        Showln sTemp1
        Procedure_Return
    End

    Get ComLoad Of hoJson sResponseBody To iSuccess
    // Show the full JSON response.. (see below)
    Get ComEmit Of hoJson To sTemp1
    Showln sTemp1
    Showln "---"

    Get Create (RefClass(cComChilkatCsv)) To hoCsv
    If (Not(IsComObjectCreated(hoCsv))) Begin
        Send CreateComObject of hoCsv
    End
    Set ComHasColumnNames Of hoCsv To True
    Get ComSetColumnName Of hoCsv 0 "id" To iSuccess
    Get ComSetColumnName Of hoCsv 1 "companyName" To iSuccess
    Get ComSetColumnName Of hoCsv 2 "businessType" To iSuccess
    Get ComSetColumnName Of hoCsv 3 "account_id" To iSuccess
    Get ComSetColumnName Of hoCsv 4 "address_line1" To iSuccess
    Get ComSetColumnName Of hoCsv 5 "address_city" To iSuccess
    Get ComSetColumnName Of hoCsv 6 "address_postcode" To iSuccess

    // Iterate over each client and populate the CSV...
    Get ComSizeOfArray Of hoJson "clients" To iNumRecords
    Move 0 To i
    While (i < iNumRecords)

        Set ComI Of hoJson To i
        Get ComStringOf Of hoJson "clients[i].id" To sTemp1
        Get ComSetCellByName Of hoCsv i "id" sTemp1 To iSuccess
        Get ComStringOf Of hoJson "clients[i].companyName" To sTemp1
        Get ComSetCellByName Of hoCsv i "companyName" sTemp1 To iSuccess
        Get ComStringOf Of hoJson "clients[i].businessType" To sTemp1
        Get ComSetCellByName Of hoCsv i "businessType" sTemp1 To iSuccess
        Get ComStringOf Of hoJson "clients[i].account.id" To sTemp1
        Get ComSetCellByName Of hoCsv i "account_id" sTemp1 To iSuccess
        Get ComStringOf Of hoJson "clients[i].address.line1" To sTemp1
        Get ComSetCellByName Of hoCsv i "address_line1" sTemp1 To iSuccess
        Get ComStringOf Of hoJson "clients[i].address.city" To sTemp1
        Get ComSetCellByName Of hoCsv i "address_city" sTemp1 To iSuccess
        Get ComStringOf Of hoJson "clients[i].address.postcode" To sTemp1
        Get ComSetCellByName Of hoCsv i "address_postcode" sTemp1 To iSuccess
        Move (i + 1) To i
    Loop

    // Show the CSV.
    Get ComSaveToString Of hoCsv To sTemp1
    Showln sTemp1

    // Save the CSV.
    Get ComSaveFile Of hoCsv "qa_output/clients.csv" To iSuccess

    // ---------------------------------------------------------------------
    // The full JSON response containing all client data:
    // 
    // 	{
    // 	  "result": "success",
    // 	  "clients": [
    // 	    {
    // 	      "id": 9555868,
    // 	      "firstName": "[ Demo",
    // 	      "lastName": "Client ]",
    // 	      "companyName": "Miller Park Cafe",
    // 	      "businessType": "Licensed Restaurant",
    // 	      "leadSource": "",
    // 	      "emailAddress": null,
    // 	      "phoneNumber": null,
    // 	      "mobileNumber": null,
    // 	      "faxNumber": null,
    // 	      "notes": "",
    // 	      "deleted": false,
    // 	      "hasRecentJobs": true,
    // 	      "created": "2016-10-26T12:05:09+00:00",
    // 	      "modified": "2016-10-26T12:05:09+00:00",
    // 	      "billingClient": null,
    // 	      "account": {
    // 	        "id": 39409
    // 	      },
    // 	      "address": {
    // 	        "line1": "1732 Pennsylvania Avenue NW",
    // 	        "line2": "",
    // 	        "city": "Washington",
    // 	        "postcode": "20006",
    // 	        "latitude": 38.899037,
    // 	        "longitude": -77.040207
    // 	      },
    // 	      "mailingAddress": {}
    // 	    },
    // 	    {
    // 	      "id": 9571176,
    // 	      "firstName": "Mildred",
    // 	      "lastName": "Vanildred",
    // 	      "companyName": "Ice Cream Industries",
    // 	      "businessType": "Ice Cream",
    // 	      "leadSource": null,
    // 	      "emailAddress": "milli@icecreamindustries.com",
    // 	      "phoneNumber": "678-555-1012",
    // 	      "mobileNumber": null,
    // 	      "faxNumber": null,
    // 	      "notes": "",
    // 	      "deleted": false,
    // 	      "hasRecentJobs": true,
    // 	      "created": "2016-10-31T12:32:12+00:00",
    // 	      "modified": "2016-10-31T12:32:13+00:00",
    // 	      "billingClient": null,
    // 	      "account": {
    // 	        "id": 39409
    // 	      },
    // 	      "address": {
    // 	        "line1": "2101 West Roosevelt Road",
    // 	        "line2": null,
    // 	        "city": "Wheaton",
    // 	        "postcode": "60187",
    // 	        "latitude": 41.8581778,
    // 	        "longitude": -88.1380111
    // 	      },
    // 	      "mailingAddress": {
    // 	        "line1": "2101 West Roosevelt Road",
    // 	        "line2": null,
    // 	        "city": "Wheaton"
    // 	      }
    // 	    },
    // 	    {
    // 	      "id": 9571218,
    // 	      "firstName": "Joe",
    // 	      "lastName": "Miller",
    // 	      "companyName": "Miller Bakery",
    // 	      "businessType": "Licensed Bakery",
    // 	      "leadSource": "",
    // 	      "emailAddress": null,
    // 	      "phoneNumber": null,
    // 	      "mobileNumber": null,
    // 	      "faxNumber": null,
    // 	      "notes": "",
    // 	      "deleted": false,
    // 	      "hasRecentJobs": true,
    // 	      "created": "2016-10-31T13:02:07+00:00",
    // 	      "modified": "2016-10-31T13:02:07+00:00",
    // 	      "billingClient": null,
    // 	      "account": {
    // 	        "id": 39409
    // 	      },
    // 	      "address": {
    // 	        "line1": "1832 Pennsylvania Avenue NW",
    // 	        "line2": "",
    // 	        "city": "Washington",
    // 	        "postcode": "20006",
    // 	        "latitude": 0,
    // 	        "longitude": 0
    // 	      },
    // 	      "mailingAddress": {
    // 	        "line1": "",
    // 	        "line2": "",
    // 	        "city": ""
    // 	      }
    // 	    }
    // 	  ],
    // 	  "metadata": {
    // 	    "page": 1,
    // 	    "pagesCount": 1,
    // 	    "recordsPerPage": 20,
    // 	    "recordsCount": 3
    // 	  }
    // 	}
    // 


End_Procedure