summaryrefslogtreecommitdiffstats
path: root/ceee/ie/plugin/bho/webnavigation_events_funnel.cc
blob: 2717131dd8c074de071df1ee6c0e58d07b79a95a (plain)
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
106
107
108
109
110
111
112
113
// Copyright (c) 2010 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.
//
// Funnel of Chrome Extension Events from wherever through the Broker.

#include "ceee/ie/plugin/bho/webnavigation_events_funnel.h"

#include "base/logging.h"
#include "base/values.h"
#include "chrome/browser/extensions/extension_webnavigation_api_constants.h"

namespace keys = extension_webnavigation_api_constants;

namespace {

double MilliSecondsFromTime(const base::Time& time) {
  return base::Time::kMillisecondsPerSecond * time.ToDoubleT();
}

}  // namespace

HRESULT WebNavigationEventsFunnel::OnBeforeNavigate(
    CeeeWindowHandle tab_handle,
    BSTR url,
    int frame_id,
    int request_id,
    const base::Time& time_stamp) {
  DictionaryValue args;
  args.SetInteger(keys::kTabIdKey, static_cast<int>(tab_handle));
  args.SetString(keys::kUrlKey, url);
  args.SetInteger(keys::kFrameIdKey, frame_id);
  args.SetInteger(keys::kRequestIdKey, request_id);
  args.SetReal(keys::kTimeStampKey, MilliSecondsFromTime(time_stamp));

  return SendEvent(keys::kOnBeforeNavigate, args);
}

HRESULT WebNavigationEventsFunnel::OnBeforeRetarget(
    CeeeWindowHandle source_tab_handle,
    BSTR source_url,
    BSTR target_url,
    const base::Time& time_stamp) {
  DictionaryValue args;
  args.SetInteger(keys::kSourceTabIdKey, static_cast<int>(source_tab_handle));
  args.SetString(keys::kSourceUrlKey, source_url);
  args.SetString(keys::kTargetUrlKey, target_url);
  args.SetReal(keys::kTimeStampKey, MilliSecondsFromTime(time_stamp));

  return SendEvent(keys::kOnBeforeRetarget, args);
}

HRESULT WebNavigationEventsFunnel::OnCommitted(
    CeeeWindowHandle tab_handle,
    BSTR url,
    int frame_id,
    const char* transition_type,
    const char* transition_qualifiers,
    const base::Time& time_stamp) {
  DictionaryValue args;
  args.SetInteger(keys::kTabIdKey, static_cast<int>(tab_handle));
  args.SetString(keys::kUrlKey, url);
  args.SetInteger(keys::kFrameIdKey, frame_id);
  args.SetString(keys::kTransitionTypeKey, transition_type);
  args.SetString(keys::kTransitionQualifiersKey, transition_qualifiers);
  args.SetReal(keys::kTimeStampKey, MilliSecondsFromTime(time_stamp));

  return SendEvent(keys::kOnCommitted, args);
}

HRESULT WebNavigationEventsFunnel::OnCompleted(
    CeeeWindowHandle tab_handle,
    BSTR url,
    int frame_id,
    const base::Time& time_stamp) {
  DictionaryValue args;
  args.SetInteger(keys::kTabIdKey, static_cast<int>(tab_handle));
  args.SetString(keys::kUrlKey, url);
  args.SetInteger(keys::kFrameIdKey, frame_id);
  args.SetReal(keys::kTimeStampKey, MilliSecondsFromTime(time_stamp));

  return SendEvent(keys::kOnCompleted, args);
}

HRESULT WebNavigationEventsFunnel::OnDOMContentLoaded(
    CeeeWindowHandle tab_handle,
    BSTR url,
    int frame_id,
    const base::Time& time_stamp) {
  DictionaryValue args;
  args.SetInteger(keys::kTabIdKey, static_cast<int>(tab_handle));
  args.SetString(keys::kUrlKey, url);
  args.SetInteger(keys::kFrameIdKey, frame_id);
  args.SetReal(keys::kTimeStampKey, MilliSecondsFromTime(time_stamp));

  return SendEvent(keys::kOnDOMContentLoaded, args);
}

HRESULT WebNavigationEventsFunnel::OnErrorOccurred(
    CeeeWindowHandle tab_handle,
    BSTR url,
    int frame_id,
    BSTR error,
    const base::Time& time_stamp) {
  DictionaryValue args;
  args.SetInteger(keys::kTabIdKey, static_cast<int>(tab_handle));
  args.SetString(keys::kUrlKey, url);
  args.SetInteger(keys::kFrameIdKey, frame_id);
  args.SetString(keys::kErrorKey, error);
  args.SetReal(keys::kTimeStampKey, MilliSecondsFromTime(time_stamp));

  return SendEvent(keys::kOnErrorOccurred, args);
}