forked from mystiq/hydrogen-web
fix errors & support login in network
This commit is contained in:
parent
b6df30bc27
commit
b15136a9e8
1 changed files with 40 additions and 13 deletions
|
@ -1,4 +1,4 @@
|
||||||
class Request {
|
class RequestWrapper {
|
||||||
constructor(promise, controller) {
|
constructor(promise, controller) {
|
||||||
this._promise = promise;
|
this._promise = promise;
|
||||||
this._controller = controller;
|
this._controller = controller;
|
||||||
|
@ -8,37 +8,45 @@ class Request {
|
||||||
this._controller.abort();
|
this._controller.abort();
|
||||||
}
|
}
|
||||||
|
|
||||||
get response() {
|
response() {
|
||||||
return this._promise;
|
return this._promise;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export class Network {
|
export default class Network {
|
||||||
constructor(homeserver, accessToken) {
|
constructor(homeserver, accessToken) {
|
||||||
this._homeserver = homeserver;
|
this._homeserver = homeserver;
|
||||||
this._accessToken = accessToken;
|
this._accessToken = accessToken;
|
||||||
}
|
}
|
||||||
|
|
||||||
_url(csPath) {
|
_url(csPath) {
|
||||||
return `${this._homeserver}/_matrix/client/r0/${csPath}`;
|
return `${this._homeserver}/_matrix/client/r0${csPath}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
_request(method, csPath, queryParams = {}) {
|
_request(method, csPath, queryParams = {}, body) {
|
||||||
const queryString = Object.entries(queryParams)
|
const queryString = Object.entries(queryParams)
|
||||||
.filter(([name, value]) => value !== undefined)
|
.filter(([name, value]) => value !== undefined)
|
||||||
.map(([name, value]) => `${encodeURIComponent(name)}=${encodeURIComponent(value)}`);
|
.map(([name, value]) => `${encodeURIComponent(name)}=${encodeURIComponent(value)}`)
|
||||||
.join("&");
|
.join("&");
|
||||||
const url = this._url(`${csPath}?${queryString}`);
|
const url = this._url(`${csPath}?${queryString}`);
|
||||||
const request = new Request(url);
|
let bodyString;
|
||||||
const headers = request.headers;
|
const headers = new Headers();
|
||||||
|
if (this._accessToken) {
|
||||||
headers.append("Authorization", `Bearer ${this._accessToken}`);
|
headers.append("Authorization", `Bearer ${this._accessToken}`);
|
||||||
|
}
|
||||||
headers.append("Accept", "application/json");
|
headers.append("Accept", "application/json");
|
||||||
if (false/* body */) {
|
if (body) {
|
||||||
headers.append("Content-Type", "application/json");
|
headers.append("Content-Type", "application/json");
|
||||||
|
bodyString = JSON.stringify(body);
|
||||||
}
|
}
|
||||||
const controller = new AbortController();
|
const controller = new AbortController();
|
||||||
// TODO: set authenticated headers with second arguments, cache them
|
// TODO: set authenticated headers with second arguments, cache them
|
||||||
let promise = fetch(request, {signal: controller.signal});
|
let promise = fetch(url, {
|
||||||
|
method,
|
||||||
|
headers,
|
||||||
|
body: bodyString,
|
||||||
|
signal: controller.signal
|
||||||
|
});
|
||||||
promise = promise.then(response => {
|
promise = promise.then(response => {
|
||||||
if (response.ok) {
|
if (response.ok) {
|
||||||
return response.json();
|
return response.json();
|
||||||
|
@ -49,10 +57,29 @@ export class Network {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
return new Request(promise, controller);
|
return new RequestWrapper(promise, controller);
|
||||||
|
}
|
||||||
|
|
||||||
|
_post(csPath, queryParams, body) {
|
||||||
|
return this._request("POST", csPath, queryParams, body);
|
||||||
|
}
|
||||||
|
|
||||||
|
_get(csPath, queryParams, body) {
|
||||||
|
return this._request("GET", csPath, queryParams, body);
|
||||||
}
|
}
|
||||||
|
|
||||||
sync(timeout = 0, since = undefined) {
|
sync(timeout = 0, since = undefined) {
|
||||||
return this._request("GET", "/sync", {since, timeout});
|
return this._get("/sync", {since, timeout});
|
||||||
|
}
|
||||||
|
|
||||||
|
passwordLogin(username, password) {
|
||||||
|
return this._post("/login", undefined, {
|
||||||
|
"type": "m.login.password",
|
||||||
|
"identifier": {
|
||||||
|
"type": "m.id.user",
|
||||||
|
"user": username
|
||||||
|
},
|
||||||
|
"password": password
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in a new issue