import {LitElement, html} from './lit-all.min.js';
import * as tfrpc from '/static/tfrpc.js';
import {styles} from './tf-styles.js';
class TfTabConnectionsElement extends LitElement {
static get properties() {
return {
broadcasts: {type: Array},
identities: {type: Array},
my_identities: {type: Array},
connections: {type: Array},
stored_connections: {type: Array},
users: {type: Object},
server_identity: {type: String},
connect_attempt: {type: Object},
connect_message: {type: String},
connect_success: {type: Boolean},
};
}
static styles = styles;
static k_broadcast_emojis = {
discovery: '🏓',
room: '🚪',
peer_exchange: '🕸',
};
constructor() {
super();
let self = this;
this.broadcasts = [];
this.identities = [];
this.my_identities = [];
this.connections = [];
this.stored_connections = [];
this.users = {};
tfrpc.rpc.getIdentities().then(function (identities) {
self.my_identities = identities || [];
});
tfrpc.rpc.getAllIdentities().then(function (identities) {
self.identities = identities || [];
});
tfrpc.rpc.getStoredConnections().then(function (connections) {
self.stored_connections = connections || [];
});
tfrpc.rpc.getServerIdentity().then(function (identity) {
self.server_identity = identity;
});
}
render_connection_summary(connection) {
if (connection.address && connection.port) {
return html`
${connection.address}:${connection.port}
`;
} else if (connection.tunnel) {
return html`room peer
`;
} else {
return JSON.stringify(connection);
}
}
render_room_peers(connection) {
let self = this;
let peers = this.broadcasts.filter((x) => x.tunnel?.id == connection);
if (peers.length) {
let connections = this.connections.map((x) => x.id);
return html`${peers
.filter((x) => connections.indexOf(x.pubkey) == -1)
.map((x) => html`${self.render_room_peer(x)}`)}`;
}
}
async _tunnel(portal, target) {
return tfrpc.rpc.createTunnel(portal, target);
}
render_room_peer(connection) {
let self = this;
return html`
📡
`;
}
render_message(connection) {
return html` (this.connect_attempt = undefined)}
>
${this.connect_message}
`;
}
render_broadcast(connection) {
let self = this;
return html`
${TfTabConnectionsElement.k_broadcast_emojis[connection.origin]}
${this.render_connection_summary(connection)}
${this.render_message(connection)}
`;
}
async forget_stored_connection(connection) {
await tfrpc.rpc.forgetStoredConnection(connection);
this.stored_connections = (await tfrpc.rpc.getStoredConnections()) || [];
}
render_connection(connection) {
let requests = Object.values(
connection.requests.reduce(function (accumulator, value) {
let key = `${value.name}:${Math.sign(value.request_number)}`;
if (!accumulator[key]) {
accumulator[key] = Object.assign({count: 0}, value);
}
accumulator[key].count++;
return accumulator;
}, {})
);
return html`
${connection.flags.one_shot ? '🔃' : undefined}
${connection.tunnel !== undefined
? '🚇'
: html`(${connection.host}:${connection.port})`}
${requests.map(
(x) => html`
${x.request_number > 0 ? '🟩' : '🟥'} ${x.name}
1 ? undefined : 'display: none'}
>${x.count}
`
)}
${this.connections
.filter((x) => x.tunnel === this.connections.indexOf(connection))
.map((x) => html`- ${this.render_connection(x)}
`)}
${this.render_room_peers(connection.id)}
${connection.destroy_reason}
`;
}
connect(address) {
let self = this;
self.connect_attempt = address;
self.connect_message = undefined;
self.connect_success = false;
tfrpc.rpc
.connect(address)
.then(function () {
if (self.connect_attempt == address) {
self.connect_message = 'Connected.';
self.connect_success = true;
}
})
.catch(function (error) {
if (self.connect_attempt == address) {
self.connect_message = 'Error: ' + error;
self.connect_success = false;
}
});
}
render() {
let self = this;
return html`
New Connection
${this.render_message(this.renderRoot.getElementById('code')?.value)}
Broadcasts
${this.broadcasts
.filter((x) => x.address)
.filter(
(x) => self.connections.map((c) => c.id).indexOf(x.pubkey) == -1
)
.map((x) => self.render_broadcast(x))}
Connections
${this.connections
.filter((x) => x.tunnel === undefined)
.map(
(x) => html`
- ${this.render_connection(x)}
`
)}
Stored Connections
${this.stored_connections.map(
(x) => html`
-
${this.render_message(x)}
`
)}
Local Accounts
${this.identities.map(
(x) =>
html`-
${x == this.server_identity
? html`🖥 local server`
: undefined}
${this.my_identities.indexOf(x) != -1
? html`😎 you`
: undefined}
`
)}
`;
}
}
customElements.define('tf-tab-connections', TfTabConnectionsElement);