snowplow-tracker 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml ADDED
@@ -0,0 +1,15 @@
1
+ ---
2
+ !binary "U0hBMQ==":
3
+ metadata.gz: !binary |-
4
+ NmI4MjYwZDE5ZGEyNjA0MTJkNTA1ZTdkYWU3MDRlOWNjZjEyNGI1NQ==
5
+ data.tar.gz: !binary |-
6
+ MjhiYjIxZWY4OGVhMmI2ODEzODY0NzQzYThhODNhMDY1YzE2Y2IwMA==
7
+ SHA512:
8
+ metadata.gz: !binary |-
9
+ M2Q0MzY5MzUyZjRhZGJkOTc2YzYyYTNmYmEzZDc5YjY1OTQyZjRjOTc5M2Q4
10
+ NTViOGZjOTUxZmVlMDI4NTJkOTFmZmVjMmQyYjE5NjdiZTc2NzZlZTY3YmUx
11
+ NjUwNTg4ZjNmYzQxMGUwOTE4YWE4NTEzMDM0ZDBlODJhOWI3M2E=
12
+ data.tar.gz: !binary |-
13
+ ZWRjZWRmNjRkZDlkMjNjMjlmNDU4ZWY0NzBmM2Q0OGM0NDZmNDU2YjRiOTA0
14
+ NjZlYTE2N2M5NWU4MjE1MzkyYzE2NzhiYmE1OGZjMTQ5NTNlZjZjOGZmNjk4
15
+ NDQ5NzRiYTAxNDVmOWNkOTJhMDIwNmE3MzdlY2I4Y2E3ZmQ1MzM=
data/LICENSE-2.0.txt ADDED
@@ -0,0 +1,202 @@
1
+
2
+ Apache License
3
+ Version 2.0, January 2004
4
+ http://www.apache.org/licenses/
5
+
6
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
7
+
8
+ 1. Definitions.
9
+
10
+ "License" shall mean the terms and conditions for use, reproduction,
11
+ and distribution as defined by Sections 1 through 9 of this document.
12
+
13
+ "Licensor" shall mean the copyright owner or entity authorized by
14
+ the copyright owner that is granting the License.
15
+
16
+ "Legal Entity" shall mean the union of the acting entity and all
17
+ other entities that control, are controlled by, or are under common
18
+ control with that entity. For the purposes of this definition,
19
+ "control" means (i) the power, direct or indirect, to cause the
20
+ direction or management of such entity, whether by contract or
21
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
22
+ outstanding shares, or (iii) beneficial ownership of such entity.
23
+
24
+ "You" (or "Your") shall mean an individual or Legal Entity
25
+ exercising permissions granted by this License.
26
+
27
+ "Source" form shall mean the preferred form for making modifications,
28
+ including but not limited to software source code, documentation
29
+ source, and configuration files.
30
+
31
+ "Object" form shall mean any form resulting from mechanical
32
+ transformation or translation of a Source form, including but
33
+ not limited to compiled object code, generated documentation,
34
+ and conversions to other media types.
35
+
36
+ "Work" shall mean the work of authorship, whether in Source or
37
+ Object form, made available under the License, as indicated by a
38
+ copyright notice that is included in or attached to the work
39
+ (an example is provided in the Appendix below).
40
+
41
+ "Derivative Works" shall mean any work, whether in Source or Object
42
+ form, that is based on (or derived from) the Work and for which the
43
+ editorial revisions, annotations, elaborations, or other modifications
44
+ represent, as a whole, an original work of authorship. For the purposes
45
+ of this License, Derivative Works shall not include works that remain
46
+ separable from, or merely link (or bind by name) to the interfaces of,
47
+ the Work and Derivative Works thereof.
48
+
49
+ "Contribution" shall mean any work of authorship, including
50
+ the original version of the Work and any modifications or additions
51
+ to that Work or Derivative Works thereof, that is intentionally
52
+ submitted to Licensor for inclusion in the Work by the copyright owner
53
+ or by an individual or Legal Entity authorized to submit on behalf of
54
+ the copyright owner. For the purposes of this definition, "submitted"
55
+ means any form of electronic, verbal, or written communication sent
56
+ to the Licensor or its representatives, including but not limited to
57
+ communication on electronic mailing lists, source code control systems,
58
+ and issue tracking systems that are managed by, or on behalf of, the
59
+ Licensor for the purpose of discussing and improving the Work, but
60
+ excluding communication that is conspicuously marked or otherwise
61
+ designated in writing by the copyright owner as "Not a Contribution."
62
+
63
+ "Contributor" shall mean Licensor and any individual or Legal Entity
64
+ on behalf of whom a Contribution has been received by Licensor and
65
+ subsequently incorporated within the Work.
66
+
67
+ 2. Grant of Copyright License. Subject to the terms and conditions of
68
+ this License, each Contributor hereby grants to You a perpetual,
69
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
70
+ copyright license to reproduce, prepare Derivative Works of,
71
+ publicly display, publicly perform, sublicense, and distribute the
72
+ Work and such Derivative Works in Source or Object form.
73
+
74
+ 3. Grant of Patent License. Subject to the terms and conditions of
75
+ this License, each Contributor hereby grants to You a perpetual,
76
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
77
+ (except as stated in this section) patent license to make, have made,
78
+ use, offer to sell, sell, import, and otherwise transfer the Work,
79
+ where such license applies only to those patent claims licensable
80
+ by such Contributor that are necessarily infringed by their
81
+ Contribution(s) alone or by combination of their Contribution(s)
82
+ with the Work to which such Contribution(s) was submitted. If You
83
+ institute patent litigation against any entity (including a
84
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
85
+ or a Contribution incorporated within the Work constitutes direct
86
+ or contributory patent infringement, then any patent licenses
87
+ granted to You under this License for that Work shall terminate
88
+ as of the date such litigation is filed.
89
+
90
+ 4. Redistribution. You may reproduce and distribute copies of the
91
+ Work or Derivative Works thereof in any medium, with or without
92
+ modifications, and in Source or Object form, provided that You
93
+ meet the following conditions:
94
+
95
+ (a) You must give any other recipients of the Work or
96
+ Derivative Works a copy of this License; and
97
+
98
+ (b) You must cause any modified files to carry prominent notices
99
+ stating that You changed the files; and
100
+
101
+ (c) You must retain, in the Source form of any Derivative Works
102
+ that You distribute, all copyright, patent, trademark, and
103
+ attribution notices from the Source form of the Work,
104
+ excluding those notices that do not pertain to any part of
105
+ the Derivative Works; and
106
+
107
+ (d) If the Work includes a "NOTICE" text file as part of its
108
+ distribution, then any Derivative Works that You distribute must
109
+ include a readable copy of the attribution notices contained
110
+ within such NOTICE file, excluding those notices that do not
111
+ pertain to any part of the Derivative Works, in at least one
112
+ of the following places: within a NOTICE text file distributed
113
+ as part of the Derivative Works; within the Source form or
114
+ documentation, if provided along with the Derivative Works; or,
115
+ within a display generated by the Derivative Works, if and
116
+ wherever such third-party notices normally appear. The contents
117
+ of the NOTICE file are for informational purposes only and
118
+ do not modify the License. You may add Your own attribution
119
+ notices within Derivative Works that You distribute, alongside
120
+ or as an addendum to the NOTICE text from the Work, provided
121
+ that such additional attribution notices cannot be construed
122
+ as modifying the License.
123
+
124
+ You may add Your own copyright statement to Your modifications and
125
+ may provide additional or different license terms and conditions
126
+ for use, reproduction, or distribution of Your modifications, or
127
+ for any such Derivative Works as a whole, provided Your use,
128
+ reproduction, and distribution of the Work otherwise complies with
129
+ the conditions stated in this License.
130
+
131
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
132
+ any Contribution intentionally submitted for inclusion in the Work
133
+ by You to the Licensor shall be under the terms and conditions of
134
+ this License, without any additional terms or conditions.
135
+ Notwithstanding the above, nothing herein shall supersede or modify
136
+ the terms of any separate license agreement you may have executed
137
+ with Licensor regarding such Contributions.
138
+
139
+ 6. Trademarks. This License does not grant permission to use the trade
140
+ names, trademarks, service marks, or product names of the Licensor,
141
+ except as required for reasonable and customary use in describing the
142
+ origin of the Work and reproducing the content of the NOTICE file.
143
+
144
+ 7. Disclaimer of Warranty. Unless required by applicable law or
145
+ agreed to in writing, Licensor provides the Work (and each
146
+ Contributor provides its Contributions) on an "AS IS" BASIS,
147
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
148
+ implied, including, without limitation, any warranties or conditions
149
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
150
+ PARTICULAR PURPOSE. You are solely responsible for determining the
151
+ appropriateness of using or redistributing the Work and assume any
152
+ risks associated with Your exercise of permissions under this License.
153
+
154
+ 8. Limitation of Liability. In no event and under no legal theory,
155
+ whether in tort (including negligence), contract, or otherwise,
156
+ unless required by applicable law (such as deliberate and grossly
157
+ negligent acts) or agreed to in writing, shall any Contributor be
158
+ liable to You for damages, including any direct, indirect, special,
159
+ incidental, or consequential damages of any character arising as a
160
+ result of this License or out of the use or inability to use the
161
+ Work (including but not limited to damages for loss of goodwill,
162
+ work stoppage, computer failure or malfunction, or any and all
163
+ other commercial damages or losses), even if such Contributor
164
+ has been advised of the possibility of such damages.
165
+
166
+ 9. Accepting Warranty or Additional Liability. While redistributing
167
+ the Work or Derivative Works thereof, You may choose to offer,
168
+ and charge a fee for, acceptance of support, warranty, indemnity,
169
+ or other liability obligations and/or rights consistent with this
170
+ License. However, in accepting such obligations, You may act only
171
+ on Your own behalf and on Your sole responsibility, not on behalf
172
+ of any other Contributor, and only if You agree to indemnify,
173
+ defend, and hold each Contributor harmless for any liability
174
+ incurred by, or claims asserted against, such Contributor by reason
175
+ of your accepting any such warranty or additional liability.
176
+
177
+ END OF TERMS AND CONDITIONS
178
+
179
+ APPENDIX: How to apply the Apache License to your work.
180
+
181
+ To apply the Apache License to your work, attach the following
182
+ boilerplate notice, with the fields enclosed by brackets "[]"
183
+ replaced with your own identifying information. (Don't include
184
+ the brackets!) The text should be enclosed in the appropriate
185
+ comment syntax for the file format. We also recommend that a
186
+ file or class name and description of purpose be included on the
187
+ same "printed page" as the copyright notice for easier
188
+ identification within third-party archives.
189
+
190
+ Copyright [yyyy] [name of copyright owner]
191
+
192
+ Licensed under the Apache License, Version 2.0 (the "License");
193
+ you may not use this file except in compliance with the License.
194
+ You may obtain a copy of the License at
195
+
196
+ http://www.apache.org/licenses/LICENSE-2.0
197
+
198
+ Unless required by applicable law or agreed to in writing, software
199
+ distributed under the License is distributed on an "AS IS" BASIS,
200
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
201
+ See the License for the specific language governing permissions and
202
+ limitations under the License.
data/README.md ADDED
@@ -0,0 +1,49 @@
1
+ # Ruby Analytics for Snowplow
2
+ [![Gem Version](https://badge.fury.io/rb/snowplow-tracker.svg)](http://badge.fury.io/rb/snowplow-tracker)
3
+ [![Build Status](https://travis-ci.org/snowplow/snowplow-ruby-tracker.png)](https://travis-ci.org/snowplow/snowplow-ruby-tracker)
4
+ [![Code Climate](https://codeclimate.com/github/snowplow/snowplow-ruby-tracker.png)](https://codeclimate.com/github/snowplow/snowplow-ruby-tracker)
5
+ [![Coverage Status](https://coveralls.io/repos/snowplow/snowplow-ruby-tracker/badge.png)](https://coveralls.io/r/snowplow/snowplow-ruby-tracker)
6
+
7
+ ## Overview
8
+
9
+ Add analytics to your Ruby and Rails apps and gems with the [Snowplow] [snowplow] event tracker for [Ruby] [ruby].
10
+
11
+ With this tracker you can collect event data from your [Ruby] [ruby] applications, [Ruby on Rails] [rails] web applications and [Ruby gems] [rubygems].
12
+
13
+ ## Find out more
14
+
15
+ | Technical Docs | Setup Guide | Roadmap | Contributing |
16
+ |---------------------------------|---------------------------|-------------------------|-----------------------------------|
17
+ | ![i1] [techdocs-image] | ![i2] [setup-image] | ![i3] [roadmap-image] | ![i4] [contributing-image] |
18
+ | **[Technical Docs] [techdocs]** | **[Setup Guide] [setup]** | **[Roadmap] [roadmap]** | **[Contributing] [contributing]** |
19
+
20
+ ## Copyright and license
21
+
22
+ The Snowplow Ruby Tracker is copyright 2013-2014 Snowplow Analytics Ltd.
23
+
24
+ Licensed under the **[Apache License, Version 2.0] [license]** (the "License");
25
+ you may not use this software except in compliance with the License.
26
+
27
+ Unless required by applicable law or agreed to in writing, software
28
+ distributed under the License is distributed on an "AS IS" BASIS,
29
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
30
+ See the License for the specific language governing permissions and
31
+ limitations under the License.
32
+
33
+ [ruby]: xxx
34
+ [rails]: xxx
35
+ [rubygems]: xxx
36
+
37
+ [snowplow]: http://snowplowanalytics.com
38
+
39
+ [techdocs-image]: https://d3i6fms1cm1j0i.cloudfront.net/github/images/techdocs.png
40
+ [setup-image]: https://d3i6fms1cm1j0i.cloudfront.net/github/images/setup.png
41
+ [roadmap-image]: https://d3i6fms1cm1j0i.cloudfront.net/github/images/roadmap.png
42
+ [contributing-image]: https://d3i6fms1cm1j0i.cloudfront.net/github/images/contributing.png
43
+
44
+ [techdocs]: https://github.com/snowplow/snowplow/wiki/Ruby-Tracker
45
+ [setup]: https://github.com/snowplow/snowplow/wiki/Ruby-Tracker-Setup
46
+ [roadmap]: https://github.com/snowplow/snowplow/wiki/Ruby-Tracker-Roadmap
47
+ [contributing]: https://github.com/snowplow/snowplow/wiki/Ruby-Tracker-Contributing
48
+
49
+ [license]: http://www.apache.org/licenses/LICENSE-2.0
@@ -0,0 +1,72 @@
1
+ # Copyright (c) 2013-2014 SnowPlow Analytics Ltd. All rights reserved.
2
+ #
3
+ # This program is licensed to you under the Apache License Version 2.0,
4
+ # and you may not use this file except in compliance with the Apache License Version 2.0.
5
+ # You may obtain a copy of the Apache License Version 2.0 at http://www.apache.org/licenses/LICENSE-2.0.
6
+ #
7
+ # Unless required by applicable law or agreed to in writing,
8
+ # software distributed under the Apache License Version 2.0 is distributed on an
9
+ # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
10
+ # See the Apache License Version 2.0 for the specific language governing permissions and limitations there under.
11
+
12
+ # Author:: Alex Dean, Fred Blundun (mailto:support@snowplowanalytics.com)
13
+ # Copyright:: Copyright (c) 2013-2014 SnowPlow Analytics Ltd
14
+ # License:: Apache License Version 2.0
15
+
16
+ require 'base64'
17
+ require 'json'
18
+ require 'net/http'
19
+ require 'contracts'
20
+ include Contracts
21
+
22
+ module SnowplowTracker
23
+
24
+ class Payload
25
+
26
+ attr_reader :context
27
+
28
+ Contract nil => Payload
29
+ def initialize
30
+ @context = {}
31
+ self
32
+ end
33
+
34
+ # Add a single name-value pair to @context
35
+ #
36
+ Contract String, Or[String, Bool, Num, nil] => Or[String, Bool, Num, nil]
37
+ def add(name, value)
38
+ if value != "" and not value.nil?
39
+ @context[name] = value
40
+ end
41
+ end
42
+
43
+ # Add each name-value pair in dict to @context
44
+ #
45
+ Contract Hash => Hash
46
+ def add_dict(dict)
47
+ for f in dict
48
+ self.add(f[0], f[1])
49
+ end
50
+ end
51
+
52
+ # Stringify a JSON and add it to @context
53
+ #
54
+ Contract Maybe[Hash], Bool, String, String => Maybe[String]
55
+ def add_json(dict, encode_base64, type_when_encoded, type_when_not_encoded)
56
+
57
+ if dict.nil?
58
+ return
59
+ end
60
+
61
+ dict_string = JSON.generate(dict)
62
+
63
+ if encode_base64
64
+ self.add(type_when_encoded, Base64.strict_encode64(dict_string))
65
+ else
66
+ self.add(type_when_not_encoded, dict_string)
67
+ end
68
+
69
+ end
70
+
71
+ end
72
+ end
@@ -0,0 +1,321 @@
1
+ # Copyright (c) 2013-2014 SnowPlow Analytics Ltd. All rights reserved.
2
+ #
3
+ # This program is licensed to you under the Apache License Version 2.0,
4
+ # and you may not use this file except in compliance with the Apache License Version 2.0.
5
+ # You may obtain a copy of the Apache License Version 2.0 at http://www.apache.org/licenses/LICENSE-2.0.
6
+ #
7
+ # Unless required by applicable law or agreed to in writing,
8
+ # software distributed under the Apache License Version 2.0 is distributed on an
9
+ # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
10
+ # See the Apache License Version 2.0 for the specific language governing permissions and limitations there under.
11
+
12
+ # Author:: Alex Dean, Fred Blundun (mailto:support@snowplowanalytics.com)
13
+ # Copyright:: Copyright (c) 2013-2014 SnowPlow Analytics Ltd
14
+ # License:: Apache License Version 2.0
15
+
16
+ require 'net/http'
17
+ require 'contracts'
18
+ require 'set'
19
+ include Contracts
20
+
21
+ module SnowplowTracker
22
+
23
+ class Tracker
24
+
25
+ @@required_transaction_keys = Set.new(%w(order_id total_value))
26
+ @@recognised_transaction_keys = Set.new(%w(order_id total_value affiliation tax_value shipping city state country currency))
27
+
28
+ @@Transaction = lambda { |x|
29
+ return false unless x.class == Hash
30
+ transaction_keys = Set.new(x.keys)
31
+ @@required_transaction_keys.subset? transaction_keys and
32
+ transaction_keys.subset? @@recognised_transaction_keys
33
+ }
34
+
35
+ @@required_item_keys = Set.new(%w(sku price quantity))
36
+ @@recognised_item_keys = Set.new(%w(sku price quantity name category context))
37
+
38
+ @@Item = lambda { |x|
39
+ return false unless x.class == Hash
40
+ item_keys = Set.new(x.keys)
41
+ @@required_item_keys.subset? item_keys and
42
+ item_keys.subset? @@recognised_item_keys
43
+ }
44
+
45
+ @@required_augmented_item_keys = Set.new(%w(sku price quantity tstamp tid order_id))
46
+ @@recognised_augmented_item_keys = Set.new(%w(sku price quantity name category context tstamp tid order_id currency))
47
+
48
+ @@AugmentedItem = lambda { |x|
49
+ return false unless x.class == Hash
50
+ augmented_item_keys = Set.new(x.keys)
51
+ @@required_augmented_item_keys.subset? augmented_item_keys and
52
+ augmented_item_keys.subset? @@recognised_augmented_item_keys
53
+ }
54
+
55
+ @@version = TRACKER_VERSION
56
+ @@default_encode_base64 = true
57
+ @@default_platform = 'pc'
58
+ @@default_vendor = 'com.snowplowanalytics'
59
+ @@supported_platforms = ['pc', 'tv', 'mob', 'cnsl', 'iot']
60
+ @@http_errors = ['host not found',
61
+ 'No address associated with name',
62
+ 'No address associated with hostname']
63
+
64
+ Contract String, Maybe[String], Maybe[String], Maybe[String], Bool => Tracker
65
+ def initialize(endpoint, namespace=nil, app_id=nil, context_vendor=nil, encode_base64=@@default_encode_base64)
66
+ @collector_uri = as_collector_uri(endpoint)
67
+ @standard_nv_pairs = {
68
+ 'tna' => namespace,
69
+ 'tv' => @@version,
70
+ 'p' => @@default_platform,
71
+ 'aid' => app_id
72
+ }
73
+ @config = {
74
+ 'context_vendor' => context_vendor,
75
+ 'encode_base64' => encode_base64
76
+ }
77
+ self
78
+ end
79
+
80
+ # Adds the protocol to the fron of the collector URL, and /i to the end
81
+ #
82
+ Contract String => String
83
+ def as_collector_uri(host)
84
+ "http://#{host}/i"
85
+ end
86
+
87
+ # Randomly generates a hopefully unique internal transaction ID for each event
88
+ #
89
+ Contract nil => Num
90
+ def get_transaction_id
91
+ rand(100000..999999)
92
+ end
93
+
94
+ # Generates the timestamp (in milliseconds) to be attached to each event
95
+ #
96
+ Contract nil => Num
97
+ def get_timestamp
98
+ (Time.now.to_f * 1000).to_i
99
+ end
100
+
101
+ # Send request
102
+ #
103
+ Contract Payload => [Bool, Num]
104
+ def http_get(payload)
105
+ destination = URI(@collector_uri + '?' + URI.encode_www_form(payload.context))
106
+ r = Net::HTTP.get_response(destination)
107
+ if @@http_errors.include? r.code
108
+ return false, "Host [#{r.host}] not found (possible connectivity error)"
109
+ elsif r.code.to_i < 0 or 400 <= r.code.to_i
110
+ return false, r.code.to_i
111
+ else
112
+ return true, r.code.to_i
113
+ end
114
+ end
115
+
116
+ # Setter methods
117
+
118
+ # Specify the platform
119
+ #
120
+ Contract String => String
121
+ def set_platform(value)
122
+ if @@supported_platforms.include?(value)
123
+ @standard_nv_pairs['p'] = value
124
+ else
125
+ raise "#{value} is not a supported platform"
126
+ end
127
+ end
128
+
129
+ # Set the business-defined user ID for a user
130
+ #
131
+ Contract String => String
132
+ def set_user_id(user_id)
133
+ @standard_nv_pairs['uid'] = user_id
134
+ end
135
+
136
+ # Set the screen resolution for a device
137
+ #
138
+ Contract Num, Num => String
139
+ def set_screen_resolution(width, height)
140
+ @standard_nv_pairs['res'] = "#{width}x#{height}"
141
+ end
142
+
143
+ # Set the dimensions of the current viewport
144
+ #
145
+ Contract Num, Num => String
146
+ def set_viewport(width, height)
147
+ @standard_nv_pairs['vp'] = "#{width}x#{height}"
148
+ end
149
+
150
+ # Set the color depth of the device in bits per pixel
151
+ #
152
+ Contract Num => Num
153
+ def set_color_depth(depth)
154
+ @standard_nv_pairs['cd'] = depth
155
+ end
156
+
157
+ # Set the timezone field
158
+ #
159
+ Contract String => String
160
+ def set_timezone(timezone)
161
+ @standard_nv_pairs['tz'] = timezone
162
+ end
163
+
164
+ # Set the language field
165
+ #
166
+ Contract String => String
167
+ def set_lang(lang)
168
+ @standard_nv_pairs['lang'] = lang
169
+ end
170
+
171
+ # Tracking methods
172
+
173
+ # Attaches all the fields in @standard_nv_pairs to the request
174
+ # Only attaches the context vendor if the event has a custom context
175
+ #
176
+ Contract Payload => [Bool, Num]
177
+ def track(pb)
178
+ pb.add_dict(@standard_nv_pairs)
179
+ if pb.context.key? 'co' or pb.context.key? 'cx'
180
+ pb.add('cv', @config['context_vendor'])
181
+ end
182
+ http_get(pb)
183
+ end
184
+
185
+ # Log a visit to this page
186
+ #
187
+ Contract String, Maybe[String], Maybe[String], Maybe[Hash] => [Bool, Num]
188
+ def track_page_view(page_url, page_title=nil, referrer=nil, context=nil, tstamp=nil)
189
+ pb = Payload.new
190
+ pb.add('e', 'pv')
191
+ pb.add('url', page_url)
192
+ pb.add('page', page_title)
193
+ pb.add('refr', referrer)
194
+ pb.add('evn', @@default_vendor)
195
+ pb.add_json(context, @config['encode_base64'], 'cx', 'co')
196
+ tid = get_transaction_id
197
+ pb.add('tid', tid)
198
+ if tstamp.nil?
199
+ tstamp = get_timestamp
200
+ end
201
+ pb.add('dtm', tstamp)
202
+ track(pb)
203
+ end
204
+
205
+ # Track a single item within an ecommerce transaction
206
+ # Not part of the public API
207
+ #
208
+ Contract @@AugmentedItem => [Bool, Num]
209
+ def track_ecommerce_transaction_item(argmap)
210
+ pb = Payload.new
211
+ pb.add('e', 'ti')
212
+ pb.add('ti_id', argmap['order_id'])
213
+ pb.add('ti_sk', argmap['sku'])
214
+ pb.add('ti_pr', argmap['price'])
215
+ pb.add('ti_qu', argmap['quantity'])
216
+ pb.add('ti_nm', argmap['name'])
217
+ pb.add('ti_ca', argmap['category'])
218
+ pb.add('ti_cu', argmap['currency'])
219
+ pb.add('evn', @default_vendor)
220
+ pb.add_json(argmap['context'], @config['encode_base64'], 'cx', 'co')
221
+ pb.add('tid', argmap['tid'])
222
+ pb.add('dtm', argmap['tstamp'])
223
+ track(pb)
224
+ end
225
+
226
+ # Track an ecommerce transaction and all the items in it
227
+ #
228
+ Contract @@Transaction, ArrayOf[@@Item], Maybe[Hash], Maybe[Num] => ({'transaction_result' => [Bool, Num], 'item_results' => ArrayOf[[Bool, Num]]})
229
+ def track_ecommerce_transaction(transaction, items,
230
+ context=nil, tstamp=nil)
231
+ pb = Payload.new
232
+ pb.add('e', 'tr')
233
+ pb.add('tr_id', transaction['order_id'])
234
+ pb.add('tr_tt', transaction['total_value'])
235
+ pb.add('tr_af', transaction['affiliation'])
236
+ pb.add('tr_tx', transaction['tax_value'])
237
+ pb.add('tr_sh', transaction['shipping'])
238
+ pb.add('tr_ci', transaction['city'])
239
+ pb.add('tr_st', transaction['state'])
240
+ pb.add('tr_co', transaction['country'])
241
+ pb.add('tr_cu', transaction['currency'])
242
+ pb.add('evn', @@default_vendor)
243
+ pb.add_json(context, @config['encode_base64'], 'cx', 'co')
244
+ tid = get_transaction_id
245
+ pb.add('tid', tid)
246
+ if tstamp.nil?
247
+ tstamp = get_timestamp
248
+ end
249
+ pb.add('dtm', tstamp)
250
+
251
+ transaction_result = track(pb)
252
+ item_results = []
253
+
254
+ for item in items
255
+ item['tstamp'] = tstamp
256
+ item['tid'] = tid
257
+ item['order_id'] = transaction['order_id']
258
+ item['currency'] = transaction['currency']
259
+ item_results.push(track_ecommerce_transaction_item(item))
260
+ end
261
+
262
+ {'transaction_result' => transaction_result, 'item_results' => item_results}
263
+ end
264
+
265
+ # Track a structured event
266
+ #
267
+ Contract String, String, Maybe[String], Maybe[String], Maybe[Num], Maybe[Hash], Maybe[Num] => [Bool, Num]
268
+ def track_struct_event(category, action, label=nil, property=nil, value=nil, context=nil, tstamp=nil)
269
+ pb = Payload.new
270
+ pb.add('e', 'se')
271
+ pb.add('se_ca', category)
272
+ pb.add('se_ac', action)
273
+ pb.add('se_la', label)
274
+ pb.add('se_pr', property)
275
+ pb.add('se_va', value)
276
+ pb.add_json(context, @config['encode_base64'], 'cx', 'co')
277
+ tid = get_transaction_id
278
+ pb.add('tid', tid)
279
+ if tstamp.nil?
280
+ tstamp = get_timestamp
281
+ end
282
+ pb.add('dtm', tstamp)
283
+ track(pb)
284
+ end
285
+
286
+ # Track a screen view event
287
+ #
288
+ Contract String, Maybe[String], Maybe[Hash], Maybe[Num] => [Bool, Num]
289
+ def track_screen_view(name, id=nil, context=nil, tstamp=nil)
290
+ self.track_unstruct_event('screen_view', {'name' => name, 'id' => id}, @@default_vendor, context, tstamp)
291
+ end
292
+
293
+ # Track an unstructured event
294
+ #
295
+ Contract String, Hash, Maybe[String], Maybe[Hash], Maybe[Num] => [Bool, Num]
296
+ def track_unstruct_event(event_name, dict, event_vendor=nil, context=nil, tstamp=nil)
297
+ pb = Payload.new
298
+ pb.add('e', 'ue')
299
+ pb.add('ue_na', event_name)
300
+ pb.add_json(dict, @config['encode_base64'], 'ue_px', 'ue_pr')
301
+ pb.add('evn', event_vendor)
302
+ pb.add_json(context, @config['encode_base64'], 'cx', 'co')
303
+ tid = get_transaction_id
304
+ pb.add('tid', tid)
305
+ if tstamp.nil?
306
+ tstamp = get_timestamp
307
+ end
308
+ pb.add('dtm', tstamp)
309
+ track(pb)
310
+ end
311
+
312
+ private :as_collector_uri,
313
+ :get_transaction_id,
314
+ :get_timestamp,
315
+ :http_get,
316
+ :track,
317
+ :track_ecommerce_transaction_item
318
+
319
+ end
320
+
321
+ end
@@ -0,0 +1,19 @@
1
+ # Copyright (c) 2013-2014 SnowPlow Analytics Ltd. All rights reserved.
2
+ #
3
+ # This program is licensed to you under the Apache License Version 2.0,
4
+ # and you may not use this file except in compliance with the Apache License Version 2.0.
5
+ # You may obtain a copy of the Apache License Version 2.0 at http://www.apache.org/licenses/LICENSE-2.0.
6
+ #
7
+ # Unless required by applicable law or agreed to in writing,
8
+ # software distributed under the Apache License Version 2.0 is distributed on an
9
+ # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
10
+ # See the Apache License Version 2.0 for the specific language governing permissions and limitations there under.
11
+
12
+ # Author:: Alex Dean, Fred Blundun (mailto:support@snowplowanalytics.com)
13
+ # Copyright:: Copyright (c) 2013-2014 SnowPlow Analytics Ltd
14
+ # License:: Apache License Version 2.0
15
+
16
+ module SnowplowTracker
17
+ VERSION = '0.1.0'
18
+ TRACKER_VERSION = "rb-#{VERSION}"
19
+ end
@@ -0,0 +1,18 @@
1
+ # Copyright (c) 2013-2014 Snowplow Analytics Ltd. All rights reserved.
2
+ #
3
+ # This program is licensed to you under the Apache License Version 2.0,
4
+ # and you may not use this file except in compliance with the Apache License Version 2.0.
5
+ # You may obtain a copy of the Apache License Version 2.0 at http://www.apache.org/licenses/LICENSE-2.0.
6
+ #
7
+ # Unless required by applicable law or agreed to in writing,
8
+ # software distributed under the Apache License Version 2.0 is distributed on an
9
+ # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
10
+ # See the Apache License Version 2.0 for the specific language governing permissions and limitations there under.
11
+
12
+ # Author:: Alex Dean, Fred Blundun (mailto:snowplow-user@googlegroups.com)
13
+ # Copyright:: Copyright (c) 2013-2014 Snowplow Analytics Ltd
14
+ # License:: Apache License Version 2.0
15
+
16
+ require 'snowplow-tracker/version.rb'
17
+ require 'snowplow-tracker/payload.rb'
18
+ require 'snowplow-tracker/tracker.rb'
metadata ADDED
@@ -0,0 +1,93 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: snowplow-tracker
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Alexander Dean
8
+ - Fred Blundun
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2014-04-23 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: contracts
16
+ requirement: !ruby/object:Gem::Requirement
17
+ requirements:
18
+ - - '='
19
+ - !ruby/object:Gem::Version
20
+ version: '0.3'
21
+ type: :runtime
22
+ prerelease: false
23
+ version_requirements: !ruby/object:Gem::Requirement
24
+ requirements:
25
+ - - '='
26
+ - !ruby/object:Gem::Version
27
+ version: '0.3'
28
+ - !ruby/object:Gem::Dependency
29
+ name: rspec
30
+ requirement: !ruby/object:Gem::Requirement
31
+ requirements:
32
+ - - ~>
33
+ - !ruby/object:Gem::Version
34
+ version: 2.14.1
35
+ type: :development
36
+ prerelease: false
37
+ version_requirements: !ruby/object:Gem::Requirement
38
+ requirements:
39
+ - - ~>
40
+ - !ruby/object:Gem::Version
41
+ version: 2.14.1
42
+ - !ruby/object:Gem::Dependency
43
+ name: webmock
44
+ requirement: !ruby/object:Gem::Requirement
45
+ requirements:
46
+ - - ~>
47
+ - !ruby/object:Gem::Version
48
+ version: 1.17.4
49
+ type: :development
50
+ prerelease: false
51
+ version_requirements: !ruby/object:Gem::Requirement
52
+ requirements:
53
+ - - ~>
54
+ - !ruby/object:Gem::Version
55
+ version: 1.17.4
56
+ description: With this tracker you can collect event data from your Ruby applications,
57
+ Ruby on Rails web applications and Ruby gems.
58
+ email: support@snowplowanalytics.com
59
+ executables: []
60
+ extensions: []
61
+ extra_rdoc_files: []
62
+ files:
63
+ - LICENSE-2.0.txt
64
+ - README.md
65
+ - lib/snowplow-tracker.rb
66
+ - lib/snowplow-tracker/payload.rb
67
+ - lib/snowplow-tracker/tracker.rb
68
+ - lib/snowplow-tracker/version.rb
69
+ homepage: http://github.com/snowplow/snowplow-ruby-tracker
70
+ licenses:
71
+ - Apache License 2.0
72
+ metadata: {}
73
+ post_install_message:
74
+ rdoc_options: []
75
+ require_paths:
76
+ - lib
77
+ required_ruby_version: !ruby/object:Gem::Requirement
78
+ requirements:
79
+ - - ! '>='
80
+ - !ruby/object:Gem::Version
81
+ version: 1.9.3
82
+ required_rubygems_version: !ruby/object:Gem::Requirement
83
+ requirements:
84
+ - - ! '>='
85
+ - !ruby/object:Gem::Version
86
+ version: '0'
87
+ requirements: []
88
+ rubyforge_project:
89
+ rubygems_version: 2.2.2
90
+ signing_key:
91
+ specification_version: 4
92
+ summary: Ruby Analytics for Snowplow
93
+ test_files: []