Tested with Browserstack.
Short answer: Rudder is an open-source Segment alternative written in Go, built for the enterprise. .
Long answer: Rudder is a platform for collecting, storing and routing customer event data to dozens of tools. Rudder is open-source, can run in your cloud environment (AWS, GCP, Azure or even your data-centre) and provides a powerful transformation framework to process your event data on the fly.
Released under Apache License 2.0
Place the below snippet in the <header>
section of your html.
<script>
rudderanalytics = window.rudderanalytics = [];
var methods = [
"load",
"page",
"track",
"identify",
"reset"
];
for (var i=0; i<methods.length; i++) {
var method = methods[i];
rudderanalytics[method] = function(methodName) {
return function() {
rudderanalytics.push([methodName, ...arguments]);
}
} (method)
}
rudderanalytics.load("YOUR_WRITE_KEY", "DATA_PLANE_URI");
//rudderanalytics.load("1S2kNlbkMrWLBO79H2eNuEST27I", "http://localhost:8080");
rudderanalytics.page();
</script>
<script src="https://cdn.rudderlabs.com/rudder-analytics.min.js"></script>
The above snippet does the following:
- Creates an array to store the events until the analytics object is ready.
- Stores a list of methods below to replay them when the analytics object is ready.
- "load" : loads analytics.js with your write key.
- "page" : to keep track whenever a user visits a page.
- "track" : to keep track of user actions, like purchase, signup.
- "identify" : to associate userId with traits.
- "reset" : resets the userId and traits.
- Loads analytics object with your writekey. You need to replace "YOUR_WRITE_KEY" with the Writekey in Rudder control plane and "DATA_PLANE_URI" with the uri of the server/data plane.
- Make the page() call to track the pageview. It auto captures the properties(path, referrer, search, title, url). If you want to override them, use the call mentioned in section Sample events.
Sample SDK usages can be found under tests directory for vanilla html integrations.
Sample calls on global analytics object, for more examples, refer the tests folder. For more info regarding the api documentation of these calls, refer For further reference of these apis, please refer Segment spec
rudderanalytics.identify(
"12345",
{ email: "[email protected]" },
{
context: {
ip: "0.0.0.0"
},
page: {
path: "",
referrer: "",
search: "",
title: "",
url: ""
},
anonymousId: "12345"
},
() => {console.log("in identify call");}
);
In the above call, these are the following parameters:
- a string - userid, if provided, will override the anonymousId.
- a dictionary, to provide user traits, like address, email etc.
- a dictionary that is optional but provides information like context, integrations, anonymousId etc. You can provide user traits in the context as well and it will set the traits value.
- anonymousId is a UUID that is generated to identify the user. If provided, it will override the generated one.
- Context is a dictionary of extra information that provides useful context about a datapoint, Eg. User’s ip address.
- you can provide callback that will be executed after the successful execution of identify call.
rudderanalytics.page(
"Cart",
"Cart Viewed",
{
path: "",
referrer: "",
search: "",
title: "",
url: ""
},
{
context: {
ip: "0.0.0.0"
},
anonymousId: "00000000000000000000000000"
},
() => {console.log("in page call");}
);
In the above call, these are the following parameters:
- a string - category of the page
- a string - name of the page
- a dictionary, to provide properties of the page. The mentioned parameters are auto captured.
- a dictionary that is optional but provides information like, context, integrations, anonymousId etc. You can provide user traits in the context as well and it will set the traits value.
- anonymousId is a UUID that is generated to identify the user, if it is provided, it will override the generated one.
- Context is a dictionary of extra information that provides useful context about a datapoint, for example the user’s ip address.
- you can provide callback that will be executed after the successful execution of page call.
rudderanalytics.track(
"test track event GA3",
{
revenue: 30,
currency: 'USD' ,
user_actual_id: 12345
},
{
context: {
ip: "0.0.0.0"
},
anonymousId: "00000000000000000000000000"
},
() => {console.log("in track call");}
);
In the above call, these are the following parameters:
- a string - event name
- a dictionary, properties of the event that you want to track, like, revenue, currency, value etc.
- a dictionary that is optional but provides information like, context, integrations, anonymousId etc. You can provide user traits in the context as well and it will set the traits value.
- anonymousId is a UUID that is generated to identify the user, if it is provided, it will override the generated one.
- Context is a dictionary of extra information that provides useful context about a datapoint, for example the user’s ip address.
- you can provide callback that will be executed after the successful execution of track call.
One can start adding integrations like Mixpanel, Facebook ads and others for sending data through their js sdks.
For building the sdk
- Look for run scripts in the package.json file for getting browser minified and non-minified specific builds.
- For adding or removing integrations, modify the imports in index.js under integrations folder.