Source of file MonitorAction.php

Size: 2,453 Bytes - Last Modified: 2019-04-30T12:53:24+00:00

/data/development/sccp/sources/PAMI/src/PAMI/Message/Action/MonitorAction.php

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
<?php
/**
 * Monitor action message. Will always record with .wav format and mixing the
 * input and output channels. Also, the filename is mandatory:
 *
 * Mix: true
 * Format: wav
 *
 * PHP Version 5
 *
 * @category   Pami
 * @package    Message
 * @subpackage Action
 * @author     Marcelo Gornstein <marcelog@gmail.com>
 * @license    http://marcelog.github.com/PAMI/ Apache License 2.0
 * @version    SVN: $Id$
 * @link       http://marcelog.github.com/PAMI/
 *
 * Copyright 2011 Marcelo Gornstein <marcelog@gmail.com>
 *
 * 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.
 *
 */
namespace PAMI\Message\Action;

/**
 * Monitor action message. Will always record with .wav format and mixing the
 * input and output channels. Also, the filename is mandatory:
 *
 * Mix: true
 * Format: wav
 *
 * PHP Version 5
 *
 * @category   Pami
 * @package    Message
 * @subpackage Action
 * @author     Marcelo Gornstein <marcelog@gmail.com>
 * @license    http://marcelog.github.com/PAMI/ Apache License 2.0
 * @link       http://marcelog.github.com/PAMI/
 */
class MonitorAction extends ActionMessage
{
    /**
     * Constructor.
     *
     * @param string $channel  Channel to monitor.
     * @param string $filename Absolute path to target filename.
     *
     * @return void
     */
    public function __construct($channel, $filename)
    {
        parent::__construct('Monitor');
        $this->setKey('Channel', $channel);
        $this->setKey('File', $filename);
    }
    
    /**
     * Sets Format
     *
     * @param string $format  Format to be used during recording
     *
     * @return void
     */
    public function setFormat($format)
    {
        $this->setKey('Format', $format);
    }

    /**
     * Sets mixing true/false
     *
     * @param boolean $monitor  Switch mixing mode on/off.
     *
     * @return void
     */
    public function setMix($mix)
    {
        $this->setKey('Mix', $mix ? 'true' : 'false');
    }
}