1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
|
// Copyright (c) 2006-2008 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 CHROME_BROWSER_RLZ_RLZ_H__
#define CHROME_BROWSER_RLZ_RLZ_H__
#include <string>
#include "base/basictypes.h"
// RLZ is a library which is used to measure partner distribution deals.
// Its job is to record certain lifetime events in the registry and to send
// them encoded as a compact string at most once per day. The sent data does
// not contain information that can be used to identify a user or to infer
// browsing habits. The API in this file is a wrapper to rlz.dll which can be
// removed of the system with no adverse effects on chrome.
class RLZTracker {
public:
// An Access Point offers a way to search using Google. Other products
// have specific entries here so do not remove the reserved access points.
enum AccessPoint {
NO_ACCESS_POINT = 0,
RESERVED_ACCESS_POINT_01,
RESERVED_ACCESS_POINT_02,
RESERVED_ACCESS_POINT_03,
RESERVED_ACCESS_POINT_04,
RESERVED_ACCESS_POINT_05,
RESERVED_ACCESS_POINT_06,
RESERVED_ACCESS_POINT_07,
RESERVED_ACCESS_POINT_08,
CHROME_OMNIBOX,
CHROME_HOME_PAGE,
LAST_ACCESS_POINT
};
// A product is an entity which wants to gets credit for setting an access
// point. Currently only the browser itself is supported but installed apps
// could have their own entry here.
enum Product {
RESERVED_PRODUCT_01 = 1,
RESERVED_PRODUCT_02,
RESERVED_PRODUCT_03,
RESERVED_PRODUCT_04,
CHROME,
LAST_PRODUCT
};
// Life cycle events. Some of them are applicable to all access points.
enum Event {
INVALID_EVENT = 0,
INSTALL = 1,
SET_TO_GOOGLE,
FIRST_SEARCH,
REPORT_RLS,
LAST_EVENT
};
// Initializes the RLZ library services. 'directory_key' indicates the base
// directory the RLZ dll would be found. For example base::DIR_CURRENT.
// If the RLZ dll is not found in this directory the code falls back to try
// to load it from base::DIR_EXE.
// Returns false if the dll could not be loaded and initialized.
// This function is intended primarily for testing.
static bool InitRlz(int directory_key);
// Like InitRlz() this function the RLZ library services for use in chrome.
// Besides binding the dll, it schedules a delayed task that performs the
// daily ping and registers the some events when 'first-run' is true.
static bool InitRlzDelayed(int directory_key, bool first_run);
// Records an RLZ event. Some events can be access point independent.
// Returns false it the event could not be recorded. Requires write access
// to the HKCU registry hive on windows.
static bool RecordProductEvent(Product product, AccessPoint point,
Event event_id);
// Get the RLZ value of the access point.
// Returns false if the rlz string could not be obtained. In some cases
// an empty string can be returned which is not an error.
static bool GetAccessPointRlz(AccessPoint point, std::wstring* rlz);
// Clear all events reported by this product. In Chrome this will be called
// when it is un-installed.
static bool ClearAllProductEvents(Product product);
// Called once a day to report the events to the server and to get updated
// RLZs for the different access points. This call uses Wininet to perform
// the http request. Returns true if the transaction succeeded and returns
// false if the transaction failed OR if a previous ping request was done
// in the last 24 hours.
static bool SendFinancialPing(Product product,
const wchar_t* product_signature,
const wchar_t* product_brand,
const wchar_t* product_id,
const wchar_t* product_lang);
private:
DISALLOW_IMPLICIT_CONSTRUCTORS(RLZTracker);
};
#endif // CHROME_BROWSER_RLZ_RLZ_H__
|