amplitude-client-node
A simple wrapper around Amplitude's Groups and HTTP (v2) APIs.
For legacy v1 HTTP API, use v0.2.0
.
Features:
- automatic, configurable retry with generated
insert_id
- TypeScript support
- No dependencies
- event tracking (
/2/httpapi
) - group identification (
/groupidentify
) - user identification (
/identify
) - there are tests
- requires Node v8 or higher
Installation
npm install amplitude-client-node
Usage
const amplitude = require('amplitude-client-node');
const client = new amplitude.AmplitudeClient('api key', {
maxRetries: 3,
timeoutMs: 2500,
enabled: true,
endpoint: 'https://api.amplitude.com',
appVersion: '1.2.3',
setTime: true,
logging: (level, message) => {
console.log(`${level}: ${message}`);
}
});
const myEvent = {
event_type: 'user register',
user_id: '12345',
event_properties: {
source: 'marketing site',
whatever: 'you want',
},
groups: {
teamId: '67890'
}
};
client.track(myEvent)
.then((result) => {
console.log(`successfully sent event to amplitude: ${result.body.toString('utf8')}`);
})
.catch((err) => {
console.error(`amplitude api call failed after ${err.response.retryCount} retries: ${err.message}`);
});
Successful calls return an AmplitudeResponse
object:
interface AmplitudeResponse<T> {
statusCode: number;
body: Buffer;
start: Date;
end: Date;
requestOptions: https.RequestOptions;
responseHeaders: http.IncomingHttpHeaders;
succeeded: boolean;
retryCount: number;
requestData: T;
}
If all retries fail, or a non-retryable status code is returned from the Amplitude
API, then an error object is thrown that has a response
property that is set to
the AmplitudeResponse
object defined above.