mirror of
https://gitlab.freedesktop.org/NetworkManager/NetworkManager.git
synced 2025-12-27 19:50:08 +01:00
"nm-error.h" is public API of libnm, and contains error numbers and quarks. Clearly our "nm-crypto" implementation wants to use those errors. I want to move "nm-crypto" out of libnm, and as it's more basic, I think it should not have a dependency on all of libnm-core. Also because libnm-core currently uses nm-crypto, so there would be a circular dependency. Which would be possible to do (libnm-core-aux-intern is also used in such a way). But it's better avoided, to have clear hierarchy of dependencies. Add a version of the same error codes to libnm-base. libnm-base is a very basic dependency (just one step above libnm-glib-aux).
67 lines
2.8 KiB
C
67 lines
2.8 KiB
C
/* SPDX-License-Identifier: LGPL-2.1-or-later */
|
|
/*
|
|
* Copyright (C) 2004 - 2014 Red Hat, Inc.
|
|
*/
|
|
|
|
#include "libnm-core-impl/nm-default-libnm-core.h"
|
|
|
|
#include "nm-errors.h"
|
|
|
|
#include "nm-vpn-dbus-interface.h"
|
|
#include "libnm-core-intern/nm-core-internal.h"
|
|
|
|
NM_CACHED_QUARK_FCN("nm-agent-manager-error-quark", nm_agent_manager_error_quark);
|
|
NM_CACHED_QUARK_FCN("nm-connection-error-quark", nm_connection_error_quark);
|
|
NM_CACHED_QUARK_FCN("nm-device-error-quark", nm_device_error_quark);
|
|
NM_CACHED_QUARK_FCN("nm-secret-agent-error-quark", nm_secret_agent_error_quark);
|
|
NM_CACHED_QUARK_FCN("nm-settings-error-quark", nm_settings_error_quark);
|
|
NM_CACHED_QUARK_FCN("nm-vpn-plugin-error-quark", nm_vpn_plugin_error_quark);
|
|
|
|
GQuark
|
|
nm_crypto_error_quark(void)
|
|
{
|
|
G_STATIC_ASSERT(NM_CRYPTO_ERROR_FAILED == _NM_CRYPTO_ERROR_FAILED);
|
|
G_STATIC_ASSERT(NM_CRYPTO_ERROR_INVALID_DATA == _NM_CRYPTO_ERROR_INVALID_DATA);
|
|
G_STATIC_ASSERT(NM_CRYPTO_ERROR_INVALID_PASSWORD == _NM_CRYPTO_ERROR_INVALID_PASSWORD);
|
|
G_STATIC_ASSERT(NM_CRYPTO_ERROR_UNKNOWN_CIPHER == _NM_CRYPTO_ERROR_UNKNOWN_CIPHER);
|
|
G_STATIC_ASSERT(NM_CRYPTO_ERROR_DECRYPTION_FAILED == _NM_CRYPTO_ERROR_DECRYPTION_FAILED);
|
|
G_STATIC_ASSERT(NM_CRYPTO_ERROR_ENCRYPTION_FAILED == _NM_CRYPTO_ERROR_ENCRYPTION_FAILED);
|
|
|
|
return _nm_crypto_error_quark();
|
|
}
|
|
|
|
static void
|
|
register_error_domain(GQuark domain, const char *interface, GType enum_type)
|
|
{
|
|
nm_auto_unref_gtypeclass GEnumClass *enum_class = g_type_class_ref(enum_type);
|
|
guint i;
|
|
|
|
for (i = 0; i < enum_class->n_values; i++) {
|
|
const GEnumValue *e = &enum_class->values[i];
|
|
char error_name[200];
|
|
|
|
nm_assert(e && e->value_nick && !strchr(e->value_nick, '-'));
|
|
|
|
nm_sprintf_buf(error_name, "%s.%s", interface, e->value_nick);
|
|
if (!g_dbus_error_register_error(domain, e->value, error_name))
|
|
nm_assert_not_reached();
|
|
}
|
|
}
|
|
|
|
void
|
|
_nm_dbus_errors_init(void)
|
|
{
|
|
register_error_domain(NM_AGENT_MANAGER_ERROR,
|
|
NM_DBUS_INTERFACE_AGENT_MANAGER,
|
|
NM_TYPE_AGENT_MANAGER_ERROR);
|
|
register_error_domain(NM_CONNECTION_ERROR,
|
|
NM_DBUS_INTERFACE_SETTINGS_CONNECTION,
|
|
NM_TYPE_CONNECTION_ERROR);
|
|
register_error_domain(NM_DEVICE_ERROR, NM_DBUS_INTERFACE_DEVICE, NM_TYPE_DEVICE_ERROR);
|
|
register_error_domain(NM_MANAGER_ERROR, NM_DBUS_INTERFACE, NM_TYPE_MANAGER_ERROR);
|
|
register_error_domain(NM_SECRET_AGENT_ERROR,
|
|
NM_DBUS_INTERFACE_SECRET_AGENT,
|
|
NM_TYPE_SECRET_AGENT_ERROR);
|
|
register_error_domain(NM_SETTINGS_ERROR, NM_DBUS_INTERFACE_SETTINGS, NM_TYPE_SETTINGS_ERROR);
|
|
register_error_domain(NM_VPN_PLUGIN_ERROR, NM_DBUS_VPN_ERROR_PREFIX, NM_TYPE_VPN_PLUGIN_ERROR);
|
|
}
|