summaryrefslogtreecommitdiffstats
path: root/cloud_print/virtual_driver
diff options
context:
space:
mode:
Diffstat (limited to 'cloud_print/virtual_driver')
-rw-r--r--cloud_print/virtual_driver/win/install/setup.cc51
-rw-r--r--cloud_print/virtual_driver/win/port_monitor/port_monitor.cc10
-rw-r--r--cloud_print/virtual_driver/win/virtual_driver_consts.cc2
-rw-r--r--cloud_print/virtual_driver/win/virtual_driver_consts.h2
4 files changed, 64 insertions, 1 deletions
diff --git a/cloud_print/virtual_driver/win/install/setup.cc b/cloud_print/virtual_driver/win/install/setup.cc
index 3497481..1b83cbb 100644
--- a/cloud_print/virtual_driver/win/install/setup.cc
+++ b/cloud_print/virtual_driver/win/install/setup.cc
@@ -13,12 +13,58 @@
#include "base/path_service.h"
#include "base/process_util.h"
#include "base/string16.h"
+#include "base/win/registry.h"
#include "base/win/scoped_handle.h"
#include "cloud_print/virtual_driver/win/virtual_driver_consts.h"
#include "cloud_print/virtual_driver/win/virtual_driver_helpers.h"
#include "grit/virtual_driver_setup_resources.h"
namespace {
+const wchar_t kVersionKey[] = L"pv";
+const wchar_t kNameKey[] = L"name";
+const wchar_t kLangKey[] = L"lang";
+const wchar_t kNameValue[] = L"GCP Virtual Driver";
+const wchar_t kLangValue[] = L"rn";
+
+void SetRegistryKeys() {
+ base::win::RegKey key;
+ if (key.Create(HKEY_LOCAL_MACHINE, cloud_print::kKeyLocation,
+ KEY_SET_VALUE) != ERROR_SUCCESS) {
+ LOG(ERROR) << "Unable to open key";
+ }
+
+ // Get the version from the resource file.
+ std::wstring version_string;
+ scoped_ptr<FileVersionInfo> version_info(
+ FileVersionInfo::CreateFileVersionInfoForCurrentModule());
+
+ if (version_info.get()) {
+ FileVersionInfoWin* version_info_win =
+ static_cast<FileVersionInfoWin*>(version_info.get());
+ version_string = version_info_win->product_version();
+ } else {
+ LOG(ERROR) << "Unable to get version string";
+ // Use a random version string so that Omaha has something to go by.
+ version_string = L"0.0.0.99";
+ }
+
+ if (key.WriteValue(kVersionKey, version_string.c_str()) != ERROR_SUCCESS ||
+ key.WriteValue(kNameKey, kNameValue) != ERROR_SUCCESS ||
+ key.WriteValue(kLangKey, kLangValue) != ERROR_SUCCESS) {
+ LOG(ERROR) << "Unable to set registry keys";
+ }
+}
+
+void DeleteRegistryKeys() {
+ base::win::RegKey key;
+ if (key.Open(HKEY_LOCAL_MACHINE, cloud_print::kKeyLocation,
+ DELETE) != ERROR_SUCCESS) {
+ LOG(ERROR) << "Unable to open key to delete";
+ }
+ if (key.DeleteKey(L"") != ERROR_SUCCESS) {
+ LOG(ERROR) << "Unable to delete key";
+ }
+}
HRESULT GetPpdPath(FilePath* path) {
if (!PathService::Get(base::DIR_EXE, path)) {
@@ -280,6 +326,7 @@ HRESULT InstallVirtualDriver(void) {
LOG(ERROR) << "Unable to install printer.";
return result;
}
+ SetRegistryKeys();
return S_OK;
}
@@ -300,6 +347,7 @@ HRESULT UninstallVirtualDriver(void) {
LOG(ERROR) << "Unable to remove port monitor.";
return result;
}
+ DeleteRegistryKeys();
return S_OK;
}
@@ -317,7 +365,8 @@ int WINAPI WinMain(__in HINSTANCE hInstance,
} else {
retval = InstallVirtualDriver();
}
- if (!CommandLine::ForCurrentProcess()->HasSwitch("silent")) {
+ // Installer is silent by default as required by Omaha.
+ if (CommandLine::ForCurrentProcess()->HasSwitch("verbose")) {
cloud_print::DisplayWindowsMessage(NULL, retval,
cloud_print::LoadLocalString(IDS_DRIVER_NAME));
}
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 fe3398f..3e02e36 100644
--- a/cloud_print/virtual_driver/win/port_monitor/port_monitor.cc
+++ b/cloud_print/virtual_driver/win/port_monitor/port_monitor.cc
@@ -357,6 +357,16 @@ BOOL WINAPI Monitor2StartDocPort(HANDLE port_handle,
DWORD,
BYTE*) {
LOG(INFO) << "Monitor2StartDocPort";
+ const wchar_t* kUsageKey = L"dr";
+ // Set appropriate key to 1 to let Omaha record usage.
+ base::win::RegKey key;
+ if (key.Create(HKEY_CURRENT_USER, kKeyLocation,
+ KEY_SET_VALUE) != ERROR_SUCCESS) {
+ LOG(ERROR) << "Unable to open key to log usage";
+ }
+ if (key.WriteValue(kUsageKey, L"1") != ERROR_SUCCESS) {
+ LOG(ERROR) << "Unable to set usage key";
+ }
if (port_handle == NULL) {
LOG(ERROR) << "port_handle should not be NULL.";
SetLastError(ERROR_INVALID_PARAMETER);
diff --git a/cloud_print/virtual_driver/win/virtual_driver_consts.cc b/cloud_print/virtual_driver/win/virtual_driver_consts.cc
index 820ee53..7d13eeb 100644
--- a/cloud_print/virtual_driver/win/virtual_driver_consts.cc
+++ b/cloud_print/virtual_driver/win/virtual_driver_consts.cc
@@ -9,5 +9,7 @@
namespace cloud_print {
const wchar_t kPortName[] = L"GCP:";
const size_t kPortNameSize = sizeof(kPortName);
+const wchar_t kKeyLocation[] =
+ L"SOFTWARE\\Google\\Update\\Clients\\{9B13FA92-1F73-4761-AB78-2C6ADAC3660D}";
}
diff --git a/cloud_print/virtual_driver/win/virtual_driver_consts.h b/cloud_print/virtual_driver/win/virtual_driver_consts.h
index 78aab9c..7f75f6e 100644
--- a/cloud_print/virtual_driver/win/virtual_driver_consts.h
+++ b/cloud_print/virtual_driver/win/virtual_driver_consts.h
@@ -9,7 +9,9 @@
namespace cloud_print {
extern const wchar_t kPortName[];
extern const size_t kPortNameSize;
+extern const wchar_t kKeyLocation[];
} // namespace cloud_print
+
#endif // CLOUD_PRINT_VIRTUAL_DRIVER_WIN_VIRTUAL_DRIVER_CONSTS_H_