mirror of
https://github.com/falk-werner/webfuse
synced 2024-10-27 20:34:10 +00:00
87f34fa768
* moves server into session * renames jsonrpc server to jsonrpc proxy * moves server into session * renames jsonrpc server to jsonrpc proxy * adds json rpc server * removes obsolete proxy from protocol * changes interface of jsonrpc_proxy_onresult to accept previously parsed messages * adds infrastructure to process incoming requests; fixes invalid read of ill formatted responses * adds description of authentication request * adds authentication request * adds userdb for authentication purposes * removes debug code: console.log() * fixes cmake build error (missing openssl symbols) * fixes typo * replaces ASCII art by UML diagram * renames BAD_NOACCESS to BAD_ACCESS_DENIED * fixes style * adds docu of authentication * ignored false positives of flawfinder * fixes style issues * fixes javascript style issues
84 lines
2.9 KiB
JavaScript
84 lines
2.9 KiB
JavaScript
export class ConnectionView {
|
|
constructor(client) {
|
|
this._client = client;
|
|
this._client.onopen = () => { this._onConnectionOpened(); };
|
|
this._client.onclose = () => { this._onConnectionClosed(); };
|
|
|
|
this.element = document.createElement("div");
|
|
|
|
const connectBox = document.createElement("div");
|
|
this.element.appendChild(connectBox);
|
|
|
|
const urlLabel = document.createElement("span");
|
|
urlLabel.textContent = "URL:";
|
|
connectBox.appendChild(urlLabel);
|
|
|
|
this.urlTextbox = document.createElement("input");
|
|
this.urlTextbox.type = "text";
|
|
this.urlTextbox.value = window.location.href.replace(/^http/, "ws");
|
|
connectBox.appendChild(this.urlTextbox);
|
|
|
|
this.connectButton = document.createElement("input");
|
|
this.connectButton.type = "button";
|
|
this.connectButton.value = "connect";
|
|
this.connectButton.addEventListener("click", () => { this._onConnectButtonClicked(); });
|
|
connectBox.appendChild(this.connectButton);
|
|
|
|
|
|
const authenticateBox = document.createElement("div");
|
|
this.element.appendChild(authenticateBox);
|
|
|
|
const usernameLabel = document.createElement("span");
|
|
usernameLabel.textContent = "user:";
|
|
authenticateBox.appendChild(usernameLabel);
|
|
|
|
this.usernameTextbox = document.createElement("input");
|
|
this.usernameTextbox.type = "text";
|
|
this.usernameTextbox.value = "bob";
|
|
authenticateBox.appendChild(this.usernameTextbox);
|
|
|
|
const passwordLabel = document.createElement("span");
|
|
passwordLabel.textContent = "user:";
|
|
authenticateBox.appendChild(passwordLabel);
|
|
|
|
this.passwordTextbox = document.createElement("input");
|
|
this.passwordTextbox.type = "password";
|
|
this.passwordTextbox.value = "secret";
|
|
authenticateBox.appendChild(this.passwordTextbox);
|
|
|
|
this.authenticateButton = document.createElement("input");
|
|
this.authenticateButton.type = "button";
|
|
this.authenticateButton.value = "authenticate";
|
|
this.authenticateButton.addEventListener("click", () => { this._onAuthenticateButtonClicked(); });
|
|
authenticateBox.appendChild(this.authenticateButton);
|
|
}
|
|
|
|
_onConnectButtonClicked() {
|
|
if (!this._client.isConnected()) {
|
|
let url = this.urlTextbox.value;
|
|
this._client.connectTo(url);
|
|
}
|
|
else {
|
|
this._client.disconnect();
|
|
}
|
|
}
|
|
|
|
_onAuthenticateButtonClicked() {
|
|
if (this._client.isConnected()) {
|
|
const username = this.usernameTextbox.value;
|
|
const password = this.passwordTextbox.value;
|
|
|
|
this._client.authenticate("username", { username, password });
|
|
}
|
|
}
|
|
|
|
_onConnectionOpened() {
|
|
this.connectButton.value = "disconnect";
|
|
}
|
|
|
|
_onConnectionClosed() {
|
|
this.connectButton.value = "connect";
|
|
}
|
|
|
|
}
|