@bugsplat/js-api-client 9.5.0 → 11.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/post/crash-post-client.d.ts +1 -1
- package/dist/cjs/post/crash-post-client.js +7 -6
- package/dist/cjs/post/crash-post-client.js.map +1 -1
- package/dist/cjs/post/crash-type.d.ts +1 -0
- package/dist/cjs/post/crash-type.js +1 -0
- package/dist/cjs/post/crash-type.js.map +1 -1
- package/dist/cjs/users/users-api-client/users-api-client.d.ts +1 -1
- package/dist/cjs/users/users-api-client/users-api-client.js +9 -9
- package/dist/cjs/users/users-api-client/users-api-client.js.map +1 -1
- package/dist/esm/post/crash-post-client.d.ts +1 -1
- package/dist/esm/post/crash-post-client.js +6 -4
- package/dist/esm/post/crash-post-client.js.map +1 -1
- package/dist/esm/post/crash-type.d.ts +1 -0
- package/dist/esm/post/crash-type.js +1 -0
- package/dist/esm/post/crash-type.js.map +1 -1
- package/dist/esm/users/users-api-client/users-api-client.d.ts +1 -1
- package/dist/esm/users/users-api-client/users-api-client.js +9 -9
- package/dist/esm/users/users-api-client/users-api-client.js.map +1 -1
- package/package.json +1 -1
|
@@ -8,7 +8,7 @@ export declare class CrashPostClient {
|
|
|
8
8
|
private _processorApiClient;
|
|
9
9
|
private _s3ApiClient;
|
|
10
10
|
constructor(_database: string, _environment?: Environment, _processor?: string);
|
|
11
|
-
postCrash(application: string, version: string, type: CrashType, file: UploadableFile,
|
|
11
|
+
postCrash(application: string, version: string, type: CrashType, file: UploadableFile, attributes?: Record<string, string>): Promise<BugSplatResponse<PostCrashResponse>>;
|
|
12
12
|
private getCrashUploadUrl;
|
|
13
13
|
private commitS3CrashUpload;
|
|
14
14
|
}
|
|
@@ -48,10 +48,9 @@ var CrashPostClient = (function () {
|
|
|
48
48
|
this._s3ApiClient = new _common_1.S3ApiClient();
|
|
49
49
|
this._processorApiClient = new _common_1.BugSplatApiClient("https://".concat(this._database, ".bugsplat.com"), this._environment);
|
|
50
50
|
}
|
|
51
|
-
CrashPostClient.prototype.postCrash = function (
|
|
52
|
-
return __awaiter(this,
|
|
51
|
+
CrashPostClient.prototype.postCrash = function (application, version, type, file, attributes) {
|
|
52
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
53
53
|
var uploadUrl;
|
|
54
|
-
if (md5 === void 0) { md5 = ''; }
|
|
55
54
|
return __generator(this, function (_a) {
|
|
56
55
|
switch (_a.label) {
|
|
57
56
|
case 0: return [4, this.getCrashUploadUrl(this._database, application, version, file.size)];
|
|
@@ -60,7 +59,7 @@ var CrashPostClient = (function () {
|
|
|
60
59
|
return [4, this._s3ApiClient.uploadFileToPresignedUrl(uploadUrl, file)];
|
|
61
60
|
case 2:
|
|
62
61
|
_a.sent();
|
|
63
|
-
return [2, this.commitS3CrashUpload(uploadUrl, this._database, application, version, type,
|
|
62
|
+
return [2, this.commitS3CrashUpload(uploadUrl, this._database, application, version, type, attributes, this._processor)];
|
|
64
63
|
}
|
|
65
64
|
});
|
|
66
65
|
});
|
|
@@ -93,7 +92,7 @@ var CrashPostClient = (function () {
|
|
|
93
92
|
});
|
|
94
93
|
});
|
|
95
94
|
};
|
|
96
|
-
CrashPostClient.prototype.commitS3CrashUpload = function (s3Key, database, application, version, crashType,
|
|
95
|
+
CrashPostClient.prototype.commitS3CrashUpload = function (s3Key, database, application, version, crashType, attributes, processor) {
|
|
97
96
|
return __awaiter(this, void 0, void 0, function () {
|
|
98
97
|
var route, formData, request;
|
|
99
98
|
return __generator(this, function (_a) {
|
|
@@ -105,7 +104,9 @@ var CrashPostClient = (function () {
|
|
|
105
104
|
formData.append('crashType', crashType.name);
|
|
106
105
|
formData.append('crashTypeId', "".concat(crashType.id));
|
|
107
106
|
formData.append('s3key', s3Key);
|
|
108
|
-
|
|
107
|
+
if (attributes) {
|
|
108
|
+
formData.append('attributes', JSON.stringify(attributes));
|
|
109
|
+
}
|
|
109
110
|
if (processor) {
|
|
110
111
|
formData.append('processor', processor);
|
|
111
112
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"crash-post-client.js","sourceRoot":"","sources":["../../../src/post/crash-post-client.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,mCAAwG;AAIxG;IAKI,yBACY,SAAiB,EACjB,YAA4C,EAC5C,UAAuB;QADvB,6BAAA,EAAA,eAA4B,qBAAW,CAAC,IAAI;QAC5C,2BAAA,EAAA,eAAuB;QAFvB,cAAS,GAAT,SAAS,CAAQ;QACjB,iBAAY,GAAZ,YAAY,CAAgC;QAC5C,eAAU,GAAV,UAAU,CAAa;QAL3B,iBAAY,GAAG,IAAI,qBAAW,EAAE,CAAC;QAOrC,IAAI,CAAC,mBAAmB,GAAG,IAAI,2BAAiB,CAC5C,kBAAW,IAAI,CAAC,SAAS,kBAAe,EACxC,IAAI,CAAC,YAAY,CACpB,CAAC;IACN,CAAC;IAEK,mCAAS,GAAf
|
|
1
|
+
{"version":3,"file":"crash-post-client.js","sourceRoot":"","sources":["../../../src/post/crash-post-client.ts"],"names":[],"mappings":"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"}
|
|
@@ -13,6 +13,7 @@ var CrashType = (function () {
|
|
|
13
13
|
CrashType.mac = new CrashType('macOS', 13);
|
|
14
14
|
CrashType.ps4 = new CrashType('PlayStation 4', 28);
|
|
15
15
|
CrashType.ps5 = new CrashType('PlayStation 5', 29);
|
|
16
|
+
CrashType.xml = new CrashType('Xml.Report', 21);
|
|
16
17
|
return CrashType;
|
|
17
18
|
}());
|
|
18
19
|
exports.CrashType = CrashType;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"crash-type.js","sourceRoot":"","sources":["../../../src/post/crash-type.ts"],"names":[],"mappings":";;;AAAA;
|
|
1
|
+
{"version":3,"file":"crash-type.js","sourceRoot":"","sources":["../../../src/post/crash-type.ts"],"names":[],"mappings":";;;AAAA;IASI,mBAAoC,IAAY,EAAkB,EAAU;QAAxC,SAAI,GAAJ,IAAI,CAAQ;QAAkB,OAAE,GAAF,EAAE,CAAQ;IAAI,CAAC;IARjE,kBAAQ,GAAG,IAAI,SAAS,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;IACxC,gBAAM,GAAG,IAAI,SAAS,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;IACzC,kBAAQ,GAAG,IAAI,SAAS,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;IACzC,gBAAM,GAAG,IAAI,SAAS,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC;IAC5C,aAAG,GAAG,IAAI,SAAS,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;IACjC,aAAG,GAAG,IAAI,SAAS,CAAC,eAAe,EAAE,EAAE,CAAC,CAAC;IACzC,aAAG,GAAG,IAAI,SAAS,CAAC,eAAe,EAAE,EAAE,CAAC,CAAC;IACzC,aAAG,GAAG,IAAI,SAAS,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;IAE1D,gBAAC;CAAA,AAVD,IAUC;AAVY,8BAAS"}
|
|
@@ -6,7 +6,7 @@ export declare class UsersApiClient {
|
|
|
6
6
|
constructor(_client: ApiClient);
|
|
7
7
|
getUsers(request: UsersTableDataRequest): Promise<TableDataResponse<UsersApiRow>>;
|
|
8
8
|
addUserToDatabase(database: string, email: string): Promise<BugSplatResponse<AddUserResponse>>;
|
|
9
|
-
removeUserFromDatabase(database: string,
|
|
9
|
+
removeUserFromDatabase(database: string, email: string): Promise<BugSplatResponse<UsersApiResponse>>;
|
|
10
10
|
updateUserForDatabase(database: string, email: string, isRestricted: boolean): Promise<BugSplatResponse<AddUserResponse>>;
|
|
11
11
|
addUserToCompany(companyId: number, email: string): Promise<BugSplatResponse<AddUserResponse>>;
|
|
12
12
|
removeUserFromCompany(companyId: number, uId: number): Promise<BugSplatResponse<UsersApiResponse>>;
|
|
@@ -73,7 +73,7 @@ var UsersApiClient = (function () {
|
|
|
73
73
|
case 2:
|
|
74
74
|
rows = _a.sent();
|
|
75
75
|
return [2, {
|
|
76
|
-
rows: rows
|
|
76
|
+
rows: rows,
|
|
77
77
|
}];
|
|
78
78
|
}
|
|
79
79
|
});
|
|
@@ -93,7 +93,7 @@ var UsersApiClient = (function () {
|
|
|
93
93
|
cache: 'no-cache',
|
|
94
94
|
credentials: 'include',
|
|
95
95
|
redirect: 'follow',
|
|
96
|
-
body: formData
|
|
96
|
+
body: formData,
|
|
97
97
|
};
|
|
98
98
|
return [4, this._client.fetch(USERS_BASE_URL, request)];
|
|
99
99
|
case 1:
|
|
@@ -106,24 +106,24 @@ var UsersApiClient = (function () {
|
|
|
106
106
|
});
|
|
107
107
|
});
|
|
108
108
|
};
|
|
109
|
-
UsersApiClient.prototype.removeUserFromDatabase = function (database,
|
|
109
|
+
UsersApiClient.prototype.removeUserFromDatabase = function (database, email) {
|
|
110
110
|
return __awaiter(this, void 0, void 0, function () {
|
|
111
111
|
var url, request, response;
|
|
112
112
|
return __generator(this, function (_a) {
|
|
113
113
|
switch (_a.label) {
|
|
114
114
|
case 0:
|
|
115
|
-
url = "".concat(USERS_BASE_URL, "?database=").concat(database, "&
|
|
115
|
+
url = "".concat(USERS_BASE_URL, "?database=").concat(database, "&username=").concat(encodeURIComponent(email));
|
|
116
116
|
request = {
|
|
117
117
|
method: 'DELETE',
|
|
118
118
|
cache: 'no-cache',
|
|
119
119
|
credentials: 'include',
|
|
120
|
-
redirect: 'follow'
|
|
120
|
+
redirect: 'follow',
|
|
121
121
|
};
|
|
122
122
|
return [4, this._client.fetch(url, request)];
|
|
123
123
|
case 1:
|
|
124
124
|
response = _a.sent();
|
|
125
125
|
if (response.status !== 200) {
|
|
126
|
-
throw new Error("Error remove user ".concat(
|
|
126
|
+
throw new Error("Error remove user ".concat(email, " for ").concat(database, " status ").concat(response.status));
|
|
127
127
|
}
|
|
128
128
|
return [2, response];
|
|
129
129
|
}
|
|
@@ -146,7 +146,7 @@ var UsersApiClient = (function () {
|
|
|
146
146
|
cache: 'no-cache',
|
|
147
147
|
credentials: 'include',
|
|
148
148
|
redirect: 'follow',
|
|
149
|
-
body: formData
|
|
149
|
+
body: formData,
|
|
150
150
|
};
|
|
151
151
|
return [4, this._client.fetch(USERS_BASE_URL, request)];
|
|
152
152
|
case 1:
|
|
@@ -173,7 +173,7 @@ var UsersApiClient = (function () {
|
|
|
173
173
|
cache: 'no-cache',
|
|
174
174
|
credentials: 'include',
|
|
175
175
|
redirect: 'follow',
|
|
176
|
-
body: formData
|
|
176
|
+
body: formData,
|
|
177
177
|
};
|
|
178
178
|
return [4, this._client.fetch(USERS_BASE_URL, request)];
|
|
179
179
|
case 1:
|
|
@@ -197,7 +197,7 @@ var UsersApiClient = (function () {
|
|
|
197
197
|
method: 'DELETE',
|
|
198
198
|
cache: 'no-cache',
|
|
199
199
|
credentials: 'include',
|
|
200
|
-
redirect: 'follow'
|
|
200
|
+
redirect: 'follow',
|
|
201
201
|
};
|
|
202
202
|
return [4, this._client.fetch(url, request)];
|
|
203
203
|
case 1:
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"users-api-client.js","sourceRoot":"","sources":["../../../../src/users/users-api-client/users-api-client.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,IAAM,cAAc,GAAG,qBAAqB,CAAC;AAC7C;
|
|
1
|
+
{"version":3,"file":"users-api-client.js","sourceRoot":"","sources":["../../../../src/users/users-api-client/users-api-client.ts"],"names":[],"mappings":"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"}
|
|
@@ -8,7 +8,7 @@ export declare class CrashPostClient {
|
|
|
8
8
|
private _processorApiClient;
|
|
9
9
|
private _s3ApiClient;
|
|
10
10
|
constructor(_database: string, _environment?: Environment, _processor?: string);
|
|
11
|
-
postCrash(application: string, version: string, type: CrashType, file: UploadableFile,
|
|
11
|
+
postCrash(application: string, version: string, type: CrashType, file: UploadableFile, attributes?: Record<string, string>): Promise<BugSplatResponse<PostCrashResponse>>;
|
|
12
12
|
private getCrashUploadUrl;
|
|
13
13
|
private commitS3CrashUpload;
|
|
14
14
|
}
|
|
@@ -11,10 +11,10 @@ export class CrashPostClient {
|
|
|
11
11
|
this._processor = _processor;
|
|
12
12
|
this._processorApiClient = new BugSplatApiClient(`https://${this._database}.bugsplat.com`, this._environment);
|
|
13
13
|
}
|
|
14
|
-
async postCrash(application, version, type, file,
|
|
14
|
+
async postCrash(application, version, type, file, attributes) {
|
|
15
15
|
const uploadUrl = await this.getCrashUploadUrl(this._database, application, version, file.size);
|
|
16
16
|
await this._s3ApiClient.uploadFileToPresignedUrl(uploadUrl, file);
|
|
17
|
-
return this.commitS3CrashUpload(uploadUrl, this._database, application, version, type,
|
|
17
|
+
return this.commitS3CrashUpload(uploadUrl, this._database, application, version, type, attributes, this._processor);
|
|
18
18
|
}
|
|
19
19
|
async getCrashUploadUrl(database, application, version, size) {
|
|
20
20
|
const route = 'api/getCrashUploadUrl'
|
|
@@ -32,7 +32,7 @@ export class CrashPostClient {
|
|
|
32
32
|
const json = await response.json();
|
|
33
33
|
return json.url;
|
|
34
34
|
}
|
|
35
|
-
async commitS3CrashUpload(s3Key, database, application, version, crashType,
|
|
35
|
+
async commitS3CrashUpload(s3Key, database, application, version, crashType, attributes, processor) {
|
|
36
36
|
const route = '/api/commitS3CrashUpload';
|
|
37
37
|
const formData = this._processorApiClient.createFormData();
|
|
38
38
|
formData.append('database', database);
|
|
@@ -41,7 +41,9 @@ export class CrashPostClient {
|
|
|
41
41
|
formData.append('crashType', crashType.name);
|
|
42
42
|
formData.append('crashTypeId', `${crashType.id}`);
|
|
43
43
|
formData.append('s3key', s3Key);
|
|
44
|
-
|
|
44
|
+
if (attributes) {
|
|
45
|
+
formData.append('attributes', JSON.stringify(attributes));
|
|
46
|
+
}
|
|
45
47
|
if (processor) {
|
|
46
48
|
formData.append('processor', processor);
|
|
47
49
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"crash-post-client.js","sourceRoot":"","sources":["../../../src/post/crash-post-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAoB,WAAW,EAAE,WAAW,EAAkB,MAAM,SAAS,CAAC;AAIxG,MAAM,OAAO,eAAe;IAMZ;IACA;IACA;IANJ,mBAAmB,CAAoB;IACvC,YAAY,GAAG,IAAI,WAAW,EAAE,CAAC;IAEzC,YACY,SAAiB,EACjB,eAA4B,WAAW,CAAC,IAAI,EAC5C,aAAqB,EAAE;QAFvB,cAAS,GAAT,SAAS,CAAQ;QACjB,iBAAY,GAAZ,YAAY,CAAgC;QAC5C,eAAU,GAAV,UAAU,CAAa;QAE/B,IAAI,CAAC,mBAAmB,GAAG,IAAI,iBAAiB,CAC5C,WAAW,IAAI,CAAC,SAAS,eAAe,EACxC,IAAI,CAAC,YAAY,CACpB,CAAC;IACN,CAAC;IAED,KAAK,CAAC,SAAS,CACX,WAAmB,EACnB,OAAe,EACf,IAAe,EACf,IAAoB,EACpB,
|
|
1
|
+
{"version":3,"file":"crash-post-client.js","sourceRoot":"","sources":["../../../src/post/crash-post-client.ts"],"names":[],"mappings":"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"}
|
|
@@ -8,6 +8,7 @@ export class CrashType {
|
|
|
8
8
|
static mac = new CrashType('macOS', 13);
|
|
9
9
|
static ps4 = new CrashType('PlayStation 4', 28);
|
|
10
10
|
static ps5 = new CrashType('PlayStation 5', 29);
|
|
11
|
+
static xml = new CrashType('Xml.Report', 21);
|
|
11
12
|
constructor(name, id) {
|
|
12
13
|
this.name = name;
|
|
13
14
|
this.id = id;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"crash-type.js","sourceRoot":"","sources":["../../../src/post/crash-type.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,SAAS;
|
|
1
|
+
{"version":3,"file":"crash-type.js","sourceRoot":"","sources":["../../../src/post/crash-type.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,SAAS;IASkB;IAA8B;IARlE,MAAM,CAAU,QAAQ,GAAG,IAAI,SAAS,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;IACxD,MAAM,CAAU,MAAM,GAAG,IAAI,SAAS,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;IACzD,MAAM,CAAU,QAAQ,GAAG,IAAI,SAAS,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;IACzD,MAAM,CAAU,MAAM,GAAG,IAAI,SAAS,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC;IAC5D,MAAM,CAAU,GAAG,GAAG,IAAI,SAAS,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;IACjD,MAAM,CAAU,GAAG,GAAG,IAAI,SAAS,CAAC,eAAe,EAAE,EAAE,CAAC,CAAC;IACzD,MAAM,CAAU,GAAG,GAAG,IAAI,SAAS,CAAC,eAAe,EAAE,EAAE,CAAC,CAAC;IACzD,MAAM,CAAU,GAAG,GAAG,IAAI,SAAS,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;IACtD,YAAoC,IAAY,EAAkB,EAAU;QAAxC,SAAI,GAAJ,IAAI,CAAQ;QAAkB,OAAE,GAAF,EAAE,CAAQ;IAAI,CAAC"}
|
|
@@ -6,7 +6,7 @@ export declare class UsersApiClient {
|
|
|
6
6
|
constructor(_client: ApiClient);
|
|
7
7
|
getUsers(request: UsersTableDataRequest): Promise<TableDataResponse<UsersApiRow>>;
|
|
8
8
|
addUserToDatabase(database: string, email: string): Promise<BugSplatResponse<AddUserResponse>>;
|
|
9
|
-
removeUserFromDatabase(database: string,
|
|
9
|
+
removeUserFromDatabase(database: string, email: string): Promise<BugSplatResponse<UsersApiResponse>>;
|
|
10
10
|
updateUserForDatabase(database: string, email: string, isRestricted: boolean): Promise<BugSplatResponse<AddUserResponse>>;
|
|
11
11
|
addUserToCompany(companyId: number, email: string): Promise<BugSplatResponse<AddUserResponse>>;
|
|
12
12
|
removeUserFromCompany(companyId: number, uId: number): Promise<BugSplatResponse<UsersApiResponse>>;
|
|
@@ -26,7 +26,7 @@ export class UsersApiClient {
|
|
|
26
26
|
const response = await this._client.fetch(url);
|
|
27
27
|
const rows = await response.json();
|
|
28
28
|
return {
|
|
29
|
-
rows
|
|
29
|
+
rows,
|
|
30
30
|
};
|
|
31
31
|
}
|
|
32
32
|
async addUserToDatabase(database, email) {
|
|
@@ -38,7 +38,7 @@ export class UsersApiClient {
|
|
|
38
38
|
cache: 'no-cache',
|
|
39
39
|
credentials: 'include',
|
|
40
40
|
redirect: 'follow',
|
|
41
|
-
body: formData
|
|
41
|
+
body: formData,
|
|
42
42
|
};
|
|
43
43
|
const response = await this._client.fetch(USERS_BASE_URL, request);
|
|
44
44
|
if (response.status !== 200) {
|
|
@@ -46,17 +46,17 @@ export class UsersApiClient {
|
|
|
46
46
|
}
|
|
47
47
|
return response;
|
|
48
48
|
}
|
|
49
|
-
async removeUserFromDatabase(database,
|
|
50
|
-
const url = `${USERS_BASE_URL}?database=${database}&
|
|
49
|
+
async removeUserFromDatabase(database, email) {
|
|
50
|
+
const url = `${USERS_BASE_URL}?database=${database}&username=${encodeURIComponent(email)}`;
|
|
51
51
|
const request = {
|
|
52
52
|
method: 'DELETE',
|
|
53
53
|
cache: 'no-cache',
|
|
54
54
|
credentials: 'include',
|
|
55
|
-
redirect: 'follow'
|
|
55
|
+
redirect: 'follow',
|
|
56
56
|
};
|
|
57
57
|
const response = await this._client.fetch(url, request);
|
|
58
58
|
if (response.status !== 200) {
|
|
59
|
-
throw new Error(`Error remove user ${
|
|
59
|
+
throw new Error(`Error remove user ${email} for ${database} status ${response.status}`);
|
|
60
60
|
}
|
|
61
61
|
return response;
|
|
62
62
|
}
|
|
@@ -71,7 +71,7 @@ export class UsersApiClient {
|
|
|
71
71
|
cache: 'no-cache',
|
|
72
72
|
credentials: 'include',
|
|
73
73
|
redirect: 'follow',
|
|
74
|
-
body: formData
|
|
74
|
+
body: formData,
|
|
75
75
|
};
|
|
76
76
|
const response = await this._client.fetch(USERS_BASE_URL, request);
|
|
77
77
|
if (response.status !== 200) {
|
|
@@ -88,7 +88,7 @@ export class UsersApiClient {
|
|
|
88
88
|
cache: 'no-cache',
|
|
89
89
|
credentials: 'include',
|
|
90
90
|
redirect: 'follow',
|
|
91
|
-
body: formData
|
|
91
|
+
body: formData,
|
|
92
92
|
};
|
|
93
93
|
const response = await this._client.fetch(USERS_BASE_URL, request);
|
|
94
94
|
if (response.status !== 200) {
|
|
@@ -102,7 +102,7 @@ export class UsersApiClient {
|
|
|
102
102
|
method: 'DELETE',
|
|
103
103
|
cache: 'no-cache',
|
|
104
104
|
credentials: 'include',
|
|
105
|
-
redirect: 'follow'
|
|
105
|
+
redirect: 'follow',
|
|
106
106
|
};
|
|
107
107
|
const response = await this._client.fetch(url, request);
|
|
108
108
|
if (response.status !== 200) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"users-api-client.js","sourceRoot":"","sources":["../../../../src/users/users-api-client/users-api-client.ts"],"names":[],"mappings":"AAIA,MAAM,cAAc,GAAG,qBAAqB,CAAC;AAC7C,MAAM,OAAO,cAAc;
|
|
1
|
+
{"version":3,"file":"users-api-client.js","sourceRoot":"","sources":["../../../../src/users/users-api-client/users-api-client.ts"],"names":[],"mappings":"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"}
|