sd_bus_set_property, sd_bus_set_propertyv, sd_bus_get_property, sd_bus_get_property_trivial, sd_bus_get_property_string, sd_bus_get_property_strv — Set or query D-Bus service properties
#include <systemd/sd-bus.h>
int sd_bus_set_property( | sd_bus *bus, | 
| const char *destination, | |
| const char *path, | |
| const char *interface, | |
| const char *member, | |
| sd_bus_error *ret_error, | |
| sd_bus_message **reply, | |
| const char *type, | |
...); | 
int sd_bus_set_propertyv( | sd_bus *bus, | 
| const char *destination, | |
| const char *path, | |
| const char *interface, | |
| const char *member, | |
| sd_bus_error *ret_error, | |
| sd_bus_message **reply, | |
| const char *type, | |
va_list ap); | 
int sd_bus_get_property( | sd_bus *bus, | 
| const char *destination, | |
| const char *path, | |
| const char *interface, | |
| const char *member, | |
| sd_bus_error *ret_error, | |
| sd_bus_message **reply, | |
const char *type); | 
int sd_bus_get_property_trivial( | sd_bus *bus, | 
| const char *destination, | |
| const char *path, | |
| const char *interface, | |
| const char *member, | |
| sd_bus_error *ret_error, | |
| char type, | |
void *ret_ptr); | 
int sd_bus_get_property_string( | sd_bus *bus, | 
| const char *destination, | |
| const char *path, | |
| const char *interface, | |
| const char *member, | |
| sd_bus_error *ret_error, | |
char **ret); | 
int sd_bus_get_property_strv( | sd_bus *bus, | 
| const char *destination, | |
| const char *path, | |
| const char *interface, | |
| const char *member, | |
| sd_bus_error *ret_error, | |
char ***ret); | 
These functions set or query D-Bus properties. D-Bus properties are service fields exposed
    via the org.freedesktop.DBus.Properties interface. Under the hood, these
    functions call methods of the org.freedesktop.DBus.Properties interface and
    as a result their semantics are similar to
    sd_bus_call_method(3).
    
sd_bus_set_property() sets a D-Bus property. On success, the response
    is stored in reply. If setting the property fails or an internal error
    occurs, an error is returned and an extended description of the error is optionally stored in
    ret_error if it is not NULL.
    type and the arguments that follow it describe the new value of the
    property and must follow the format described in
    sd_bus_message_append(3).
    
sd_bus_set_propertyv() is equivalent to
    sd_bus_set_property(), except that it is called with a
    "va_list" instead of a variable number of arguments.
sd_bus_get_property() queries a D-Bus property. If retrieving the
    property fails or an internal error occurs, an error is returned and an extended description of
    the error is optionally stored in ret_error if it is not
    NULL. On success, the property is stored in reply.
    type describes the property type and must follow the format described in
    sd_bus_message_append(3).
    
sd_bus_get_property_trivial(),
    sd_bus_get_property_string() and
    sd_bus_get_property_strv() are shorthands for
    sd_bus_get_property() that are used to query basic, string and string
    vector properties respectively. The caller is responsible for freeing the string and string
    vector results stored in ret by
    sd_bus_get_property_string() and
    sd_bus_get_property_strv().
On success, these functions return a non-negative integer. On failure, they return a negative errno-style error code.
These APIs are implemented as a shared
  library, which can be compiled and linked to with the
  libsystemd pkg-config(1)
  file.