import { NewPipeProducer } from './socket-receive-methods/new-pipe-producer.service'; import { ProducerClosed } from './socket-receive-methods/producer-closed.service'; import { JoinConsumeRoom } from './socket-receive-methods/join-consume-room.service'; import { types } from 'mediasoup-client'; import { ReorderStreamsParameters, ReorderStreamsType, NewPipeProducerParameters, NewPipeProducerType, ProducerClosedType, ProducerClosedParameters, JoinConsumeRoomType, JoinConsumeRoomParameters, ConsumeSocket } from '../@types/types'; import * as i0 from "@angular/core"; type Device = types.Device; export interface ConnectIpsParameters extends ReorderStreamsParameters, JoinConsumeRoomParameters, ProducerClosedParameters, NewPipeProducerParameters { device: Device | null; roomRecvIPs: string[]; updateRoomRecvIPs: (roomRecvIPs: string[]) => void; updateConsume_sockets: (consume_sockets: ConsumeSocket[]) => void; reorderStreams: ReorderStreamsType; getUpdatedAllParams: () => ConnectIpsParameters; [key: string]: any; } export interface ConnectIpsOptions { consume_sockets: ConsumeSocket[]; remIP: string[]; apiUserName: string; apiKey?: string; apiToken: string; newProducerMethod?: NewPipeProducerType; closedProducerMethod?: ProducerClosedType; joinConsumeRoomMethod?: JoinConsumeRoomType; parameters: ConnectIpsParameters; } export type ConnectIpsType = (options: ConnectIpsOptions) => Promise<[Record[], string[]]>; /** * Connects to remote IPs and manages socket connections. * * This method establishes connections to remote IPs for media streaming, handles new pipe producer events, * and manages producer closure events. It updates the necessary state in the application to reflect * the current connections and stream configurations. * * @param {ConnectIpsOptions} options - The options for connecting IPs. * @param {Record[]} options.consume_sockets - The array of current socket connections. * @param {string[]} options.remIP - The list of remote IPs to connect to. * @param {string} options.apiUserName - The API username for authentication. * @param {string} [options.apiKey] - The API key for authentication. * @param {string} [options.apiToken] - The API token for authentication. * @param {Function} [options.newProducerMethod] - The method to handle new pipe producer events (default: newPipeProducer). * @param {Function} [options.closedProducerMethod] - The method to handle producer closed events (default: producerClosed). * @param {Function} [options.joinConsumeRoomMethod] - The method to handle joining a consuming room (default: joinConsumeRoom). * @param {ConnectIpsParameters} options.parameters - Additional parameters for the operation. * @param {string[]} options.parameters.roomRecvIPs - The list of IPs that have been received in the room. * @param {Function} options.parameters.updateRoomRecvIPs - Function to update the room received IPs. * @param {Function} options.parameters.updateConsume_sockets - Function to update the consume sockets. * * @returns {Promise<[Record[], string[]]>} A promise that resolves to an array containing the updated consume sockets and room received IPs. * * @throws Will throw an error if required parameters are missing or if there is an issue connecting to a remote IP. * * @example * ```typescript * const result = await connectIps({ * consume_sockets: currentSockets, * remIP: ['192.168.1.1', '192.168.1.2'], * apiUserName: 'username', * apiKey: 'your-api-key', * apiToken: 'your-api-token', * parameters: { * roomRecvIPs: [], * updateRoomRecvIPs: (ips) => { }, * updateConsume_sockets: (sockets) => { }, * // ...other parameters * }, * }); * ``` */ export declare class ConnectIps { private newPipeProducerService; private producerClosedService; private joinConsumeRoomService; constructor(newPipeProducerService: NewPipeProducer, producerClosedService: ProducerClosed, joinConsumeRoomService: JoinConsumeRoom); connectIps: ConnectIpsType; static ɵfac: i0.ɵɵFactoryDeclaration; static ɵprov: i0.ɵɵInjectableDeclaration; } export {};