2020-12-23 22:21:36 +01:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
2012-02-13 15:37:00 +01:00
|
|
|
/*
|
2019-10-01 09:20:35 +02:00
|
|
|
* Copyright (C) 2012 Red Hat, Inc.
|
2012-02-13 15:37:00 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* This example monitors NM state via D-Bus "StateChanged" signal on
|
|
|
|
|
* "org.freedesktop.NetworkManager" object.
|
2014-05-19 13:44:02 -04:00
|
|
|
* It uses GDBus and the libnm headers.
|
2012-02-13 15:37:00 +01:00
|
|
|
|
2014-08-20 10:08:18 -04:00
|
|
|
* You don't need to have the NetworkManager devel packages installed. You can just
|
2014-07-05 16:23:30 -04:00
|
|
|
* grab nm-dbus-interface.h and put it in the path.
|
2012-02-13 15:37:00 +01:00
|
|
|
*
|
|
|
|
|
* Standalone compilation:
|
2017-09-20 14:13:18 -07:00
|
|
|
* gcc -Wall monitor-nm-state-gdbus.c -o monitor-nm-state-gdbus `pkg-config --cflags --libs libnm`
|
2012-02-13 15:37:00 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include <gio/gio.h>
|
|
|
|
|
#include <string.h>
|
2014-07-05 16:23:30 -04:00
|
|
|
#include <nm-dbus-interface.h>
|
2012-02-13 15:37:00 +01:00
|
|
|
|
|
|
|
|
static const char *
|
|
|
|
|
nm_state_to_string(NMState state)
|
|
|
|
|
{
|
|
|
|
|
switch (state) {
|
|
|
|
|
case NM_STATE_ASLEEP:
|
|
|
|
|
return "asleep";
|
|
|
|
|
case NM_STATE_CONNECTING:
|
|
|
|
|
return "connecting";
|
|
|
|
|
case NM_STATE_CONNECTED_LOCAL:
|
|
|
|
|
return "connected (local only)";
|
|
|
|
|
case NM_STATE_CONNECTED_SITE:
|
|
|
|
|
return "connected (site only)";
|
|
|
|
|
case NM_STATE_CONNECTED_GLOBAL:
|
|
|
|
|
return "connected";
|
|
|
|
|
case NM_STATE_DISCONNECTING:
|
|
|
|
|
return "disconnecting";
|
|
|
|
|
case NM_STATE_DISCONNECTED:
|
|
|
|
|
return "disconnected";
|
|
|
|
|
case NM_STATE_UNKNOWN:
|
|
|
|
|
default:
|
|
|
|
|
return "unknown";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
on_signal(GDBusProxy *proxy,
|
2021-11-09 13:28:54 +01:00
|
|
|
char *sender_name,
|
|
|
|
|
char *signal_name,
|
|
|
|
|
GVariant *parameters,
|
2012-02-13 15:37:00 +01:00
|
|
|
gpointer user_data)
|
|
|
|
|
{
|
|
|
|
|
guint32 new_state;
|
2020-09-28 16:03:33 +02:00
|
|
|
|
2012-02-13 15:37:00 +01:00
|
|
|
/* Print all signals */
|
all: don't use gchar/gshort/gint/glong but C types
We commonly don't use the glib typedefs for char/short/int/long,
but their C types directly.
$ git grep '\<g\(char\|short\|int\|long\|float\|double\)\>' | wc -l
587
$ git grep '\<\(char\|short\|int\|long\|float\|double\)\>' | wc -l
21114
One could argue that using the glib typedefs is preferable in
public API (of our glib based libnm library) or where it clearly
is related to glib, like during
g_object_set (obj, PROPERTY, (gint) value, NULL);
However, that argument does not seem strong, because in practice we don't
follow that argument today, and seldomly use the glib typedefs.
Also, the style guide for this would be hard to formalize, because
"using them where clearly related to a glib" is a very loose suggestion.
Also note that glib typedefs will always just be typedefs of the
underlying C types. There is no danger of glib changing the meaning
of these typedefs (because that would be a major API break of glib).
A simple style guide is instead: don't use these typedefs.
No manual actions, I only ran the bash script:
FILES=($(git ls-files '*.[hc]'))
sed -i \
-e 's/\<g\(char\|short\|int\|long\|float\|double\)\>\( [^ ]\)/\1\2/g' \
-e 's/\<g\(char\|short\|int\|long\|float\|double\)\> /\1 /g' \
-e 's/\<g\(char\|short\|int\|long\|float\|double\)\>/\1/g' \
"${FILES[@]}"
2018-07-11 07:40:19 +02:00
|
|
|
//char *parameters_str;
|
2012-02-13 15:37:00 +01:00
|
|
|
//parameters_str = g_variant_print (parameters, TRUE);
|
|
|
|
|
//g_print (" *** Received Signal: %s: %s\n", signal_name, parameters_str);
|
|
|
|
|
//g_free (parameters_str);
|
2020-09-28 16:03:33 +02:00
|
|
|
|
2012-02-13 15:37:00 +01:00
|
|
|
/* We are only interested in "StateChanged" signal */
|
|
|
|
|
if (strcmp(signal_name, "StateChanged") == 0) {
|
|
|
|
|
GVariant *tmp = g_variant_get_child_value(parameters, 0);
|
|
|
|
|
new_state = g_variant_get_uint32(tmp);
|
|
|
|
|
g_variant_unref(tmp);
|
|
|
|
|
g_print("NetworkManager state is: (%d) %s\n",
|
|
|
|
|
new_state,
|
|
|
|
|
nm_state_to_string((NMState) new_state));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
|
main(int argc, char *argv[])
|
|
|
|
|
{
|
2021-11-09 13:28:54 +01:00
|
|
|
GMainLoop *loop;
|
|
|
|
|
GError *error = NULL;
|
2012-02-13 15:37:00 +01:00
|
|
|
GDBusProxyFlags flags;
|
2021-11-09 13:28:54 +01:00
|
|
|
GDBusProxy *proxy;
|
2020-09-28 16:03:33 +02:00
|
|
|
|
2012-02-13 15:37:00 +01:00
|
|
|
/* Monitor 'StateChanged' signal on 'org.freedesktop.NetworkManager' interface */
|
|
|
|
|
g_print("Monitor NetworkManager's state\n");
|
|
|
|
|
g_print("==============================\n");
|
2020-09-28 16:03:33 +02:00
|
|
|
|
2012-02-13 15:37:00 +01:00
|
|
|
flags = G_DBUS_PROXY_FLAGS_DO_NOT_LOAD_PROPERTIES | G_DBUS_PROXY_FLAGS_DO_NOT_AUTO_START;
|
|
|
|
|
proxy = g_dbus_proxy_new_for_bus_sync(G_BUS_TYPE_SYSTEM,
|
|
|
|
|
flags,
|
|
|
|
|
NULL, /* GDBusInterfaceInfo */
|
|
|
|
|
"org.freedesktop.NetworkManager",
|
|
|
|
|
"/org/freedesktop/NetworkManager",
|
|
|
|
|
"org.freedesktop.NetworkManager",
|
|
|
|
|
NULL, /* GCancellable */
|
|
|
|
|
&error);
|
2020-09-28 16:03:33 +02:00
|
|
|
|
2012-02-13 15:37:00 +01:00
|
|
|
if (proxy == NULL) {
|
2014-08-20 10:08:18 -04:00
|
|
|
g_dbus_error_strip_remote_error(error);
|
2012-02-13 15:37:00 +01:00
|
|
|
g_printerr("Error creating D-Bus proxy: %s\n", error->message);
|
|
|
|
|
g_error_free(error);
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
2020-09-28 16:03:33 +02:00
|
|
|
|
2012-02-13 15:37:00 +01:00
|
|
|
/* Connect to g-signal to receive signals from proxy (remote object) */
|
|
|
|
|
g_signal_connect(proxy, "g-signal", G_CALLBACK(on_signal), NULL);
|
2020-09-28 16:03:33 +02:00
|
|
|
|
2012-02-13 15:37:00 +01:00
|
|
|
/* Run main loop */
|
|
|
|
|
loop = g_main_loop_new(NULL, FALSE);
|
|
|
|
|
g_main_loop_run(loop);
|
2020-09-28 16:03:33 +02:00
|
|
|
|
2012-02-13 15:37:00 +01:00
|
|
|
g_object_unref(proxy);
|
2020-09-28 16:03:33 +02:00
|
|
|
|
2012-02-13 15:37:00 +01:00
|
|
|
return 0;
|
|
|
|
|
}
|