Sample code for 30+ languages & platforms
Unicode C++

Datev - Upload File (Transfer a file to DATEV data center)

See more Datev Examples

Demonstrates how to transfer a file to the DATEV data center.

Chilkat Unicode C++ Downloads

Unicode C++
#include <CkHttpW.h>
#include <CkBinDataW.h>
#include <CkHttpResponseW.h>

void ChilkatSample(void)
    {
    bool success = false;

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

    CkHttpW http;

    // Implements the following CURL command:

    // curl --request POST \
    //   --url "https://accounting-extf-files.api.datev.de/platform-sandbox/v3/clients/REPLACE_CLIENT-ID/extf-files/import" \
    //   --header "Authorization: Bearer REPLACE_BEARER_TOKEN" \
    //   --header "X-Datev-Client-ID: clientId" \
    //   --header "accept: application/json;charset=utf-8" \
    //   --header "content-type: application/octet-stream" \
    //   --header "Filename: EXTF_BS_20200101_1.csv" \
    //   --header "Reference-Id: Buchungsstapel_Verkäufe_2020_01_Nr_001" \
    //   --header "Client-Application-Version: 2.0c" \
    //   --data-binary "@REPLACE_BODY"

    // Use the following online tool to generate HTTP code from a CURL command
    // Convert a cURL Command to HTTP Source Code

    CkBinDataW bdRequestBody;
    success = bdRequestBody.LoadFile(L"c:/temp/EXTF_BS_20200101_1.csv");
    if (success != true) {
        wprintf(L"Failed to load the csv file.\n");
        return;
    }

    http.SetRequestHeader(L"accept",L"application/json;charset=utf-8");
    http.SetRequestHeader(L"X-Datev-Client-ID",L"clientId");
    http.SetRequestHeader(L"Client-Application-Version",L"2.0c");
    http.SetRequestHeader(L"Filename",L"EXTF_BS_20200101_1.csv");
    http.SetRequestHeader(L"Reference-Id",L"Buchungsstapel_Verkäufe_2020_01_Nr_001");
    // Adds the "Authorization: Bearer REPLACE_BEARER_TOKEN" header.
    http.put_AuthToken(L"REPLACE_BEARER_TOKEN");

    CkHttpResponseW resp;
    const wchar_t *url = L"https://accounting-extf-files.api.datev.de/platform-sandbox/v3/clients/DATEV_USER_ID/extf-files/import";
    success = http.HttpBd(L"POST",url,bdRequestBody,L"application/octet-stream",resp);
    if (success == false) {
        wprintf(L"%s\n",http.lastErrorText());
        return;
    }

    wprintf(L"%d\n",resp.get_StatusCode());
    wprintf(L"%s\n",resp.bodyStr());
    }