All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.asteriskjava.manager.action.MixMonitorMuteAction Maven / Gradle / Ivy

There is a newer version: 3.41.0
Show newest version
/*
 * Copyright 2012 Stefan Reuter.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.asteriskjava.manager.action;

/**
 * MixMonitorMute can be used to mute and un-mute an existing recording.
 * @author Bob Wienholt
 * @version $Id$
 */
public class MixMonitorMuteAction extends AbstractManagerAction
{
	private static final long serialVersionUID = 1L;
	private String channel;
	private String direction;
	private Integer state;

	/**
	 * Creates a new empty MixMonitorMuteAction
	 */
	public MixMonitorMuteAction()
	{
		super();
	}
	
	/**
	 * Mutes the monitor on the given channel.
	 * @param channel 
	 */
	public MixMonitorMuteAction(String channel)
	{
		super();
		this.channel = channel;
	}
	
	/**
	 * Mutes the monitor on the given channel for the given portion
	 * of the call.
	 * @param channel
	 * @param direction 
	 */
	public MixMonitorMuteAction(String channel, String direction)
	{
		super();
		this.channel = channel;
		this.direction = direction;
	}
	
	/**
	 * Either mutes or un-mutes the monitor on the given channel for 
	 * the given portion of the call.
	 * @param channel
	 * @param direction
	 * @param state 
	 */
	public MixMonitorMuteAction(String channel, String direction, Integer state)
	{
		super();
		this.channel = channel;
		this.direction = direction;
		this.state = state;
	}
	
	/**
	 * Either mutes or un-mutes the monitor on the given channel.
	 * @param channel
	 * @param state 
	 */
	public MixMonitorMuteAction(String channel, Integer state)
	{
		super();
		this.channel = channel;
		this.state = state;
	}
	
	/**
	 * Returns the name of this action.
	 */
	@Override
	public String getAction() {
		return "MixMonitorMute";
	}

	/**
	 * Returns the name of the channel to mute.
	 */
	public String getChannel() {
		return channel;
	}

	/**
	 * Sets the name of the channel to mute.
	 * @param channel 
	 */
	public void setChannel(String channel) {
		this.channel = channel;
	}

	/**
	 * Gets the direction of the part of the recording to mute.
	 */
	public String getDirection() {
		return direction;
	}

	/**
	 * Sets the direction of the part of the recording to mute.
	 * Can be one of: read, write, or both.  Defaults to both.
	 * @param direction 
	 */
	public void setDirection(String direction) {
		this.direction = direction;
	}

	/**
	 * Gets the state of the mute.
	 */
	public Integer getState() {
		return state;
	}

	/**
	 * Sets the state of the mute operation.  1 = on, 0 = off.
	 * @param state 
	 */
	public void setState(Integer state) {
		this.state = state;
	}
	
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy