Blame src/ppp/nm-pppd-plugin.c

Packit Service 87a54e
/* SPDX-License-Identifier: GPL-2.0-or-later */
Packit 5756e2
/*
Packit 5756e2
 * Copyright (C) 2008 Novell, Inc.
Packit 5756e2
 * Copyright (C) 2008 Red Hat, Inc.
Packit 5756e2
 */
Packit 5756e2
Packit 5756e2
#include <config.h>
Packit 5756e2
#define ___CONFIG_H__
Packit 5756e2
Packit 5756e2
#include <pppd/pppd.h>
Packit 5756e2
#include <pppd/fsm.h>
Packit 5756e2
#include <pppd/ipcp.h>
Packit 5756e2
#include <sys/socket.h>
Packit 5756e2
#include <netinet/in.h>
Packit 5756e2
#include <net/if.h>
Packit 5756e2
#include <arpa/inet.h>
Packit 5756e2
#include <dlfcn.h>
Packit 5756e2
Packit 5756e2
#define INET6
Packit 5756e2
#include <pppd/eui64.h>
Packit 5756e2
#include <pppd/ipv6cp.h>
Packit 5756e2
Packit 5756e2
#include "nm-default.h"
Packit 5756e2
Packit 5756e2
#include "nm-dbus-interface.h"
Packit 5756e2
Packit 5756e2
#include "nm-pppd-plugin.h"
Packit 5756e2
#include "nm-ppp-status.h"
Packit 5756e2
Packit Service a1bd4f
int plugin_init(void);
Packit 5756e2
Packit 5756e2
char pppd_version[] = VERSION;
Packit 5756e2
Packit 5756e2
static struct {
Packit Service a1bd4f
    GDBusConnection *dbus_connection;
Packit Service a1bd4f
    char *           ipparam;
Packit 5756e2
} gl;
Packit 5756e2
Packit 5756e2
static void
Packit Service a1bd4f
nm_phasechange(int arg)
Packit 5756e2
{
Packit Service a1bd4f
    NMPPPStatus ppp_status = NM_PPP_STATUS_UNKNOWN;
Packit Service a1bd4f
    char *      ppp_phase;
Packit Service a1bd4f
Packit Service a1bd4f
    g_return_if_fail(G_IS_DBUS_CONNECTION(gl.dbus_connection));
Packit Service a1bd4f
Packit Service a1bd4f
    switch (arg) {
Packit Service a1bd4f
    case PHASE_DEAD:
Packit Service a1bd4f
        ppp_status = NM_PPP_STATUS_DEAD;
Packit Service a1bd4f
        ppp_phase  = "dead";
Packit Service a1bd4f
        break;
Packit Service a1bd4f
    case PHASE_INITIALIZE:
Packit Service a1bd4f
        ppp_status = NM_PPP_STATUS_INITIALIZE;
Packit Service a1bd4f
        ppp_phase  = "initialize";
Packit Service a1bd4f
        break;
Packit Service a1bd4f
    case PHASE_SERIALCONN:
Packit Service a1bd4f
        ppp_status = NM_PPP_STATUS_SERIALCONN;
Packit Service a1bd4f
        ppp_phase  = "serial connection";
Packit Service a1bd4f
        break;
Packit Service a1bd4f
    case PHASE_DORMANT:
Packit Service a1bd4f
        ppp_status = NM_PPP_STATUS_DORMANT;
Packit Service a1bd4f
        ppp_phase  = "dormant";
Packit Service a1bd4f
        break;
Packit Service a1bd4f
    case PHASE_ESTABLISH:
Packit Service a1bd4f
        ppp_status = NM_PPP_STATUS_ESTABLISH;
Packit Service a1bd4f
        ppp_phase  = "establish";
Packit Service a1bd4f
        break;
Packit Service a1bd4f
    case PHASE_AUTHENTICATE:
Packit Service a1bd4f
        ppp_status = NM_PPP_STATUS_AUTHENTICATE;
Packit Service a1bd4f
        ppp_phase  = "authenticate";
Packit Service a1bd4f
        break;
Packit Service a1bd4f
    case PHASE_CALLBACK:
Packit Service a1bd4f
        ppp_status = NM_PPP_STATUS_CALLBACK;
Packit Service a1bd4f
        ppp_phase  = "callback";
Packit Service a1bd4f
        break;
Packit Service a1bd4f
    case PHASE_NETWORK:
Packit Service a1bd4f
        ppp_status = NM_PPP_STATUS_NETWORK;
Packit Service a1bd4f
        ppp_phase  = "network";
Packit Service a1bd4f
        break;
Packit Service a1bd4f
    case PHASE_RUNNING:
Packit Service a1bd4f
        ppp_status = NM_PPP_STATUS_RUNNING;
Packit Service a1bd4f
        ppp_phase  = "running";
Packit Service a1bd4f
        break;
Packit Service a1bd4f
    case PHASE_TERMINATE:
Packit Service a1bd4f
        ppp_status = NM_PPP_STATUS_TERMINATE;
Packit Service a1bd4f
        ppp_phase  = "terminate";
Packit Service a1bd4f
        break;
Packit Service a1bd4f
    case PHASE_DISCONNECT:
Packit Service a1bd4f
        ppp_status = NM_PPP_STATUS_DISCONNECT;
Packit Service a1bd4f
        ppp_phase  = "disconnect";
Packit Service a1bd4f
        break;
Packit Service a1bd4f
    case PHASE_HOLDOFF:
Packit Service a1bd4f
        ppp_status = NM_PPP_STATUS_HOLDOFF;
Packit Service a1bd4f
        ppp_phase  = "holdoff";
Packit Service a1bd4f
        break;
Packit Service a1bd4f
    case PHASE_MASTER:
Packit Service a1bd4f
        ppp_status = NM_PPP_STATUS_MASTER;
Packit Service a1bd4f
        ppp_phase  = "master";
Packit Service a1bd4f
        break;
Packit Service a1bd4f
Packit Service a1bd4f
    default:
Packit Service a1bd4f
        ppp_phase = "unknown";
Packit Service a1bd4f
        break;
Packit Service a1bd4f
    }
Packit Service a1bd4f
Packit Service a1bd4f
    g_message("nm-ppp-plugin: status %d / phase '%s'", ppp_status, ppp_phase);
Packit Service a1bd4f
Packit Service a1bd4f
    if (ppp_status != NM_PPP_STATUS_UNKNOWN) {
Packit Service a1bd4f
        g_dbus_connection_call(gl.dbus_connection,
Packit Service a1bd4f
                               NM_DBUS_SERVICE,
Packit Service a1bd4f
                               gl.ipparam,
Packit Service a1bd4f
                               NM_DBUS_INTERFACE_PPP,
Packit Service a1bd4f
                               "SetState",
Packit Service a1bd4f
                               g_variant_new("(u)", ppp_status),
Packit Service a1bd4f
                               G_VARIANT_TYPE("()"),
Packit Service a1bd4f
                               G_DBUS_CALL_FLAGS_NONE,
Packit Service a1bd4f
                               -1,
Packit Service a1bd4f
                               NULL,
Packit Service a1bd4f
                               NULL,
Packit Service a1bd4f
                               NULL);
Packit Service a1bd4f
    }
Packit Service a1bd4f
Packit Service a1bd4f
    if (ppp_status == NM_PPP_STATUS_RUNNING) {
Packit Service a1bd4f
        gs_unref_variant GVariant *ret = NULL;
Packit Service a1bd4f
        char                       new_name[IF_NAMESIZE];
Packit Service a1bd4f
        int                        ifindex;
Packit Service a1bd4f
Packit Service a1bd4f
        ifindex = if_nametoindex(ifname);
Packit Service a1bd4f
Packit Service a1bd4f
        /* Make a sync call to ensure that when the call
Packit Service a1bd4f
         * terminates the interface already has its final
Packit Service a1bd4f
         * name. */
Packit Service a1bd4f
        ret = g_dbus_connection_call_sync(gl.dbus_connection,
Packit Service a1bd4f
                                          NM_DBUS_SERVICE,
Packit Service a1bd4f
                                          gl.ipparam,
Packit Service a1bd4f
                                          NM_DBUS_INTERFACE_PPP,
Packit Service a1bd4f
                                          "SetIfindex",
Packit Service a1bd4f
                                          g_variant_new("(i)", ifindex),
Packit Service a1bd4f
                                          G_VARIANT_TYPE("()"),
Packit Service a1bd4f
                                          G_DBUS_CALL_FLAGS_NONE,
Packit Service a1bd4f
                                          25000,
Packit Service a1bd4f
                                          NULL,
Packit Service a1bd4f
                                          NULL);
Packit Service a1bd4f
Packit Service a1bd4f
        /* Update the name in pppd if NM changed it */
Packit Service a1bd4f
        if (if_indextoname(ifindex, new_name) && !nm_streq0(ifname, new_name)) {
Packit Service a1bd4f
            g_message("nm-ppp-plugin: interface name changed from '%s' to '%s'", ifname, new_name);
Packit Service a1bd4f
            g_strlcpy(ifname, new_name, IF_NAMESIZE);
Packit Service a1bd4f
        }
Packit Service a1bd4f
    }
Packit 5756e2
}
Packit 5756e2
Packit 5756e2
static void
Packit Service a1bd4f
nm_phasechange_hook(void *data, int arg)
Packit 5756e2
{
Packit Service a1bd4f
    /* We send the nofication in exitnotify instead */
Packit Service a1bd4f
    if (arg == PHASE_DEAD)
Packit Service a1bd4f
        return;
Packit 5756e2
Packit Service a1bd4f
    nm_phasechange(arg);
Packit 5756e2
}
Packit 5756e2
Packit 5756e2
static void
Packit Service a1bd4f
nm_ip_up(void *data, int arg)
Packit 5756e2
{
Packit Service a1bd4f
    ipcp_options    opts      = ipcp_gotoptions[0];
Packit Service a1bd4f
    ipcp_options    peer_opts = ipcp_hisoptions[0];
Packit Service a1bd4f
    GVariantBuilder builder;
Packit Service a1bd4f
    guint32         pppd_made_up_address = htonl(0x0a404040 + ifunit);
Packit Service a1bd4f
Packit Service a1bd4f
    g_return_if_fail(G_IS_DBUS_CONNECTION(gl.dbus_connection));
Packit Service a1bd4f
Packit Service a1bd4f
    g_message("nm-ppp-plugin: ip-up event");
Packit Service a1bd4f
Packit Service a1bd4f
    if (!opts.ouraddr) {
Packit Service a1bd4f
        g_warning("nm-ppp-plugin: didn't receive an internal IP from pppd!");
Packit Service a1bd4f
        nm_phasechange(PHASE_DEAD);
Packit Service a1bd4f
        return;
Packit Service a1bd4f
    }
Packit Service a1bd4f
Packit Service a1bd4f
    g_variant_builder_init(&builder, G_VARIANT_TYPE_VARDICT);
Packit Service a1bd4f
Packit Service a1bd4f
    /* Keep sending the interface name to be backwards compatible
Packit Service a1bd4f
     * with older versions of NM during a package upgrade, where
Packit Service a1bd4f
     * NM is not restarted and the pppd plugin was not loaded. */
Packit Service a1bd4f
    g_variant_builder_add(&builder,
Packit Service a1bd4f
                          "{sv}",
Packit Service a1bd4f
                          NM_PPP_IP4_CONFIG_INTERFACE,
Packit Service a1bd4f
                          g_variant_new_string(ifname));
Packit Service a1bd4f
Packit Service a1bd4f
    g_variant_builder_add(&builder,
Packit Service a1bd4f
                          "{sv}",
Packit Service a1bd4f
                          NM_PPP_IP4_CONFIG_ADDRESS,
Packit Service a1bd4f
                          g_variant_new_uint32(opts.ouraddr));
Packit Service a1bd4f
Packit Service a1bd4f
    /* Prefer the peer options remote address first, _unless_ pppd made the
Packit Service a1bd4f
     * address up, at which point prefer the local options remote address,
Packit Service a1bd4f
     * and if that's not right, use the made-up address as a last resort.
Packit Service a1bd4f
     */
Packit Service a1bd4f
    if (peer_opts.hisaddr && (peer_opts.hisaddr != pppd_made_up_address)) {
Packit Service a1bd4f
        g_variant_builder_add(&builder,
Packit Service a1bd4f
                              "{sv}",
Packit Service a1bd4f
                              NM_PPP_IP4_CONFIG_GATEWAY,
Packit Service a1bd4f
                              g_variant_new_uint32(peer_opts.hisaddr));
Packit Service a1bd4f
    } else if (opts.hisaddr) {
Packit Service a1bd4f
        g_variant_builder_add(&builder,
Packit Service a1bd4f
                              "{sv}",
Packit Service a1bd4f
                              NM_PPP_IP4_CONFIG_GATEWAY,
Packit Service a1bd4f
                              g_variant_new_uint32(opts.hisaddr));
Packit Service a1bd4f
    } else if (peer_opts.hisaddr == pppd_made_up_address) {
Packit Service a1bd4f
        /* As a last resort, use the made-up address */
Packit Service a1bd4f
        g_variant_builder_add(&builder,
Packit Service a1bd4f
                              "{sv}",
Packit Service a1bd4f
                              NM_PPP_IP4_CONFIG_GATEWAY,
Packit Service a1bd4f
                              g_variant_new_uint32(peer_opts.ouraddr));
Packit Service a1bd4f
    }
Packit Service a1bd4f
Packit Service a1bd4f
    g_variant_builder_add(&builder, "{sv}", NM_PPP_IP4_CONFIG_PREFIX, g_variant_new_uint32(32));
Packit Service a1bd4f
Packit Service a1bd4f
    if (opts.dnsaddr[0] || opts.dnsaddr[1]) {
Packit Service a1bd4f
        guint32 dns[2];
Packit Service a1bd4f
        int     len = 0;
Packit Service a1bd4f
Packit Service a1bd4f
        if (opts.dnsaddr[0])
Packit Service a1bd4f
            dns[len++] = opts.dnsaddr[0];
Packit Service a1bd4f
        if (opts.dnsaddr[1])
Packit Service a1bd4f
            dns[len++] = opts.dnsaddr[1];
Packit Service a1bd4f
Packit Service a1bd4f
        g_variant_builder_add(
Packit Service a1bd4f
            &builder,
Packit Service a1bd4f
            "{sv}",
Packit Service a1bd4f
            NM_PPP_IP4_CONFIG_DNS,
Packit Service a1bd4f
            g_variant_new_fixed_array(G_VARIANT_TYPE_UINT32, dns, len, sizeof(guint32)));
Packit Service a1bd4f
    }
Packit Service a1bd4f
Packit Service a1bd4f
    if (opts.winsaddr[0] || opts.winsaddr[1]) {
Packit Service a1bd4f
        guint32 wins[2];
Packit Service a1bd4f
        int     len = 0;
Packit Service a1bd4f
Packit Service a1bd4f
        if (opts.winsaddr[0])
Packit Service a1bd4f
            wins[len++] = opts.winsaddr[0];
Packit Service a1bd4f
        if (opts.winsaddr[1])
Packit Service a1bd4f
            wins[len++] = opts.winsaddr[1];
Packit Service a1bd4f
Packit Service a1bd4f
        g_variant_builder_add(
Packit Service a1bd4f
            &builder,
Packit Service a1bd4f
            "{sv}",
Packit Service a1bd4f
            NM_PPP_IP4_CONFIG_WINS,
Packit Service a1bd4f
            g_variant_new_fixed_array(G_VARIANT_TYPE_UINT32, wins, len, sizeof(guint32)));
Packit Service a1bd4f
    }
Packit Service a1bd4f
Packit Service a1bd4f
    g_message("nm-ppp-plugin: sending IPv4 config to NetworkManager...");
Packit Service a1bd4f
Packit Service a1bd4f
    g_dbus_connection_call(gl.dbus_connection,
Packit Service a1bd4f
                           NM_DBUS_SERVICE,
Packit Service a1bd4f
                           gl.ipparam,
Packit Service a1bd4f
                           NM_DBUS_INTERFACE_PPP,
Packit Service a1bd4f
                           "SetIp4Config",
Packit Service a1bd4f
                           g_variant_new("(a{sv})", &builder),
Packit Service a1bd4f
                           G_VARIANT_TYPE("()"),
Packit Service a1bd4f
                           G_DBUS_CALL_FLAGS_NONE,
Packit Service a1bd4f
                           -1,
Packit Service a1bd4f
                           NULL,
Packit Service a1bd4f
                           NULL,
Packit Service a1bd4f
                           NULL);
Packit 5756e2
}
Packit 5756e2
Packit 5756e2
static GVariant *
Packit Service a1bd4f
eui64_to_variant(eui64_t eui)
Packit 5756e2
{
Packit Service a1bd4f
    guint64 iid;
Packit 5756e2
Packit Service a1bd4f
    G_STATIC_ASSERT(sizeof(iid) == sizeof(eui));
Packit 5756e2
Packit Service a1bd4f
    memcpy(&iid, &eui, sizeof(eui));
Packit Service a1bd4f
    return g_variant_new_uint64(iid);
Packit 5756e2
}
Packit 5756e2
Packit 5756e2
static void
Packit Service a1bd4f
nm_ip6_up(void *data, int arg)
Packit 5756e2
{
Packit Service a1bd4f
    ipv6cp_options *ho = &ipv6cp_hisoptions[0];
Packit Service a1bd4f
    ipv6cp_options *go = &ipv6cp_gotoptions[0];
Packit Service a1bd4f
    GVariantBuilder builder;
Packit Service a1bd4f
Packit Service a1bd4f
    g_return_if_fail(G_IS_DBUS_CONNECTION(gl.dbus_connection));
Packit Service a1bd4f
Packit Service a1bd4f
    g_message("nm-ppp-plugin: ip6-up event");
Packit Service a1bd4f
Packit Service a1bd4f
    g_variant_builder_init(&builder, G_VARIANT_TYPE_VARDICT);
Packit Service a1bd4f
    /* Keep sending the interface name to be backwards compatible
Packit Service a1bd4f
     * with older versions of NM during a package upgrade, where
Packit Service a1bd4f
     * NM is not restarted and the pppd plugin was not loaded. */
Packit Service a1bd4f
    g_variant_builder_add(&builder,
Packit Service a1bd4f
                          "{sv}",
Packit Service a1bd4f
                          NM_PPP_IP6_CONFIG_INTERFACE,
Packit Service a1bd4f
                          g_variant_new_string(ifname));
Packit Service a1bd4f
    g_variant_builder_add(&builder, "{sv}", NM_PPP_IP6_CONFIG_OUR_IID, eui64_to_variant(go->ourid));
Packit Service a1bd4f
    g_variant_builder_add(&builder,
Packit Service a1bd4f
                          "{sv}",
Packit Service a1bd4f
                          NM_PPP_IP6_CONFIG_PEER_IID,
Packit Service a1bd4f
                          eui64_to_variant(ho->hisid));
Packit Service a1bd4f
Packit Service a1bd4f
    /* DNS is done via DHCPv6 or router advertisements */
Packit Service a1bd4f
Packit Service a1bd4f
    g_message("nm-ppp-plugin: sending IPv6 config to NetworkManager...");
Packit Service a1bd4f
Packit Service a1bd4f
    g_dbus_connection_call(gl.dbus_connection,
Packit Service a1bd4f
                           NM_DBUS_SERVICE,
Packit Service a1bd4f
                           gl.ipparam,
Packit Service a1bd4f
                           NM_DBUS_INTERFACE_PPP,
Packit Service a1bd4f
                           "SetIp6Config",
Packit Service a1bd4f
                           g_variant_new("(a{sv})", &builder),
Packit Service a1bd4f
                           G_VARIANT_TYPE("()"),
Packit Service a1bd4f
                           G_DBUS_CALL_FLAGS_NONE,
Packit Service a1bd4f
                           -1,
Packit Service a1bd4f
                           NULL,
Packit Service a1bd4f
                           NULL,
Packit Service a1bd4f
                           NULL);
Packit 5756e2
}
Packit 5756e2
Packit 5756e2
static int
Packit Service a1bd4f
get_chap_check(void)
Packit 5756e2
{
Packit Service a1bd4f
    return 1;
Packit 5756e2
}
Packit 5756e2
Packit 5756e2
static int
Packit Service a1bd4f
get_pap_check(void)
Packit 5756e2
{
Packit Service a1bd4f
    return 1;
Packit 5756e2
}
Packit 5756e2
Packit 5756e2
static int
Packit Service a1bd4f
get_credentials(char *username, char *password)
Packit 5756e2
{
Packit Service a1bd4f
    gs_unref_variant GVariant *ret = NULL;
Packit Service a1bd4f
    gs_free_error GError *error    = NULL;
Packit Service a1bd4f
    const char *          my_username;
Packit Service a1bd4f
    const char *          my_password;
Packit Service a1bd4f
Packit Service a1bd4f
    if (!password) {
Packit Service a1bd4f
        /* pppd is checking pap support; return 1 for supported */
Packit Service a1bd4f
        g_return_val_if_fail(username, -1);
Packit Service a1bd4f
        return 1;
Packit Service a1bd4f
    }
Packit Service a1bd4f
Packit Service a1bd4f
    g_return_val_if_fail(username, -1);
Packit Service a1bd4f
    g_return_val_if_fail(G_IS_DBUS_CONNECTION(gl.dbus_connection), -1);
Packit Service a1bd4f
Packit Service a1bd4f
    g_message("nm-ppp-plugin: passwd-hook, requesting credentials...");
Packit Service a1bd4f
Packit Service a1bd4f
    ret = g_dbus_connection_call_sync(gl.dbus_connection,
Packit Service a1bd4f
                                      NM_DBUS_SERVICE,
Packit Service a1bd4f
                                      gl.ipparam,
Packit Service a1bd4f
                                      NM_DBUS_INTERFACE_PPP,
Packit Service a1bd4f
                                      "NeedSecrets",
Packit Service a1bd4f
                                      NULL,
Packit Service a1bd4f
                                      G_VARIANT_TYPE("(ss)"),
Packit Service a1bd4f
                                      G_DBUS_CALL_FLAGS_NONE,
Packit Service a1bd4f
                                      -1,
Packit Service a1bd4f
                                      NULL,
Packit Service a1bd4f
                                      &error);
Packit Service a1bd4f
    if (!ret) {
Packit Service a1bd4f
        g_warning("nm-ppp-plugin: could not get secrets: %s", error->message);
Packit Service a1bd4f
        return -1;
Packit Service a1bd4f
    }
Packit Service a1bd4f
Packit Service a1bd4f
    g_message("nm-ppp-plugin: got credentials from NetworkManager");
Packit Service a1bd4f
Packit Service a1bd4f
    g_variant_get(ret, "(&s&s)", &my_username, &my_password);
Packit Service a1bd4f
Packit Service a1bd4f
    g_strlcpy(username, my_username, MAXNAMELEN);
Packit Service a1bd4f
    g_strlcpy(password, my_password, MAXSECRETLEN);
Packit Service a1bd4f
Packit Service a1bd4f
    return 1;
Packit 5756e2
}
Packit 5756e2
Packit 5756e2
static void
Packit Service a1bd4f
nm_exit_notify(void *data, int arg)
Packit 5756e2
{
Packit Service a1bd4f
    g_return_if_fail(G_IS_DBUS_CONNECTION(gl.dbus_connection));
Packit 5756e2
Packit Service a1bd4f
    /* We wait until this point to notify dead phase to make sure that
Packit Service a1bd4f
     * the serial port has recovered already its original settings.
Packit Service a1bd4f
     */
Packit Service a1bd4f
    nm_phasechange(PHASE_DEAD);
Packit 5756e2
Packit Service a1bd4f
    g_message("nm-ppp-plugin: cleaning up");
Packit 5756e2
Packit Service a1bd4f
    g_clear_object(&gl.dbus_connection);
Packit Service a1bd4f
    nm_clear_g_free(&gl.ipparam);
Packit 5756e2
}
Packit 5756e2
Packit 5756e2
static void
Packit Service a1bd4f
add_ip6_notifier(void)
Packit 5756e2
{
Packit Service a1bd4f
    static struct notifier **notifier  = NULL;
Packit Service a1bd4f
    static gsize             load_once = 0;
Packit Service a1bd4f
Packit Service a1bd4f
    if (g_once_init_enter(&load_once)) {
Packit Service a1bd4f
        void *handle = dlopen(NULL, RTLD_NOW | RTLD_GLOBAL);
Packit Service a1bd4f
Packit Service a1bd4f
        if (handle) {
Packit Service a1bd4f
            notifier = dlsym(handle, "ipv6_up_notifier");
Packit Service a1bd4f
            dlclose(handle);
Packit Service a1bd4f
        }
Packit Service a1bd4f
        g_once_init_leave(&load_once, 1);
Packit Service a1bd4f
    }
Packit Service a1bd4f
    if (notifier)
Packit Service a1bd4f
        add_notifier(notifier, nm_ip6_up, NULL);
Packit Service a1bd4f
    else
Packit Service a1bd4f
        g_message("nm-ppp-plugin: no IPV6CP notifier support; IPv6 not available");
Packit 5756e2
}
Packit 5756e2
Packit 5756e2
int
Packit Service a1bd4f
plugin_init(void)
Packit 5756e2
{
Packit Service a1bd4f
    gs_free_error GError *err = NULL;
Packit 5756e2
Packit Service a1bd4f
    g_message("nm-ppp-plugin: initializing");
Packit 5756e2
Packit Service a1bd4f
    nm_assert(!gl.dbus_connection);
Packit Service a1bd4f
    nm_assert(!gl.ipparam);
Packit 5756e2
Packit Service a1bd4f
    gl.dbus_connection = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &err;;
Packit Service a1bd4f
    if (!gl.dbus_connection) {
Packit Service a1bd4f
        g_warning("nm-pppd-plugin: couldn't connect to system bus: %s", err->message);
Packit Service a1bd4f
        return -1;
Packit Service a1bd4f
    }
Packit 5756e2
Packit Service a1bd4f
    gl.ipparam = g_strdup(ipparam);
Packit 5756e2
Packit Service a1bd4f
    chap_passwd_hook = get_credentials;
Packit Service a1bd4f
    chap_check_hook  = get_chap_check;
Packit Service a1bd4f
    pap_passwd_hook  = get_credentials;
Packit Service a1bd4f
    pap_check_hook   = get_pap_check;
Packit 5756e2
Packit Service a1bd4f
    add_notifier(&phasechange, nm_phasechange_hook, NULL);
Packit Service a1bd4f
    add_notifier(&ip_up_notifier, nm_ip_up, NULL);
Packit Service a1bd4f
    add_notifier(&exitnotify, nm_exit_notify, NULL);
Packit Service a1bd4f
    add_ip6_notifier();
Packit 5756e2
Packit Service a1bd4f
    return 0;
Packit 5756e2
}