partey_workadventure/front/src/Connexion/ConnectionManager.ts

70 lines
2.3 KiB
TypeScript
Raw Normal View History

2020-09-25 18:29:22 +02:00
import Axios from "axios";
import {API_URL} from "../Enum/EnvironmentVariable";
import {RoomConnection} from "./RoomConnection";
2020-09-28 15:02:37 +02:00
interface LoginApiData {
authToken: string
userUuid: string
mapUrlStart: string
newUrl: string
}
2020-09-25 18:29:22 +02:00
class ConnectionManager {
2020-09-28 15:02:37 +02:00
private initPromise: Promise<LoginApiData> = Promise.reject();
2020-09-25 18:29:22 +02:00
private mapUrlStart: string|null = null;
2020-09-25 18:29:22 +02:00
private authToken:string|null = null;
private userUuid: string|null = null;
2020-09-25 18:29:22 +02:00
public async init(): Promise<void> {
const match = /\/register\/(.+)/.exec(window.location.toString());
const organizationMemberToken = match ? match[1] : null;
2020-09-28 15:02:37 +02:00
this.initPromise = Axios.post(`${API_URL}/login`, {organizationMemberToken}).then(res => res.data);
const data = await this.initPromise
this.authToken = data.authToken;
this.userUuid = data.userUuid;
this.mapUrlStart = data.mapUrlStart;
const newUrl = data.newUrl;
2020-09-25 18:29:22 +02:00
if (newUrl) {
history.pushState({}, '', newUrl);
}
}
2020-09-30 12:12:24 +02:00
public initBenchmark(): void {
this.authToken = 'test';
}
2020-09-25 18:29:22 +02:00
public connectToRoomSocket(): Promise<RoomConnection> {
2020-09-28 15:02:37 +02:00
return new Promise<RoomConnection>((resolve, reject) => {
const connection = new RoomConnection(this.authToken as string);
connection.onConnectError((error: object) => {
console.log('An error occurred while connecting to socket server. Retrying');
reject(error);
2020-09-25 18:29:22 +02:00
});
connection.onConnect(() => {
resolve(connection);
})
2020-09-28 15:02:37 +02:00
}).catch((err) => {
// Let's retry in 4-6 seconds
return new Promise<RoomConnection>((resolve, reject) => {
setTimeout(() => {
//todo: allow a way to break recurrsion?
this.connectToRoomSocket().then((connection) => resolve(connection));
}, 4000 + Math.floor(Math.random() * 2000) );
});
});
}
2020-09-28 15:02:37 +02:00
public getMapUrlStart(): Promise<string> {
return this.initPromise.then(() => {
if (!this.mapUrlStart) {
throw new Error('No map url set!');
}
return this.mapUrlStart;
})
2020-09-25 18:29:22 +02:00
}
}
export const connectionManager = new ConnectionManager();