forked from exceptionless/Exceptionless.JavaScript
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDefaultSubmissionClient.ts
More file actions
81 lines (66 loc) · 3.52 KB
/
DefaultSubmissionClient.ts
File metadata and controls
81 lines (66 loc) · 3.52 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
import { Configuration } from '../configuration/Configuration';
import { SettingsManager } from '../configuration/SettingsManager';
import { IClientConfiguration } from '../models/IClientConfiguration';
import { IEvent } from '../models/IEvent';
import { IUserDescription } from '../models/IUserDescription';
import { ISubmissionClient } from './ISubmissionClient';
import { SettingsResponse } from './SettingsResponse';
import { SubmissionRequest } from './SubmissionRequest';
import { SubmissionResponse } from './SubmissionResponse';
// tslint:disable-next-line:prefer-const
declare var XDomainRequest: { new (); create(); };
export class DefaultSubmissionClient implements ISubmissionClient {
public configurationVersionHeader: string = 'x-exceptionless-configversion';
public postEvents(events: IEvent[], config: Configuration, callback: (response: SubmissionResponse) => void, isAppExiting?: boolean): void {
const data = JSON.stringify(events);
const request = this.createRequest(config, 'POST', `${config.serverUrl}/api/v2/events`, data);
const cb = this.createSubmissionCallback(config, callback);
return config.submissionAdapter.sendRequest(request, cb, isAppExiting);
}
public postUserDescription(referenceId: string, description: IUserDescription, config: Configuration, callback: (response: SubmissionResponse) => void): void {
const path = `${config.serverUrl}/api/v2/events/by-ref/${encodeURIComponent(referenceId)}/user-description`;
const data = JSON.stringify(description);
const request = this.createRequest(config, 'POST', path, data);
const cb = this.createSubmissionCallback(config, callback);
return config.submissionAdapter.sendRequest(request, cb);
}
public getSettings(config: Configuration, version: number, callback: (response: SettingsResponse) => void): void {
const request = this.createRequest(config, 'GET', `${config.serverUrl}/api/v2/projects/config?v=${version}`);
const cb = (status, message, data?, headers?) => {
if (status !== 200) {
return callback(new SettingsResponse(false, null, -1, null, message));
}
let settings: IClientConfiguration;
try {
settings = JSON.parse(data);
} catch (e) {
config.log.error(`Unable to parse settings: '${data}'`);
}
if (!settings || isNaN(settings.version)) {
return callback(new SettingsResponse(false, null, -1, null, 'Invalid configuration settings.'));
}
callback(new SettingsResponse(true, settings.settings || {}, settings.version));
};
return config.submissionAdapter.sendRequest(request, cb);
}
public sendHeartbeat(sessionIdOrUserId: string, closeSession: boolean, config: Configuration): void {
const request = this.createRequest(config, 'GET', `${config.heartbeatServerUrl}/api/v2/events/session/heartbeat?id=${sessionIdOrUserId}&close=${closeSession}`);
config.submissionAdapter.sendRequest(request);
}
private createRequest(config: Configuration, method: string, url: string, data: string = null): SubmissionRequest {
return {
method,
url,
data,
apiKey: config.apiKey,
userAgent: config.userAgent
};
}
private createSubmissionCallback(config: Configuration, callback: (response: SubmissionResponse) => void) {
return (status, message, data?, headers?) => {
const settingsVersion: number = headers && parseInt(headers[this.configurationVersionHeader], 10);
SettingsManager.checkVersion(settingsVersion, config);
callback(new SubmissionResponse(status, message));
};
}
}