2020-08-05 18:38:55 +02:00
|
|
|
/*
|
|
|
|
Copyright 2020 Bruno Windels <bruno@windels.cloud>
|
2020-09-22 13:40:38 +02:00
|
|
|
Copyright 2020 The Matrix.org Foundation C.I.C.
|
2020-08-05 18:38:55 +02:00
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2021-11-21 21:12:28 +05:30
|
|
|
import {encodeQueryParams, encodeBody} from "./common";
|
2021-11-21 21:28:16 +05:30
|
|
|
import {HomeServerRequest} from "./HomeServerRequest";
|
2021-11-24 21:05:01 +05:30
|
|
|
import type {IHomeServerRequest} from "./HomeServerRequest";
|
2021-11-23 18:09:33 +05:30
|
|
|
import type {Reconnector} from "./Reconnector";
|
2021-12-01 11:42:24 +05:30
|
|
|
import type {EncodedBody} from "./common";
|
2021-11-23 19:37:25 +05:30
|
|
|
import type {IRequestOptions, RequestFunction} from "../../platform/types/types";
|
2021-12-03 11:48:01 +05:30
|
|
|
import type {ILogItem} from "../../logging/types";
|
2021-11-23 18:09:33 +05:30
|
|
|
|
|
|
|
type RequestMethod = "POST" | "GET" | "PUT";
|
2020-11-11 10:45:23 +01:00
|
|
|
|
2021-10-26 18:47:46 +02:00
|
|
|
const CS_R0_PREFIX = "/_matrix/client/r0";
|
2021-12-23 15:17:09 +05:30
|
|
|
const CS_V3_PREFIX = "/_matrix/client/v3";
|
2021-10-27 15:08:53 +02:00
|
|
|
const DEHYDRATION_PREFIX = "/_matrix/client/unstable/org.matrix.msc2697.v2";
|
2021-10-26 18:47:46 +02:00
|
|
|
|
2021-12-01 11:21:11 +05:30
|
|
|
type Options = {
|
2021-11-24 13:05:13 +05:30
|
|
|
homeserver: string;
|
|
|
|
accessToken: string;
|
|
|
|
request: RequestFunction;
|
|
|
|
reconnector: Reconnector;
|
|
|
|
};
|
|
|
|
|
2020-04-20 21:26:39 +02:00
|
|
|
export class HomeServerApi {
|
2021-11-23 18:09:33 +05:30
|
|
|
private readonly _homeserver: string;
|
|
|
|
private readonly _accessToken: string;
|
|
|
|
private readonly _requestFn: RequestFunction;
|
|
|
|
private readonly _reconnector: Reconnector;
|
|
|
|
|
2021-12-01 11:21:58 +05:30
|
|
|
constructor({homeserver, accessToken, request, reconnector}: Options) {
|
2019-03-08 20:03:47 +01:00
|
|
|
// store these both in a closure somehow so it's harder to get at in case of XSS?
|
|
|
|
// one could change the homeserver as well so the token gets sent there, so both must be protected from read/write
|
2021-08-23 19:26:39 +02:00
|
|
|
this._homeserver = homeserver;
|
2019-06-26 22:31:36 +02:00
|
|
|
this._accessToken = accessToken;
|
2019-12-23 14:28:27 +01:00
|
|
|
this._requestFn = request;
|
2020-04-05 15:11:15 +02:00
|
|
|
this._reconnector = reconnector;
|
2019-06-26 22:31:36 +02:00
|
|
|
}
|
2018-12-21 14:35:24 +01:00
|
|
|
|
2021-11-23 19:31:13 +05:30
|
|
|
private _url(csPath: string, prefix: string = CS_R0_PREFIX): string {
|
2021-10-26 18:47:46 +02:00
|
|
|
return this._homeserver + prefix + csPath;
|
2019-06-26 22:31:36 +02:00
|
|
|
}
|
2018-12-21 14:35:24 +01:00
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
private _baseRequest(method: RequestMethod, url: string, queryParams?: Record<string, any>, body?: Record<string, any>, options?: IRequestOptions, accessToken?: string): IHomeServerRequest {
|
2020-08-20 15:40:43 +02:00
|
|
|
const queryString = encodeQueryParams(queryParams);
|
2020-03-30 23:56:03 +02:00
|
|
|
url = `${url}?${queryString}`;
|
2021-12-01 11:42:24 +05:30
|
|
|
let encodedBody: EncodedBody["body"];
|
2021-11-23 18:09:33 +05:30
|
|
|
const headers: Map<string, string | number> = new Map();
|
2020-09-18 18:13:20 +02:00
|
|
|
if (accessToken) {
|
|
|
|
headers.set("Authorization", `Bearer ${accessToken}`);
|
2019-06-26 22:31:36 +02:00
|
|
|
}
|
2020-04-22 20:46:47 +02:00
|
|
|
headers.set("Accept", "application/json");
|
2019-06-26 22:31:36 +02:00
|
|
|
if (body) {
|
2020-11-11 10:45:23 +01:00
|
|
|
const encoded = encodeBody(body);
|
|
|
|
headers.set("Content-Type", encoded.mimeType);
|
|
|
|
encodedBody = encoded.body;
|
2019-06-26 22:31:36 +02:00
|
|
|
}
|
2021-02-12 18:35:33 +01:00
|
|
|
|
2019-12-23 14:28:27 +01:00
|
|
|
const requestResult = this._requestFn(url, {
|
2019-06-26 22:31:36 +02:00
|
|
|
method,
|
|
|
|
headers,
|
2020-11-11 10:45:23 +01:00
|
|
|
body: encodedBody,
|
2020-10-23 17:18:11 +02:00
|
|
|
timeout: options?.timeout,
|
2020-11-16 10:45:46 +01:00
|
|
|
uploadProgress: options?.uploadProgress,
|
2021-12-26 17:57:27 +05:30
|
|
|
format: "json", // response format
|
2022-02-01 17:07:32 +05:30
|
|
|
cache: method !== "GET",
|
2019-06-26 22:31:36 +02:00
|
|
|
});
|
2020-04-05 15:11:15 +02:00
|
|
|
|
2022-02-01 15:38:55 +05:30
|
|
|
const hsRequest = new HomeServerRequest(method, url, requestResult, options);
|
2020-04-05 15:11:15 +02:00
|
|
|
|
|
|
|
if (this._reconnector) {
|
2021-04-09 15:15:28 +02:00
|
|
|
hsRequest.response().catch(err => {
|
2020-09-25 10:45:41 +02:00
|
|
|
// Some endpoints such as /sync legitimately time-out
|
|
|
|
// (which is also reported as a ConnectionError) and will re-attempt,
|
|
|
|
// but spinning up the reconnector in this case is ok,
|
|
|
|
// as all code ran on session and sync start should be reentrant
|
2020-05-06 19:38:33 +02:00
|
|
|
if (err.name === "ConnectionError") {
|
2020-04-05 15:11:15 +02:00
|
|
|
this._reconnector.onRequestFailed(this);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2021-04-09 15:15:28 +02:00
|
|
|
return hsRequest;
|
2019-06-26 22:31:36 +02:00
|
|
|
}
|
2019-02-04 22:26:24 +00:00
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
private _unauthedRequest(method: RequestMethod, url: string, queryParams?: Record<string, any>, body?: Record<string, any>, options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._baseRequest(method, url, queryParams, body, options);
|
2020-09-18 18:13:20 +02:00
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
private _authedRequest(method: RequestMethod, url: string, queryParams?: Record<string, any>, body?: Record<string, any>, options?: IRequestOptions): IHomeServerRequest {
|
2020-09-18 18:13:20 +02:00
|
|
|
return this._baseRequest(method, url, queryParams, body, options, this._accessToken);
|
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
private _post(csPath: string, queryParams: Record<string, any>, body: Record<string, any>, options?: IRequestOptions): IHomeServerRequest {
|
2021-10-26 18:47:46 +02:00
|
|
|
return this._authedRequest("POST", this._url(csPath, options?.prefix || CS_R0_PREFIX), queryParams, body, options);
|
2019-06-26 22:31:36 +02:00
|
|
|
}
|
2019-02-04 22:26:24 +00:00
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
private _put(csPath: string, queryParams: Record<string, any>, body?: Record<string, any>, options?: IRequestOptions): IHomeServerRequest {
|
2021-10-26 18:47:46 +02:00
|
|
|
return this._authedRequest("PUT", this._url(csPath, options?.prefix || CS_R0_PREFIX), queryParams, body, options);
|
2019-07-26 22:03:57 +02:00
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
private _get(csPath: string, queryParams?: Record<string, any>, body?: Record<string, any>, options?: IRequestOptions): IHomeServerRequest {
|
2021-10-26 18:47:46 +02:00
|
|
|
return this._authedRequest("GET", this._url(csPath, options?.prefix || CS_R0_PREFIX), queryParams, body, options);
|
2019-06-26 22:31:36 +02:00
|
|
|
}
|
2018-12-21 14:35:24 +01:00
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
sync(since: string, filter: string, timeout: number, options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._get("/sync", {since, timeout, filter}, undefined, options);
|
2019-06-26 22:31:36 +02:00
|
|
|
}
|
2019-02-04 22:26:24 +00:00
|
|
|
|
2021-12-07 12:18:51 +05:30
|
|
|
context(roomId: string, eventId: string, limit: number, filter: string): IHomeServerRequest {
|
|
|
|
return this._get(`/rooms/${encodeURIComponent(roomId)}/context/${encodeURIComponent(eventId)}`, {filter, limit});
|
2021-12-06 11:36:45 +05:30
|
|
|
}
|
|
|
|
|
2019-03-09 00:41:06 +01:00
|
|
|
// params is from, dir and optionally to, limit, filter.
|
2021-11-24 21:05:01 +05:30
|
|
|
messages(roomId: string, params: Record<string, any>, options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._get(`/rooms/${encodeURIComponent(roomId)}/messages`, params, undefined, options);
|
2019-03-09 00:41:06 +01:00
|
|
|
}
|
|
|
|
|
2020-08-19 16:11:33 +02:00
|
|
|
// params is at, membership and not_membership
|
2021-11-24 21:05:01 +05:30
|
|
|
members(roomId: string, params: Record<string, any>, options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._get(`/rooms/${encodeURIComponent(roomId)}/members`, params, undefined, options);
|
2020-08-19 16:11:33 +02:00
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
send(roomId: string, eventType: string, txnId: string, content: Record<string, any>, options?: IRequestOptions): IHomeServerRequest {
|
2020-04-05 15:11:15 +02:00
|
|
|
return this._put(`/rooms/${encodeURIComponent(roomId)}/send/${encodeURIComponent(eventType)}/${encodeURIComponent(txnId)}`, {}, content, options);
|
2019-07-26 22:03:57 +02:00
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
redact(roomId: string, eventId: string, txnId: string, content: Record<string, any>, options?: IRequestOptions): IHomeServerRequest {
|
2021-05-19 16:41:07 +02:00
|
|
|
return this._put(`/rooms/${encodeURIComponent(roomId)}/redact/${encodeURIComponent(eventId)}/${encodeURIComponent(txnId)}`, {}, content, options);
|
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
receipt(roomId: string, receiptType: string, eventId: string, options?: IRequestOptions): IHomeServerRequest {
|
2020-08-21 15:16:57 +02:00
|
|
|
return this._post(`/rooms/${encodeURIComponent(roomId)}/receipt/${encodeURIComponent(receiptType)}/${encodeURIComponent(eventId)}`,
|
|
|
|
{}, {}, options);
|
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
state(roomId: string, eventType: string, stateKey: string, options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._get(`/rooms/${encodeURIComponent(roomId)}/state/${encodeURIComponent(eventType)}/${encodeURIComponent(stateKey)}`, {}, undefined, options);
|
2021-08-02 17:50:09 +05:30
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
getLoginFlows(): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._unauthedRequest("GET", this._url("/login"));
|
2021-07-27 19:23:46 +05:30
|
|
|
}
|
|
|
|
|
2022-02-01 17:45:14 +05:30
|
|
|
register(username: string | null, password: string, initialDeviceDisplayName: string, auth?: Record<string, any>, inhibitLogin: boolean = true , options: IRequestOptions = {}): IHomeServerRequest {
|
|
|
|
Object.assign(options, { allowedErrors: [401] });
|
2022-02-01 12:52:52 +05:30
|
|
|
const body = {
|
|
|
|
auth,
|
|
|
|
password,
|
|
|
|
initial_device_displayname: initialDeviceDisplayName,
|
2022-02-01 17:45:14 +05:30
|
|
|
inhibit_login: inhibitLogin,
|
2022-02-01 12:52:52 +05:30
|
|
|
};
|
|
|
|
if (username) {
|
|
|
|
// username is optional for registration
|
|
|
|
Object.assign(body, { username });
|
|
|
|
}
|
2022-02-01 17:45:14 +05:30
|
|
|
return this._unauthedRequest( "POST", this._url("/register", CS_V3_PREFIX), undefined, body, options);
|
2021-12-23 15:17:09 +05:30
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
passwordLogin(username: string, password: string, initialDeviceDisplayName: string, options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._unauthedRequest("POST", this._url("/login"), undefined, {
|
2019-02-04 22:26:24 +00:00
|
|
|
"type": "m.login.password",
|
|
|
|
"identifier": {
|
|
|
|
"type": "m.id.user",
|
|
|
|
"user": username
|
|
|
|
},
|
2020-09-08 10:53:15 +02:00
|
|
|
"password": password,
|
|
|
|
"initial_device_display_name": initialDeviceDisplayName
|
2020-04-05 15:11:15 +02:00
|
|
|
}, options);
|
2019-06-26 22:31:36 +02:00
|
|
|
}
|
2019-10-12 20:24:09 +02:00
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
tokenLogin(loginToken: string, txnId: string, initialDeviceDisplayName: string, options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._unauthedRequest("POST", this._url("/login"), undefined, {
|
2021-08-15 12:23:32 +05:30
|
|
|
"type": "m.login.token",
|
|
|
|
"identifier": {
|
|
|
|
"type": "m.id.user",
|
|
|
|
},
|
|
|
|
"token": loginToken,
|
|
|
|
"txn_id": txnId,
|
|
|
|
"initial_device_display_name": initialDeviceDisplayName
|
|
|
|
}, options);
|
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
createFilter(userId: string, filter: Record<string, any>, options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._post(`/user/${encodeURIComponent(userId)}/filter`, {}, filter, options);
|
2019-10-12 20:24:09 +02:00
|
|
|
}
|
2020-03-30 23:56:03 +02:00
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
versions(options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._unauthedRequest("GET", `${this._homeserver}/_matrix/client/versions`, undefined, undefined, options);
|
2020-03-30 23:56:03 +02:00
|
|
|
}
|
2020-05-09 20:02:08 +02:00
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
uploadKeys(dehydratedDeviceId: string, payload: Record<string, any>, options?: IRequestOptions): IHomeServerRequest {
|
2021-10-26 18:47:46 +02:00
|
|
|
let path = "/keys/upload";
|
|
|
|
if (dehydratedDeviceId) {
|
|
|
|
path = path + `/${encodeURIComponent(dehydratedDeviceId)}`;
|
|
|
|
}
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._post(path, {}, payload, options);
|
2020-08-27 19:13:24 +02:00
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
queryKeys(queryRequest: Record<string, any>, options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._post("/keys/query", {}, queryRequest, options);
|
2020-08-31 14:24:09 +02:00
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
claimKeys(payload: Record<string, any>, options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._post("/keys/claim", {}, payload, options);
|
2020-09-03 15:33:23 +02:00
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
sendToDevice(type: string, payload: Record<string, any>, txnId: string, options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._put(`/sendToDevice/${encodeURIComponent(type)}/${encodeURIComponent(txnId)}`, {}, payload, options);
|
2020-09-03 15:36:17 +02:00
|
|
|
}
|
2020-09-17 14:19:57 +02:00
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
roomKeysVersion(version?: string, options?: IRequestOptions): IHomeServerRequest {
|
2020-09-17 17:57:12 +02:00
|
|
|
let versionPart = "";
|
|
|
|
if (version) {
|
|
|
|
versionPart = `/${encodeURIComponent(version)}`;
|
2020-09-17 14:19:57 +02:00
|
|
|
}
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._get(`/room_keys/version${versionPart}`, undefined, undefined, options);
|
2020-09-17 14:19:57 +02:00
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
roomKeyForRoomAndSession(version: string, roomId: string, sessionId: string, options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._get(`/room_keys/keys/${encodeURIComponent(roomId)}/${encodeURIComponent(sessionId)}`, {version}, undefined, options);
|
2020-09-17 14:19:57 +02:00
|
|
|
}
|
2020-11-11 10:45:44 +01:00
|
|
|
|
2022-01-25 18:47:42 +01:00
|
|
|
uploadRoomKeysToBackup(version: string, payload: Record<string, any>, options?: IRequestOptions): IHomeServerRequest {
|
|
|
|
return this._put(`/room_keys/keys`, {version}, payload, options);
|
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
uploadAttachment(blob: Blob, filename: string, options?: IRequestOptions): IHomeServerRequest {
|
2020-11-11 11:50:40 +01:00
|
|
|
return this._authedRequest("POST", `${this._homeserver}/_matrix/media/r0/upload`, {filename}, blob, options);
|
2020-11-11 10:45:44 +01:00
|
|
|
}
|
2021-03-18 20:42:46 +01:00
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
setPusher(pusher: Record<string, any>, options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._post("/pushers/set", {}, pusher, options);
|
2021-03-18 20:42:46 +01:00
|
|
|
}
|
2021-04-01 14:59:46 +02:00
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
getPushers(options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._get("/pushers", undefined, undefined, options);
|
2021-04-01 14:59:46 +02:00
|
|
|
}
|
2021-04-20 19:02:45 +02:00
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
join(roomId: string, options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._post(`/rooms/${encodeURIComponent(roomId)}/join`, {}, {}, options);
|
2021-04-20 19:02:45 +02:00
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
joinIdOrAlias(roomIdOrAlias: string, options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._post(`/join/${encodeURIComponent(roomIdOrAlias)}`, {}, {}, options);
|
2021-05-18 11:05:31 +02:00
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
leave(roomId: string, options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._post(`/rooms/${encodeURIComponent(roomId)}/leave`, {}, {}, options);
|
2021-04-20 19:02:45 +02:00
|
|
|
}
|
2021-05-12 15:38:54 +02:00
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
forget(roomId: string, options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._post(`/rooms/${encodeURIComponent(roomId)}/forget`, {}, {}, options);
|
2021-05-12 15:38:54 +02:00
|
|
|
}
|
2021-10-26 12:49:31 +02:00
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
logout(options?: IRequestOptions): IHomeServerRequest {
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._post(`/logout`, {}, {}, options);
|
2021-10-26 12:49:31 +02:00
|
|
|
}
|
2021-10-26 18:47:46 +02:00
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
getDehydratedDevice(options: IRequestOptions): IHomeServerRequest {
|
2021-10-26 18:47:46 +02:00
|
|
|
options.prefix = DEHYDRATION_PREFIX;
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._get(`/dehydrated_device`, undefined, undefined, options);
|
2021-10-26 18:47:46 +02:00
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
createDehydratedDevice(payload: Record<string, any>, options: IRequestOptions): IHomeServerRequest {
|
2021-10-26 18:47:46 +02:00
|
|
|
options.prefix = DEHYDRATION_PREFIX;
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._put(`/dehydrated_device`, {}, payload, options);
|
2021-10-26 18:47:46 +02:00
|
|
|
}
|
|
|
|
|
2021-11-24 21:05:01 +05:30
|
|
|
claimDehydratedDevice(deviceId: string, options: IRequestOptions): IHomeServerRequest {
|
2021-10-26 18:47:46 +02:00
|
|
|
options.prefix = DEHYDRATION_PREFIX;
|
2021-11-23 18:09:33 +05:30
|
|
|
return this._post(`/dehydrated_device/claim`, {}, {device_id: deviceId}, options);
|
2021-10-26 18:47:46 +02:00
|
|
|
}
|
2019-03-08 12:26:59 +01:00
|
|
|
}
|
2020-04-22 20:47:31 +02:00
|
|
|
|
2021-04-09 15:15:28 +02:00
|
|
|
import {Request as MockRequest} from "../../mocks/Request.js";
|
2020-04-22 20:47:31 +02:00
|
|
|
|
2021-04-09 15:15:28 +02:00
|
|
|
export function tests() {
|
2020-04-22 20:47:31 +02:00
|
|
|
return {
|
|
|
|
"superficial happy path for GET": async assert => {
|
2021-11-23 18:09:33 +05:30
|
|
|
// @ts-ignore
|
2020-04-22 20:47:31 +02:00
|
|
|
const hsApi = new HomeServerApi({
|
2021-04-09 15:15:28 +02:00
|
|
|
request: () => new MockRequest().respond(200, 42),
|
2021-11-23 18:09:33 +05:30
|
|
|
homeserver: "https://hs.tld",
|
2020-04-22 20:47:31 +02:00
|
|
|
});
|
2021-11-23 19:31:13 +05:30
|
|
|
// @ts-ignore
|
2021-11-24 12:59:10 +05:30
|
|
|
const result = await hsApi._get("foo").response();
|
2020-04-22 20:47:31 +02:00
|
|
|
assert.strictEqual(result, 42);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|