mirror of
https://github.com/danog/MadelineProto.git
synced 2024-12-04 17:27:48 +01:00
207 lines
5.6 KiB
PHP
207 lines
5.6 KiB
PHP
<?php declare(strict_types=1);
|
|
|
|
/**
|
|
* This file is part of MadelineProto.
|
|
* MadelineProto is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
|
|
* MadelineProto 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 Affero General Public License for more details.
|
|
* You should have received a copy of the GNU General Public License along with MadelineProto.
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
* @author Daniil Gentili <daniil@daniil.it>
|
|
* @copyright 2016-2023 Daniil Gentili <daniil@daniil.it>
|
|
* @license https://opensource.org/licenses/AGPL-3.0 AGPLv3
|
|
* @link https://docs.madelineproto.xyz MadelineProto documentation
|
|
*/
|
|
|
|
namespace danog\MadelineProto;
|
|
|
|
use Amp\ByteStream\ReadableStream;
|
|
use Amp\ByteStream\WritableStream;
|
|
use danog\MadelineProto\EventHandler\SimpleFilters;
|
|
use danog\MadelineProto\EventHandler\Update;
|
|
use danog\MadelineProto\VoIP\CallState;
|
|
use danog\MadelineProto\VoIP\DiscardReason;
|
|
|
|
/**
|
|
* This update represents a VoIP Telegram call.
|
|
*/
|
|
final class VoIP extends Update implements SimpleFilters
|
|
{
|
|
/** Phone call ID */
|
|
public readonly int $callID;
|
|
/** Whether the call is an outgoing call */
|
|
public readonly bool $outgoing;
|
|
/** ID of the other user in the call */
|
|
public readonly int $otherID;
|
|
/** When was the call created */
|
|
public readonly int $date;
|
|
|
|
/**
|
|
* Constructor.
|
|
*
|
|
* @internal
|
|
*/
|
|
public function __construct(
|
|
MTProto $API,
|
|
array $call
|
|
) {
|
|
parent::__construct($API);
|
|
$call['_'] = 'inputPhoneCall';
|
|
$this->date = $call['date'];
|
|
$this->callID = $call['id'];
|
|
if ($call['admin_id'] === $API->getSelf()['id']) {
|
|
$this->outgoing = true;
|
|
$this->otherID = $call['participant_id'];
|
|
} else {
|
|
$this->outgoing = false;
|
|
$this->otherID = $call['admin_id'];
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Accept call.
|
|
*/
|
|
public function accept(): self
|
|
{
|
|
$this->getClient()->acceptCall($this->callID);
|
|
return $this;
|
|
}
|
|
/**
|
|
* Discard call.
|
|
*
|
|
* @param int<1, 5> $rating Call rating in stars
|
|
* @param string $comment Additional comment on call quality.
|
|
*/
|
|
public function discard(DiscardReason $reason = DiscardReason::HANGUP, ?int $rating = null, ?string $comment = null): self
|
|
{
|
|
$this->getClient()->discardCall($this->callID, $reason, $rating, $comment);
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get call emojis (will return null if the call is not inited yet).
|
|
*
|
|
* @return ?list{string, string, string, string}
|
|
*/
|
|
public function getVisualization(): ?array
|
|
{
|
|
return $this->getClient()->getCallVisualization($this->callID);
|
|
}
|
|
|
|
/**
|
|
* Play file.
|
|
*/
|
|
public function play(LocalFile|RemoteUrl|ReadableStream $file): self
|
|
{
|
|
$this->getClient()->callPlay($this->callID, $file);
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Set output file or stream for incoming OPUS audio packets.
|
|
*
|
|
* Will write an OGG OPUS stream to the specified file or stream.
|
|
*/
|
|
public function setOutput(LocalFile|WritableStream $file): self
|
|
{
|
|
$this->getClient()->callSetOutput($this->callID, $file);
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Play file.
|
|
*/
|
|
public function then(LocalFile|RemoteUrl|ReadableStream $file): self
|
|
{
|
|
$this->getClient()->callPlay($this->callID, $file);
|
|
|
|
return $this;
|
|
}
|
|
/**
|
|
* When called, skips to the next file in the playlist.
|
|
*/
|
|
public function skip(): self
|
|
{
|
|
$this->getClient()->skipPlay($this->callID);
|
|
|
|
return $this;
|
|
}
|
|
/**
|
|
* Stops playing all files, clears the main and the hold playlist.
|
|
*/
|
|
public function stop(): self
|
|
{
|
|
$this->getClient()->stopPlay($this->callID);
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Pauses the currently playing file.
|
|
*/
|
|
public function pause(): self
|
|
{
|
|
$this->getClient()->pausePlay($this->callID);
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Whether the currently playing file is paused.
|
|
*
|
|
* @return boolean
|
|
*/
|
|
public function isPaused(): bool
|
|
{
|
|
return $this->getClient()->isPlayPaused($this->callID);
|
|
}
|
|
|
|
/**
|
|
* Resumes the currently playing file.
|
|
*/
|
|
public function resume(): self
|
|
{
|
|
$this->getClient()->resumePlay($this->callID);
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Files to play on hold.
|
|
*/
|
|
public function playOnHold(LocalFile|RemoteUrl|ReadableStream ...$files): self
|
|
{
|
|
$this->getClient()->callPlayOnHold($this->callID, ...$files);
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get the file that is currently being played.
|
|
*
|
|
* Will return a string with the object ID of the stream if we're currently playing a stream, otherwise returns the related LocalFile or RemoteUrl.
|
|
*/
|
|
public function getCurrent(): RemoteUrl|LocalFile|string|null
|
|
{
|
|
return $this->getClient()->callGetCurrent($this->callID);
|
|
}
|
|
|
|
/**
|
|
* Get call state.
|
|
*/
|
|
public function getCallState(): CallState
|
|
{
|
|
return $this->getClient()->getCallState($this->callID) ?? CallState::ENDED;
|
|
}
|
|
/**
|
|
* Get call representation.
|
|
*/
|
|
public function __toString(): string
|
|
{
|
|
return "call {$this->callID} with {$this->otherID}";
|
|
}
|
|
}
|