Node tracker for Snowplow
npm install @snowplow/node-tracker[![npm version][npm-image]][npm-url]
[![License][license-image]](LICENSE)
Add Snowplow Tracking to your Node.js Application with @snowplow/node-tracker.
Part of the Snowplow JavaScript Tracker monorepo.
Build with Node.js (18 - 20) and Rush.
``bash`
npm install -g @microsoft/rush
git clone https://github.com/snowplow/snowplow-javascript-tracker.git
rush update
With npm:
`bash`
npm install @snowplow/node-tracker
Initialize your tracker with your desired configuration:
`js`
import { newTracker } from '@snowplow/node-tracker';
const t = newTracker(
{ namespace: 'myTracker', appId: 'myApp', encodeBase64: false },
{ endpoint: 'collector.mydomain.net', port: 8080, bufferSize: 5 }
);
Then use the track function from this package, along with the buildX functions to send events to your configured emitters:
`js
import {
buildSelfDescribingEvent,
buildPageView
} from '@snowplow/node-tracker';
const context = [
{
schema: 'iglu:com.acme/user/jsonschema/1-0-0',
data: {
type: 'tester',
},
},
];
t.track(
buildPageView({ pageUrl: 'http://www.example.com', pageTitle: 'example page', referrer: 'http://google.com' }),
context
);
const eventJson = {
schema: 'iglu:com.acme/viewed_product/jsonschema/1-0-0',
data: {
price: 20,
},
};
t.track(buildSelfDescribingEvent({ event: eventJson }), context);
`
To enable success and failure callback debugging, run your application with NODE_DEBUG=snowplow`.
Licensed and distributed under the BSD 3-Clause License ([An OSI Approved License][osi]).
Copyright (c) 2022 Snowplow Analytics Ltd.
All rights reserved.
[osi]: https://opensource.org/licenses/BSD-3-Clause
[license-image]: https://img.shields.io/npm/l/@snowplow/node-tracker
[npm-url]: https://www.npmjs.com/package/@snowplow/node-tracker
[npm-image]: https://img.shields.io/npm/v/@snowplow/node-tracker