calling: update setTurnServerOverride to support overriding all ice server fields

This commit is contained in:
adel-signal 2024-05-03 09:01:59 -07:00 committed by GitHub
parent a1f0afdae8
commit a57d5582f0
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 61 additions and 35 deletions

View file

@ -82,6 +82,7 @@ import * as durations from '../util/durations';
import { clearTimeoutIfNecessary } from '../util/clearTimeoutIfNecessary'; import { clearTimeoutIfNecessary } from '../util/clearTimeoutIfNecessary';
import { fetchMembershipProof, getMembershipList } from '../groups'; import { fetchMembershipProof, getMembershipList } from '../groups';
import type { ProcessedEnvelope } from '../textsecure/Types.d'; import type { ProcessedEnvelope } from '../textsecure/Types.d';
import type { GetIceServersResultType } from '../textsecure/WebAPI';
import { missingCaseError } from '../util/missingCaseError'; import { missingCaseError } from '../util/missingCaseError';
import { normalizeGroupCallTimestamp } from '../util/ringrtc/normalizeGroupCallTimestamp'; import { normalizeGroupCallTimestamp } from '../util/ringrtc/normalizeGroupCallTimestamp';
import { import {
@ -317,7 +318,7 @@ export class CallingClass {
public _sfuUrl?: string; public _sfuUrl?: string;
public _iceServerOverride?: string; public _iceServerOverride?: GetIceServersResultType | string;
private lastMediaDeviceSettings?: MediaDeviceSettings; private lastMediaDeviceSettings?: MediaDeviceSettings;
@ -2658,12 +2659,39 @@ export class CallingClass {
} }
private async handleStartCall(call: Call): Promise<boolean> { private async handleStartCall(call: Call): Promise<boolean> {
type IceServer = {
username?: string;
password?: string;
hostname?: string;
urls: Array<string>;
};
function iceServerConfigToList(
iceServerConfig: GetIceServersResultType
): Array<IceServer> {
return [
{
hostname: iceServerConfig.hostname ?? '',
username: iceServerConfig.username,
password: iceServerConfig.password,
urls: (iceServerConfig.urlsWithIps ?? []).slice(),
},
{
hostname: '',
username: iceServerConfig.username,
password: iceServerConfig.password,
urls: (iceServerConfig.urls ?? []).slice(),
},
];
}
if (!window.textsecure.messaging) { if (!window.textsecure.messaging) {
log.error('handleStartCall: offline!'); log.error('handleStartCall: offline!');
return false; return false;
} }
const iceServer = await window.textsecure.messaging.server.getIceServers(); const iceServerConfig =
await window.textsecure.messaging.server.getIceServers();
const shouldRelayCalls = window.Events.getAlwaysRelayCalls(); const shouldRelayCalls = window.Events.getAlwaysRelayCalls();
@ -2676,33 +2704,23 @@ export class CallingClass {
// If the peer is not in the user's system contacts, force IP hiding. // If the peer is not in the user's system contacts, force IP hiding.
const isContactUntrusted = !isInSystemContacts(conversation.attributes); const isContactUntrusted = !isInSystemContacts(conversation.attributes);
// proritize ice servers with IPs to avoid DNS
// only include hostname with urlsWithIps // only include hostname with urlsWithIps
const iceServers = this._iceServerOverride let iceServers = iceServerConfigToList(iceServerConfig);
? [
{ if (this._iceServerOverride) {
hostname: ICE_SERVER_IS_IP_LIKE.test(this._iceServerOverride) if (typeof this._iceServerOverride === 'string') {
? iceServer.hostname if (ICE_SERVER_IS_IP_LIKE.test(this._iceServerOverride)) {
: '', iceServers[0].urls = [this._iceServerOverride];
username: iceServer.username, iceServers = [iceServers[0]];
password: iceServer.password, } else {
urls: [this._iceServerOverride.toString()], iceServers[1].urls = [this._iceServerOverride];
}, iceServers = [iceServers[1]];
] }
: // proritize ice servers with IPs to avoid DNS } else {
[ iceServers = iceServerConfigToList(this._iceServerOverride);
{ }
hostname: iceServer.hostname ?? '', }
username: iceServer.username,
password: iceServer.password,
urls: (iceServer.urlsWithIps ?? []).slice(),
},
{
hostname: '',
username: iceServer.username,
password: iceServer.password,
urls: (iceServer.urls ?? []).slice(),
},
];
const callSettings = { const callSettings = {
iceServers, iceServers,

View file

@ -13,7 +13,10 @@ import './phase3-post-signal';
import './phase4-test'; import './phase4-test';
import '../../backbone/reliable_trigger'; import '../../backbone/reliable_trigger';
import type { CdsLookupOptionsType } from '../../textsecure/WebAPI'; import type {
CdsLookupOptionsType,
GetIceServersResultType,
} from '../../textsecure/WebAPI';
import type { FeatureFlagType } from '../../window.d'; import type { FeatureFlagType } from '../../window.d';
import type { StorageAccessType } from '../../types/Storage.d'; import type { StorageAccessType } from '../../types/Storage.d';
import { start as startConversationController } from '../../ConversationController'; import { start as startConversationController } from '../../ConversationController';
@ -71,13 +74,18 @@ if (!isProduction(window.SignalContext.getVersion())) {
setSfuUrl: (url: string) => { setSfuUrl: (url: string) => {
window.Signal.Services.calling._sfuUrl = url; window.Signal.Services.calling._sfuUrl = url;
}, },
setIceServerOverride: (url: string) => { setIceServerOverride: (
if (!/(turn|turns|stun):.*]/.test(url)) { override: GetIceServersResultType | string | undefined
) => {
if (typeof override === 'string') {
if (!/(turn|turns|stun):.*/.test(override)) {
log.warn( log.warn(
'Override url should be prefixed with `turn:`, `turns:`, or `stun:` else override may not work' 'Override url should be prefixed with `turn:`, `turns:`, or `stun:` else override may not work'
); );
} }
window.Signal.Services.calling._iceServerOverride = url; }
window.Signal.Services.calling._iceServerOverride = override;
}, },
sqlCall: (name: string, ...args: ReadonlyArray<unknown>) => sqlCall: (name: string, ...args: ReadonlyArray<unknown>) =>
ipcInvoke(name, args), ipcInvoke(name, args),