Project

nark

0.0
No commit activity in last 3 years
No release in over 3 years
abstraction layer for publishing analytics events.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.6
>= 0
~> 3.0

Runtime

~> 0.1.8
 Project Readme

Nark

Ruby API for sending generic events for analytics purpose. Currently it assumes the InfluxDB is the receiving end.

Installation

Add this line to your application's Gemfile:

gem 'nark'

And then execute:

$ bundle

Or install it yourself as:

$ gem install nark

Usage

Configuration

As Nark currently only supports InfluxDB, the simplest way to set it up is by providing the set of required InfluxDB specific environment variables:

ENV['INFLUXDB_DATABASE'] # required, eg. supporter-events
ENV['INFLUXDB_USERNAME'] # required
ENV['INFLUXDB_PASSWORD'] # required
ENV['EVENT_GATEWAY_URL'] # optional but recommended for reporting
ENV['INFLUXDB_HOST']     # optional, default to localhost
ENV['INFLUXDB_PORT']     # optional, default to 8086
ENV['INFLUXDB_USE_SSL']  # optional, default to false

To provide more sophisticated configurations, the Nark.configure helper can be utilised, for example:

Nark.configure do |nark|
  nark.emitter = Nark::InfluxDBEmitter.new database: 'some_db'
end

Making object emittable

The Nark module is meant to be used as mixin that enables object to emit itself as event. The following code snippet shows a basic use case:

class TestSignup
  include Nark

  collection_name :test_signups

  def initialize attributes
    serializable_hash attributes #entire attributes hash will be send as event data
  end
end

With the above setting, it makes all of the TestSignup events to be send to the test_signups collection, as the collection_name is set in the class level. The following shows how to emit the event object:

TestSignup.new.emit

By default, the timestamp of the event will be set to the time when the event is received, it is also possible to explicitly set the timestamp:

TestSignup.new.emit timestamp: Time.now

Or if the serialised event data contains the time field (need to be in numeric UNIX timestamp format), it will be used as the timestamp:

TestSignup.new(time: Time.now.i).emit

Sometimes it is desirable to make the same type of objects to be send to different collections:

class TestSignup
  include Nark

  def initialize attributes
    collection_name "test_signups_#{Date.today}"
    serializable_hash attributes
  end
end

The above example will send the events to new collections each day.

Bulk Emit

Nark also allows events to be send in bulk:

events = 10.times.map { TestSignup.new }

TestSignup.emit events

Please note, when sending events in bulk, it is good idea to have the time field explicitly included in the serialised hash, otherwise the events will have the same timestamp set.

Contributing

  1. Fork it ( https://github.com/[my-github-username]/nark/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request