UNPKG

mediasfu-reactnative

Version:
62 lines (61 loc) 3.94 kB
import { Transport, Producer, ProducerOptions } from 'mediasoup-client/lib/types'; export interface ConnectSendTransportAudioParameters { audioProducer: Producer | null; producerTransport: Transport | null; localAudioProducer?: Producer | null; localProducerTransport?: Transport | null; updateAudioProducer: (producer: Producer | null) => void; updateProducerTransport: (transport: Transport | null) => void; updateLocalAudioProducer?: (localProducer: Producer | null) => void; updateLocalProducerTransport?: (localTransport: Transport | null) => void; updateAudioLevel: (level: number) => void; getUpdatedAllParams: () => ConnectSendTransportAudioParameters; [key: string]: any; } export interface ConnectSendTransportAudioOptions { audioParams: ProducerOptions; parameters: ConnectSendTransportAudioParameters; targetOption?: 'all' | 'local' | 'remote'; } export type ConnectSendTransportAudioType = (options: ConnectSendTransportAudioOptions) => Promise<void>; export declare const updateMicLevel: (audioProducer: Producer, updateAudioLevel: (level: number) => void) => Promise<void>; /** * Connects the send transport for audio by producing audio data and updating the audio producer and producer transport objects. * * If the primary connection fails, it attempts to connect using the local transport via a separate function. * * @param {ConnectSendTransportAudioOptions} options - The options for connecting the send transport. * @param {ProducerOptions} options.audioParams - The audio parameters. * @param {ConnectSendTransportAudioParameters} options.parameters - The parameters required for connecting the transport. * @param {Producer | null} options.parameters.audioProducer - The audio producer object. * @param {Transport | null} options.parameters.producerTransport - The producer transport object. * @param {Producer | null} [options.parameters.localAudioProducer] - The local audio producer object. * @param {Transport | null} [options.parameters.localProducerTransport] - The local producer transport object. * @param {(producer: Producer | null) => void} options.parameters.updateAudioProducer - The function to update the audio producer object. * @param {(transport: Transport | null) => void} options.parameters.updateProducerTransport - The function to update the producer transport object. * @param {(localProducer: Producer | null) => void} [options.parameters.updateLocalAudioProducer] - The function to update the local audio producer object. * @param {(localTransport: Transport | null) => void} [options.parameters.updateLocalProducerTransport] - The function to update the local producer transport object. * @param {(level: number) => void} [options.parameters.updateAudioLevel] - The function to update the audio level. * @returns {Promise<void>} A promise that resolves when the connection is established. * * @example * const options = { * audioParams: { codec: 'opus', maxBitrate: 128000 }, * parameters: { * audioProducer: null, * producerTransport: transport, * localAudioProducer: null, * localProducerTransport: localTransport, * updateAudioProducer: (producer) => console.log('Updated producer:', producer), * updateProducerTransport: (transport) => console.log('Updated transport:', transport), * updateLocalAudioProducer: (localProducer) => console.log('Updated local producer:', localProducer), * updateLocalProducerTransport: (localTransport) => console.log('Updated local transport:', localTransport), * updateAudioLevel: (level) => console.log('Updated audio level:', level), * }, * }; * * connectSendTransportAudio(options) * .then(() => console.log('Audio transport connected successfully')) * .catch((error) => console.error('Error connecting audio transport:', error)); */ export declare const connectSendTransportAudio: ConnectSendTransportAudioType;