Sample code for 30+ languages & platforms
PowerBuilder

UK Vehicle Data VRM Lookup

See more REST Examples

Demonstrates how to query the UK Vehicle Data VRM online API's. (See https://ukvehicledata.co.uk/)

Chilkat PowerBuilder Downloads

PowerBuilder
integer li_rc
integer li_Success
oleobject loo_Rest
integer li_BAutoReconnect
string ls_JsonResponseStr
oleobject loo_Json
integer li_NumBatteries
integer i

li_Success = 0

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

loo_Rest = create oleobject
li_rc = loo_Rest.ConnectToNewObject("Chilkat.Rest")
if li_rc < 0 then
    destroy loo_Rest
    MessageBox("Error","Connecting to COM object failed")
    return
end if

// Connect using TLS.
li_BAutoReconnect = 1
li_Success = loo_Rest.Connect("uk1.ukvehicledata.co.uk",443,1,li_BAutoReconnect)
if li_Success <> 1 then
    Write-Debug loo_Rest.LastErrorText
    destroy loo_Rest
    return
end if

// Replace UKVD-API-KEY with your actual API KEY,
// which looks something like "abcdb1234-0abc-1235-abcf-1234c3d1abcd"
loo_Rest.Authorization = "ukvd-ipwhitelist UKVD-API-KEY"

// Replace "ABCDE" with a real VRM...
loo_Rest.AddQueryParam("key_vrm","ABCDE")

// Add the Content-Type HTTP request header.
// success = rest.AddHeader("Content-Type","application/json; charset=UTF-8");

// This request gets vehicle data.
// See below for a request to get battery data.
ls_JsonResponseStr = loo_Rest.FullRequestNoBody("GET","/api/datapackage/vehicledata")
if loo_Rest.LastMethodSuccess <> 1 then
    Write-Debug loo_Rest.LastErrorText
    destroy loo_Rest
    return
end if

if loo_Rest.ResponseStatusCode <> 200 then
    Write-Debug "Response Status Code = " + string(loo_Rest.ResponseStatusCode)
    Write-Debug ls_JsonResponseStr
    destroy loo_Rest
    return
end if

loo_Json = create oleobject
li_rc = loo_Json.ConnectToNewObject("Chilkat.JsonObject")

loo_Json.Load(ls_JsonResponseStr)
loo_Json.EmitCompact = 0

// Show the JSON response.
Write-Debug loo_Json.Emit()

// A sample vehicledata response will be as shown below.
// To get a few bits of data from the response:
Write-Debug "RequestGuid: " + loo_Json.StringOf("RequestGuid")
Write-Debug "EngineNumber: " + loo_Json.StringOf("DataItems.EngineNumber")
Write-Debug "Vrm: " + loo_Json.StringOf("DataKeys.Vrm")

// {
//   "RequestGuid": "xxxxxxxx-cc72-4b63-xxxxxxxxxxxx",
//   "StatusCode": 0,
//   "StatusMessage": "Success",
//   "PackageId": "xxxxxxxx-a4bc-4a84-af22-xxxxxxxxxxxx",
//   "PackageVersion": 1,
//   "DataKeys": {
//     "Vrm": "ABCDE"
//   },
//   "DataItems": {
//     "DriveAxle": "4x2",
//     "Exported": "False",
//     "DriverSeatPosition": "RHD",
//     "EngineNumber": "LN910940728622",
//     "Class": "Sport",
//     "ImportedNorthernIreland": "False",
//     "HistoryPreviousKeeperAcquisitionDate": "2013-01-12",
//     "RoadFundLicenseSixMonth": "�126.50",
//     "EnginePowerBhp": "262",
//     "SpecDateRangeFrom": "1987-10-01",
//     "RegistrationDateUK": "1994-08-03",
//     "SoundLevelDriveBy": "0",
//     "RoadFundLicenseTwelveMonth": "�235.00",
//     "RoadFundLicenseBand": "Not available",
//     "Vrm": "J5YVK",
//     "TrimCode": "BA",
//     "Derivative": "S4",
//     "EngineSizeCc": "2174",
//     "EngineCylinderCount": "4",
//     "HistoryLatestV5cIssueDate": "2015-05-12",
//     "Category": "Car",
//     "HistoryPreviousKeeperCount": "9",
//     "ConditionScrapped": "False",
//     "EngineValveCount": "16",
//     "WeightUnladen": "0",
//     "RoadFundLicenseRenewalDate": "2017-04-01",
//     "Model": "Esprit",
//     "SpecDateRangeTo": "2003-06-01",
//     "RoadFundLicenseCurrentStatus": "Tax not due",
//     "BuildYear": "1994",
//     "BuildDate": "1994-12-31",
//     "VinLast4": "1448",
//     "GearCount": "5",
//     "SeatCount": "2",
//     "Make": "Lotus",
//     "Vin": "SCC082910RHA61448",
//     "ColourChangeCount": "0",
//     "DriveType": "Rear Wheel Drive",
//     "WeightGross": "0",
//     "EngineCode": "N/A",
//     "EnginePowerKw": "193",
//     "SoundLevelEngineSpeed": "0",
//     "ConditionUnscrapped": "False",
//     "HistoryPreviousKeeperDisposalDate": "2014-04-26",
//     "EngineAlignment": "Longitudinal",
//     "Imported": "False",
//     "BodyType": "Coupe",
//     "EnginePosition": "Mid",
//     "TransmissionType": "Manual",
//     "WeightFullyLaden": "0",
//     "SoundLevelStationary": "0",
//     "FuelType": "Petrol",
//     "Colour": "YELLOW",
//     "EngineSizeLitre": "2.2",
//     "RegistrationDate": "1994-08-03",
//     "Co2Emissions": "000",
//     "WeightMaxTowingUnbraked": "0",
//     "HistoryCurrentKeeperAcquisitionDate": "2015-04-25",
//     "WeightMaxTowingBraked": "0",
//     "DoorCount": "2",
//     "EngineCylinderConfig": "Inline",
//     "EngineFuelDelivery": "Turbo Injection"
//   }
// }

// -----------------------------------------------------------------------------------
// Now get battery data...
ls_JsonResponseStr = loo_Rest.FullRequestNoBody("GET","/api/datapackage/batterydata")
if loo_Rest.LastMethodSuccess <> 1 then
    Write-Debug loo_Rest.LastErrorText
    destroy loo_Rest
    destroy loo_Json
    return
end if

if loo_Rest.ResponseStatusCode <> 200 then
    Write-Debug "Response Status Code = " + string(loo_Rest.ResponseStatusCode)
    Write-Debug ls_JsonResponseStr
    destroy loo_Rest
    destroy loo_Json
    return
end if

loo_Json.Load(ls_JsonResponseStr)

// Show the JSON response containing battery data.
Write-Debug loo_Json.Emit()

// To get a few pieces of information out of the response...
li_NumBatteries = loo_Json.SizeOfArray("DataItems.BatteryList")
i = 0
do while (i < li_NumBatteries)
    loo_Json.I = i
    Write-Debug "---- Battery " + string(i) + ":"
    Write-Debug "  Type = " + loo_Json.StringOf("DataItems.BatteryList[I].Type")
    Write-Debug "  LayoutImage = " + loo_Json.StringOf("DataItems.BatteryList[I].LayoutImage")
    Write-Debug "  TerminalCode = " + loo_Json.StringOf("DataItems.BatteryList[I].TerminalCode")
    i = i + 1
loop

// The battery data looks like this:
// {
//   "RequestGuid": "xxxxxxxx-5030-4b3d-a2ed-xxxxxxxxxxxx",
//   "StatusCode": 0,
//   "StatusMessage": "Success",
//   "PackageId": "xxxxxxxx-9ec2-4fd3-9247-xxxxxxxxxxxx",
//   "PackageVersion": 1,
//   "DataKeys": {
//     "Vrm": "ABCDE"
//   },
//   "DataItems": {
//     "BatteryList": [
//       {
//         "Type": "Primary",
//         "UkRef": "075",
//         "LayoutCode": "0",
//         "LayoutImage": "http://cdn.ukvehicledata.co.uk/battery/layout/0.png",
//         "TerminalCode": "T1",
//         "TerminalImage": "http://cdn.ukvehicledata.co.uk/battery/terminal/T1.png",
//         "HoldDownCode": "B13",
//         "HoldDownImage": "http://cdn.ukvehicledata.co.uk/battery/holddown/B13.png"
//       }
//     ],
//     "BatteryCount": "1"
//   }
// }


destroy loo_Rest
destroy loo_Json