realm-js/lib/submit-analytics.js
Nikola Irinchev f0fc556f6e
Give the app a chance to disable analytics (#2108)
* Give the app a chance to disable analytics

* Add changelog and stub for getWindowsIdentifier

* Use node-machine-id to get machine identifier for analytics

* Be async-ier

* Update changelog
2018-11-14 13:33:55 +01:00

86 lines
3.5 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

#!/usr/bin/env node
// Asynchronously submits install information to Realm.
//
// Why are we doing this? In short, because it helps us build a better product
// for you. None of the data personally identifies you, your employer or your
// app, but it *will* help us understand what language you use, what Node.js
// versions you target, etc. Having this info will help prioritizing our time,
// adding new features and deprecating old features. Collecting an anonymized
// application path & anonymized machine identifier is the only way for us to
// count actual usage of the other metrics accurately. If we dont have a way to
// deduplicate the info reported, it will be useless, as a single developer
// `npm install`-ing the same app 10 times would report 10 times more than another
// developer that only installs once, making the data all but useless.
// No one likes sharing data unless its necessary, we get it, and weve
// debated adding this for a long long time. If you truly, absolutely
// feel compelled to not send this data back to Realm, then you can set an env
// variable named REALM_DISABLE_ANALYTICS.
//
// Currently the following information is reported:
// - What version of Realm is being installed.
// - The OS platform and version which is being used.
// - Node.js, v8, libuv, OpenSSL version numbers.
// - An anonymous machine identifier and hashed application path to aggregate the other information on.
'use strict';
function isAnalyticsDisabled() {
return 'REALM_DISABLE_ANALYTICS' in process.env;
}
if (isAnalyticsDisabled()) {
module.exports = function(){};
} else {
const os = require('os');
const request = require('request');
const crypto = require('crypto');
const { machineId } = require("node-machine-id");
function sha256(data) {
let hash = crypto.createHash('sha256');
hash.update(data);
return hash.digest('hex');
}
module.exports = function(eventName, context) {
// Submit analytics after some time - we do this to give the application a chance to disable analytics.
setTimeout(() => {
if (isAnalyticsDisabled()) {
return;
}
machineId()
.catch() // Ignore errors
.then((identifier) => {
if (!identifier) {
identifier = sha256('unknown');
}
const payload = {
'event': eventName,
'properties': {
'token': 'aab85907a13e1ff44a95be539d9942a9',
'distinct_id': identifier,
'Anonymized Machine Identifier': identifier,
'Anonymized Application ID': sha256(__dirname),
'Binding': context || 'node.js',
'Version': require('../package.json').version,
'Language': 'javascript',
'OS Type': os.platform(),
'OS Version': os.release(),
'Node.js versions': process.versions
}
};
request(`https://api.mixpanel.com/track/?data=${Buffer.from(JSON.stringify(payload), 'utf8').toString('base64')}&ip=1`,
() => { /* Analytics failed. Do nothing. */ });
});
}, 100);
}
if (require.main === module) {
module.exports('Install');
}
}