summaryrefslogtreecommitdiff
path: root/src/bluez-manager
diff options
context:
space:
mode:
Diffstat (limited to 'src/bluez-manager')
-rw-r--r--src/bluez-manager/Makefile.am44
-rw-r--r--src/bluez-manager/Makefile.in786
-rw-r--r--src/bluez-manager/nm-bluez-common.h51
-rw-r--r--src/bluez-manager/nm-bluez-device.c1223
-rw-r--r--src/bluez-manager/nm-bluez-device.h97
-rw-r--r--src/bluez-manager/nm-bluez-manager.c438
-rw-r--r--src/bluez-manager/nm-bluez-manager.h69
-rw-r--r--src/bluez-manager/nm-bluez4-adapter.c397
-rw-r--r--src/bluez-manager/nm-bluez4-adapter.h69
-rw-r--r--src/bluez-manager/nm-bluez4-manager.c386
10 files changed, 0 insertions, 3560 deletions
diff --git a/src/bluez-manager/Makefile.am b/src/bluez-manager/Makefile.am
deleted file mode 100644
index fb836abf6..000000000
--- a/src/bluez-manager/Makefile.am
+++ /dev/null
@@ -1,44 +0,0 @@
-noinst_LTLIBRARIES = libbluez-manager.la
-
-libbluez_manager_la_CPPFLAGS = \
- -I${top_srcdir} \
- -I${top_builddir}/include \
- -I${top_srcdir}/include \
- -I${top_builddir}/libnm-util \
- -I${top_srcdir}/libnm-util \
- -I${top_srcdir}/src \
- -I${top_builddir}/src/generated \
- -I${top_srcdir}/src/generated \
- -I${top_srcdir}/src/logging \
- $(DBUS_CFLAGS) \
- $(GLIB_CFLAGS) \
- $(BLUEZ_CFLAGS) \
- -DBINDIR=\"$(bindir)\" \
- -DDATADIR=\"$(datadir)\" \
- -DSYSCONFDIR=\"$(sysconfdir)\" \
- -DLIBEXECDIR=\"$(libexecdir)\" \
- -DLOCALSTATEDIR=\"$(localstatedir)\"
-
-libbluez_manager_la_SOURCES = \
- nm-bluez-common.h \
- nm-bluez-device.c \
- nm-bluez-device.h \
- nm-bluez-manager.h
-
-if WITH_BLUEZ4
-libbluez_manager_la_SOURCES += \
- nm-bluez4-adapter.h \
- nm-bluez4-adapter.c \
- nm-bluez4-manager.c
-else
-libbluez_manager_la_SOURCES += \
- nm-bluez-manager.c
-endif
-
-libbluez_manager_la_LIBADD = \
- $(top_builddir)/src/generated/libnm-generated.la \
- $(top_builddir)/src/logging/libnm-logging.la \
- $(DBUS_LIBS) \
- $(GLIB_LIBS) \
- $(BLUEZ_LIBS)
-
diff --git a/src/bluez-manager/Makefile.in b/src/bluez-manager/Makefile.in
deleted file mode 100644
index f72768a60..000000000
--- a/src/bluez-manager/Makefile.in
+++ /dev/null
@@ -1,786 +0,0 @@
-# Makefile.in generated by automake 1.13.4 from Makefile.am.
-# @configure_input@
-
-# Copyright (C) 1994-2013 Free Software Foundation, Inc.
-
-# This Makefile.in is free software; the Free Software Foundation
-# gives unlimited permission to copy and/or distribute it,
-# with or without modifications, as long as this notice is preserved.
-
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
-# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
-# PARTICULAR PURPOSE.
-
-@SET_MAKE@
-
-VPATH = @srcdir@
-am__is_gnu_make = test -n '$(MAKEFILE_LIST)' && test -n '$(MAKELEVEL)'
-am__make_running_with_option = \
- case $${target_option-} in \
- ?) ;; \
- *) echo "am__make_running_with_option: internal error: invalid" \
- "target option '$${target_option-}' specified" >&2; \
- exit 1;; \
- esac; \
- has_opt=no; \
- sane_makeflags=$$MAKEFLAGS; \
- if $(am__is_gnu_make); then \
- sane_makeflags=$$MFLAGS; \
- else \
- case $$MAKEFLAGS in \
- *\\[\ \ ]*) \
- bs=\\; \
- sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \
- | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \
- esac; \
- fi; \
- skip_next=no; \
- strip_trailopt () \
- { \
- flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \
- }; \
- for flg in $$sane_makeflags; do \
- test $$skip_next = yes && { skip_next=no; continue; }; \
- case $$flg in \
- *=*|--*) continue;; \
- -*I) strip_trailopt 'I'; skip_next=yes;; \
- -*I?*) strip_trailopt 'I';; \
- -*O) strip_trailopt 'O'; skip_next=yes;; \
- -*O?*) strip_trailopt 'O';; \
- -*l) strip_trailopt 'l'; skip_next=yes;; \
- -*l?*) strip_trailopt 'l';; \
- -[dEDm]) skip_next=yes;; \
- -[JT]) skip_next=yes;; \
- esac; \
- case $$flg in \
- *$$target_option*) has_opt=yes; break;; \
- esac; \
- done; \
- test $$has_opt = yes
-am__make_dryrun = (target_option=n; $(am__make_running_with_option))
-am__make_keepgoing = (target_option=k; $(am__make_running_with_option))
-pkgdatadir = $(datadir)/@PACKAGE@
-pkgincludedir = $(includedir)/@PACKAGE@
-pkglibdir = $(libdir)/@PACKAGE@
-pkglibexecdir = $(libexecdir)/@PACKAGE@
-am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
-install_sh_DATA = $(install_sh) -c -m 644
-install_sh_PROGRAM = $(install_sh) -c
-install_sh_SCRIPT = $(install_sh) -c
-INSTALL_HEADER = $(INSTALL_DATA)
-transform = $(program_transform_name)
-NORMAL_INSTALL = :
-PRE_INSTALL = :
-POST_INSTALL = :
-NORMAL_UNINSTALL = :
-PRE_UNINSTALL = :
-POST_UNINSTALL = :
-build_triplet = @build@
-host_triplet = @host@
-@WITH_BLUEZ4_TRUE@am__append_1 = \
-@WITH_BLUEZ4_TRUE@ nm-bluez4-adapter.h \
-@WITH_BLUEZ4_TRUE@ nm-bluez4-adapter.c \
-@WITH_BLUEZ4_TRUE@ nm-bluez4-manager.c
-
-@WITH_BLUEZ4_FALSE@am__append_2 = \
-@WITH_BLUEZ4_FALSE@ nm-bluez-manager.c
-
-subdir = src/bluez-manager
-DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/Makefile.am \
- $(top_srcdir)/build-aux/depcomp
-ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
-am__aclocal_m4_deps = $(top_srcdir)/m4/compiler_warnings.m4 \
- $(top_srcdir)/m4/gettext.m4 \
- $(top_srcdir)/m4/gnome-code-coverage.m4 \
- $(top_srcdir)/m4/gtk-doc.m4 $(top_srcdir)/m4/iconv.m4 \
- $(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/intltool.m4 \
- $(top_srcdir)/m4/introspection.m4 $(top_srcdir)/m4/lib-ld.m4 \
- $(top_srcdir)/m4/lib-link.m4 $(top_srcdir)/m4/lib-prefix.m4 \
- $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \
- $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \
- $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/m4/nls.m4 \
- $(top_srcdir)/m4/po.m4 $(top_srcdir)/m4/progtest.m4 \
- $(top_srcdir)/m4/vapigen.m4 $(top_srcdir)/configure.ac
-am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
- $(ACLOCAL_M4)
-mkinstalldirs = $(install_sh) -d
-CONFIG_HEADER = $(top_builddir)/config.h
-CONFIG_CLEAN_FILES =
-CONFIG_CLEAN_VPATH_FILES =
-LTLIBRARIES = $(noinst_LTLIBRARIES)
-am__DEPENDENCIES_1 =
-libbluez_manager_la_DEPENDENCIES = \
- $(top_builddir)/src/generated/libnm-generated.la \
- $(top_builddir)/src/logging/libnm-logging.la \
- $(am__DEPENDENCIES_1) $(am__DEPENDENCIES_1)
-am__libbluez_manager_la_SOURCES_DIST = nm-bluez-common.h \
- nm-bluez-device.c nm-bluez-device.h nm-bluez-manager.h \
- nm-bluez4-adapter.h nm-bluez4-adapter.c nm-bluez4-manager.c \
- nm-bluez-manager.c
-@WITH_BLUEZ4_TRUE@am__objects_1 = \
-@WITH_BLUEZ4_TRUE@ libbluez_manager_la-nm-bluez4-adapter.lo \
-@WITH_BLUEZ4_TRUE@ libbluez_manager_la-nm-bluez4-manager.lo
-@WITH_BLUEZ4_FALSE@am__objects_2 = \
-@WITH_BLUEZ4_FALSE@ libbluez_manager_la-nm-bluez-manager.lo
-am_libbluez_manager_la_OBJECTS = \
- libbluez_manager_la-nm-bluez-device.lo $(am__objects_1) \
- $(am__objects_2)
-libbluez_manager_la_OBJECTS = $(am_libbluez_manager_la_OBJECTS)
-AM_V_lt = $(am__v_lt_@AM_V@)
-am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@)
-am__v_lt_0 = --silent
-am__v_lt_1 =
-AM_V_P = $(am__v_P_@AM_V@)
-am__v_P_ = $(am__v_P_@AM_DEFAULT_V@)
-am__v_P_0 = false
-am__v_P_1 = :
-AM_V_GEN = $(am__v_GEN_@AM_V@)
-am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@)
-am__v_GEN_0 = @echo " GEN " $@;
-am__v_GEN_1 =
-AM_V_at = $(am__v_at_@AM_V@)
-am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)
-am__v_at_0 = @
-am__v_at_1 =
-DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)
-depcomp = $(SHELL) $(top_srcdir)/build-aux/depcomp
-am__depfiles_maybe = depfiles
-am__mv = mv -f
-COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
- $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
-LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
- $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \
- $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \
- $(AM_CFLAGS) $(CFLAGS)
-AM_V_CC = $(am__v_CC_@AM_V@)
-am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@)
-am__v_CC_0 = @echo " CC " $@;
-am__v_CC_1 =
-CCLD = $(CC)
-LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
- $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
- $(AM_LDFLAGS) $(LDFLAGS) -o $@
-AM_V_CCLD = $(am__v_CCLD_@AM_V@)
-am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@)
-am__v_CCLD_0 = @echo " CCLD " $@;
-am__v_CCLD_1 =
-SOURCES = $(libbluez_manager_la_SOURCES)
-DIST_SOURCES = $(am__libbluez_manager_la_SOURCES_DIST)
-am__can_run_installinfo = \
- case $$AM_UPDATE_INFO_DIR in \
- n|no|NO) false;; \
- *) (install-info --version) >/dev/null 2>&1;; \
- esac
-am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP)
-# Read a list of newline-separated strings from the standard input,
-# and print each of them once, without duplicates. Input order is
-# *not* preserved.
-am__uniquify_input = $(AWK) '\
- BEGIN { nonempty = 0; } \
- { items[$$0] = 1; nonempty = 1; } \
- END { if (nonempty) { for (i in items) print i; }; } \
-'
-# Make sure the list of sources is unique. This is necessary because,
-# e.g., the same source file might be shared among _SOURCES variables
-# for different programs/libraries.
-am__define_uniq_tagged_files = \
- list='$(am__tagged_files)'; \
- unique=`for i in $$list; do \
- if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
- done | $(am__uniquify_input)`
-ETAGS = etags
-CTAGS = ctags
-DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
-ACLOCAL = @ACLOCAL@
-ALL_LINGUAS = @ALL_LINGUAS@
-AMTAR = @AMTAR@
-AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@
-AR = @AR@
-AUTOCONF = @AUTOCONF@
-AUTOHEADER = @AUTOHEADER@
-AUTOMAKE = @AUTOMAKE@
-AWK = @AWK@
-CC = @CC@
-CCDEPMODE = @CCDEPMODE@
-CFLAGS = @CFLAGS@
-CKDB_PATH = @CKDB_PATH@
-CODE_COVERAGE_CFLAGS = @CODE_COVERAGE_CFLAGS@
-CODE_COVERAGE_ENABLED = @CODE_COVERAGE_ENABLED@
-CODE_COVERAGE_LDFLAGS = @CODE_COVERAGE_LDFLAGS@
-CPP = @CPP@
-CPPFLAGS = @CPPFLAGS@
-CXX = @CXX@
-CXXCPP = @CXXCPP@
-CXXDEPMODE = @CXXDEPMODE@
-CXXFLAGS = @CXXFLAGS@
-CYGPATH_W = @CYGPATH_W@
-DATADIRNAME = @DATADIRNAME@
-DBUS_CFLAGS = @DBUS_CFLAGS@
-DBUS_LIBS = @DBUS_LIBS@
-DBUS_SYS_DIR = @DBUS_SYS_DIR@
-DEFS = @DEFS@
-DEPDIR = @DEPDIR@
-DHCLIENT_PATH = @DHCLIENT_PATH@
-DHCPCD_PATH = @DHCPCD_PATH@
-DLLTOOL = @DLLTOOL@
-DNSMASQ_PATH = @DNSMASQ_PATH@
-DSYMUTIL = @DSYMUTIL@
-DUMPBIN = @DUMPBIN@
-ECHO_C = @ECHO_C@
-ECHO_N = @ECHO_N@
-ECHO_T = @ECHO_T@
-EGREP = @EGREP@
-EXEEXT = @EXEEXT@
-FGREP = @FGREP@
-GENHTML = @GENHTML@
-GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@
-GETTEXT_PACKAGE = @GETTEXT_PACKAGE@
-GLIB_CFLAGS = @GLIB_CFLAGS@
-GLIB_GENMARSHAL = @GLIB_GENMARSHAL@
-GLIB_LIBS = @GLIB_LIBS@
-GLIB_MAKEFILE = @GLIB_MAKEFILE@
-GLIB_MKENUMS = @GLIB_MKENUMS@
-GMSGFMT = @GMSGFMT@
-GMSGFMT_015 = @GMSGFMT_015@
-GNUTLS_CFLAGS = @GNUTLS_CFLAGS@
-GNUTLS_LIBS = @GNUTLS_LIBS@
-GREP = @GREP@
-GTKDOC_CHECK = @GTKDOC_CHECK@
-GTKDOC_CHECK_PATH = @GTKDOC_CHECK_PATH@
-GTKDOC_DEPS_CFLAGS = @GTKDOC_DEPS_CFLAGS@
-GTKDOC_DEPS_LIBS = @GTKDOC_DEPS_LIBS@
-GTKDOC_MKPDF = @GTKDOC_MKPDF@
-GTKDOC_REBASE = @GTKDOC_REBASE@
-GUDEV_CFLAGS = @GUDEV_CFLAGS@
-GUDEV_LIBS = @GUDEV_LIBS@
-HTML_DIR = @HTML_DIR@
-INSTALL = @INSTALL@
-INSTALL_DATA = @INSTALL_DATA@
-INSTALL_PROGRAM = @INSTALL_PROGRAM@
-INSTALL_SCRIPT = @INSTALL_SCRIPT@
-INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
-INTLLIBS = @INTLLIBS@
-INTLTOOL_EXTRACT = @INTLTOOL_EXTRACT@
-INTLTOOL_MERGE = @INTLTOOL_MERGE@
-INTLTOOL_PERL = @INTLTOOL_PERL@
-INTLTOOL_UPDATE = @INTLTOOL_UPDATE@
-INTLTOOL_V_MERGE = @INTLTOOL_V_MERGE@
-INTLTOOL_V_MERGE_OPTIONS = @INTLTOOL_V_MERGE_OPTIONS@
-INTLTOOL__v_MERGE_ = @INTLTOOL__v_MERGE_@
-INTLTOOL__v_MERGE_0 = @INTLTOOL__v_MERGE_0@
-INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@
-INTROSPECTION_CFLAGS = @INTROSPECTION_CFLAGS@
-INTROSPECTION_COMPILER = @INTROSPECTION_COMPILER@
-INTROSPECTION_GENERATE = @INTROSPECTION_GENERATE@
-INTROSPECTION_GIRDIR = @INTROSPECTION_GIRDIR@
-INTROSPECTION_LIBS = @INTROSPECTION_LIBS@
-INTROSPECTION_MAKEFILE = @INTROSPECTION_MAKEFILE@
-INTROSPECTION_SCANNER = @INTROSPECTION_SCANNER@
-INTROSPECTION_TYPELIBDIR = @INTROSPECTION_TYPELIBDIR@
-IPTABLES_PATH = @IPTABLES_PATH@
-IWMX_SDK_CFLAGS = @IWMX_SDK_CFLAGS@
-IWMX_SDK_LIBS = @IWMX_SDK_LIBS@
-KERNEL_FIRMWARE_DIR = @KERNEL_FIRMWARE_DIR@
-LCOV = @LCOV@
-LD = @LD@
-LDFLAGS = @LDFLAGS@
-LIBDL = @LIBDL@
-LIBGCRYPT_CFLAGS = @LIBGCRYPT_CFLAGS@
-LIBGCRYPT_CONFIG = @LIBGCRYPT_CONFIG@
-LIBGCRYPT_LIBS = @LIBGCRYPT_LIBS@
-LIBICONV = @LIBICONV@
-LIBINTL = @LIBINTL@
-LIBM = @LIBM@
-LIBNL_CFLAGS = @LIBNL_CFLAGS@
-LIBNL_LIBS = @LIBNL_LIBS@
-LIBOBJS = @LIBOBJS@
-LIBS = @LIBS@
-LIBSOUP_CFLAGS = @LIBSOUP_CFLAGS@
-LIBSOUP_LIBS = @LIBSOUP_LIBS@
-LIBTOOL = @LIBTOOL@
-LIPO = @LIPO@
-LN_S = @LN_S@
-LTLIBICONV = @LTLIBICONV@
-LTLIBINTL = @LTLIBINTL@
-LTLIBOBJS = @LTLIBOBJS@
-MAINT = @MAINT@
-MAKEINFO = @MAKEINFO@
-MANIFEST_TOOL = @MANIFEST_TOOL@
-MKDIR_P = @MKDIR_P@
-MM_GLIB_CFLAGS = @MM_GLIB_CFLAGS@
-MM_GLIB_LIBS = @MM_GLIB_LIBS@
-MOC = @MOC@
-MSGFMT = @MSGFMT@
-MSGFMT_015 = @MSGFMT_015@
-MSGMERGE = @MSGMERGE@
-NM = @NM@
-NMEDIT = @NMEDIT@
-NM_MAJOR_VERSION = @NM_MAJOR_VERSION@
-NM_MICRO_VERSION = @NM_MICRO_VERSION@
-NM_MINOR_VERSION = @NM_MINOR_VERSION@
-NM_MODIFY_SYSTEM_POLICY = @NM_MODIFY_SYSTEM_POLICY@
-NM_VERSION = @NM_VERSION@
-NSS_CFLAGS = @NSS_CFLAGS@
-NSS_LIBS = @NSS_LIBS@
-OBJDUMP = @OBJDUMP@
-OBJEXT = @OBJEXT@
-OTOOL = @OTOOL@
-OTOOL64 = @OTOOL64@
-PACKAGE = @PACKAGE@
-PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
-PACKAGE_NAME = @PACKAGE_NAME@
-PACKAGE_STRING = @PACKAGE_STRING@
-PACKAGE_TARNAME = @PACKAGE_TARNAME@
-PACKAGE_URL = @PACKAGE_URL@
-PACKAGE_VERSION = @PACKAGE_VERSION@
-PATH_SEPARATOR = @PATH_SEPARATOR@
-PKG_CONFIG = @PKG_CONFIG@
-PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@
-PKG_CONFIG_PATH = @PKG_CONFIG_PATH@
-POLKIT_CFLAGS = @POLKIT_CFLAGS@
-POLKIT_LIBS = @POLKIT_LIBS@
-POSUB = @POSUB@
-PPPD_PLUGIN_DIR = @PPPD_PLUGIN_DIR@
-QT_CFLAGS = @QT_CFLAGS@
-QT_LIBS = @QT_LIBS@
-RANLIB = @RANLIB@
-SED = @SED@
-SET_MAKE = @SET_MAKE@
-SHELL = @SHELL@
-STRIP = @STRIP@
-SYSTEMD_200_CFLAGS = @SYSTEMD_200_CFLAGS@
-SYSTEMD_200_LIBS = @SYSTEMD_200_LIBS@
-SYSTEMD_INHIBIT_CFLAGS = @SYSTEMD_INHIBIT_CFLAGS@
-SYSTEMD_INHIBIT_LIBS = @SYSTEMD_INHIBIT_LIBS@
-SYSTEMD_LOGIN_CFLAGS = @SYSTEMD_LOGIN_CFLAGS@
-SYSTEMD_LOGIN_LIBS = @SYSTEMD_LOGIN_LIBS@
-SYSTEM_CA_PATH = @SYSTEM_CA_PATH@
-UDEV_BASE_DIR = @UDEV_BASE_DIR@
-USE_NLS = @USE_NLS@
-UUID_CFLAGS = @UUID_CFLAGS@
-UUID_LIBS = @UUID_LIBS@
-VAPIGEN = @VAPIGEN@
-VAPIGEN_MAKEFILE = @VAPIGEN_MAKEFILE@
-VAPIGEN_VAPIDIR = @VAPIGEN_VAPIDIR@
-VERSION = @VERSION@
-XGETTEXT = @XGETTEXT@
-XGETTEXT_015 = @XGETTEXT_015@
-XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@
-abs_builddir = @abs_builddir@
-abs_srcdir = @abs_srcdir@
-abs_top_builddir = @abs_top_builddir@
-abs_top_srcdir = @abs_top_srcdir@
-ac_ct_AR = @ac_ct_AR@
-ac_ct_CC = @ac_ct_CC@
-ac_ct_CXX = @ac_ct_CXX@
-ac_ct_DUMPBIN = @ac_ct_DUMPBIN@
-am__include = @am__include@
-am__leading_dot = @am__leading_dot@
-am__quote = @am__quote@
-am__tar = @am__tar@
-am__untar = @am__untar@
-bindir = @bindir@
-build = @build@
-build_alias = @build_alias@
-build_cpu = @build_cpu@
-build_os = @build_os@
-build_vendor = @build_vendor@
-builddir = @builddir@
-datadir = @datadir@
-datarootdir = @datarootdir@
-docdir = @docdir@
-dvidir = @dvidir@
-exec_prefix = @exec_prefix@
-host = @host@
-host_alias = @host_alias@
-host_cpu = @host_cpu@
-host_os = @host_os@
-host_vendor = @host_vendor@
-htmldir = @htmldir@
-includedir = @includedir@
-infodir = @infodir@
-install_sh = @install_sh@
-intltool__v_merge_options_ = @intltool__v_merge_options_@
-intltool__v_merge_options_0 = @intltool__v_merge_options_0@
-libdir = @libdir@
-libexecdir = @libexecdir@
-localedir = @localedir@
-localstatedir = @localstatedir@
-mandir = @mandir@
-mkdir_p = @mkdir_p@
-nmbinary = @nmbinary@
-nmconfdir = @nmconfdir@
-nmdatadir = @nmdatadir@
-nmrundir = @nmrundir@
-nmstatedir = @nmstatedir@
-oldincludedir = @oldincludedir@
-pdfdir = @pdfdir@
-prefix = @prefix@
-program_transform_name = @program_transform_name@
-psdir = @psdir@
-sbindir = @sbindir@
-sharedstatedir = @sharedstatedir@
-srcdir = @srcdir@
-sysconfdir = @sysconfdir@
-systemdsystemunitdir = @systemdsystemunitdir@
-target_alias = @target_alias@
-top_build_prefix = @top_build_prefix@
-top_builddir = @top_builddir@
-top_srcdir = @top_srcdir@
-with_dhclient = @with_dhclient@
-with_dhcpcd = @with_dhcpcd@
-with_netconfig = @with_netconfig@
-with_resolvconf = @with_resolvconf@
-noinst_LTLIBRARIES = libbluez-manager.la
-libbluez_manager_la_CPPFLAGS = \
- -I${top_srcdir} \
- -I${top_builddir}/include \
- -I${top_srcdir}/include \
- -I${top_builddir}/libnm-util \
- -I${top_srcdir}/libnm-util \
- -I${top_srcdir}/src \
- -I${top_builddir}/src/generated \
- -I${top_srcdir}/src/generated \
- -I${top_srcdir}/src/logging \
- $(DBUS_CFLAGS) \
- $(GLIB_CFLAGS) \
- $(BLUEZ_CFLAGS) \
- -DBINDIR=\"$(bindir)\" \
- -DDATADIR=\"$(datadir)\" \
- -DSYSCONFDIR=\"$(sysconfdir)\" \
- -DLIBEXECDIR=\"$(libexecdir)\" \
- -DLOCALSTATEDIR=\"$(localstatedir)\"
-
-libbluez_manager_la_SOURCES = nm-bluez-common.h nm-bluez-device.c \
- nm-bluez-device.h nm-bluez-manager.h $(am__append_1) \
- $(am__append_2)
-libbluez_manager_la_LIBADD = \
- $(top_builddir)/src/generated/libnm-generated.la \
- $(top_builddir)/src/logging/libnm-logging.la \
- $(DBUS_LIBS) \
- $(GLIB_LIBS) \
- $(BLUEZ_LIBS)
-
-all: all-am
-
-.SUFFIXES:
-.SUFFIXES: .c .lo .o .obj
-$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.am $(am__configure_deps)
- @for dep in $?; do \
- case '$(am__configure_deps)' in \
- *$$dep*) \
- ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \
- && { if test -f $@; then exit 0; else break; fi; }; \
- exit 1;; \
- esac; \
- done; \
- echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/bluez-manager/Makefile'; \
- $(am__cd) $(top_srcdir) && \
- $(AUTOMAKE) --gnu src/bluez-manager/Makefile
-.PRECIOUS: Makefile
-Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
- @case '$?' in \
- *config.status*) \
- cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
- *) \
- echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
- cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
- esac;
-
-$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
- cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
-
-$(top_srcdir)/configure: @MAINTAINER_MODE_TRUE@ $(am__configure_deps)
- cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
-$(ACLOCAL_M4): @MAINTAINER_MODE_TRUE@ $(am__aclocal_m4_deps)
- cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
-$(am__aclocal_m4_deps):
-
-clean-noinstLTLIBRARIES:
- -test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES)
- @list='$(noinst_LTLIBRARIES)'; \
- locs=`for p in $$list; do echo $$p; done | \
- sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \
- sort -u`; \
- test -z "$$locs" || { \
- echo rm -f $${locs}; \
- rm -f $${locs}; \
- }
-
-libbluez-manager.la: $(libbluez_manager_la_OBJECTS) $(libbluez_manager_la_DEPENDENCIES) $(EXTRA_libbluez_manager_la_DEPENDENCIES)
- $(AM_V_CCLD)$(LINK) $(libbluez_manager_la_OBJECTS) $(libbluez_manager_la_LIBADD) $(LIBS)
-
-mostlyclean-compile:
- -rm -f *.$(OBJEXT)
-
-distclean-compile:
- -rm -f *.tab.c
-
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libbluez_manager_la-nm-bluez-device.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libbluez_manager_la-nm-bluez-manager.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libbluez_manager_la-nm-bluez4-adapter.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libbluez_manager_la-nm-bluez4-manager.Plo@am__quote@
-
-.c.o:
-@am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
-@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
-@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
-@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
-@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c $<
-
-.c.obj:
-@am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'`
-@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
-@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
-@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
-@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c `$(CYGPATH_W) '$<'`
-
-.c.lo:
-@am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
-@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo
-@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
-@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
-@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $<
-
-libbluez_manager_la-nm-bluez-device.lo: nm-bluez-device.c
-@am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libbluez_manager_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libbluez_manager_la-nm-bluez-device.lo -MD -MP -MF $(DEPDIR)/libbluez_manager_la-nm-bluez-device.Tpo -c -o libbluez_manager_la-nm-bluez-device.lo `test -f 'nm-bluez-device.c' || echo '$(srcdir)/'`nm-bluez-device.c
-@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libbluez_manager_la-nm-bluez-device.Tpo $(DEPDIR)/libbluez_manager_la-nm-bluez-device.Plo
-@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='nm-bluez-device.c' object='libbluez_manager_la-nm-bluez-device.lo' libtool=yes @AMDEPBACKSLASH@
-@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
-@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libbluez_manager_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libbluez_manager_la-nm-bluez-device.lo `test -f 'nm-bluez-device.c' || echo '$(srcdir)/'`nm-bluez-device.c
-
-libbluez_manager_la-nm-bluez4-adapter.lo: nm-bluez4-adapter.c
-@am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libbluez_manager_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libbluez_manager_la-nm-bluez4-adapter.lo -MD -MP -MF $(DEPDIR)/libbluez_manager_la-nm-bluez4-adapter.Tpo -c -o libbluez_manager_la-nm-bluez4-adapter.lo `test -f 'nm-bluez4-adapter.c' || echo '$(srcdir)/'`nm-bluez4-adapter.c
-@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libbluez_manager_la-nm-bluez4-adapter.Tpo $(DEPDIR)/libbluez_manager_la-nm-bluez4-adapter.Plo
-@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='nm-bluez4-adapter.c' object='libbluez_manager_la-nm-bluez4-adapter.lo' libtool=yes @AMDEPBACKSLASH@
-@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
-@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libbluez_manager_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libbluez_manager_la-nm-bluez4-adapter.lo `test -f 'nm-bluez4-adapter.c' || echo '$(srcdir)/'`nm-bluez4-adapter.c
-
-libbluez_manager_la-nm-bluez4-manager.lo: nm-bluez4-manager.c
-@am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libbluez_manager_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libbluez_manager_la-nm-bluez4-manager.lo -MD -MP -MF $(DEPDIR)/libbluez_manager_la-nm-bluez4-manager.Tpo -c -o libbluez_manager_la-nm-bluez4-manager.lo `test -f 'nm-bluez4-manager.c' || echo '$(srcdir)/'`nm-bluez4-manager.c
-@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libbluez_manager_la-nm-bluez4-manager.Tpo $(DEPDIR)/libbluez_manager_la-nm-bluez4-manager.Plo
-@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='nm-bluez4-manager.c' object='libbluez_manager_la-nm-bluez4-manager.lo' libtool=yes @AMDEPBACKSLASH@
-@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
-@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libbluez_manager_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libbluez_manager_la-nm-bluez4-manager.lo `test -f 'nm-bluez4-manager.c' || echo '$(srcdir)/'`nm-bluez4-manager.c
-
-libbluez_manager_la-nm-bluez-manager.lo: nm-bluez-manager.c
-@am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libbluez_manager_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT libbluez_manager_la-nm-bluez-manager.lo -MD -MP -MF $(DEPDIR)/libbluez_manager_la-nm-bluez-manager.Tpo -c -o libbluez_manager_la-nm-bluez-manager.lo `test -f 'nm-bluez-manager.c' || echo '$(srcdir)/'`nm-bluez-manager.c
-@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/libbluez_manager_la-nm-bluez-manager.Tpo $(DEPDIR)/libbluez_manager_la-nm-bluez-manager.Plo
-@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='nm-bluez-manager.c' object='libbluez_manager_la-nm-bluez-manager.lo' libtool=yes @AMDEPBACKSLASH@
-@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
-@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(libbluez_manager_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o libbluez_manager_la-nm-bluez-manager.lo `test -f 'nm-bluez-manager.c' || echo '$(srcdir)/'`nm-bluez-manager.c
-
-mostlyclean-libtool:
- -rm -f *.lo
-
-clean-libtool:
- -rm -rf .libs _libs
-
-ID: $(am__tagged_files)
- $(am__define_uniq_tagged_files); mkid -fID $$unique
-tags: tags-am
-TAGS: tags
-
-tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
- set x; \
- here=`pwd`; \
- $(am__define_uniq_tagged_files); \
- shift; \
- if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \
- test -n "$$unique" || unique=$$empty_fix; \
- if test $$# -gt 0; then \
- $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
- "$$@" $$unique; \
- else \
- $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
- $$unique; \
- fi; \
- fi
-ctags: ctags-am
-
-CTAGS: ctags
-ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
- $(am__define_uniq_tagged_files); \
- test -z "$(CTAGS_ARGS)$$unique" \
- || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
- $$unique
-
-GTAGS:
- here=`$(am__cd) $(top_builddir) && pwd` \
- && $(am__cd) $(top_srcdir) \
- && gtags -i $(GTAGS_ARGS) "$$here"
-cscopelist: cscopelist-am
-
-cscopelist-am: $(am__tagged_files)
- list='$(am__tagged_files)'; \
- case "$(srcdir)" in \
- [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \
- *) sdir=$(subdir)/$(srcdir) ;; \
- esac; \
- for i in $$list; do \
- if test -f "$$i"; then \
- echo "$(subdir)/$$i"; \
- else \
- echo "$$sdir/$$i"; \
- fi; \
- done >> $(top_builddir)/cscope.files
-
-distclean-tags:
- -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
-
-distdir: $(DISTFILES)
- @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
- topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
- list='$(DISTFILES)'; \
- dist_files=`for file in $$list; do echo $$file; done | \
- sed -e "s|^$$srcdirstrip/||;t" \
- -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \
- case $$dist_files in \
- */*) $(MKDIR_P) `echo "$$dist_files" | \
- sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \
- sort -u` ;; \
- esac; \
- for file in $$dist_files; do \
- if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
- if test -d $$d/$$file; then \
- dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
- if test -d "$(distdir)/$$file"; then \
- find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
- fi; \
- if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
- cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \
- find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
- fi; \
- cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \
- else \
- test -f "$(distdir)/$$file" \
- || cp -p $$d/$$file "$(distdir)/$$file" \
- || exit 1; \
- fi; \
- done
-check-am: all-am
-check: check-am
-all-am: Makefile $(LTLIBRARIES)
-installdirs:
-install: install-am
-install-exec: install-exec-am
-install-data: install-data-am
-uninstall: uninstall-am
-
-install-am: all-am
- @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
-
-installcheck: installcheck-am
-install-strip:
- if test -z '$(STRIP)'; then \
- $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
- install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
- install; \
- else \
- $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
- install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
- "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \
- fi
-mostlyclean-generic:
-
-clean-generic:
-
-distclean-generic:
- -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
- -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES)
-
-maintainer-clean-generic:
- @echo "This command is intended for maintainers to use"
- @echo "it deletes files that may require special tools to rebuild."
-clean: clean-am
-
-clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \
- mostlyclean-am
-
-distclean: distclean-am
- -rm -rf ./$(DEPDIR)
- -rm -f Makefile
-distclean-am: clean-am distclean-compile distclean-generic \
- distclean-tags
-
-dvi: dvi-am
-
-dvi-am:
-
-html: html-am
-
-html-am:
-
-info: info-am
-
-info-am:
-
-install-data-am:
-
-install-dvi: install-dvi-am
-
-install-dvi-am:
-
-install-exec-am:
-
-install-html: install-html-am
-
-install-html-am:
-
-install-info: install-info-am
-
-install-info-am:
-
-install-man:
-
-install-pdf: install-pdf-am
-
-install-pdf-am:
-
-install-ps: install-ps-am
-
-install-ps-am:
-
-installcheck-am:
-
-maintainer-clean: maintainer-clean-am
- -rm -rf ./$(DEPDIR)
- -rm -f Makefile
-maintainer-clean-am: distclean-am maintainer-clean-generic
-
-mostlyclean: mostlyclean-am
-
-mostlyclean-am: mostlyclean-compile mostlyclean-generic \
- mostlyclean-libtool
-
-pdf: pdf-am
-
-pdf-am:
-
-ps: ps-am
-
-ps-am:
-
-uninstall-am:
-
-.MAKE: install-am install-strip
-
-.PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \
- clean-libtool clean-noinstLTLIBRARIES cscopelist-am ctags \
- ctags-am distclean distclean-compile distclean-generic \
- distclean-libtool distclean-tags distdir dvi dvi-am html \
- html-am info info-am install install-am install-data \
- install-data-am install-dvi install-dvi-am install-exec \
- install-exec-am install-html install-html-am install-info \
- install-info-am install-man install-pdf install-pdf-am \
- install-ps install-ps-am install-strip installcheck \
- installcheck-am installdirs maintainer-clean \
- maintainer-clean-generic mostlyclean mostlyclean-compile \
- mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \
- tags tags-am uninstall uninstall-am
-
-
-# Tell versions [3.59,3.63) of GNU make to not export all variables.
-# Otherwise a system limit (for SysV at least) may be exceeded.
-.NOEXPORT:
diff --git a/src/bluez-manager/nm-bluez-common.h b/src/bluez-manager/nm-bluez-common.h
deleted file mode 100644
index ecc4d7094..000000000
--- a/src/bluez-manager/nm-bluez-common.h
+++ /dev/null
@@ -1,51 +0,0 @@
-/* -*- Mode: C; tab-width: 4; indent-tabs-mode: t; c-basic-offset: 4 -*- */
-/* NetworkManager -- Network link manager
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License along
- * with this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
- *
- * Copyright (C) 2009 Red Hat, Inc.
- */
-
-#ifndef NM_BLUEZ_COMMON_H
-#define NM_BLUEZ_COMMON_H
-
-#include <config.h>
-
-#define BLUETOOTH_CONNECT_DUN "dun"
-#define BLUETOOTH_CONNECT_NAP "nap"
-
-#define BLUEZ_SERVICE "org.bluez"
-
-#define BLUEZ_MANAGER_PATH "/"
-#define OBJECT_MANAGER_INTERFACE "org.freedesktop.DBus.ObjectManager"
-
-#if ! WITH_BLUEZ4
-
-#define BLUEZ_ADAPTER_INTERFACE "org.bluez.Adapter1"
-#define BLUEZ_DEVICE_INTERFACE "org.bluez.Device1"
-#define BLUEZ_NETWORK_INTERFACE "org.bluez.Network1"
-
-#else
-
-#define BLUEZ_MANAGER_INTERFACE "org.bluez.Manager"
-#define BLUEZ_ADAPTER_INTERFACE "org.bluez.Adapter"
-#define BLUEZ_DEVICE_INTERFACE "org.bluez.Device"
-#define BLUEZ_SERIAL_INTERFACE "org.bluez.Serial"
-#define BLUEZ_NETWORK_INTERFACE "org.bluez.Network"
-
-#endif /* WITH_BLUEZ */
-
-#endif /* NM_BLUEZ_COMMON_H */
-
diff --git a/src/bluez-manager/nm-bluez-device.c b/src/bluez-manager/nm-bluez-device.c
deleted file mode 100644
index ed5e345d2..000000000
--- a/src/bluez-manager/nm-bluez-device.c
+++ /dev/null
@@ -1,1223 +0,0 @@
-/* -*- Mode: C; tab-width: 4; indent-tabs-mode: t; c-basic-offset: 4 -*- */
-/* NetworkManager -- Network link manager
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License along
- * with this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
- *
- * Copyright (C) 2009 - 2012 Red Hat, Inc.
- * Copyright (C) 2013 Intel Corporation.
- */
-
-#include <glib.h>
-#include <glib/gi18n.h>
-#include <gio/gio.h>
-#include <string.h>
-#include <net/ethernet.h>
-#include <netinet/ether.h>
-
-#include "NetworkManager.h"
-#include "nm-setting-bluetooth.h"
-
-#include "nm-bluez-common.h"
-#if WITH_BLUEZ4
-#include "nm-dbus-manager.h"
-#include "nm-dbus-glib-types.h"
-#endif
-#include "nm-bluez-device.h"
-#include "nm-logging.h"
-#include "nm-marshal.h"
-#include "nm-utils.h"
-
-
-G_DEFINE_TYPE (NMBluezDevice, nm_bluez_device, G_TYPE_OBJECT)
-
-#define NM_BLUEZ_DEVICE_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), NM_TYPE_BLUEZ_DEVICE, NMBluezDevicePrivate))
-
-typedef struct {
- char *path;
- GDBusConnection *dbus_connection;
-#if ! WITH_BLUEZ4
- GDBusProxy *proxy5;
- GDBusProxy *adapter;
- gboolean adapter_powered;
-#else
- DBusGProxy *proxy4;
-#endif
-
- gboolean initialized;
- gboolean usable;
- NMBluetoothCapabilities connection_bt_type;
-
- char *address;
- guint8 bin_address[ETH_ALEN];
- char *name;
- guint32 capabilities;
- gint rssi;
- gboolean connected;
-
- char *bt_iface;
-
- NMConnectionProvider *provider;
- GSList *connections;
-
- NMConnection *pan_connection;
- gboolean pan_connection_no_autocreate;
-} NMBluezDevicePrivate;
-
-
-enum {
- PROP_0,
- PROP_PATH,
- PROP_ADDRESS,
- PROP_NAME,
- PROP_CAPABILITIES,
- PROP_RSSI,
- PROP_USABLE,
- PROP_CONNECTED,
-
- LAST_PROP
-};
-
-/* Signals */
-enum {
- INITIALIZED,
- LAST_SIGNAL
-};
-static guint signals[LAST_SIGNAL] = { 0 };
-
-
-static void cp_connection_added (NMConnectionProvider *provider,
- NMConnection *connection, NMBluezDevice *self);
-static gboolean connection_compatible (NMBluezDevice *self, NMConnection *connection);
-
-
-/***********************************************************/
-
-const char *
-nm_bluez_device_get_path (NMBluezDevice *self)
-{
- g_return_val_if_fail (NM_IS_BLUEZ_DEVICE (self), NULL);
-
- return NM_BLUEZ_DEVICE_GET_PRIVATE (self)->path;
-}
-
-const char *
-nm_bluez_device_get_address (NMBluezDevice *self)
-{
- g_return_val_if_fail (NM_IS_BLUEZ_DEVICE (self), NULL);
-
- return NM_BLUEZ_DEVICE_GET_PRIVATE (self)->address;
-}
-
-gboolean
-nm_bluez_device_get_initialized (NMBluezDevice *self)
-{
- g_return_val_if_fail (NM_IS_BLUEZ_DEVICE (self), FALSE);
-
- return NM_BLUEZ_DEVICE_GET_PRIVATE (self)->initialized;
-}
-
-gboolean
-nm_bluez_device_get_usable (NMBluezDevice *self)
-{
- g_return_val_if_fail (NM_IS_BLUEZ_DEVICE (self), FALSE);
-
- return NM_BLUEZ_DEVICE_GET_PRIVATE (self)->usable;
-}
-
-const char *
-nm_bluez_device_get_name (NMBluezDevice *self)
-{
- g_return_val_if_fail (NM_IS_BLUEZ_DEVICE (self), NULL);
-
- return NM_BLUEZ_DEVICE_GET_PRIVATE (self)->name;
-}
-
-guint32
-nm_bluez_device_get_capabilities (NMBluezDevice *self)
-{
- g_return_val_if_fail (NM_IS_BLUEZ_DEVICE (self), 0);
-
- return NM_BLUEZ_DEVICE_GET_PRIVATE (self)->capabilities;
-}
-
-gint
-nm_bluez_device_get_rssi (NMBluezDevice *self)
-{
- g_return_val_if_fail (NM_IS_BLUEZ_DEVICE (self), 0);
-
- return NM_BLUEZ_DEVICE_GET_PRIVATE (self)->rssi;
-}
-
-gboolean
-nm_bluez_device_get_connected (NMBluezDevice *self)
-{
- g_return_val_if_fail (NM_IS_BLUEZ_DEVICE (self), FALSE);
-
- return NM_BLUEZ_DEVICE_GET_PRIVATE (self)->connected;
-}
-
-static void
-pan_connection_check_create (NMBluezDevice *self)
-{
- NMConnection *connection;
- NMConnection *added;
- NMSetting *setting;
- char *uuid, *id;
- GByteArray *bdaddr_array;
- GError *error = NULL;
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
-
- g_return_if_fail (priv->capabilities & NM_BT_CAPABILITY_NAP);
- g_return_if_fail (priv->connections == NULL);
- g_return_if_fail (priv->name);
-
- if (priv->pan_connection || priv->pan_connection_no_autocreate) {
- /* already have a connection or we don't want to create one, nothing to do. */
- return;
- }
-
- if (!nm_connection_provider_has_connections_loaded (priv->provider)) {
- /* do not try to create any connections until the connection provider is ready. */
- return;
- }
-
- /* Only try once to create a connection. If it does not succeed, we do not try again. Also,
- * if the connection gets deleted later, do not create another one for this device. */
- priv->pan_connection_no_autocreate = TRUE;
-
- /* create a new connection */
-
- connection = nm_connection_new ();
-
- /* Setting: Connection */
- uuid = nm_utils_uuid_generate ();
- id = g_strdup_printf (_("%s Network"), priv->name);
- setting = nm_setting_connection_new ();
- g_object_set (setting,
- NM_SETTING_CONNECTION_ID, id,
- NM_SETTING_CONNECTION_UUID, uuid,
- NM_SETTING_CONNECTION_AUTOCONNECT, FALSE,
- NM_SETTING_CONNECTION_TYPE, NM_SETTING_BLUETOOTH_SETTING_NAME,
- NULL);
- nm_connection_add_setting (connection, setting);
-
- /* Setting: Bluetooth */
- bdaddr_array = g_byte_array_sized_new (sizeof (priv->bin_address));
- g_byte_array_append (bdaddr_array, priv->bin_address, sizeof (priv->bin_address));
- setting = nm_setting_bluetooth_new ();
- g_object_set (G_OBJECT (setting),
- NM_SETTING_BLUETOOTH_BDADDR, bdaddr_array,
- NM_SETTING_BLUETOOTH_TYPE, NM_SETTING_BLUETOOTH_TYPE_PANU,
- NULL);
- nm_connection_add_setting (connection, setting);
- g_byte_array_free (bdaddr_array, TRUE);
-
- /* Setting: IPv4 */
- setting = nm_setting_ip4_config_new ();
- g_object_set (G_OBJECT (setting),
- NM_SETTING_IP4_CONFIG_METHOD, NM_SETTING_IP4_CONFIG_METHOD_AUTO,
- NM_SETTING_IP4_CONFIG_MAY_FAIL, FALSE,
- NULL);
- nm_connection_add_setting (connection, setting);
-
- /* Setting: IPv6 */
- setting = nm_setting_ip6_config_new ();
- g_object_set (G_OBJECT (setting),
- NM_SETTING_IP6_CONFIG_METHOD, NM_SETTING_IP6_CONFIG_METHOD_AUTO,
- NM_SETTING_IP6_CONFIG_MAY_FAIL, TRUE,
- NULL);
- nm_connection_add_setting (connection, setting);
-
- /* Adding a new connection raises a signal which eventually calls check_emit_usable (again)
- * which then already finds the suitable connection in priv->connections. This is confusing,
- * so block the signal. check_emit_usable will succeed after this function call returns. */
- g_signal_handlers_block_by_func (priv->provider, cp_connection_added, self);
- added = nm_connection_provider_add_connection (priv->provider, connection, &error);
- g_signal_handlers_unblock_by_func (priv->provider, cp_connection_added, self);
-
- if (added) {
- g_assert (!g_slist_find (priv->connections, added));
- g_assert (connection_compatible (self, added));
-
- priv->connections = g_slist_prepend (priv->connections, g_object_ref (added));
- priv->pan_connection = added;
- nm_log_dbg (LOGD_SETTINGS, "added new Bluetooth connection for NAP device '%s': '%s' (%s)", priv->path, id, uuid);
- } else {
- nm_log_warn (LOGD_SETTINGS, "couldn't add new Bluetooth connection for NAP device '%s': '%s' (%s): %d / %s",
- priv->path, id, uuid, error ? error->code : -1,
- (error && error->message) ? error->message : "(unknown)");
- g_clear_error (&error);
- }
-
- g_object_unref (connection);
- g_free (id);
- g_free (uuid);
-}
-
-static void
-check_emit_usable (NMBluezDevice *self)
-{
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
- gboolean new_usable;
-
- /* only expect the supported capabilities set. */
- g_assert ((priv->capabilities & ~( NM_BT_CAPABILITY_NAP
-#if WITH_BLUEZ4
- | NM_BT_CAPABILITY_DUN
-#endif
- )) == NM_BT_CAPABILITY_NONE);
-
- new_usable = (priv->initialized && priv->capabilities && priv->name &&
-#if ! WITH_BLUEZ4
- priv->adapter && priv->adapter_powered &&
-#endif
- priv->dbus_connection && priv->address);
-
- if (!new_usable)
- goto END;
-
- if (priv->connections)
- goto END;
-
- if (!(priv->capabilities & NM_BT_CAPABILITY_NAP)) {
- /* non NAP devices are only usable, if they already have a connection. */
- new_usable = FALSE;
- goto END;
- }
-
- pan_connection_check_create (self);
- new_usable = !!priv->pan_connection;
-
-END:
- if (new_usable != priv->usable) {
- priv->usable = new_usable;
- g_object_notify (G_OBJECT (self), NM_BLUEZ_DEVICE_USABLE);
- }
-}
-
-/********************************************************************/
-
-static gboolean
-connection_compatible (NMBluezDevice *self, NMConnection *connection)
-{
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
- NMSettingBluetooth *s_bt;
- const char *bt_type;
- const GByteArray *bdaddr;
-
- if (!nm_connection_is_type (connection, NM_SETTING_BLUETOOTH_SETTING_NAME))
- return FALSE;
-
- s_bt = nm_connection_get_setting_bluetooth (connection);
- if (!s_bt)
- return FALSE;
-
- if (!priv->address) {
- /* unless address is set, bin_address is not initialized. */
- return FALSE;
- }
- bdaddr = nm_setting_bluetooth_get_bdaddr (s_bt);
- if (!bdaddr || bdaddr->len != ETH_ALEN)
- return FALSE;
- if (memcmp (bdaddr->data, priv->bin_address, ETH_ALEN) != 0)
- return FALSE;
-
- bt_type = nm_setting_bluetooth_get_connection_type (s_bt);
- if ( g_str_equal (bt_type, NM_SETTING_BLUETOOTH_TYPE_DUN)
- && !(priv->capabilities & NM_BT_CAPABILITY_DUN))
- return FALSE;
-
- if ( g_str_equal (bt_type, NM_SETTING_BLUETOOTH_TYPE_PANU)
- && !(priv->capabilities & NM_BT_CAPABILITY_NAP))
- return FALSE;
-
- return TRUE;
-}
-
-static void
-_internal_add_connection (NMBluezDevice *self, NMConnection *connection)
-{
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
-
- if (!g_slist_find (priv->connections, connection)) {
- priv->connections = g_slist_prepend (priv->connections, g_object_ref (connection));
- check_emit_usable (self);
- }
-}
-
-static void
-cp_connection_added (NMConnectionProvider *provider,
- NMConnection *connection,
- NMBluezDevice *self)
-{
- if (connection_compatible (self, connection))
- _internal_add_connection (self, connection);
-}
-
-static void
-cp_connection_removed (NMConnectionProvider *provider,
- NMConnection *connection,
- NMBluezDevice *self)
-{
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
-
- if (g_slist_find (priv->connections, connection)) {
- priv->connections = g_slist_remove (priv->connections, connection);
- if (priv->pan_connection == connection) {
- priv->pan_connection = NULL;
- }
- g_object_unref (connection);
- check_emit_usable (self);
- }
-}
-
-static void
-cp_connection_updated (NMConnectionProvider *provider,
- NMConnection *connection,
- NMBluezDevice *self)
-{
- if (connection_compatible (self, connection))
- _internal_add_connection (self, connection);
- else
- cp_connection_removed (provider, connection, self);
-}
-
-static void
-cp_connections_loaded (NMConnectionProvider *provider, NMBluezDevice *self)
-{
- const GSList *connections, *iter;
-
- connections = nm_connection_provider_get_connections (provider);
- for (iter = connections; iter; iter = g_slist_next (iter))
- cp_connection_added (provider, NM_CONNECTION (iter->data), self);
-}
-
-/***********************************************************/
-
-static void
-bluez_disconnect_cb (GDBusConnection *dbus_connection,
- GAsyncResult *res,
- gpointer user_data)
-{
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (user_data);
- GError *error = NULL;
- GVariant *variant;
-
- variant = g_dbus_connection_call_finish (dbus_connection, res, &error);
- if (!variant) {
- nm_log_warn (LOGD_BT, "%s: failed to disconnect: %s", priv->address, error->message);
- g_error_free (error);
- } else
- g_variant_unref (variant);
-}
-
-void
-nm_bluez_device_disconnect (NMBluezDevice *self)
-{
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
- GVariant *args = NULL;
- const char *dbus_iface = BLUEZ_NETWORK_INTERFACE;
-
- g_return_if_fail (priv->dbus_connection);
-
-#if ! WITH_BLUEZ4
- g_return_if_fail (priv->connection_bt_type == NM_BT_CAPABILITY_NAP);
-#else
- g_return_if_fail (priv->connection_bt_type == NM_BT_CAPABILITY_NAP || priv->connection_bt_type == NM_BT_CAPABILITY_DUN);
-
- if (priv->connection_bt_type == NM_BT_CAPABILITY_DUN) {
- /* Can't pass a NULL interface name through dbus to bluez, so just
- * ignore the disconnect if the interface isn't known.
- */
- if (!priv->bt_iface)
- return;
-
- args = g_variant_new ("(s)", priv->bt_iface),
- dbus_iface = BLUEZ_SERIAL_INTERFACE;
- }
-#endif
-
- g_dbus_connection_call (priv->dbus_connection,
- BLUEZ_SERVICE,
- priv->path,
- dbus_iface,
- "Disconnect",
- args ? args : g_variant_new ("()"),
- NULL,
- G_DBUS_CALL_FLAGS_NONE,
- 10000,
- NULL,
- (GAsyncReadyCallback) bluez_disconnect_cb,
- self);
-
- priv->connection_bt_type = NM_BT_CAPABILITY_NONE;
-}
-
-static void
-bluez_connect_cb (GDBusConnection *dbus_connection,
- GAsyncResult *res,
- gpointer user_data)
-{
- GSimpleAsyncResult *result = G_SIMPLE_ASYNC_RESULT (user_data);
- GObject *result_object = g_async_result_get_source_object (G_ASYNC_RESULT (result));
- NMBluezDevice *self = NM_BLUEZ_DEVICE (result_object);
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
- GError *error = NULL;
- char *device;
- GVariant *variant;
-
- variant = g_dbus_connection_call_finish (dbus_connection, res, &error);
-
- if (!variant) {
- g_simple_async_result_take_error (result, error);
- } else {
- g_variant_get (variant, "(s)", &device);
-
- g_simple_async_result_set_op_res_gpointer (result,
- g_strdup (device),
- g_free);
- priv->bt_iface = device;
- g_variant_unref (variant);
- }
-
- g_simple_async_result_complete (result);
- g_object_unref (result);
- g_object_unref (result_object);
-}
-
-void
-nm_bluez_device_connect_async (NMBluezDevice *self,
- NMBluetoothCapabilities connection_bt_type,
- GAsyncReadyCallback callback,
- gpointer user_data)
-{
- GSimpleAsyncResult *simple;
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
- const char *dbus_iface = BLUEZ_NETWORK_INTERFACE;
- const char *connect_type = BLUETOOTH_CONNECT_NAP;
-
- g_return_if_fail (priv->capabilities & connection_bt_type & (NM_BT_CAPABILITY_DUN | NM_BT_CAPABILITY_NAP));
-#if ! WITH_BLUEZ4
- g_return_if_fail (connection_bt_type == NM_BT_CAPABILITY_NAP);
-#else
- g_return_if_fail (connection_bt_type == NM_BT_CAPABILITY_NAP || connection_bt_type == NM_BT_CAPABILITY_DUN);
-
- if (connection_bt_type == NM_BT_CAPABILITY_DUN) {
- dbus_iface = BLUEZ_SERIAL_INTERFACE;
- connect_type = BLUETOOTH_CONNECT_DUN;
- }
-#endif
-
- simple = g_simple_async_result_new (G_OBJECT (self),
- callback,
- user_data,
- nm_bluez_device_connect_async);
-
- g_dbus_connection_call (priv->dbus_connection,
- BLUEZ_SERVICE,
- priv->path,
- dbus_iface,
- "Connect",
- g_variant_new ("(s)", connect_type),
- NULL,
- G_DBUS_CALL_FLAGS_NONE,
- 20000,
- NULL,
- (GAsyncReadyCallback) bluez_connect_cb,
- simple);
-
- priv->connection_bt_type = connection_bt_type;
-}
-
-const char *
-nm_bluez_device_connect_finish (NMBluezDevice *self,
- GAsyncResult *result,
- GError **error)
-{
- GSimpleAsyncResult *simple;
- const char *device;
-
- g_return_val_if_fail (g_simple_async_result_is_valid (result,
- G_OBJECT (self),
- nm_bluez_device_connect_async),
- NULL);
-
- simple = (GSimpleAsyncResult *) result;
-
- if (g_simple_async_result_propagate_error (simple, error))
- return NULL;
-
- device = (const char *) g_simple_async_result_get_op_res_gpointer (simple);
- return device;
-}
-
-/***********************************************************/
-
-static guint32
-convert_uuids_to_capabilities (const char **strings)
-{
- const char **iter;
- guint32 capabilities = 0;
-
- for (iter = strings; iter && *iter; iter++) {
- char **parts;
-
- parts = g_strsplit (*iter, "-", -1);
- if (parts && parts[0]) {
- switch (g_ascii_strtoull (parts[0], NULL, 16)) {
-#if WITH_BLUEZ4
- case 0x1103:
- capabilities |= NM_BT_CAPABILITY_DUN;
- break;
-#endif
- case 0x1116:
- capabilities |= NM_BT_CAPABILITY_NAP;
- break;
- default:
- break;
- }
- }
- g_strfreev (parts);
- }
-
- return capabilities;
-}
-
-static void
-_set_property_capabilities (NMBluezDevice *self, const char **uuids, gboolean notify)
-{
- guint32 uint_val;
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
-
- uint_val = convert_uuids_to_capabilities (uuids);
- if (priv->capabilities != uint_val) {
- if (priv->capabilities) {
- /* changing (relevant) capabilities is not supported and ignored -- except setting initially */
- nm_log_warn (LOGD_BT, "ignore change of capabilities for Bluetooth device %s from %u to %u",
- priv->path, priv->capabilities, uint_val);
- return;
- }
- nm_log_dbg (LOGD_BT, "set capabilities for Bluetooth device %s: %s%s%s", priv->path,
- uint_val & NM_BT_CAPABILITY_NAP ? "NAP" : "",
- ((uint_val & NM_BT_CAPABILITY_DUN) && (uint_val &NM_BT_CAPABILITY_NAP)) ? " | " : "",
- uint_val & NM_BT_CAPABILITY_DUN ? "DUN" : "");
- priv->capabilities = uint_val;
- if (notify)
- g_object_notify (G_OBJECT (self), NM_BLUEZ_DEVICE_CAPABILITIES);
- }
-}
-
-/**
- * priv->address can only be set one to a certain (non NULL) value. Every later attempt
- * to reset it to another value will be ignored and a warning will be logged.
- *
- * When setting the address for the first time, we also set bin_address.
- **/
-static void
-_set_property_address (NMBluezDevice *self, const char *addr)
-{
- struct ether_addr *tmp;
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
-
- if (g_strcmp0 (priv->address, addr) == 0)
- return;
-
- if (!addr) {
- nm_log_warn (LOGD_BT, "[%s] cannot reset address from '%s' to NULL", priv->path, priv->address);
- return;
- }
-
- if (priv->address != NULL) {
- nm_log_warn (LOGD_BT, "[%s] cannot reset address from '%s' to '%s'", priv->path, priv->address, addr);
- return;
- }
-
- tmp = ether_aton (addr);
- if (!tmp) {
- if (priv->address)
- nm_log_warn (LOGD_BT, "[%s] cannot reset address from '%s' to '%s' (invalid value)", priv->path, priv->address, addr);
- else
- nm_log_warn (LOGD_BT, "[%s] cannot reset address from NULL to '%s' (invalid value)", priv->path, addr);
- return;
- }
- memcpy (priv->bin_address, tmp->ether_addr_octet, ETH_ALEN);
- priv->address = g_strdup (addr);
- return;
-}
-
-#if ! WITH_BLUEZ4
-static void
-adapter_properties_changed (GDBusProxy *proxy5,
- GVariant *changed_properties,
- GStrv invalidated_properties,
- gpointer user_data)
-{
- NMBluezDevice *self = NM_BLUEZ_DEVICE (user_data);
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
- GVariantIter i;
- const char *property;
- GVariant *v;
-
- g_variant_iter_init (&i, changed_properties);
- while (g_variant_iter_next (&i, "{&sv}", &property, &v)) {
- if (!strcmp (property, "Powered")) {
- gboolean powered = g_variant_get_boolean (v);
- if (priv->adapter_powered != powered)
- priv->adapter_powered = powered;
- }
- g_variant_unref (v);
- }
-
- check_emit_usable (self);
-}
-
-static void
-on_adapter_acquired (GObject *object, GAsyncResult *res, NMBluezDevice *self)
-{
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
- GError *error;
- GVariant *v;
-
- priv->adapter = g_dbus_proxy_new_for_bus_finish (res, &error);
- if (!priv->adapter) {
- nm_log_warn (LOGD_BT, "failed to acquire adapter proxy: %s.", error->message);
- g_clear_error (&error);
- g_signal_emit (self, signals[INITIALIZED], 0, FALSE);
- } else {
- g_signal_connect (priv->adapter, "g-properties-changed",
- G_CALLBACK (adapter_properties_changed), self);
-
- /* Check adapter's powered state */
- v = g_dbus_proxy_get_cached_property (priv->adapter, "Powered");
- priv->adapter_powered = v ? g_variant_get_boolean (v) : FALSE;
- if (v)
- g_variant_unref (v);
-
- priv->initialized = TRUE;
- g_signal_emit (self, signals[INITIALIZED], 0, TRUE);
-
- check_emit_usable (self);
- }
-
- g_object_unref (self);
-}
-
-static void
-properties_changed (GDBusProxy *proxy5,
- GVariant *changed_properties,
- GStrv invalidated_properties,
- gpointer user_data)
-{
- NMBluezDevice *self = NM_BLUEZ_DEVICE (user_data);
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
- GVariantIter i;
- const char *property;
- const char *str;
- GVariant *v;
- gint int_val;
- const char **strv;
-
- g_object_freeze_notify (G_OBJECT (self));
- g_variant_iter_init (&i, changed_properties);
- while (g_variant_iter_next (&i, "{&sv}", &property, &v)) {
- if (!strcmp (property, "Name")) {
- str = g_variant_get_string (v, NULL);
- if (g_strcmp0 (priv->name, str)) {
- g_free (priv->name);
- priv->name = g_strdup (str);
- g_object_notify (G_OBJECT (self), NM_BLUEZ_DEVICE_NAME);
- }
- } else if (!strcmp (property, "RSSI")) {
- int_val = g_variant_get_int16 (v);
- if (priv->rssi != int_val) {
- priv->rssi = int_val;
- g_object_notify (G_OBJECT (self), NM_BLUEZ_DEVICE_RSSI);
- }
- } else if (!strcmp (property, "UUIDs")) {
- strv = g_variant_get_strv (v, NULL);
- _set_property_capabilities (self, strv, TRUE);
- g_free (strv);
- } else if (!strcmp (property, "Connected")) {
- gboolean connected = g_variant_get_boolean (v);
- if (priv->connected != connected) {
- priv->connected = connected;
- g_object_notify (G_OBJECT (self), NM_BLUEZ_DEVICE_CONNECTED);
- }
- }
- g_variant_unref (v);
- }
- g_object_thaw_notify (G_OBJECT (self));
-
- check_emit_usable (self);
-}
-#else
-static void
-property_changed (DBusGProxy *proxy4,
- const char *property,
- GValue *value,
- gpointer user_data)
-{
- NMBluezDevice *self = NM_BLUEZ_DEVICE (user_data);
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
- const char *str;
- gint int_val;
-
- g_object_freeze_notify (G_OBJECT (self));
- {
- if (!strcmp (property, "Name")) {
- str = g_value_get_string (value);
- if ( (!priv->name && str)
- || (priv->name && !str)
- || (priv->name && str && strcmp (priv->name, str))) {
- g_free (priv->name);
- priv->name = g_strdup (str);
- g_object_notify (G_OBJECT (self), NM_BLUEZ_DEVICE_NAME);
- }
- } else if (!strcmp (property, "RSSI")) {
- int_val = g_value_get_int (value);
- if (priv->rssi != int_val) {
- priv->rssi = int_val;
- g_object_notify (G_OBJECT (self), NM_BLUEZ_DEVICE_RSSI);
- }
- } else if (!strcmp (property, "UUIDs")) {
- _set_property_capabilities (self, (const char **) g_value_get_boxed (value), TRUE);
- } else if (!strcmp (property, "Connected")) {
- gboolean connected = g_value_get_boolean (value);
- if (priv->connected != connected) {
- priv->connected = connected;
- g_object_notify (G_OBJECT (self), NM_BLUEZ_DEVICE_CONNECTED);
- }
- }
- }
- g_object_thaw_notify (G_OBJECT (self));
-
- check_emit_usable (self);
-}
-#endif
-
-#if ! WITH_BLUEZ4
-static void
-query_properties (NMBluezDevice *self)
-{
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
- GVariant *v;
- const char **uuids;
-
- v = g_dbus_proxy_get_cached_property (priv->proxy5, "Address");
- _set_property_address (self, v ? g_variant_get_string (v, NULL) : NULL);
- if (v)
- g_variant_unref (v);
-
- v = g_dbus_proxy_get_cached_property (priv->proxy5, "Name");
- priv->name = v ? g_variant_dup_string (v, NULL) : NULL;
- if (v)
- g_variant_unref (v);
-
- v = g_dbus_proxy_get_cached_property (priv->proxy5, "RSSI");
- priv->rssi = v ? g_variant_get_int16 (v) : 0;
- if (v)
- g_variant_unref (v);
-
- v = g_dbus_proxy_get_cached_property (priv->proxy5, "UUIDs");
- if (v) {
- uuids = g_variant_get_strv (v, NULL);
- _set_property_capabilities (self, uuids, FALSE);
- g_variant_unref (v);
- } else
- priv->capabilities = NM_BT_CAPABILITY_NONE;
-
- v = g_dbus_proxy_get_cached_property (priv->proxy5, "Adapter");
- if (v) {
- g_dbus_proxy_new_for_bus (G_BUS_TYPE_SYSTEM,
- G_DBUS_PROXY_FLAGS_NONE,
- NULL,
- BLUEZ_SERVICE,
- g_variant_get_string (v, NULL),
- BLUEZ_ADAPTER_INTERFACE,
- NULL,
- (GAsyncReadyCallback) on_adapter_acquired,
- g_object_ref (self));
- g_variant_unref (v);
- }
-
- /* Check if any connections match this device */
- cp_connections_loaded (priv->provider, self);
-}
-#else
-static void
-get_properties_cb (DBusGProxy *proxy4, DBusGProxyCall *call, gpointer user_data)
-{
- NMBluezDevice *self = NM_BLUEZ_DEVICE (user_data);
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
- GHashTable *properties = NULL;
- GError *err = NULL;
- GValue *value;
-
- if (!dbus_g_proxy_end_call (proxy4, call, &err,
- DBUS_TYPE_G_MAP_OF_VARIANT, &properties,
- G_TYPE_INVALID)) {
- nm_log_warn (LOGD_BT, "bluez error getting device properties: %s",
- err && err->message ? err->message : "(unknown)");
- g_error_free (err);
- g_signal_emit (self, signals[INITIALIZED], 0, FALSE);
- return;
- }
-
- value = g_hash_table_lookup (properties, "Address");
- _set_property_address (self, value ? g_value_get_string (value) : NULL);
-
- value = g_hash_table_lookup (properties, "Name");
- priv->name = value ? g_value_dup_string (value) : NULL;
-
- value = g_hash_table_lookup (properties, "RSSI");
- priv->rssi = value ? g_value_get_int (value) : 0;
-
- value = g_hash_table_lookup (properties, "UUIDs");
- if (value) {
- _set_property_capabilities (self, (const char **) g_value_get_boxed (value), FALSE);
- } else
- priv->capabilities = NM_BT_CAPABILITY_NONE;
-
- g_hash_table_unref (properties);
-
- /* Check if any connections match this device */
- cp_connections_loaded (priv->provider, self);
-
- priv->initialized = TRUE;
- g_signal_emit (self, signals[INITIALIZED], 0, TRUE);
-
- check_emit_usable (self);
-}
-
-static void
-query_properties (NMBluezDevice *self)
-{
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
- DBusGProxyCall *call;
-
- call = dbus_g_proxy_begin_call (priv->proxy4, "GetProperties",
- get_properties_cb,
- self,
- NULL, G_TYPE_INVALID);
- if (!call) {
- nm_log_warn (LOGD_BT, "failed to request Bluetooth device properties for %s.",
- priv->path);
- }
-}
-#endif
-
-
-#if ! WITH_BLUEZ4
-static void
-on_proxy_acquired (GObject *object, GAsyncResult *res, NMBluezDevice *self)
-{
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
- GError *error;
-
- priv->proxy5 = g_dbus_proxy_new_for_bus_finish (res, &error);
-
- if (!priv->proxy5) {
- nm_log_warn (LOGD_BT, "failed to acquire device proxy: %s.", error->message);
- g_clear_error (&error);
- g_signal_emit (self, signals[INITIALIZED], 0, FALSE);
- } else {
- g_signal_connect (priv->proxy5, "g-properties-changed",
- G_CALLBACK (properties_changed), self);
-
- query_properties (self);
- }
- g_object_unref (self);
-}
-#endif
-
-static void
-on_bus_acquired (GObject *object, GAsyncResult *res, NMBluezDevice *self)
-{
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
- GError *error = NULL;
-
- priv->dbus_connection = g_bus_get_finish (res, &error);
-
- if (!priv->dbus_connection) {
- nm_log_warn (LOGD_BT, "failed to acquire bus connection: %s.", error->message);
- g_clear_error (&error);
- g_signal_emit (self, signals[INITIALIZED], 0, FALSE);
- return;
- }
-
- check_emit_usable (self);
-}
-
-/********************************************************************/
-
-NMBluezDevice *
-nm_bluez_device_new (const char *path, NMConnectionProvider *provider)
-{
- NMBluezDevice *self;
- NMBluezDevicePrivate *priv;
-#if WITH_BLUEZ4
- NMDBusManager *dbus_mgr;
- DBusGConnection *connection;
-#endif
-
- g_return_val_if_fail (path != NULL, NULL);
- g_return_val_if_fail (provider != NULL, NULL);
-
- self = (NMBluezDevice *) g_object_new (NM_TYPE_BLUEZ_DEVICE,
- NM_BLUEZ_DEVICE_PATH, path,
- NULL);
- if (!self)
- return NULL;
-
- priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
-
- priv->provider = provider;
-
- g_signal_connect (priv->provider,
- NM_CP_SIGNAL_CONNECTION_ADDED,
- G_CALLBACK (cp_connection_added),
- self);
-
- g_signal_connect (priv->provider,
- NM_CP_SIGNAL_CONNECTION_REMOVED,
- G_CALLBACK (cp_connection_removed),
- self);
-
- g_signal_connect (priv->provider,
- NM_CP_SIGNAL_CONNECTION_UPDATED,
- G_CALLBACK (cp_connection_updated),
- self);
-
- g_signal_connect (priv->provider,
- NM_CP_SIGNAL_CONNECTIONS_LOADED,
- G_CALLBACK (cp_connections_loaded),
- self);
-
- g_bus_get (G_BUS_TYPE_SYSTEM,
- NULL,
- (GAsyncReadyCallback) on_bus_acquired,
- self);
-
-#if ! WITH_BLUEZ4
- g_object_ref (self);
- g_dbus_proxy_new_for_bus (G_BUS_TYPE_SYSTEM,
- G_DBUS_PROXY_FLAGS_NONE,
- NULL,
- BLUEZ_SERVICE,
- priv->path,
- BLUEZ_DEVICE_INTERFACE,
- NULL,
- (GAsyncReadyCallback) on_proxy_acquired,
- self);
-#else
- dbus_mgr = nm_dbus_manager_get ();
- connection = nm_dbus_manager_get_connection (dbus_mgr);
-
- priv->proxy4 = dbus_g_proxy_new_for_name (connection,
- BLUEZ_SERVICE,
- priv->path,
- BLUEZ_DEVICE_INTERFACE);
- g_object_unref (dbus_mgr);
-
- dbus_g_object_register_marshaller (_nm_marshal_VOID__STRING_BOXED,
- G_TYPE_NONE,
- G_TYPE_STRING, G_TYPE_VALUE,
- G_TYPE_INVALID);
- dbus_g_proxy_add_signal (priv->proxy4, "PropertyChanged",
- G_TYPE_STRING, G_TYPE_VALUE, G_TYPE_INVALID);
- dbus_g_proxy_connect_signal (priv->proxy4, "PropertyChanged",
- G_CALLBACK (property_changed), self, NULL);
-
- query_properties (self);
-#endif
- return self;
-}
-
-static void
-nm_bluez_device_init (NMBluezDevice *self)
-{
-}
-
-static void
-dispose (GObject *object)
-{
- NMBluezDevice *self = NM_BLUEZ_DEVICE (object);
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (self);
-
- g_slist_foreach (priv->connections, (GFunc) g_object_unref, NULL);
- g_slist_free (priv->connections);
- priv->connections = NULL;
-
- g_signal_handlers_disconnect_by_func (priv->provider, cp_connection_added, self);
- g_signal_handlers_disconnect_by_func (priv->provider, cp_connection_removed, self);
- g_signal_handlers_disconnect_by_func (priv->provider, cp_connection_updated, self);
- g_signal_handlers_disconnect_by_func (priv->provider, cp_connections_loaded, self);
-
-#if ! WITH_BLUEZ4
- g_clear_object (&priv->adapter);
-#endif
- g_clear_object (&priv->dbus_connection);
-
- G_OBJECT_CLASS (nm_bluez_device_parent_class)->dispose (object);
-}
-
-static void
-finalize (GObject *object)
-{
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (object);
-
- g_free (priv->path);
- g_free (priv->address);
- g_free (priv->name);
- g_free (priv->bt_iface);
-#if ! WITH_BLUEZ4
- g_object_unref (priv->proxy5);
-#else
- g_object_unref (priv->proxy4);
-#endif
-
- G_OBJECT_CLASS (nm_bluez_device_parent_class)->finalize (object);
-}
-
-static void
-get_property (GObject *object, guint prop_id,
- GValue *value, GParamSpec *pspec)
-{
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (object);
-
- switch (prop_id) {
- case PROP_PATH:
- g_value_set_string (value, priv->path);
- break;
- case PROP_ADDRESS:
- g_value_set_string (value, priv->address);
- break;
- case PROP_NAME:
- g_value_set_string (value, priv->name);
- break;
- case PROP_CAPABILITIES:
- g_value_set_uint (value, priv->capabilities);
- break;
- case PROP_RSSI:
- g_value_set_int (value, priv->rssi);
- break;
- case PROP_USABLE:
- g_value_set_boolean (value, priv->usable);
- break;
- case PROP_CONNECTED:
- g_value_set_boolean (value, priv->connected);
- break;
- default:
- G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
- break;
- }
-}
-
-static void
-set_property (GObject *object, guint prop_id,
- const GValue *value, GParamSpec *pspec)
-{
- NMBluezDevicePrivate *priv = NM_BLUEZ_DEVICE_GET_PRIVATE (object);
-
- switch (prop_id) {
- case PROP_PATH:
- /* construct only */
- priv->path = g_value_dup_string (value);
- break;
- default:
- G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
- break;
- }
-}
-
-static void
-nm_bluez_device_class_init (NMBluezDeviceClass *config_class)
-{
- GObjectClass *object_class = G_OBJECT_CLASS (config_class);
-
- g_type_class_add_private (config_class, sizeof (NMBluezDevicePrivate));
-
- /* virtual methods */
- object_class->get_property = get_property;
- object_class->set_property = set_property;
- object_class->dispose = dispose;
- object_class->finalize = finalize;
-
- /* Properties */
- g_object_class_install_property
- (object_class, PROP_PATH,
- g_param_spec_string (NM_BLUEZ_DEVICE_PATH,
- "DBus Path",
- "DBus Path",
- NULL,
- G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY));
-
- g_object_class_install_property
- (object_class, PROP_ADDRESS,
- g_param_spec_string (NM_BLUEZ_DEVICE_ADDRESS,
- "Address",
- "Address",
- NULL,
- G_PARAM_READABLE));
-
- g_object_class_install_property
- (object_class, PROP_NAME,
- g_param_spec_string (NM_BLUEZ_DEVICE_NAME,
- "Name",
- "Name",
- NULL,
- G_PARAM_READABLE));
-
- g_object_class_install_property
- (object_class, PROP_CAPABILITIES,
- g_param_spec_uint (NM_BLUEZ_DEVICE_CAPABILITIES,
- "Capabilities",
- "Capabilities",
- 0, G_MAXUINT, 0,
- G_PARAM_READABLE));
-
- g_object_class_install_property
- (object_class, PROP_RSSI,
- g_param_spec_int (NM_BLUEZ_DEVICE_RSSI,
- "RSSI",
- "RSSI",
- G_MININT, G_MAXINT, 0,
- G_PARAM_READABLE));
-
- g_object_class_install_property
- (object_class, PROP_USABLE,
- g_param_spec_boolean (NM_BLUEZ_DEVICE_USABLE,
- "Usable",
- "Usable",
- FALSE,
- G_PARAM_READABLE));
-
- g_object_class_install_property
- (object_class, PROP_CONNECTED,
- g_param_spec_boolean (NM_BLUEZ_DEVICE_CONNECTED,
- "Connected",
- "Connected",
- FALSE,
- G_PARAM_READABLE));
-
- /* Signals */
- signals[INITIALIZED] = g_signal_new ("initialized",
- G_OBJECT_CLASS_TYPE (object_class),
- G_SIGNAL_RUN_LAST,
- G_STRUCT_OFFSET (NMBluezDeviceClass, initialized),
- NULL, NULL, NULL,
- G_TYPE_NONE, 1, G_TYPE_BOOLEAN);
-}
-
diff --git a/src/bluez-manager/nm-bluez-device.h b/src/bluez-manager/nm-bluez-device.h
deleted file mode 100644
index 11add3890..000000000
--- a/src/bluez-manager/nm-bluez-device.h
+++ /dev/null
@@ -1,97 +0,0 @@
-/* -*- Mode: C; tab-width: 4; indent-tabs-mode: t; c-basic-offset: 4 -*- */
-/* NetworkManager -- Network link manager
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License along
- * with this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
- *
- * Copyright (C) 2009 - 2012 Red Hat, Inc.
- */
-
-#ifndef NM_BLUEZ_DEVICE_H
-#define NM_BLUEZ_DEVICE_H
-
-#include <glib.h>
-#include <glib-object.h>
-#include <gio/gio.h>
-
-#include <config.h>
-#include "nm-connection.h"
-#include "nm-connection-provider.h"
-
-#define NM_TYPE_BLUEZ_DEVICE (nm_bluez_device_get_type ())
-#define NM_BLUEZ_DEVICE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), NM_TYPE_BLUEZ_DEVICE, NMBluezDevice))
-#define NM_BLUEZ_DEVICE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), NM_TYPE_BLUEZ_DEVICE, NMBluezDeviceClass))
-#define NM_IS_BLUEZ_DEVICE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), NM_TYPE_BLUEZ_DEVICE))
-#define NM_IS_BLUEZ_DEVICE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), NM_TYPE_BLUEZ_DEVICE))
-#define NM_BLUEZ_DEVICE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), NM_TYPE_BLUEZ_DEVICE, NMBluezDeviceClass))
-
-#define NM_BLUEZ_DEVICE_PATH "path"
-#define NM_BLUEZ_DEVICE_ADDRESS "address"
-#define NM_BLUEZ_DEVICE_NAME "name"
-#define NM_BLUEZ_DEVICE_CAPABILITIES "capabilities"
-#define NM_BLUEZ_DEVICE_RSSI "rssi"
-#define NM_BLUEZ_DEVICE_USABLE "usable"
-#define NM_BLUEZ_DEVICE_CONNECTED "connected"
-
-typedef struct {
- GObject parent;
-} NMBluezDevice;
-
-typedef struct {
- GObjectClass parent;
-
- /* virtual functions */
- void (*initialized) (NMBluezDevice *self, gboolean success);
-
- void (*invalid) (NMBluezDevice *self);
-} NMBluezDeviceClass;
-
-GType nm_bluez_device_get_type (void);
-
-NMBluezDevice *nm_bluez_device_new (const char *path, NMConnectionProvider *provider);
-
-const char *nm_bluez_device_get_path (NMBluezDevice *self);
-
-gboolean nm_bluez_device_get_initialized (NMBluezDevice *self);
-
-gboolean nm_bluez_device_get_usable (NMBluezDevice *self);
-
-const char *nm_bluez_device_get_address (NMBluezDevice *self);
-
-const char *nm_bluez_device_get_name (NMBluezDevice *self);
-
-guint32 nm_bluez_device_get_class (NMBluezDevice *self);
-
-guint32 nm_bluez_device_get_capabilities (NMBluezDevice *self);
-
-gint nm_bluez_device_get_rssi (NMBluezDevice *self);
-
-gboolean nm_bluez_device_get_connected (NMBluezDevice *self);
-
-void
-nm_bluez_device_connect_async (NMBluezDevice *self,
- NMBluetoothCapabilities connection_bt_type,
- GAsyncReadyCallback callback,
- gpointer user_data);
-
-const char *
-nm_bluez_device_connect_finish (NMBluezDevice *self,
- GAsyncResult *result,
- GError **error);
-
-void
-nm_bluez_device_disconnect (NMBluezDevice *self);
-
-#endif /* NM_BLUEZ_DEVICE_H */
-
diff --git a/src/bluez-manager/nm-bluez-manager.c b/src/bluez-manager/nm-bluez-manager.c
deleted file mode 100644
index 3801d5ee3..000000000
--- a/src/bluez-manager/nm-bluez-manager.c
+++ /dev/null
@@ -1,438 +0,0 @@
-/* -*- Mode: C; tab-width: 4; indent-tabs-mode: t; c-basic-offset: 4 -*- */
-/* NetworkManager -- Network link manager
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License along
- * with this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
- *
- * Copyright (C) 2007 - 2008 Novell, Inc.
- * Copyright (C) 2007 - 2012 Red Hat, Inc.
- * Copyright (C) 2013 Intel Corporation.
- */
-
-#include <signal.h>
-#include <string.h>
-#include <stdlib.h>
-#include <gio/gio.h>
-
-#include "nm-logging.h"
-#include "nm-bluez-manager.h"
-#include "nm-bluez-device.h"
-#include "nm-bluez-common.h"
-
-#include "nm-dbus-manager.h"
-
-typedef struct {
- NMDBusManager *dbus_mgr;
- gulong name_owner_changed_id;
-
- NMConnectionProvider *provider;
-
- GDBusProxy *proxy;
-
- GHashTable *devices;
-} NMBluezManagerPrivate;
-
-#define NM_BLUEZ_MANAGER_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), NM_TYPE_BLUEZ_MANAGER, NMBluezManagerPrivate))
-
-G_DEFINE_TYPE (NMBluezManager, nm_bluez_manager, G_TYPE_OBJECT)
-
-enum {
- BDADDR_ADDED,
- BDADDR_REMOVED,
-
- LAST_SIGNAL
-};
-
-static guint signals[LAST_SIGNAL] = { 0 };
-
-static void device_initialized (NMBluezDevice *device, gboolean success, NMBluezManager *self);
-static void device_usable (NMBluezDevice *device, GParamSpec *pspec, NMBluezManager *self);
-
-static void
-emit_bdaddr_added (NMBluezManager *self, NMBluezDevice *device)
-{
- g_signal_emit (self, signals[BDADDR_ADDED], 0,
- device,
- nm_bluez_device_get_address (device),
- nm_bluez_device_get_name (device),
- nm_bluez_device_get_path (device),
- nm_bluez_device_get_capabilities (device));
-}
-
-void
-nm_bluez_manager_query_devices (NMBluezManager *self)
-{
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
- NMBluezDevice *device;
- GHashTableIter iter;
-
- g_hash_table_iter_init (&iter, priv->devices);
- while (g_hash_table_iter_next (&iter, NULL, (gpointer) &device)) {
- if (nm_bluez_device_get_usable (device))
- emit_bdaddr_added (self, device);
- }
-}
-
-static void
-remove_device (NMBluezManager *self, NMBluezDevice *device)
-{
- if (nm_bluez_device_get_usable (device)) {
- g_signal_emit (self, signals[BDADDR_REMOVED], 0,
- nm_bluez_device_get_address (device),
- nm_bluez_device_get_path (device));
- }
- g_signal_handlers_disconnect_by_func (device, G_CALLBACK (device_initialized), self);
- g_signal_handlers_disconnect_by_func (device, G_CALLBACK (device_usable), self);
-}
-
-static void
-remove_all_devices (NMBluezManager *self)
-{
- GHashTableIter iter;
- NMBluezDevice *device;
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
-
- g_hash_table_iter_init (&iter, priv->devices);
- while (g_hash_table_iter_next (&iter, NULL, (gpointer) &device)) {
- g_hash_table_iter_steal (&iter);
- remove_device (self, device);
- g_object_unref (device);
- }
-}
-
-static void
-device_usable (NMBluezDevice *device, GParamSpec *pspec, NMBluezManager *self)
-{
- gboolean usable = nm_bluez_device_get_usable (device);
-
- nm_log_dbg (LOGD_BT, "(%s): bluez device now %s",
- nm_bluez_device_get_path (device),
- usable ? "usable" : "unusable");
-
- if (usable) {
- nm_log_dbg (LOGD_BT, "(%s): bluez device address %s",
- nm_bluez_device_get_path (device),
- nm_bluez_device_get_address (device));
- emit_bdaddr_added (self, device);
- } else
- g_signal_emit (self, signals[BDADDR_REMOVED], 0,
- nm_bluez_device_get_address (device),
- nm_bluez_device_get_path (device));
-}
-
-static void
-device_initialized (NMBluezDevice *device, gboolean success, NMBluezManager *self)
-{
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
-
- nm_log_dbg (LOGD_BT, "(%s): bluez device %s",
- nm_bluez_device_get_path (device),
- success ? "initialized" : "failed to initialize");
- if (!success)
- g_hash_table_remove (priv->devices, nm_bluez_device_get_path (device));
-}
-
-static void
-device_added (GDBusProxy *proxy, const gchar *path, NMBluezManager *self)
-{
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
- NMBluezDevice *device;
-
- device = nm_bluez_device_new (path, priv->provider);
- g_signal_connect (device, "initialized", G_CALLBACK (device_initialized), self);
- g_signal_connect (device, "notify::usable", G_CALLBACK (device_usable), self);
- g_hash_table_insert (priv->devices, (gpointer) nm_bluez_device_get_path (device), device);
-
- nm_log_dbg (LOGD_BT, "(%s): new bluez device found", path);
-}
-
-static void
-device_removed (GDBusProxy *proxy, const gchar *path, NMBluezManager *self)
-{
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
- NMBluezDevice *device;
-
- nm_log_dbg (LOGD_BT, "(%s): bluez device removed", path);
-
- device = g_hash_table_lookup (priv->devices, path);
- if (device) {
- g_hash_table_steal (priv->devices, nm_bluez_device_get_path (device));
- remove_device (NM_BLUEZ_MANAGER (self), device);
- g_object_unref (device);
- }
-}
-
-static void
-object_manager_g_signal (GDBusProxy *proxy,
- gchar *sender_name,
- gchar *signal_name,
- GVariant *parameters,
- NMBluezManager *self)
-{
- GVariant *variant;
- const gchar *path;
-
- if (!strcmp (signal_name, "InterfacesRemoved")) {
- const gchar **ifaces;
- gsize i, length;
-
- g_variant_get (parameters, "(&o*)", &path, &variant);
-
- ifaces = g_variant_get_strv (variant, &length);
-
- for (i = 0; i < length; i++) {
- if (!strcmp (ifaces[i], BLUEZ_DEVICE_INTERFACE)) {
- device_removed (proxy, path, self);
- break;
- }
- }
-
- g_free (ifaces);
-
- } else if (!strcmp (signal_name, "InterfacesAdded")) {
- g_variant_get (parameters, "(&o*)", &path, &variant);
-
- if (g_variant_lookup_value (variant, BLUEZ_DEVICE_INTERFACE,
- G_VARIANT_TYPE_DICTIONARY))
- device_added (proxy, path, self);
- }
-}
-
-static void
-get_managed_objects_cb (GDBusProxy *proxy,
- GAsyncResult *res,
- NMBluezManager *self)
-{
- GVariant *variant, *ifaces;
- GVariantIter i;
- GError *error = NULL;
- const char *path;
-
- variant = g_dbus_proxy_call_finish (proxy, res, &error);
-
- if (!variant) {
- nm_log_warn (LOGD_BT, "Couldn't get managed objects: %s",
- error && error->message ? error->message : "(unknown)");
- g_clear_error (&error);
- return;
- }
- g_variant_iter_init (&i, g_variant_get_child_value (variant, 0));
- while ((g_variant_iter_next (&i, "{&o*}", &path, &ifaces))) {
- if (g_variant_lookup_value (ifaces, BLUEZ_DEVICE_INTERFACE,
- G_VARIANT_TYPE_DICTIONARY)) {
- device_added (proxy, path, self);
- }
- }
-
- g_variant_unref (variant);
-}
-
-static void
-on_proxy_acquired (GObject *object,
- GAsyncResult *res,
- NMBluezManager *self)
-{
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
- GError *error = NULL;
-
- priv->proxy = g_dbus_proxy_new_for_bus_finish (res, &error);
-
- if (!priv->proxy) {
- nm_log_warn (LOGD_BT, "Couldn't acquire object manager proxy: %s",
- error && error->message ? error->message : "(unknown)");
- g_clear_error (&error);
- return;
- }
-
- /* Get already managed devices. */
- g_dbus_proxy_call (priv->proxy, "GetManagedObjects",
- NULL,
- G_DBUS_CALL_FLAGS_NONE,
- -1,
- NULL,
- (GAsyncReadyCallback) get_managed_objects_cb,
- self);
-
- g_signal_connect (priv->proxy, "g-signal",
- G_CALLBACK (object_manager_g_signal), self);
-}
-
-static void
-bluez_connect (NMBluezManager *self)
-{
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
-
- g_return_if_fail (priv->proxy == NULL);
-
- g_dbus_proxy_new_for_bus (G_BUS_TYPE_SYSTEM,
- G_DBUS_PROXY_FLAGS_NONE,
- NULL,
- BLUEZ_SERVICE,
- BLUEZ_MANAGER_PATH,
- OBJECT_MANAGER_INTERFACE,
- NULL,
- (GAsyncReadyCallback) on_proxy_acquired,
- self);
-}
-
-static void
-name_owner_changed_cb (NMDBusManager *dbus_mgr,
- const char *name,
- const char *old_owner,
- const char *new_owner,
- gpointer user_data)
-{
- NMBluezManager *self = NM_BLUEZ_MANAGER (user_data);
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
- gboolean old_owner_good = (old_owner && strlen (old_owner));
- gboolean new_owner_good = (new_owner && strlen (new_owner));
-
- /* Can't handle the signal if its not from the Bluez */
- if (strcmp (BLUEZ_SERVICE, name))
- return;
-
- if (old_owner_good && !new_owner_good) {
- if (priv->devices)
- remove_all_devices (self);
- }
-}
-
-static void
-bluez_cleanup (NMBluezManager *self, gboolean do_signal)
-{
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
-
- if (priv->proxy) {
- g_object_unref (priv->proxy);
- priv->proxy = NULL;
- }
-
- if (do_signal)
- remove_all_devices (self);
- else
- g_hash_table_remove_all (priv->devices);
-}
-
-static void
-dbus_connection_changed_cb (NMDBusManager *dbus_mgr,
- DBusGConnection *connection,
- gpointer user_data)
-{
- NMBluezManager *self = NM_BLUEZ_MANAGER (user_data);
-
- if (!connection)
- bluez_cleanup (self, TRUE);
- else
- bluez_connect (self);
-}
-
-/****************************************************************/
-
-NMBluezManager *
-nm_bluez_manager_get (NMConnectionProvider *provider)
-{
- static NMBluezManager *singleton = NULL;
-
- if (singleton)
- return g_object_ref (singleton);
-
- singleton = (NMBluezManager *) g_object_new (NM_TYPE_BLUEZ_MANAGER, NULL);
- g_assert (singleton);
-
- /* Cache the connection provider for NMBluezAdapter objects */
- NM_BLUEZ_MANAGER_GET_PRIVATE (singleton)->provider = provider;
-
- return singleton;
-}
-
-static void
-nm_bluez_manager_init (NMBluezManager *self)
-{
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
-
- priv->dbus_mgr = nm_dbus_manager_get ();
- g_assert (priv->dbus_mgr);
-
- g_signal_connect (priv->dbus_mgr,
- NM_DBUS_MANAGER_NAME_OWNER_CHANGED,
- G_CALLBACK (name_owner_changed_cb),
- self);
-
- g_signal_connect (priv->dbus_mgr,
- NM_DBUS_MANAGER_DBUS_CONNECTION_CHANGED,
- G_CALLBACK (dbus_connection_changed_cb),
- self);
-
- bluez_connect (self);
-
- priv->devices = g_hash_table_new_full (g_str_hash, g_str_equal,
- NULL, g_object_unref);
-}
-
-static void
-dispose (GObject *object)
-{
- NMBluezManager *self = NM_BLUEZ_MANAGER (object);
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
-
- bluez_cleanup (self, FALSE);
-
- if (priv->dbus_mgr) {
- g_signal_handlers_disconnect_by_func (priv->dbus_mgr, name_owner_changed_cb, self);
- g_signal_handlers_disconnect_by_func (priv->dbus_mgr, dbus_connection_changed_cb, self);
- priv->dbus_mgr = NULL;
- }
-
- G_OBJECT_CLASS (nm_bluez_manager_parent_class)->dispose (object);
-}
-
-static void
-finalize (GObject *object)
-{
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (object);
-
- g_hash_table_destroy (priv->devices);
-
- G_OBJECT_CLASS (nm_bluez_manager_parent_class)->finalize (object);
-}
-
-static void
-nm_bluez_manager_class_init (NMBluezManagerClass *klass)
-{
- GObjectClass *object_class = G_OBJECT_CLASS (klass);
-
- g_type_class_add_private (klass, sizeof (NMBluezManagerPrivate));
-
- /* virtual methods */
- object_class->dispose = dispose;
- object_class->finalize = finalize;
-
- /* Signals */
- signals[BDADDR_ADDED] =
- g_signal_new (NM_BLUEZ_MANAGER_BDADDR_ADDED,
- G_OBJECT_CLASS_TYPE (object_class),
- G_SIGNAL_RUN_FIRST,
- G_STRUCT_OFFSET (NMBluezManagerClass, bdaddr_added),
- NULL, NULL, NULL,
- G_TYPE_NONE, 5, G_TYPE_OBJECT, G_TYPE_STRING,
- G_TYPE_STRING, G_TYPE_STRING, G_TYPE_UINT);
-
- signals[BDADDR_REMOVED] =
- g_signal_new (NM_BLUEZ_MANAGER_BDADDR_REMOVED,
- G_OBJECT_CLASS_TYPE (object_class),
- G_SIGNAL_RUN_FIRST,
- G_STRUCT_OFFSET (NMBluezManagerClass, bdaddr_removed),
- NULL, NULL, NULL,
- G_TYPE_NONE, 2, G_TYPE_STRING, G_TYPE_STRING);
-}
diff --git a/src/bluez-manager/nm-bluez-manager.h b/src/bluez-manager/nm-bluez-manager.h
deleted file mode 100644
index 95e319c5e..000000000
--- a/src/bluez-manager/nm-bluez-manager.h
+++ /dev/null
@@ -1,69 +0,0 @@
-/* -*- Mode: C; tab-width: 4; indent-tabs-mode: t; c-basic-offset: 4 -*- */
-/* NetworkManager -- Network link manager
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License along
- * with this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
- *
- * Copyright (C) 2007 - 2008 Novell, Inc.
- * Copyright (C) 2007 - 2012 Red Hat, Inc.
- */
-
-#ifndef NM_BLUEZ_MANAGER_H
-#define NM_BLUEZ_MANAGER_H
-
-#include <glib.h>
-#include <glib-object.h>
-
-#include <config.h>
-#include "nm-connection-provider.h"
-
-G_BEGIN_DECLS
-
-#define NM_TYPE_BLUEZ_MANAGER (nm_bluez_manager_get_type ())
-#define NM_BLUEZ_MANAGER(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), NM_TYPE_BLUEZ_MANAGER, NMBluezManager))
-#define NM_BLUEZ_MANAGER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), NM_TYPE_BLUEZ_MANAGER, NMBluezManagerClass))
-#define NM_IS_BLUEZ_MANAGER(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), NM_TYPE_BLUEZ_MANAGER))
-#define NM_IS_BLUEZ_MANAGER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), NM_TYPE_BLUEZ_MANAGER))
-#define NM_BLUEZ_MANAGER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), NM_TYPE_BLUEZ_MANAGER, NMBluezManagerClass))
-
-#define NM_BLUEZ_MANAGER_BDADDR_ADDED "bdaddr-added"
-#define NM_BLUEZ_MANAGER_BDADDR_REMOVED "bdaddr-removed"
-
-typedef struct {
- GObject parent;
-} NMBluezManager;
-
-typedef struct {
- GObjectClass parent;
-
- /* Virtual functions */
- void (*bdaddr_added) (NMBluezManager *manager,
- const char *bdaddr,
- const char *name,
- const char *object_path,
- guint uuids);
-
- void (*bdaddr_removed) (NMBluezManager *manager,
- const char *bdaddr,
- const char *object_path);
-} NMBluezManagerClass;
-
-GType nm_bluez_manager_get_type (void);
-
-NMBluezManager *nm_bluez_manager_get (NMConnectionProvider *provider);
-
-void nm_bluez_manager_query_devices (NMBluezManager *manager);
-
-#endif /* NM_BLUEZ_MANAGER_H */
-
diff --git a/src/bluez-manager/nm-bluez4-adapter.c b/src/bluez-manager/nm-bluez4-adapter.c
deleted file mode 100644
index 817df73d5..000000000
--- a/src/bluez-manager/nm-bluez4-adapter.c
+++ /dev/null
@@ -1,397 +0,0 @@
-/* -*- Mode: C; tab-width: 4; indent-tabs-mode: t; c-basic-offset: 4 -*- */
-/* NetworkManager -- Network link manager
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License along
- * with this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
- *
- * Copyright (C) 2009 - 2012 Red Hat, Inc.
- */
-
-#include <glib.h>
-#include <string.h>
-
-#include "NetworkManager.h"
-#include "nm-dbus-manager.h"
-#include "nm-bluez4-adapter.h"
-#include "nm-bluez-device.h"
-#include "nm-bluez-common.h"
-#include "nm-dbus-glib-types.h"
-#include "nm-logging.h"
-
-
-G_DEFINE_TYPE (NMBluezAdapter, nm_bluez_adapter, G_TYPE_OBJECT)
-
-#define NM_BLUEZ_ADAPTER_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), NM_TYPE_BLUEZ_ADAPTER, NMBluezAdapterPrivate))
-
-typedef struct {
- char *path;
- DBusGProxy *proxy;
- gboolean initialized;
-
- char *address;
- GHashTable *devices;
-
- /* Cached for devices */
- NMConnectionProvider *provider;
-} NMBluezAdapterPrivate;
-
-
-enum {
- PROP_0,
- PROP_PATH,
- PROP_ADDRESS,
-
- LAST_PROP
-};
-
-/* Signals */
-enum {
- INITIALIZED,
- DEVICE_ADDED,
- DEVICE_REMOVED,
- LAST_SIGNAL
-};
-static guint signals[LAST_SIGNAL] = { 0 };
-
-const char *
-nm_bluez_adapter_get_path (NMBluezAdapter *self)
-{
- g_return_val_if_fail (NM_IS_BLUEZ_ADAPTER (self), NULL);
-
- return NM_BLUEZ_ADAPTER_GET_PRIVATE (self)->path;
-}
-
-const char *
-nm_bluez_adapter_get_address (NMBluezAdapter *self)
-{
- g_return_val_if_fail (NM_IS_BLUEZ_ADAPTER (self), NULL);
-
- return NM_BLUEZ_ADAPTER_GET_PRIVATE (self)->address;
-}
-
-gboolean
-nm_bluez_adapter_get_initialized (NMBluezAdapter *self)
-{
- g_return_val_if_fail (NM_IS_BLUEZ_ADAPTER (self), FALSE);
-
- return NM_BLUEZ_ADAPTER_GET_PRIVATE (self)->initialized;
-}
-
-GSList *
-nm_bluez_adapter_get_devices (NMBluezAdapter *self)
-{
- GSList *devices = NULL;
- GHashTableIter iter;
- NMBluezDevice *device;
-
- g_hash_table_iter_init (&iter, NM_BLUEZ_ADAPTER_GET_PRIVATE (self)->devices);
- while (g_hash_table_iter_next (&iter, NULL, (gpointer) &device)) {
- if (nm_bluez_device_get_usable (device))
- devices = g_slist_append (devices, device);
- }
- return devices;
-}
-
-static void
-device_usable (NMBluezDevice *device, GParamSpec *pspec, gpointer user_data)
-{
- NMBluezAdapter *self = NM_BLUEZ_ADAPTER (user_data);
- gboolean usable = nm_bluez_device_get_usable (device);
-
- nm_log_dbg (LOGD_BT, "(%s): bluez device now %s",
- nm_bluez_device_get_path (device),
- usable ? "usable" : "unusable");
-
- if (usable) {
- nm_log_dbg (LOGD_BT, "(%s): bluez device address %s",
- nm_bluez_device_get_path (device),
- nm_bluez_device_get_address (device));
- g_signal_emit (self, signals[DEVICE_ADDED], 0, device);
- } else
- g_signal_emit (self, signals[DEVICE_REMOVED], 0, device);
-}
-
-static void
-device_initialized (NMBluezDevice *device, gboolean success, gpointer user_data)
-{
- NMBluezAdapter *self = NM_BLUEZ_ADAPTER (user_data);
- NMBluezAdapterPrivate *priv = NM_BLUEZ_ADAPTER_GET_PRIVATE (self);
-
- nm_log_dbg (LOGD_BT, "(%s): bluez device %s",
- nm_bluez_device_get_path (device),
- success ? "initialized" : "failed to initialize");
- if (!success)
- g_hash_table_remove (priv->devices, nm_bluez_device_get_path (device));
-}
-
-static void
-device_created (DBusGProxy *proxy, const char *path, gpointer user_data)
-{
- NMBluezAdapter *self = NM_BLUEZ_ADAPTER (user_data);
- NMBluezAdapterPrivate *priv = NM_BLUEZ_ADAPTER_GET_PRIVATE (self);
- NMBluezDevice *device;
-
- device = nm_bluez_device_new (path, priv->provider);
- g_signal_connect (device, "initialized", G_CALLBACK (device_initialized), self);
- g_signal_connect (device, "notify::usable", G_CALLBACK (device_usable), self);
- g_hash_table_insert (priv->devices, (gpointer) nm_bluez_device_get_path (device), device);
-
- nm_log_dbg (LOGD_BT, "(%s): new bluez device found", path);
-}
-
-static void
-device_removed (DBusGProxy *proxy, const char *path, gpointer user_data)
-{
- NMBluezAdapter *self = NM_BLUEZ_ADAPTER (user_data);
- NMBluezAdapterPrivate *priv = NM_BLUEZ_ADAPTER_GET_PRIVATE (self);
- NMBluezDevice *device;
-
- nm_log_dbg (LOGD_BT, "(%s): bluez device removed", path);
-
- device = g_hash_table_lookup (priv->devices, path);
- if (device) {
- g_object_ref (device);
- g_hash_table_remove (priv->devices, nm_bluez_device_get_path (device));
- g_signal_emit (self, signals[DEVICE_REMOVED], 0, device);
- g_object_unref (device);
- }
-}
-
-
-static void
-get_properties_cb (DBusGProxy *proxy, DBusGProxyCall *call, gpointer user_data)
-{
- NMBluezAdapter *self = NM_BLUEZ_ADAPTER (user_data);
- NMBluezAdapterPrivate *priv = NM_BLUEZ_ADAPTER_GET_PRIVATE (self);
- GHashTable *properties = NULL;
- GError *err = NULL;
- GValue *value;
- GPtrArray *devices;
- int i;
-
- if (!dbus_g_proxy_end_call (proxy, call, &err,
- DBUS_TYPE_G_MAP_OF_VARIANT, &properties,
- G_TYPE_INVALID)) {
- nm_log_warn (LOGD_BT, "bluez error getting adapter properties: %s",
- err && err->message ? err->message : "(unknown)");
- g_error_free (err);
- goto done;
- }
-
- value = g_hash_table_lookup (properties, "Address");
- priv->address = value ? g_value_dup_string (value) : NULL;
-
- value = g_hash_table_lookup (properties, "Devices");
- devices = value ? g_value_get_boxed (value) : NULL;
-
- for (i = 0; devices && i < devices->len; i++)
- device_created (priv->proxy, g_ptr_array_index (devices, i), self);
-
- g_hash_table_unref (properties);
-
- priv->initialized = TRUE;
-
-done:
- g_signal_emit (self, signals[INITIALIZED], 0, priv->initialized);
-}
-
-static void
-query_properties (NMBluezAdapter *self)
-{
- NMBluezAdapterPrivate *priv = NM_BLUEZ_ADAPTER_GET_PRIVATE (self);
- DBusGProxyCall *call;
-
- call = dbus_g_proxy_begin_call (priv->proxy, "GetProperties",
- get_properties_cb,
- self,
- NULL, G_TYPE_INVALID);
- if (!call) {
- nm_log_warn (LOGD_BT, "failed to request Bluetooth adapter properties for %s.",
- priv->path);
- }
-}
-
-/***********************************************************/
-
-NMBluezAdapter *
-nm_bluez_adapter_new (const char *path, NMConnectionProvider *provider)
-{
- NMBluezAdapter *self;
- NMBluezAdapterPrivate *priv;
- NMDBusManager *dbus_mgr;
- DBusGConnection *connection;
-
- self = (NMBluezAdapter *) g_object_new (NM_TYPE_BLUEZ_ADAPTER,
- NM_BLUEZ_ADAPTER_PATH, path,
- NULL);
- if (!self)
- return NULL;
-
- priv = NM_BLUEZ_ADAPTER_GET_PRIVATE (self);
-
- priv->provider = provider;
-
- dbus_mgr = nm_dbus_manager_get ();
- connection = nm_dbus_manager_get_connection (dbus_mgr);
-
- priv->proxy = dbus_g_proxy_new_for_name (connection,
- BLUEZ_SERVICE,
- priv->path,
- BLUEZ_ADAPTER_INTERFACE);
- g_object_unref (dbus_mgr);
-
- dbus_g_proxy_add_signal (priv->proxy, "DeviceCreated",
- DBUS_TYPE_G_OBJECT_PATH, G_TYPE_INVALID);
- dbus_g_proxy_connect_signal (priv->proxy, "DeviceCreated",
- G_CALLBACK (device_created), self, NULL);
-
- dbus_g_proxy_add_signal (priv->proxy, "DeviceRemoved",
- DBUS_TYPE_G_OBJECT_PATH, G_TYPE_INVALID);
- dbus_g_proxy_connect_signal (priv->proxy, "DeviceRemoved",
- G_CALLBACK (device_removed), self, NULL);
-
- query_properties (self);
- return self;
-}
-
-static void
-nm_bluez_adapter_init (NMBluezAdapter *self)
-{
- NMBluezAdapterPrivate *priv = NM_BLUEZ_ADAPTER_GET_PRIVATE (self);
-
- priv->devices = g_hash_table_new_full (g_str_hash, g_str_equal,
- NULL, g_object_unref);
-}
-
-static void
-dispose (GObject *object)
-{
- NMBluezAdapter *self = NM_BLUEZ_ADAPTER (object);
- NMBluezAdapterPrivate *priv = NM_BLUEZ_ADAPTER_GET_PRIVATE (self);
- GHashTableIter iter;
- NMBluezDevice *device;
-
- g_hash_table_iter_init (&iter, priv->devices);
- while (g_hash_table_iter_next (&iter, NULL, (gpointer) &device))
- g_signal_emit (self, signals[DEVICE_REMOVED], 0, device);
- g_hash_table_remove_all (priv->devices);
-
- G_OBJECT_CLASS (nm_bluez_adapter_parent_class)->dispose (object);
-}
-
-static void
-finalize (GObject *object)
-{
- NMBluezAdapterPrivate *priv = NM_BLUEZ_ADAPTER_GET_PRIVATE (object);
-
- g_hash_table_destroy (priv->devices);
- g_free (priv->address);
- g_free (priv->path);
- g_object_unref (priv->proxy);
-
- G_OBJECT_CLASS (nm_bluez_adapter_parent_class)->finalize (object);
-}
-
-static void
-get_property (GObject *object, guint prop_id,
- GValue *value, GParamSpec *pspec)
-{
- NMBluezAdapterPrivate *priv = NM_BLUEZ_ADAPTER_GET_PRIVATE (object);
-
- switch (prop_id) {
- case PROP_PATH:
- g_value_set_string (value, priv->path);
- break;
- case PROP_ADDRESS:
- g_value_set_string (value, priv->address);
- break;
- default:
- G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
- break;
- }
-}
-
-static void
-set_property (GObject *object, guint prop_id,
- const GValue *value, GParamSpec *pspec)
-{
- NMBluezAdapterPrivate *priv = NM_BLUEZ_ADAPTER_GET_PRIVATE (object);
-
- switch (prop_id) {
- case PROP_PATH:
- /* construct only */
- priv->path = g_value_dup_string (value);
- break;
- default:
- G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
- break;
- }
-}
-
-static void
-nm_bluez_adapter_class_init (NMBluezAdapterClass *config_class)
-{
- GObjectClass *object_class = G_OBJECT_CLASS (config_class);
-
- g_type_class_add_private (config_class, sizeof (NMBluezAdapterPrivate));
-
- /* virtual methods */
- object_class->get_property = get_property;
- object_class->set_property = set_property;
- object_class->dispose = dispose;
- object_class->finalize = finalize;
-
- /* Properties */
- g_object_class_install_property
- (object_class, PROP_PATH,
- g_param_spec_string (NM_BLUEZ_ADAPTER_PATH,
- "DBus Path",
- "DBus Path",
- NULL,
- G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY));
-
- g_object_class_install_property
- (object_class, PROP_ADDRESS,
- g_param_spec_string (NM_BLUEZ_ADAPTER_ADDRESS,
- "Address",
- "Address",
- NULL,
- G_PARAM_READABLE));
-
- /* Signals */
- signals[INITIALIZED] = g_signal_new ("initialized",
- G_OBJECT_CLASS_TYPE (object_class),
- G_SIGNAL_RUN_LAST,
- G_STRUCT_OFFSET (NMBluezAdapterClass, initialized),
- NULL, NULL,
- g_cclosure_marshal_VOID__BOOLEAN,
- G_TYPE_NONE, 1, G_TYPE_BOOLEAN);
-
- signals[DEVICE_ADDED] = g_signal_new ("device-added",
- G_OBJECT_CLASS_TYPE (object_class),
- G_SIGNAL_RUN_LAST,
- G_STRUCT_OFFSET (NMBluezAdapterClass, device_added),
- NULL, NULL,
- g_cclosure_marshal_VOID__OBJECT,
- G_TYPE_NONE, 1, G_TYPE_OBJECT);
-
- signals[DEVICE_REMOVED] = g_signal_new ("device-removed",
- G_OBJECT_CLASS_TYPE (object_class),
- G_SIGNAL_RUN_LAST,
- G_STRUCT_OFFSET (NMBluezAdapterClass, device_removed),
- NULL, NULL,
- g_cclosure_marshal_VOID__OBJECT,
- G_TYPE_NONE, 1, G_TYPE_OBJECT);
-}
-
diff --git a/src/bluez-manager/nm-bluez4-adapter.h b/src/bluez-manager/nm-bluez4-adapter.h
deleted file mode 100644
index 8e53b40d1..000000000
--- a/src/bluez-manager/nm-bluez4-adapter.h
+++ /dev/null
@@ -1,69 +0,0 @@
-/* -*- Mode: C; tab-width: 4; indent-tabs-mode: t; c-basic-offset: 4 -*- */
-/* NetworkManager -- Network link manager
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License along
- * with this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
- *
- * Copyright (C) 2009 - 2012 Red Hat, Inc.
- */
-
-#ifndef NM_BLUEZ_ADAPTER_H
-#define NM_BLUEZ_ADAPTER_H
-
-#include <glib.h>
-#include <glib-object.h>
-
-#include "nm-bluez-device.h"
-#include "nm-connection-provider.h"
-
-#define NM_TYPE_BLUEZ_ADAPTER (nm_bluez_adapter_get_type ())
-#define NM_BLUEZ_ADAPTER(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), NM_TYPE_BLUEZ_ADAPTER, NMBluezAdapter))
-#define NM_BLUEZ_ADAPTER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), NM_TYPE_BLUEZ_ADAPTER, NMBluezAdapterClass))
-#define NM_IS_BLUEZ_ADAPTER(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), NM_TYPE_BLUEZ_ADAPTER))
-#define NM_IS_BLUEZ_ADAPTER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), NM_TYPE_BLUEZ_ADAPTER))
-#define NM_BLUEZ_ADAPTER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), NM_TYPE_BLUEZ_ADAPTER, NMBluezAdapterClass))
-
-#define NM_BLUEZ_ADAPTER_PATH "path"
-#define NM_BLUEZ_ADAPTER_ADDRESS "address"
-
-typedef struct {
- GObject parent;
-} NMBluezAdapter;
-
-typedef struct {
- GObjectClass parent;
-
- /* virtual functions */
- void (*initialized) (NMBluezAdapter *self, gboolean success);
-
- void (*device_added) (NMBluezAdapter *self, NMBluezDevice *device);
-
- void (*device_removed) (NMBluezAdapter *self, NMBluezDevice *device);
-} NMBluezAdapterClass;
-
-GType nm_bluez_adapter_get_type (void);
-
-NMBluezAdapter *nm_bluez_adapter_new (const char *path,
- NMConnectionProvider *provider);
-
-const char *nm_bluez_adapter_get_path (NMBluezAdapter *self);
-
-const char *nm_bluez_adapter_get_address (NMBluezAdapter *self);
-
-gboolean nm_bluez_adapter_get_initialized (NMBluezAdapter *self);
-
-GSList *nm_bluez_adapter_get_devices (NMBluezAdapter *self);
-
-#endif /* NM_BLUEZ_ADAPTER_H */
-
diff --git a/src/bluez-manager/nm-bluez4-manager.c b/src/bluez-manager/nm-bluez4-manager.c
deleted file mode 100644
index bd1d251ac..000000000
--- a/src/bluez-manager/nm-bluez4-manager.c
+++ /dev/null
@@ -1,386 +0,0 @@
-/* -*- Mode: C; tab-width: 4; indent-tabs-mode: t; c-basic-offset: 4 -*- */
-/* NetworkManager -- Network link manager
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License along
- * with this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
- *
- * Copyright (C) 2007 - 2008 Novell, Inc.
- * Copyright (C) 2007 - 2012 Red Hat, Inc.
- */
-
-#include <signal.h>
-#include <string.h>
-#include <stdlib.h>
-#include <dbus/dbus-glib.h>
-
-#include "nm-logging.h"
-#include "nm-dbus-glib-types.h"
-#include "nm-marshal.h"
-#include "nm-bluez-manager.h"
-#include "nm-bluez4-adapter.h"
-#include "nm-dbus-manager.h"
-#include "nm-bluez-common.h"
-
-
-typedef struct {
- NMDBusManager *dbus_mgr;
- gulong name_owner_changed_id;
-
- NMConnectionProvider *provider;
-
- DBusGProxy *proxy;
-
- NMBluezAdapter *adapter;
-} NMBluezManagerPrivate;
-
-#define NM_BLUEZ_MANAGER_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), NM_TYPE_BLUEZ_MANAGER, NMBluezManagerPrivate))
-
-G_DEFINE_TYPE (NMBluezManager, nm_bluez_manager, G_TYPE_OBJECT)
-
-enum {
- BDADDR_ADDED,
- BDADDR_REMOVED,
-
- LAST_SIGNAL
-};
-
-static guint signals[LAST_SIGNAL] = { 0 };
-
-static void
-
-emit_bdaddr_added (NMBluezManager *self, NMBluezDevice *device)
-{
- g_signal_emit (self, signals[BDADDR_ADDED], 0,
- device,
- nm_bluez_device_get_address (device),
- nm_bluez_device_get_name (device),
- nm_bluez_device_get_path (device),
- nm_bluez_device_get_capabilities (device));
-}
-
-void
-nm_bluez_manager_query_devices (NMBluezManager *self)
-{
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
- GSList *devices, *iter;
-
- if (!priv->adapter)
- return;
-
- devices = nm_bluez_adapter_get_devices (priv->adapter);
- for (iter = devices; iter; iter = g_slist_next (iter))
- emit_bdaddr_added (self, NM_BLUEZ_DEVICE (iter->data));
- g_slist_free (devices);
-}
-
-static void
-device_added (NMBluezAdapter *adapter, NMBluezDevice *device, gpointer user_data)
-{
- emit_bdaddr_added (NM_BLUEZ_MANAGER (user_data), device);
-}
-
-static void
-device_removed (NMBluezAdapter *adapter, NMBluezDevice *device, gpointer user_data)
-{
- NMBluezManager *self = NM_BLUEZ_MANAGER (user_data);
-
- g_signal_emit (self, signals[BDADDR_REMOVED], 0,
- nm_bluez_device_get_address (device),
- nm_bluez_device_get_path (device));
-}
-
-static void
-adapter_initialized (NMBluezAdapter *adapter, gboolean success, gpointer user_data)
-{
- NMBluezManager *self = NM_BLUEZ_MANAGER (user_data);
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
-
- if (success) {
- GSList *devices, *iter;
-
- devices = nm_bluez_adapter_get_devices (adapter);
- for (iter = devices; iter; iter = g_slist_next (iter))
- emit_bdaddr_added (self, NM_BLUEZ_DEVICE (iter->data));
- g_slist_free (devices);
-
- g_signal_connect (adapter, "device-added", G_CALLBACK (device_added), self);
- g_signal_connect (adapter, "device-removed", G_CALLBACK (device_removed), self);
- } else {
- g_object_unref (priv->adapter);
- priv->adapter = NULL;
- }
-}
-
-static void
-adapter_removed (DBusGProxy *proxy, const char *path, NMBluezManager *self)
-{
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
-
- if (priv->adapter && !strcmp (path, nm_bluez_adapter_get_path (priv->adapter))) {
- if (nm_bluez_adapter_get_initialized (priv->adapter)) {
- GSList *devices, *iter;
-
- devices = nm_bluez_adapter_get_devices (priv->adapter);
- for (iter = devices; iter; iter = g_slist_next (iter)) {
- NMBluezDevice *device = NM_BLUEZ_DEVICE (iter->data);
-
- g_signal_emit (self, signals[BDADDR_REMOVED], 0,
- nm_bluez_device_get_address (device),
- nm_bluez_device_get_path (device));
- }
- g_slist_free (devices);
- }
-
- g_object_unref (priv->adapter);
- priv->adapter = NULL;
- }
-}
-
-static void
-default_adapter_changed (DBusGProxy *proxy, const char *path, NMBluezManager *self)
-{
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
- const char *cur_path = NULL;
-
- if (priv->adapter)
- cur_path = nm_bluez_adapter_get_path (priv->adapter);
-
- if (cur_path) {
- if (!path || strcmp (path, cur_path)) {
- /* Default adapter changed */
- adapter_removed (priv->proxy, cur_path, self);
- } else {
- /* This adapter is already the default */
- return;
- }
- }
-
- /* Add the new default adapter */
- if (path) {
- priv->adapter = nm_bluez_adapter_new (path, priv->provider);
- g_signal_connect (priv->adapter, "initialized", G_CALLBACK (adapter_initialized), self);
- }
-}
-
-static void
-default_adapter_cb (DBusGProxy *proxy, DBusGProxyCall *call, gpointer user_data)
-{
- NMBluezManager *self = NM_BLUEZ_MANAGER (user_data);
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
- const char *default_adapter = NULL;
- GError *err = NULL;
-
- if (!dbus_g_proxy_end_call (proxy, call, &err,
- DBUS_TYPE_G_OBJECT_PATH, &default_adapter,
- G_TYPE_INVALID)) {
- /* Ignore "No such adapter" errors; just means bluetooth isn't active */
- if ( !dbus_g_error_has_name (err, "org.bluez.Error.NoSuchAdapter")
- && !dbus_g_error_has_name (err, "org.freedesktop.systemd1.LoadFailed")
- && !g_error_matches (err, DBUS_GERROR, DBUS_GERROR_SERVICE_UNKNOWN)) {
- nm_log_warn (LOGD_BT, "bluez error getting default adapter: %s",
- err && err->message ? err->message : "(unknown)");
- }
- g_error_free (err);
- return;
- }
-
- default_adapter_changed (priv->proxy, default_adapter, self);
-}
-
-static void
-query_default_adapter (NMBluezManager *self)
-{
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
- DBusGProxyCall *call;
-
- call = dbus_g_proxy_begin_call (priv->proxy, "DefaultAdapter",
- default_adapter_cb,
- self,
- NULL, G_TYPE_INVALID);
- if (!call)
- nm_log_warn (LOGD_BT, "failed to request default Bluetooth adapter.");
-}
-
-static void
-bluez_connect (NMBluezManager *self)
-{
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
- DBusGConnection *connection;
-
- g_return_if_fail (priv->proxy == NULL);
-
- connection = nm_dbus_manager_get_connection (priv->dbus_mgr);
- if (!connection)
- return;
-
- priv->proxy = dbus_g_proxy_new_for_name (connection,
- BLUEZ_SERVICE,
- BLUEZ_MANAGER_PATH,
- BLUEZ_MANAGER_INTERFACE);
-
- dbus_g_proxy_add_signal (priv->proxy, "AdapterRemoved",
- DBUS_TYPE_G_OBJECT_PATH, G_TYPE_INVALID);
- dbus_g_proxy_connect_signal (priv->proxy, "AdapterRemoved",
- G_CALLBACK (adapter_removed), self, NULL);
-
- dbus_g_proxy_add_signal (priv->proxy, "DefaultAdapterChanged",
- DBUS_TYPE_G_OBJECT_PATH, G_TYPE_INVALID);
- dbus_g_proxy_connect_signal (priv->proxy, "DefaultAdapterChanged",
- G_CALLBACK (default_adapter_changed), self, NULL);
-
- query_default_adapter (self);
-}
-
-static void
-name_owner_changed_cb (NMDBusManager *dbus_mgr,
- const char *name,
- const char *old_owner,
- const char *new_owner,
- gpointer user_data)
-{
- NMBluezManager *self = NM_BLUEZ_MANAGER (user_data);
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
- gboolean old_owner_good = (old_owner && strlen (old_owner));
- gboolean new_owner_good = (new_owner && strlen (new_owner));
-
- /* Can't handle the signal if its not from the Bluez */
- if (strcmp (BLUEZ_SERVICE, name))
- return;
-
- if (!old_owner_good && new_owner_good)
- query_default_adapter (self);
- else if (old_owner_good && !new_owner_good) {
- /* Throwing away the adapter removes all devices too */
- if (priv->adapter) {
- g_object_unref (priv->adapter);
- priv->adapter = NULL;
- }
- }
-}
-
-static void
-bluez_cleanup (NMBluezManager *self, gboolean do_signal)
-{
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
-
- if (priv->proxy) {
- g_object_unref (priv->proxy);
- priv->proxy = NULL;
- }
-
- if (priv->adapter) {
- g_object_unref (priv->adapter);
- priv->adapter = NULL;
- }
-}
-
-static void
-dbus_connection_changed_cb (NMDBusManager *dbus_mgr,
- DBusGConnection *connection,
- gpointer user_data)
-{
- NMBluezManager *self = NM_BLUEZ_MANAGER (user_data);
-
- if (!connection)
- bluez_cleanup (self, TRUE);
- else
- bluez_connect (self);
-}
-
-/****************************************************************/
-
-NMBluezManager *
-nm_bluez_manager_get (NMConnectionProvider *provider)
-{
- static NMBluezManager *singleton = NULL;
-
- if (singleton)
- return g_object_ref (singleton);
-
- singleton = (NMBluezManager *) g_object_new (NM_TYPE_BLUEZ_MANAGER, NULL);
- g_assert (singleton);
-
- /* Cache the connection provider for NMBluezAdapter objects */
- NM_BLUEZ_MANAGER_GET_PRIVATE (singleton)->provider = provider;
-
- return singleton;
-}
-
-static void
-nm_bluez_manager_init (NMBluezManager *self)
-{
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
-
- priv->dbus_mgr = nm_dbus_manager_get ();
- g_assert (priv->dbus_mgr);
-
- g_signal_connect (priv->dbus_mgr,
- NM_DBUS_MANAGER_NAME_OWNER_CHANGED,
- G_CALLBACK (name_owner_changed_cb),
- self);
-
- g_signal_connect (priv->dbus_mgr,
- NM_DBUS_MANAGER_DBUS_CONNECTION_CHANGED,
- G_CALLBACK (dbus_connection_changed_cb),
- self);
-
- bluez_connect (self);
-}
-
-static void
-dispose (GObject *object)
-{
- NMBluezManager *self = NM_BLUEZ_MANAGER (object);
- NMBluezManagerPrivate *priv = NM_BLUEZ_MANAGER_GET_PRIVATE (self);
-
- bluez_cleanup (self, FALSE);
-
- if (priv->dbus_mgr) {
- g_signal_handlers_disconnect_by_func (priv->dbus_mgr, name_owner_changed_cb, self);
- g_signal_handlers_disconnect_by_func (priv->dbus_mgr, dbus_connection_changed_cb, self);
- g_object_unref (priv->dbus_mgr);
- }
-
- G_OBJECT_CLASS (nm_bluez_manager_parent_class)->dispose (object);
-}
-
-static void
-nm_bluez_manager_class_init (NMBluezManagerClass *klass)
-{
- GObjectClass *object_class = G_OBJECT_CLASS (klass);
-
- g_type_class_add_private (klass, sizeof (NMBluezManagerPrivate));
-
- /* virtual methods */
- object_class->dispose = dispose;
-
- /* Signals */
- signals[BDADDR_ADDED] =
- g_signal_new (NM_BLUEZ_MANAGER_BDADDR_ADDED,
- G_OBJECT_CLASS_TYPE (object_class),
- G_SIGNAL_RUN_FIRST,
- G_STRUCT_OFFSET (NMBluezManagerClass, bdaddr_added),
- NULL, NULL, NULL,
- G_TYPE_NONE, 5, G_TYPE_OBJECT, G_TYPE_STRING,
- G_TYPE_STRING, G_TYPE_STRING, G_TYPE_UINT);
-
- signals[BDADDR_REMOVED] =
- g_signal_new (NM_BLUEZ_MANAGER_BDADDR_REMOVED,
- G_OBJECT_CLASS_TYPE (object_class),
- G_SIGNAL_RUN_FIRST,
- G_STRUCT_OFFSET (NMBluezManagerClass, bdaddr_removed),
- NULL, NULL, NULL,
- G_TYPE_NONE, 2, G_TYPE_STRING, G_TYPE_STRING);
-}
-