Snowplow Ruby Domain UserId

A gem that exposes the Snowplow domain userid in Rack applications. Also allows you to set your own domain userid that will be shared with the Snowplow Javascript tracker. Related Snowplow Google Group discussion here.

Instructions

Add the gem to your Gemfile

gem 'snowplow_ruby_duid'

Rails

The helper will be included in ActionController::Base when the gem is loaded.

Configuration

Since 2020 some browsers require extra settings on cookies, like SameSite and secure settings.

The library provides default values for these two settings(:lax, false), that you can change:

SnowplowRubyDuid::Configuration.same_site = :none
SnowplowRubyDuid::Configuration.secure = true

Sinatra

Add the following to Sinatra::Base

require 'snowplow_ruby_duid'
helpers SnowplowRubyDuid::Helper

Usage

A method called snowplow_domain_userid will be exposed in your application's context. Calling this method results in the following behaviour:

  • If there is already a Snowplow domain userid in the request's cookie, the value of the id will be returned.
  • Else, a Snowplow domain userid will be generated and persisted in the response's cookie. This domain userid will continue to be used by the Snowplow Javascript tracker on the client side.

Running the specs and features

Use this command to run the specs and features: bundle exec rspec