diff options
author | sadrul@chromium.org <sadrul@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-07-13 17:59:12 +0000 |
---|---|---|
committer | sadrul@chromium.org <sadrul@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-07-13 17:59:12 +0000 |
commit | 04eb2a4471cd1bcfbedd711360d5eaa1dc0d2bdf (patch) | |
tree | 362cd7f2f654274794672ce3b1c2383c9acb4b5e /cloud_print/virtual_driver | |
parent | 509d9b37a4c35fbc6210b3232d79e777cec0ff3a (diff) | |
download | chromium_src-04eb2a4471cd1bcfbedd711360d5eaa1dc0d2bdf.zip chromium_src-04eb2a4471cd1bcfbedd711360d5eaa1dc0d2bdf.tar.gz chromium_src-04eb2a4471cd1bcfbedd711360d5eaa1dc0d2bdf.tar.bz2 |
Revert 92378 because it broke Win Builder (dbg)(shared) - Additional Commits for Linux printer driver
Initial commit for Linux virtual printer
BUG=
TEST=
Review URL: http://codereview.chromium.org/7222011
TBR=abeera@google.com
Review URL: http://codereview.chromium.org/7354024
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@92379 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'cloud_print/virtual_driver')
9 files changed, 23 insertions, 316 deletions
diff --git a/cloud_print/virtual_driver/posix/backend.gyp b/cloud_print/virtual_driver/posix/backend.gyp deleted file mode 100644 index 8492a80..0000000 --- a/cloud_print/virtual_driver/posix/backend.gyp +++ /dev/null @@ -1,32 +0,0 @@ -# Copyright (c) 2011 The Chromium Authors. All rights reserved. -# Use of this source code is governed by a BSD-style license that can be -# found in the LICENSE file. - -{ - 'target_defaults': { - 'include_dirs': [ - '../..' - ], - }, - 'targets' : [ - { - 'target_name': 'GCP-driver', - 'type': 'executable', - 'dependencies': [ - '../../../base/base.gyp:base', - ], - 'msvs_guid': '8D06D53B-289E-4f99-99FC-77C77DB478A8', - 'sources' : [ - 'virtual_driver_posix.cc', - 'printer_driver_util_linux.cc', - '../virtual_driver_switches.cc', - ] - }, - ], -} - -# Local Variables: -# tab-width:2 -# indent-tabs-mode:nil -# End: -# vim: set expandtab tabstop=2 shiftwidth=2: diff --git a/cloud_print/virtual_driver/posix/printer_driver_util_linux.cc b/cloud_print/virtual_driver/posix/printer_driver_util_linux.cc deleted file mode 100644 index 119a4b5..0000000 --- a/cloud_print/virtual_driver/posix/printer_driver_util_linux.cc +++ /dev/null @@ -1,48 +0,0 @@ -// Copyright (c) 2011 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include <cups/backend.h> - -#include "base/base_paths.h" -#include "base/command_line.h" -#include "base/file_path.h" -#include "base/logging.h" -#include "base/path_service.h" - -#include "cloud_print/virtual_driver/posix/printer_driver_util_posix.h" -#include "cloud_print/virtual_driver/virtual_driver_switches.h" - -void LaunchPrintDialog(std::string output_path, std::string job_title, - std::string current_user) { - std::string set_var; - - // Set Environment variable to control display. - set_var="/home/" + current_user + "/.Xauthority"; - if(setenv("DISPLAY",":0.0",0) == -1) { - LOG(ERROR) << "Unable to set DISPLAY environment variable"; - } - if(setenv("XAUTHORITY",set_var.c_str(),0) == -1) { - LOG(ERROR) << "Unable to set XAUTHORITY environment variable"; - } - - // Construct the call to Chrome - - FilePath chrome_path("google-chrome"); - FilePath job_path(output_path); - CommandLine command_line(chrome_path); - command_line.AppendSwitchPath(switches::kCloudPrintFile,job_path); - command_line.AppendSwitchNative(switches::kCloudPrintJobTitle, job_title); - command_line.AppendSwitch(switches::kCloudPrintDeleteFile); - LOG(INFO) << "Call to chrome is " << command_line.command_line_string(); - - if(system(command_line.command_line_string().c_str())== -1 ) { - LOG(ERROR) << "Unable to call Chrome"; - exit(CUPS_BACKEND_CANCEL); - } - - else { - LOG(INFO) << "Call to Chrome succeeded"; - } -} - diff --git a/cloud_print/virtual_driver/posix/printer_driver_util_posix.h b/cloud_print/virtual_driver/posix/printer_driver_util_posix.h deleted file mode 100644 index 4d8d7a5..0000000 --- a/cloud_print/virtual_driver/posix/printer_driver_util_posix.h +++ /dev/null @@ -1,12 +0,0 @@ -// Copyright (c) 2011 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. -#ifndef CLOUD_PRINT_VIRTUAL_DRIVER_LINUX_PRINTER_DRIVER_UTIL_POSIX_H_ -#define CLOUD_PRINT_VIRTUAL_DRIVER_LINUX_PRINTER_DRIVER_UTIL_POSIX_H_ -#pragma once -#include <string> - -void LaunchPrintDialog(std::string output_path, std::string job_title, - std::string current_user); - -#endif // CLOUD_PRINT_VIRTUAL_DRIVER_LINUX_PRINTER_DRIVER_UTIL_POSIX_H_ diff --git a/cloud_print/virtual_driver/posix/virtual_driver_posix.cc b/cloud_print/virtual_driver/posix/virtual_driver_posix.cc deleted file mode 100644 index 868228a..0000000 --- a/cloud_print/virtual_driver/posix/virtual_driver_posix.cc +++ /dev/null @@ -1,156 +0,0 @@ -// Copyright (c) 2011 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include <pwd.h> -#include <stdio.h> - -#include <cups/backend.h> - -#include <sys/stat.h> -#include <sys/types.h> -#include <sys/wait.h> - -#include "base/at_exit.h" -#include "base/base_paths.h" -#include "base/command_line.h" -#include "base/file_path.h" -#include "base/logging.h" -#include "base/path_service.h" - -#include "cloud_print/virtual_driver/posix/printer_driver_util_posix.h" - -using namespace std; - -int WriteToTemp(FILE* input_pdf, FilePath output_path) { - FILE* output_pdf; - char buffer[128]; - output_pdf = fopen(output_path.value().c_str(),"w"); - if(output_pdf == NULL) { - LOG(ERROR) <<"Unable to open file handle for writing output file"; - exit(CUPS_BACKEND_CANCEL); - } - // Read from input file or stdin and write to output file. - while(fgets(buffer,128,input_pdf) != NULL){ - fputs(buffer, output_pdf); - } - - LOG(INFO) << "Successfully wrote output file"; - // ensure everything is written, then close the files. - fflush(output_pdf); - fclose(input_pdf); - fclose(output_pdf); -} - -void SetUser(const char* user) { - struct passwd* calling_user=NULL; - calling_user=getpwnam(user); - if(calling_user == NULL) { - LOG(ERROR) << "Unable to get calling user"; - exit(CUPS_BACKEND_CANCEL); - } - if(setgid(calling_user->pw_gid)==-1) { - LOG(ERROR) << "Unable to set group ID"; - exit(CUPS_BACKEND_CANCEL); - } - if(!setuid(calling_user->pw_uid)==-1) { - LOG(ERROR) << "Unable to set UID"; - exit(CUPS_BACKEND_CANCEL); - } - - LOG(INFO) << "Successfully set user and group ID"; -} - - - -// Main function for backend. -int main(int argc, const char* argv[]) { - // With no arguments, send identification string as required by CUPS. - if (argc==1) { - printf("file GCP-driver:/ \"GCP Virtual Driver\" \"GCP Virtual Driver\" " - "\"MFG:Google Inc.;MDL:GCP Virtual Driver;DES:GCP Virtual Driver;" - "CLS:PRINTER;CMD:POSTSCRIPT;\"\n"); - return 0; - } - - if (argc<6 || argc>7) { - fprintf(stderr,"Usage: GCP-Driver job-id user" - "title copies options [file]\n"); - return 0; - } - - //AtExitManager is necessary to use the path service. - base::AtExitManager aemanager; - // File handler for the temporary PDF we pass onto Chrome. - FILE* output_pdf; - //CommandLine is only setup to enable logging, never used subseqeuently. - CommandLine::Init(argc,argv); - // Location for the log file. - std::string log_location="/var/log/GCP-Driver.log"; - - // Set up logging. - logging::InitLogging(log_location.c_str(), - logging::LOG_ONLY_TO_FILE, - logging::LOCK_LOG_FILE, - logging::APPEND_TO_OLD_LOG_FILE, - logging::DISABLE_DCHECK_FOR_NON_OFFICIAL_RELEASE_BUILDS); - - // Temporary directory to hold the output file. - FilePath temp_dir; - // Strings to hold details of current job. - std::string current_user; - std::string set_var; - std::string job_title; - std::string job_id; - std::string file_name; - - // Get temp directory to hold spool file. - if(!PathService::Get(base::DIR_TEMP, &temp_dir)) { - LOG(ERROR) << "Unable to get DIR_TEMP"; - return CUPS_BACKEND_CANCEL; - } - // Get details from command line and set spool path. - current_user = argv[2]; - job_title = argv[3]; - job_id = argv[1]; - file_name = current_user + "-" + job_title + "-" + job_id; - FilePath output_path = temp_dir.Append(file_name); - - // Read from file if specified. - if(argc==7){ - FILE* input_pdf=fopen(argv[6],"r"); - if(input_pdf == NULL) { - LOG(ERROR) << "Unable to read input PDF"; - return CUPS_BACKEND_CANCEL; - } - // File is opened. - WriteToTemp(input_pdf,output_path); - } - // Otherwise, read from stdin. - else{ - WriteToTemp(stdin, output_path); - } - - // Set File permissions to allow non-sudo user to read spool file. - if(chmod(output_path.value().c_str(),S_IRUSR|S_IWUSR|S_IROTH|S_IWOTH)!=0) { - LOG(ERROR)<<"Unable to change file permissions"; - return CUPS_BACKEND_CANCEL; - } - - pid_t pid=fork(); - - if(!pid) { - // In child process. - - // Set the user to the one that initiated print job. - SetUser(argv[2]); - - // Launch Chrome and pass the print job onto Cloud Print. - LaunchPrintDialog(output_path.value(), job_title, current_user); - - return 0; - }// back in parent process. - // wait for child, then terminate. - waitpid(pid,NULL,0); - return 0; -}// main diff --git a/cloud_print/virtual_driver/virtual_driver_linux.gyp b/cloud_print/virtual_driver/virtual_driver_linux.gyp deleted file mode 100644 index 53fa411..0000000 --- a/cloud_print/virtual_driver/virtual_driver_linux.gyp +++ /dev/null @@ -1,20 +0,0 @@ -# Copyright (c) 2011 The Chromium Authors. All rights reserved. -# Use of this source code is governed by a BSD-style license that can be -# found in the LICENSE file. -{ - 'targets': [ - { - 'target_name': 'virtual_driver', - 'type': 'none', - 'dependencies': [ - 'posix/backend.gyp:*', - ], - }, - ], -} - -# Local Variables: -# tab-width:2 -# indent-tabs-mode:nil -# End: -# vim: set expandtab tabstop=2 shiftwidth=2: diff --git a/cloud_print/virtual_driver/virtual_driver_switches.cc b/cloud_print/virtual_driver/virtual_driver_switches.cc deleted file mode 100644 index 59022f1..0000000 --- a/cloud_print/virtual_driver/virtual_driver_switches.cc +++ /dev/null @@ -1,13 +0,0 @@ -// Copyright (c) 2011 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "cloud_print/virtual_driver/virtual_driver_switches.h" - -namespace switches { -const char kCloudPrintDeleteFile[] = "cloud-print-delete-file"; -const char kCloudPrintFile[] = "cloud-print-file"; -const char kCloudPrintJobTitle[] = "cloud-print-job-title"; -const char kCloudPrintFileType[] = "cloud-print-file-type"; -} //namespace switches - diff --git a/cloud_print/virtual_driver/virtual_driver_switches.h b/cloud_print/virtual_driver/virtual_driver_switches.h deleted file mode 100644 index aa8f127..0000000 --- a/cloud_print/virtual_driver/virtual_driver_switches.h +++ /dev/null @@ -1,33 +0,0 @@ -// Copyright (c) 2011 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef CLOUD_PRINT_VIRTUAL_DRIVER_VIRTUAL_DRIVER_SWITCHES_H -#define CLOUD_PRINT_VIRTUAL_DRIVER_VIRTUAL_DRIVER_SWITCHES_H -#pragma once - -namespace switches { -// These constants are duplicated from chrome/common/chrome_switches.cc -// in order to avoid dependency problems. -// TODO(abodenha@chromium.org) Reunify them in some sensible manner. -// Bug: www.crbug.com/88991 - -// Used with kCloudPrintFile. Tells Chrome to delete the file when -// finished displaying the print dialog. -extern const char kCloudPrintDeleteFile[]; - -// Tells chrome to display the cloud print dialog and upload the -// specified file for printing. -extern const char kCloudPrintFile[]; - -// Used with kCloudPrintFile to specify a title for the resulting print -// job. -extern const char kCloudPrintJobTitle[]; - -// Specifies the mime type to be used when uploading data from the -// file referenced by cloud-print-file. -// Defaults to "application/pdf" if unspecified. -extern const char kCloudPrintFileType[]; -} //namespace switches - -#endif // CLOUD_PRINT_VIRTUAL_DRIVER_VIRTUAL_DRIVER_SWITCHES_H diff --git a/cloud_print/virtual_driver/win/port_monitor/port_monitor.cc b/cloud_print/virtual_driver/win/port_monitor/port_monitor.cc index 0c196ba1..562d0b8 100644 --- a/cloud_print/virtual_driver/win/port_monitor/port_monitor.cc +++ b/cloud_print/virtual_driver/win/port_monitor/port_monitor.cc @@ -25,7 +25,29 @@ #include "cloud_print/virtual_driver/win/port_monitor/spooler_win.h" #include "cloud_print/virtual_driver/win/virtual_driver_consts.h" #include "cloud_print/virtual_driver/win/virtual_driver_helpers.h" -#include "cloud_print/virtual_driver/virtual_driver_switches.h" + +namespace switches { +// These constants are duplicated from chrome/common/chrome_switches.cc +// in order to avoid dependency problems. +// TODO(abodenha@chromium.org) Reunify them in some sensible manner. + +// Used with kCloudPrintFile. Tells Chrome to delete the file when +// finished displaying the print dialog. +const char kCloudPrintDeleteFile[] = "cloud-print-delete-file"; + +// Tells chrome to display the cloud print dialog and upload the +// specified file for printing. +const char kCloudPrintFile[] = "cloud-print-file"; + +// Used with kCloudPrintFile to specify a title for the resulting print +// job. +const char kCloudPrintJobTitle[] = "cloud-print-job-title"; + +// Specifies the mime type to be used when uploading data from the +// file referenced by cloud-print-file. +// Defaults to "application/pdf" if unspecified. +const char kCloudPrintFileType[] = "cloud-print-file-type"; +} namespace cloud_print { diff --git a/cloud_print/virtual_driver/win/port_monitor/virtual_driver_port_monitor.gyp b/cloud_print/virtual_driver/win/port_monitor/virtual_driver_port_monitor.gyp index 0a15c14..e04c25f 100644 --- a/cloud_print/virtual_driver/win/port_monitor/virtual_driver_port_monitor.gyp +++ b/cloud_print/virtual_driver/win/port_monitor/virtual_driver_port_monitor.gyp @@ -17,7 +17,6 @@ 'userenv.lib', ], 'sources': [ - '../../virtual_driver_switches.cc', '../virtual_driver_consts.h', '../virtual_driver_consts.cc', '../virtual_driver_helpers.h', |