printing: List Avahi printers

Show printers advertised by avahi on local network. CUPS
backend now looks for _ipps._tcp and _ipp._tcp services
offered by avahi. If it finds such a service (printer)
it requests its attributes through IPP_GET_PRINTER_ATTRIBUTES
ipp request and adds it to the list of printers. Such printer
behaves like a remote printer then.
If an avahi printer is a default printer then it is considered
default by the backend only if there is no local or remote
default printer.
This functionality is enabled when building Gtk+ with CUPS 1.6
or later because it replaces browsing protocol removed in CUPS 1.6.

https://bugzilla.gnome.org/show_bug.cgi?id=688956
This commit is contained in:
Marek Kasik 2013-03-04 14:29:24 +01:00
parent bfb327deda
commit eed9e72e83
7 changed files with 1081 additions and 160 deletions

View File

@ -1421,7 +1421,7 @@ else
$CUPS_API_MAJOR -eq 1 -a $CUPS_API_MINOR -ge 6; then $CUPS_API_MAJOR -eq 1 -a $CUPS_API_MINOR -ge 6; then
AC_DEFINE(HAVE_CUPS_API_1_6, 1, AC_DEFINE(HAVE_CUPS_API_1_6, 1,
[Define to 1 if CUPS 1.6 API is available]) [Define to 1 if CUPS 1.6 API is available])
have_cups_api_1_6=yes
fi fi
AC_SUBST(CUPS_API_MAJOR) AC_SUBST(CUPS_API_MAJOR)
@ -1452,6 +1452,45 @@ else
fi fi
fi fi
# Check for Avahi flags
AC_ARG_ENABLE(avahi-browsing,
[AS_HELP_STRING([--disable-avahi-browsing],
[disable avahi browsing of printers])],,
[enable_avahi_browsing=auto])
have_avahi_browsing=no
if test "x$enable_avahi_browsing" != "xno" -a \
"x$have_cups_api_1_6" = "xyes"; then
AC_MSG_CHECKING([avahi-gobject])
if $PKG_CONFIG --exists avahi-gobject ; then
AVAHI_CFLAGS=`$PKG_CONFIG --cflags avahi-gobject`
AC_SUBST(AVAHI_CFLAGS)
AVAHI_LIBS=`$PKG_CONFIG --libs avahi-gobject`
AC_SUBST(AVAHI_LIBS)
have_avahi_gobject=yes
AC_MSG_RESULT([yes])
else
AC_MSG_RESULT([no])
fi
if test "x$have_avahi_gobject" = "xyes" ; then
AC_DEFINE([HAVE_AVAHI_BROWSING], [1], [Define to 1 if avahi-gobject available])
have_avahi_browsing=yes
else
AC_MSG_ERROR([
*** avahi-gobject not found. avahi-gobject is required to build GTK+ with support
*** for avahi browsed printers when using CUPS 1.6.
])
fi
else
if test "x$enable_avahi_browsing" = "xyes"; then
AC_MSG_ERROR([
*** Avahi browsing support requested but CUPS 1.6 not found.
])
fi
fi
# Checks to see if we should compile with PAPI backend for GTK+ # Checks to see if we should compile with PAPI backend for GTK+
# #
@ -1828,6 +1867,7 @@ echo " Dynamic modules: $build_dynamic_modules"
echo " Included immodules: $included_immodules" echo " Included immodules: $included_immodules"
echo " PackageKit support: $build_packagekit" echo " PackageKit support: $build_packagekit"
echo " colord support: $have_colord" echo " colord support: $have_colord"
echo " Avahi browsing: $have_avahi_browsing"
echo " Introspection: $found_introspection" echo " Introspection: $found_introspection"
echo " Debugging: $enable_debug" echo " Debugging: $enable_debug"
echo " Documentation: $enable_gtk_doc" echo " Documentation: $enable_gtk_doc"

View File

@ -12,6 +12,7 @@ AM_CPPFLAGS = \
-I$(top_builddir)/gdk \ -I$(top_builddir)/gdk \
$(CUPS_CFLAGS) \ $(CUPS_CFLAGS) \
$(COLORD_CFLAGS) \ $(COLORD_CFLAGS) \
$(AVAHI_CFLAGS) \
-DGTK_COMPILATION \ -DGTK_COMPILATION \
-DGTK_PRINT_BACKEND_ENABLE_UNSUPPORTED \ -DGTK_PRINT_BACKEND_ENABLE_UNSUPPORTED \
$(GTK_DEP_CFLAGS) \ $(GTK_DEP_CFLAGS) \
@ -37,6 +38,6 @@ noinst_HEADERS = \
gtkcupsutils.h gtkcupsutils.h
libprintbackend_cups_la_LDFLAGS = -avoid-version -module $(no_undefined) libprintbackend_cups_la_LDFLAGS = -avoid-version -module $(no_undefined)
libprintbackend_cups_la_LIBADD = $(LDADDS) $(CUPS_LIBS) libprintbackend_cups_la_LIBADD = $(LDADDS) $(CUPS_LIBS) $(AVAHI_LIBS)
-include $(top_srcdir)/git.mk -include $(top_srcdir)/git.mk

View File

@ -87,6 +87,20 @@ static GtkCupsRequestStateFunc get_states[] = {
#define ippSetState(ipp_request, ipp_state) ipp_request->state = ipp_state #define ippSetState(ipp_request, ipp_state) ipp_request->state = ipp_state
#define ippGetString(attr, index, foo) attr->values[index].string.text #define ippGetString(attr, index, foo) attr->values[index].string.text
#define ippGetCount(attr) attr->num_values #define ippGetCount(attr) attr->num_values
int
ippSetVersion (ipp_t *ipp,
int major,
int minor)
{
if (!ipp || major < 0 || minor < 0)
return 0;
ipp->request.any.version[0] = major;
ipp->request.any.version[1] = minor;
return 1;
}
#endif #endif
static void static void
@ -656,6 +670,13 @@ gtk_cups_request_encode_option (GtkCupsRequest *request,
} }
} }
void
gtk_cups_request_set_ipp_version (GtkCupsRequest *request,
gint major,
gint minor)
{
ippSetVersion (request->ipp_request, major, minor);
}
static void static void
_connect (GtkCupsRequest *request) _connect (GtkCupsRequest *request)

View File

@ -178,6 +178,9 @@ gboolean gtk_cups_request_is_done (GtkCupsRequest *
void gtk_cups_request_encode_option (GtkCupsRequest *request, void gtk_cups_request_encode_option (GtkCupsRequest *request,
const gchar *option, const gchar *option,
const gchar *value); const gchar *value);
void gtk_cups_request_set_ipp_version (GtkCupsRequest *request,
gint major,
gint minor);
gboolean gtk_cups_result_is_error (GtkCupsResult *result); gboolean gtk_cups_result_is_error (GtkCupsResult *result);
ipp_t * gtk_cups_result_get_response (GtkCupsResult *result); ipp_t * gtk_cups_result_get_response (GtkCupsResult *result);
GtkCupsErrorType gtk_cups_result_get_error_type (GtkCupsResult *result); GtkCupsErrorType gtk_cups_result_get_error_type (GtkCupsResult *result);

File diff suppressed because it is too large Load Diff

View File

@ -114,6 +114,17 @@ gtk_printer_cups_init (GtkPrinterCups *printer)
printer->remote_cups_connection_test = NULL; printer->remote_cups_connection_test = NULL;
printer->auth_info_required = NULL; printer->auth_info_required = NULL;
printer->default_number_up = 1; printer->default_number_up = 1;
#ifdef HAVE_AVAHI_BROWSING
printer->avahi_browsed = FALSE;
printer->avahi_name = NULL;
printer->avahi_type = NULL;
printer->avahi_domain = NULL;
#endif
printer->ipp_version_major = 1;
printer->ipp_version_minor = 1;
printer->supports_copies = FALSE;
printer->supports_collate = FALSE;
printer->supports_number_up = FALSE;
} }
static void static void
@ -134,8 +145,11 @@ gtk_printer_cups_finalize (GObject *object)
g_strfreev (printer->auth_info_required); g_strfreev (printer->auth_info_required);
#ifdef HAVE_COLORD #ifdef HAVE_COLORD
if (printer->colord_cancellable)
{
g_cancellable_cancel (printer->colord_cancellable); g_cancellable_cancel (printer->colord_cancellable);
g_object_unref (printer->colord_cancellable); g_object_unref (printer->colord_cancellable);
}
g_free (printer->colord_title); g_free (printer->colord_title);
g_free (printer->colord_qualifier); g_free (printer->colord_qualifier);
if (printer->colord_client) if (printer->colord_client)
@ -146,6 +160,12 @@ gtk_printer_cups_finalize (GObject *object)
g_object_unref (printer->colord_profile); g_object_unref (printer->colord_profile);
#endif #endif
#ifdef HAVE_AVAHI_BROWSING
g_free (printer->avahi_name);
g_free (printer->avahi_type);
g_free (printer->avahi_domain);
#endif
if (printer->ppd_file) if (printer->ppd_file)
ppdClose (printer->ppd_file); ppdClose (printer->ppd_file);
@ -512,6 +532,7 @@ colord_printer_details_aquired_cb (GtkPrinterCups *printer,
gpointer user_data) gpointer user_data)
{ {
/* refresh the device */ /* refresh the device */
if (printer->colord_client)
colord_update_device (printer); colord_update_device (printer);
} }
#endif #endif
@ -565,6 +586,14 @@ gtk_printer_cups_new (const char *name,
G_CALLBACK (colord_printer_details_aquired_cb), G_CALLBACK (colord_printer_details_aquired_cb),
printer); printer);
#endif #endif
/*
* IPP version 1.1 has to be supported
* by all implementations according to rfc 2911
*/
printer->ipp_version_major = 1;
printer->ipp_version_minor = 1;
return printer; return printer;
} }

View File

@ -75,6 +75,17 @@ struct _GtkPrinterCups
gchar *colord_title; gchar *colord_title;
gchar *colord_qualifier; gchar *colord_qualifier;
#endif #endif
#ifdef HAVE_AVAHI_BROWSING
gboolean avahi_browsed;
gchar *avahi_name;
gchar *avahi_type;
gchar *avahi_domain;
#endif
guchar ipp_version_major;
guchar ipp_version_minor;
gboolean supports_copies;
gboolean supports_collate;
gboolean supports_number_up;
}; };
struct _GtkPrinterCupsClass struct _GtkPrinterCupsClass