'use strict' exports.start = startMetrics exports.stop = stopMetrics exports.save = saveMetrics exports.send = sendMetrics const fs = require('fs') const path = require('path') const npm = require('../npm.js') const regFetch = require('libnpm/fetch') const uuid = require('uuid') const cacheFile = require('./cache-file.js') let inMetrics = false function startMetrics () { if (inMetrics) return // loaded on demand to avoid any recursive deps when `./metrics-launch` requires us. var metricsLaunch = require('./metrics-launch.js') npm.metricsProcess = metricsLaunch() } function stopMetrics () { if (inMetrics) return if (npm.metricsProcess) npm.metricsProcess.kill('SIGKILL') } function saveMetrics (itWorked) { if (inMetrics) return // If the metrics reporter hasn't managed to PUT yet then kill it so that it doesn't // step on our updating the anonymous-cli-metrics json stopMetrics() var metricsFile = path.join(npm.config.get('cache'), 'anonymous-cli-metrics.json') var metrics try { metrics = JSON.parse(fs.readFileSync(metricsFile)) metrics.metrics.to = new Date().toISOString() if (itWorked) { ++metrics.metrics.successfulInstalls } else { ++metrics.metrics.failedInstalls } } catch (ex) { metrics = { metricId: uuid.v4(), metrics: { from: new Date().toISOString(), to: new Date().toISOString(), successfulInstalls: itWorked ? 1 : 0, failedInstalls: itWorked ? 0 : 1 } } } try { cacheFile.write(metricsFile, JSON.stringify(metrics)) } catch (ex) { // we couldn't write and/or chown the error metrics file, oh well. } } function sendMetrics (metricsFile, metricsRegistry) { inMetrics = true var cliMetrics = JSON.parse(fs.readFileSync(metricsFile)) regFetch( `/-/npm/anon-metrics/v1/${encodeURIComponent(cliMetrics.metricId)}`, // NOTE: skip npmConfig() to prevent auth { registry: metricsRegistry, method: 'PUT', body: cliMetrics.metrics, retry: false } ).then(() => { fs.unlinkSync(metricsFile) }, err => { cacheFile.write(path.join(path.dirname(metricsFile), 'last-send-metrics-error.txt'), err.stack) }) }
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
completion | Folder | 0755 |
|
|
ansi-trim.js | File | 211 B | 0644 |
|
cache-file.js | File | 1.7 KB | 0644 |
|
child-path.js | File | 290 B | 0644 |
|
completion.sh | File | 1.74 KB | 0755 |
|
correct-mkdir.js | File | 1.24 KB | 0644 |
|
deep-sort-object.js | File | 363 B | 0644 |
|
depr-check.js | File | 451 B | 0644 |
|
did-you-mean.js | File | 446 B | 0644 |
|
error-handler.js | File | 6.04 KB | 0644 |
|
error-message.js | File | 13.44 KB | 0644 |
|
escape-arg.js | File | 657 B | 0644 |
|
escape-exec-path.js | File | 761 B | 0644 |
|
funding.js | File | 4.48 KB | 0644 |
|
gently-rm.js | File | 484 B | 0644 |
|
git.js | File | 1.7 KB | 0644 |
|
gunzip-maybe.js | File | 556 B | 0644 |
|
is-registry.js | File | 294 B | 0644 |
|
is-windows-bash.js | File | 166 B | 0644 |
|
is-windows-shell.js | File | 153 B | 0644 |
|
is-windows.js | File | 59 B | 0644 |
|
lifecycle-cmd.js | File | 496 B | 0644 |
|
lifecycle.js | File | 364 B | 0644 |
|
link.js | File | 234 B | 0644 |
|
locker.js | File | 1.81 KB | 0644 |
|
metrics-launch.js | File | 1.08 KB | 0644 |
|
metrics.js | File | 2.17 KB | 0644 |
|
module-name.js | File | 973 B | 0644 |
|
move.js | File | 290 B | 0644 |
|
no-progress-while-running.js | File | 541 B | 0644 |
|
open-url.js | File | 819 B | 0644 |
|
otplease.js | File | 721 B | 0644 |
|
output.js | File | 210 B | 0644 |
|
package-id.js | File | 399 B | 0644 |
|
parse-json.js | File | 653 B | 0644 |
|
perf.js | File | 548 B | 0644 |
|
pick-manifest-from-registry-metadata.js | File | 895 B | 0644 |
|
pulse-till-done.js | File | 783 B | 0644 |
|
read-local-package.js | File | 329 B | 0644 |
|
read-user-info.js | File | 2.08 KB | 0644 |
|
replace-info.js | File | 556 B | 0644 |
|
save-stack.js | File | 349 B | 0644 |
|
spawn.js | File | 1.38 KB | 0644 |
|
temp-filename.js | File | 173 B | 0644 |
|
umask.js | File | 343 B | 0644 |
|
unix-format-path.js | File | 85 B | 0644 |
|
unsupported.js | File | 1.29 KB | 0644 |
|
usage.js | File | 576 B | 0644 |
|
warn-deprecated.js | File | 556 B | 0644 |
|