diff options
author | Marek Kasik <mkasik@redhat.com> | 2019-09-19 18:35:23 +0200 |
---|---|---|
committer | Marek Kasik <mkasik@redhat.com> | 2019-09-19 18:35:23 +0200 |
commit | 58cfa3fd4956332797f0dd35563cdccb1e0323ea (patch) | |
tree | 3b9a54e6325f65da6cca3388b129aa931b5a81f7 | |
parent | 87e7fa9917d89f1ad74a744995ea6c0e81281659 (diff) | |
download | gtk+-58cfa3fd4956332797f0dd35563cdccb1e0323ea.tar.gz |
printing: Get PPD from original host if needed
Try to get PPD from original host if there is no PPD for remote printer
on current CUPS server.
-rw-r--r-- | modules/printbackends/gtkprintbackendcups.c | 86 | ||||
-rw-r--r-- | modules/printbackends/gtkprintercups.c | 6 | ||||
-rw-r--r-- | modules/printbackends/gtkprintercups.h | 4 |
3 files changed, 84 insertions, 12 deletions
diff --git a/modules/printbackends/gtkprintbackendcups.c b/modules/printbackends/gtkprintbackendcups.c index 87cf6d3ce3..c0f6d98439 100644 --- a/modules/printbackends/gtkprintbackendcups.c +++ b/modules/printbackends/gtkprintbackendcups.c @@ -2458,13 +2458,25 @@ cups_create_printer (GtkPrintBackendCups *cups_backend, cups_printer->default_cover_before = g_strdup (info->default_cover_before); cups_printer->default_cover_after = g_strdup (info->default_cover_after); cups_printer->original_device_uri = g_strdup (info->original_device_uri); + cups_printer->hostname = g_strdup (hostname); + cups_printer->port = port; + + if (cups_printer->original_device_uri != NULL) + { + httpSeparateURI (HTTP_URI_CODING_ALL, cups_printer->original_device_uri, + method, sizeof (method), + username, sizeof (username), + hostname, sizeof (hostname), + &port, + resource, sizeof (resource)); + cups_printer->original_hostname = g_strdup (hostname); + cups_printer->original_resource = g_strdup (resource); + cups_printer->original_port = port; + } if (info->default_number_up > 0) cups_printer->default_number_up = info->default_number_up; - cups_printer->hostname = g_strdup (hostname); - cups_printer->port = port; - cups_printer->auth_info_required = g_strdupv (info->auth_info_required); g_strfreev (info->auth_info_required); @@ -3760,10 +3772,47 @@ cups_request_ppd_cb (GtkPrintBackendCups *print_backend, ((gtk_cups_result_get_error_type (result) == GTK_CUPS_ERROR_HTTP) && (gtk_cups_result_get_error_status (result) == HTTP_NOT_FOUND)))) { - cups_request_printer_info (GTK_PRINTER_CUPS (printer)->printer_uri, - GTK_PRINTER_CUPS (printer)->hostname, - GTK_PRINTER_CUPS (printer)->port, - GTK_PRINT_BACKEND_CUPS (gtk_printer_get_backend (printer))); + GtkPrinterCups *cups_printer = GTK_PRINTER_CUPS (printer); + + /* Try to get the PPD from original host if it is not + * available on current CUPS server. + */ + if (!cups_printer->avahi_browsed && + (gtk_cups_result_is_error (result) && + ((gtk_cups_result_get_error_type (result) == GTK_CUPS_ERROR_HTTP) && + (gtk_cups_result_get_error_status (result) == HTTP_NOT_FOUND))) && + cups_printer->remote && + !cups_printer->request_original_uri && + cups_printer->original_device_uri != NULL && + (g_str_has_prefix (cups_printer->original_device_uri, "ipp://") || + g_str_has_prefix (cups_printer->original_device_uri, "ipps://"))) + { + cups_printer->request_original_uri = TRUE; + + gtk_cups_connection_test_free (cups_printer->remote_cups_connection_test); + g_clear_handle_id (&cups_printer->get_remote_ppd_poll, g_source_remove); + cups_printer->get_remote_ppd_attempts = 0; + + cups_printer->remote_cups_connection_test = + gtk_cups_connection_test_new (cups_printer->original_hostname, + cups_printer->original_port); + + if (cups_request_ppd (printer)) + { + cups_printer->get_remote_ppd_poll = g_timeout_add (50, (GSourceFunc) cups_request_ppd, printer); + g_source_set_name_by_id (cups_printer->get_remote_ppd_poll, "[gtk] cups_request_ppd"); + } + } + else + { + if (cups_printer->request_original_uri) + cups_printer->request_original_uri = FALSE; + + cups_request_printer_info (cups_printer->printer_uri, + cups_printer->hostname, + cups_printer->port, + GTK_PRINT_BACKEND_CUPS (gtk_printer_get_backend (printer))); + } return; } @@ -3784,6 +3833,8 @@ cups_request_ppd (GtkPrinter *printer) http_t *http; GetPPDData *data; int fd; + const gchar *hostname; + gint port; cups_printer = GTK_PRINTER_CUPS (printer); @@ -3826,7 +3877,21 @@ cups_request_ppd (GtkPrinter *printer) } } - http = httpConnect2 (cups_printer->hostname, cups_printer->port, + if (cups_printer->request_original_uri) + { + hostname = cups_printer->original_hostname; + port = cups_printer->original_port; + resource = g_strdup_printf ("%s.ppd", cups_printer->original_resource); + } + else + { + hostname = cups_printer->hostname; + port = cups_printer->port; + resource = g_strdup_printf ("/printers/%s.ppd", + gtk_printer_cups_get_ppd_name (GTK_PRINTER_CUPS (printer))); + } + + http = httpConnect2 (hostname, port, NULL, AF_UNSPEC, cupsEncryption (), 1, 30000, NULL); @@ -3867,16 +3932,13 @@ cups_request_ppd (GtkPrinter *printer) data->printer = (GtkPrinterCups *) g_object_ref (printer); - resource = g_strdup_printf ("/printers/%s.ppd", - gtk_printer_cups_get_ppd_name (GTK_PRINTER_CUPS (printer))); - print_backend = gtk_printer_get_backend (printer); request = gtk_cups_request_new_with_username (data->http, GTK_CUPS_GET, 0, data->ppd_io, - cups_printer->hostname, + hostname, resource, GTK_PRINT_BACKEND_CUPS (print_backend)->username); diff --git a/modules/printbackends/gtkprintercups.c b/modules/printbackends/gtkprintercups.c index d358d19eab..e50dcf7d98 100644 --- a/modules/printbackends/gtkprintercups.c +++ b/modules/printbackends/gtkprintercups.c @@ -105,6 +105,10 @@ gtk_printer_cups_init (GtkPrinterCups *printer) printer->state = 0; printer->hostname = NULL; printer->port = 0; + printer->original_hostname = NULL; + printer->original_resource = NULL; + printer->original_port = 0; + printer->request_original_uri = FALSE; printer->ppd_name = NULL; printer->ppd_file = NULL; printer->default_cover_before = NULL; @@ -153,6 +157,8 @@ gtk_printer_cups_finalize (GObject *object) g_free (printer->original_device_uri); g_free (printer->printer_uri); g_free (printer->hostname); + g_free (printer->original_hostname); + g_free (printer->original_resource); g_free (printer->ppd_name); g_free (printer->default_cover_before); g_free (printer->default_cover_after); diff --git a/modules/printbackends/gtkprintercups.h b/modules/printbackends/gtkprintercups.h index 7517e4b99f..02a440b4e5 100644 --- a/modules/printbackends/gtkprintercups.h +++ b/modules/printbackends/gtkprintercups.h @@ -53,6 +53,10 @@ struct _GtkPrinterCups gchar *hostname; gint port; gchar **auth_info_required; + gchar *original_hostname; + gchar *original_resource; + gint original_port; + gboolean request_original_uri; /* Request PPD from original host */ ipp_pstate_t state; gboolean reading_ppd; |