Skip to content

eclipse-velocitas/vehicle-app-cpp-sdk

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

88 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Vehicle App C++ SDK

SDK CI Workflow License: Apache

The Vehicle App SDK for C++ allows to create Vehicle Apps from the Velocitas Development Model in the C++ programming language.

Folder structure

  • πŸ“ examples - example vehicle apps showcasing the use of the SDK
    • πŸ“ seat-adjuster - an example application showing how to adjust the driver seat when receiving MQTT messages
    • πŸ“ set-data-points - an example application showing how to set single and multiple data points
    • πŸ“ example_model - a handwritten example model used by some of the examples.
    • πŸ“ performance-subscribe - an example application subscribing to signals and printing time and value when updates are received.
    • πŸ“ grpc_client - an example application implementing a gRPC client, matching the example in Velocitas documentation.
    • πŸ“ grpc_server - an example application implementing a gRPC server, matching the example in Velocitas documentation.
  • πŸ“ sdk
    • πŸ“ include - the headers which need to be included by users of the SDK
    • πŸ“ src - contains the source code for the SDK from which the SDK library is built
    • πŸ“ test - contains the unit test code for the SDK

Prerequisites

  • Visual Studio Code with the Remote Containers extension
  • Docker installation on the host

Building

Installing dependencies

Before a build can be started, all dependencies required by the SDK need to be installed. Issue the following command in the SDK root directory:

./install_dependencies.sh

Proxy Issues

If you are working behind a corporate proxy, the install_dependcies.sh (which is also called during devcontainer build!) might probably fail downloading 3rd party packages via https with a TLS/SSL certificate validation error (we actually saw this issue in the build of gRPC trying to download the opencensus-proto package from storage.googleapis.com).

Please have a look at our "working behind proxy" tutorial to get hints how to possibly overcome this.

Building the SDK

To build the SDK (including examples), run the build script:

./build.sh

Starting the runtime

Open the Run Task view in VSCode and select Local Runtime - Up.

Launching the example

With the runtime running in the background, you can run the app.

Without debugging

Open the Run Task view in VSCode and select Local Runtime - Start SeatAdjuster.

With debugging

You can simply launch the example in the Debugging Tab. Make sure the Example - <example of your choice> is selected at the top. After the selection is done, you can also simply hit F5, to start the debugging session.

Note: This launch task will also make sure to re-build the app if it has been modified!

Run App as Docker container

docker run --rm -it --net="host" -e SDV_MIDDLEWARE_TYPE="native" -e SDV_MQTT_ADDRESS="localhost:1883" -e SDV_VEHICLEDATABROKER_ADDRESS="localhost:55555" localhost:12345/vehicleapp:local

Middleware configuration for the example apps

You can configure the middleware to be used (currently only native is supported) via environment variables of the app processs.

Middleware Environment Variable Default Meaning
SDV_MIDDLEWARE_TYPE native Defines the middleware to be used by the app (currently only native is supported)

| | native | SDV_MQTT_ADDRESS | localhost:1883 | Address of the MQTT broker | | SDV_VEHICLEDATABROKER_ADDRESS | localhost:55555 | Address of the Kuksa (Vehicle) Data Broker

Using MQTT Broker with authentication

If you have configured a MQTT Broker which requires authentication, you can also configure your app to properly connect to the broker. Currently the SDK supports authentication via credentials (username and password), tokens (depends on the broker) and certificates. In order to enable this feature you need to use the native middleware (set SDV_MIDDLEWARE_TYPE to native). To configure the authentication, you have to provide the details directly in the constructor of the app, see the example for username and password below:

SampleApp::SampleApp()
    : VehicleApp(velocitas::IVehicleDataBrokerClient::createInstance("vehicledatabroker"),
                 velocitas::IPubSubClient::createInstance("localhost:1883", "SampleApp",
                                                          "username", "password")) {}

Optimizing the gRPC communication channel settings

For possible optimizations of the communication with the KUKSA Databroker you can define setting for the used gRPC channel via so-called ChannelArguments as defined here: https://grpc.github.io/grpc/core/channel__arg__names_8h.html.

You have to define those settings in a JSON based file and pass its filepath via environment varaiable SDV_VDB_CHANNEL_CONFIG_PATH to the Velocitas SDK based application. The JSON has this structure:

{
    "channelArguments": {
        "<name of channel arg>": <value - either string or integer>
    }
}

The possible names of channel arguments are as they are defined in the above linked page, for example:

{
    "channelArguments": {
        "grpc.http2.lookahead_bytes": 65536,
        "grpc.default_authority": "Some authority defining string"
    }
}

The buffer size for subscribe requests to the databroker can be set via environment variable SDV_SUBSCRIBE_BUFFER_SIZE (default is 0).

Documentation

Quickstart Tutorials

  1. Setup and Explore Development Environment
  2. Develop your own Vehicle Model
  3. Develop your own Vehicle App

Contribution

Release Management

The SDK is installed into the Velocitas Development environment by the Velocitas Package for DevContainer Setup. To release a new version re-run all GitHub actions manually and verify that they all pass. Then create a new GitHub release and tag the commit used. No need to include any additional artifacts.

After creating the GitHub release, verify that the new release can be used by the Vehicle App C++ Template. Update the conanfile.txt with the new version in the line

vehicle-app-sdk/X.Y.Z

Then verify that the example application in the template can be successfully built. After successful verification, consider creating a Pull Request in the Vehicle App C++ Template repository tp update the SDK version.

Resources