org.restcomm.media.control.mgcp.connection.MgcpConnectionProvider Maven / Gradle / Ivy
/*
* TeleStax, Open Source Cloud Communications
* Copyright 2011-2016, Telestax Inc and individual contributors
* by the @authors tag.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.restcomm.media.control.mgcp.connection;
import java.util.concurrent.atomic.AtomicInteger;
import org.restcomm.media.control.mgcp.pkg.MgcpEventProvider;
import org.restcomm.media.rtp.ChannelsManager;
import org.restcomm.media.rtp.channels.MediaChannelProvider;
import com.google.common.util.concurrent.ListeningScheduledExecutorService;
/**
* @author Henrique Rosa ([email protected])
*
*/
public class MgcpConnectionProvider {
private final AtomicInteger idGenerator;
private final int timeout;
private final MediaChannelProvider channelProvider;
private final ChannelsManager channelsManager;
private final ListeningScheduledExecutorService executor;
private final MgcpEventProvider eventProvider;
public MgcpConnectionProvider(int timeout, MgcpEventProvider eventProvider, MediaChannelProvider channelProvider, ChannelsManager channelsManager, ListeningScheduledExecutorService executor) {
this.idGenerator = new AtomicInteger(0);
this.timeout = timeout;
this.eventProvider = eventProvider;
this.channelProvider = channelProvider;
this.channelsManager = channelsManager;
this.executor = executor;
}
public MgcpRemoteConnection provideRemote(int callId) {
return new MgcpRemoteConnection(this.idGenerator.incrementAndGet(), callId, this.timeout, eventProvider, channelProvider, executor);
}
public MgcpLocalConnection provideLocal(int callId) {
return new MgcpLocalConnection(this.idGenerator.incrementAndGet(), callId, this.timeout, eventProvider, channelsManager, executor);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy