Chilkat Online Tools

delphiAx / easybill REST API / Fetch position

Back to Collection Items

var
http: TChilkatHttp;
success: Integer;
sbResponseBody: TChilkatStringBuilder;
jResp: TChilkatJsonObject;
respStatusCode: Integer;
v_number: WideString;
description: WideString;
sale_price: WideString;
id: WideString;
v_type: WideString;
document_note: WideString;
note: WideString;
unit: WideString;
export_identifier: WideString;
v_NULL: WideString;
NStb: WideString;
NStbUstID: WideString;
NStbNoneUstID: WideString;
NStbIm: WideString;
Revc: WideString;
IG: WideString;
AL: WideString;
SStfr: WideString;
SmallBusiness: WideString;
login_id: WideString;
price_type: WideString;
vat_percent: Integer;
sale_price2: WideString;
sale_price3: WideString;
sale_price4: WideString;
sale_price5: WideString;
sale_price6: WideString;
sale_price7: WideString;
sale_price8: WideString;
sale_price9: WideString;
sale_price10: WideString;
cost_price: WideString;
export_cost1: WideString;
export_cost2: WideString;
group_id: WideString;
stock: WideString;
stock_count: Integer;
stock_limit_notify: Integer;
stock_limit_notify_frequency: WideString;
stock_limit: Integer;
quantity: WideString;
archived: Integer;

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

http := TChilkatHttp.Create(Self);

http.SetRequestHeader('Authorization','{{apiKey}}');
http.SetRequestHeader('Accept','application/json');

sbResponseBody := TChilkatStringBuilder.Create(Self);
success := http.QuickGetSb('https://api.easybill.de/rest/v1/positions/:id',sbResponseBody.ControlInterface);
if (success = 0) then
  begin
    Memo1.Lines.Add(http.LastErrorText);
    Exit;
  end;

jResp := TChilkatJsonObject.Create(Self);
jResp.LoadSb(sbResponseBody.ControlInterface);
jResp.EmitCompact := 0;

Memo1.Lines.Add('Response Body:');
Memo1.Lines.Add(jResp.Emit());

respStatusCode := http.LastStatus;
Memo1.Lines.Add('Response Status Code = ' + IntToStr(respStatusCode));
if (respStatusCode >= 400) then
  begin
    Memo1.Lines.Add('Response Header:');
    Memo1.Lines.Add(http.LastHeader);
    Memo1.Lines.Add('Failed.');
    Exit;
  end;

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

// {
//   "number": "<string>",
//   "description": "<string>",
//   "sale_price": "<float>",
//   "id": "<long>",
//   "type": "PRODUCT",
//   "document_note": "<string>",
//   "note": null,
//   "unit": null,
//   "export_identifier": null,
//   "export_identifier_extended": {
//     "NULL": null,
//     "nStb": null,
//     "nStbUstID": null,
//     "nStbNoneUstID": null,
//     "nStbIm": null,
//     "revc": null,
//     "IG": null,
//     "AL": null,
//     "sStfr": null,
//     "smallBusiness": null
//   },
//   "login_id": "<long>",
//   "price_type": "NETTO",
//   "vat_percent": 19,
//   "sale_price2": null,
//   "sale_price3": null,
//   "sale_price4": null,
//   "sale_price5": null,
//   "sale_price6": null,
//   "sale_price7": null,
//   "sale_price8": null,
//   "sale_price9": null,
//   "sale_price10": null,
//   "cost_price": "<float>",
//   "export_cost1": null,
//   "export_cost2": null,
//   "group_id": "<long>",
//   "stock": "NO",
//   "stock_count": 0,
//   "stock_limit_notify": false,
//   "stock_limit_notify_frequency": "ALWAYS",
//   "stock_limit": 0,
//   "quantity": null,
//   "archived": false
// }

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

v_number := jResp.StringOf('number');
description := jResp.StringOf('description');
sale_price := jResp.StringOf('sale_price');
id := jResp.StringOf('id');
v_type := jResp.StringOf('type');
document_note := jResp.StringOf('document_note');
note := jResp.StringOf('note');
unit := jResp.StringOf('unit');
export_identifier := jResp.StringOf('export_identifier');
v_NULL := jResp.StringOf('export_identifier_extended.NULL');
NStb := jResp.StringOf('export_identifier_extended.nStb');
NStbUstID := jResp.StringOf('export_identifier_extended.nStbUstID');
NStbNoneUstID := jResp.StringOf('export_identifier_extended.nStbNoneUstID');
NStbIm := jResp.StringOf('export_identifier_extended.nStbIm');
Revc := jResp.StringOf('export_identifier_extended.revc');
IG := jResp.StringOf('export_identifier_extended.IG');
AL := jResp.StringOf('export_identifier_extended.AL');
SStfr := jResp.StringOf('export_identifier_extended.sStfr');
SmallBusiness := jResp.StringOf('export_identifier_extended.smallBusiness');
login_id := jResp.StringOf('login_id');
price_type := jResp.StringOf('price_type');
vat_percent := jResp.IntOf('vat_percent');
sale_price2 := jResp.StringOf('sale_price2');
sale_price3 := jResp.StringOf('sale_price3');
sale_price4 := jResp.StringOf('sale_price4');
sale_price5 := jResp.StringOf('sale_price5');
sale_price6 := jResp.StringOf('sale_price6');
sale_price7 := jResp.StringOf('sale_price7');
sale_price8 := jResp.StringOf('sale_price8');
sale_price9 := jResp.StringOf('sale_price9');
sale_price10 := jResp.StringOf('sale_price10');
cost_price := jResp.StringOf('cost_price');
export_cost1 := jResp.StringOf('export_cost1');
export_cost2 := jResp.StringOf('export_cost2');
group_id := jResp.StringOf('group_id');
stock := jResp.StringOf('stock');
stock_count := jResp.IntOf('stock_count');
stock_limit_notify := jResp.BoolOf('stock_limit_notify');
stock_limit_notify_frequency := jResp.StringOf('stock_limit_notify_frequency');
stock_limit := jResp.IntOf('stock_limit');
quantity := jResp.StringOf('quantity');
archived := jResp.BoolOf('archived');

Curl Command

curl -X GET
	-H "Authorization: {{apiKey}}"
	-H "Accept: application/json"
https://api.easybill.de/rest/v1/positions/:id

Postman Collection Item JSON

{
  "name": "Fetch position",
  "request": {
    "method": "GET",
    "header": [
      {
        "key": "Accept",
        "value": "application/json"
      }
    ],
    "url": {
      "raw": "{{baseUrl}}/positions/:id",
      "host": [
        "{{baseUrl}}"
      ],
      "path": [
        "positions",
        ":id"
      ],
      "variable": [
        {
          "key": "id",
          "value": "<long>",
          "description": "(Required) ID of position"
        }
      ]
    }
  },
  "response": [
    {
      "name": "Successful operation",
      "originalRequest": {
        "method": "GET",
        "header": [
          {
            "key": "Accept",
            "value": "application/json"
          },
          {
            "description": "Added as a part of security scheme: apikey",
            "key": "Authorization",
            "value": "<API Key>"
          }
        ],
        "url": {
          "raw": "{{baseUrl}}/positions/:id",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "positions",
            ":id"
          ],
          "variable": [
            {
              "key": "id"
            }
          ]
        }
      },
      "status": "OK",
      "code": 200,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n  \"number\": \"<string>\",\n  \"description\": \"<string>\",\n  \"sale_price\": \"<float>\",\n  \"id\": \"<long>\",\n  \"type\": \"PRODUCT\",\n  \"document_note\": \"<string>\",\n  \"note\": null,\n  \"unit\": null,\n  \"export_identifier\": null,\n  \"export_identifier_extended\": {\n    \"NULL\": null,\n    \"nStb\": null,\n    \"nStbUstID\": null,\n    \"nStbNoneUstID\": null,\n    \"nStbIm\": null,\n    \"revc\": null,\n    \"IG\": null,\n    \"AL\": null,\n    \"sStfr\": null,\n    \"smallBusiness\": null\n  },\n  \"login_id\": \"<long>\",\n  \"price_type\": \"NETTO\",\n  \"vat_percent\": 19,\n  \"sale_price2\": null,\n  \"sale_price3\": null,\n  \"sale_price4\": null,\n  \"sale_price5\": null,\n  \"sale_price6\": null,\n  \"sale_price7\": null,\n  \"sale_price8\": null,\n  \"sale_price9\": null,\n  \"sale_price10\": null,\n  \"cost_price\": \"<float>\",\n  \"export_cost1\": null,\n  \"export_cost2\": null,\n  \"group_id\": \"<long>\",\n  \"stock\": \"NO\",\n  \"stock_count\": 0,\n  \"stock_limit_notify\": false,\n  \"stock_limit_notify_frequency\": \"ALWAYS\",\n  \"stock_limit\": 0,\n  \"quantity\": null,\n  \"archived\": false\n}"
    },
    {
      "name": "Not found",
      "originalRequest": {
        "method": "GET",
        "header": [
          {
            "description": "Added as a part of security scheme: apikey",
            "key": "Authorization",
            "value": "<API Key>"
          }
        ],
        "url": {
          "raw": "{{baseUrl}}/positions/:id",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "positions",
            ":id"
          ],
          "variable": [
            {
              "key": "id"
            }
          ]
        }
      },
      "status": "Not Found",
      "code": 404,
      "_postman_previewlanguage": "text",
      "header": [
      ],
      "cookie": [
      ],
      "body": ""
    },
    {
      "name": "Too Many Requests",
      "originalRequest": {
        "method": "GET",
        "header": [
          {
            "description": "Added as a part of security scheme: apikey",
            "key": "Authorization",
            "value": "<API Key>"
          }
        ],
        "url": {
          "raw": "{{baseUrl}}/positions/:id",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "positions",
            ":id"
          ],
          "variable": [
            {
              "key": "id"
            }
          ]
        }
      },
      "status": "Too Many Requests",
      "code": 429,
      "_postman_previewlanguage": "text",
      "header": [
      ],
      "cookie": [
      ],
      "body": ""
    }
  ]
}