|
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 |
}
|