cloud_bbb/lib/BigBlueButton/API.php

261 lines
7.5 KiB
PHP
Raw Normal View History

2020-05-16 17:14:17 +02:00
<?php
namespace OCA\BigBlueButton\BigBlueButton;
use BigBlueButton\BigBlueButton;
use BigBlueButton\Core\Record;
2020-09-23 12:33:09 +02:00
use BigBlueButton\Parameters\CreateMeetingParameters;
use BigBlueButton\Parameters\DeleteRecordingsParameters;
2020-09-23 12:33:09 +02:00
use BigBlueButton\Parameters\GetRecordingsParameters;
use BigBlueButton\Parameters\IsMeetingRunningParameters;
2020-09-23 12:33:09 +02:00
use BigBlueButton\Parameters\JoinMeetingParameters;
use OCA\BigBlueButton\Crypto;
2020-05-16 17:14:17 +02:00
use OCA\BigBlueButton\Db\Room;
2020-09-23 12:33:09 +02:00
use OCA\BigBlueButton\Event\MeetingStartedEvent;
use OCA\BigBlueButton\Permission;
use OCA\BigBlueButton\UrlHelper;
2020-09-23 12:33:09 +02:00
use OCP\EventDispatcher\IEventDispatcher;
2020-05-16 17:14:17 +02:00
use OCP\IConfig;
2020-09-22 16:08:14 +02:00
use OCP\IL10N;
2020-09-23 12:33:09 +02:00
use OCP\IURLGenerator;
2020-05-16 17:14:17 +02:00
class API {
2020-05-16 17:14:17 +02:00
/** @var IConfig */
private $config;
/** @var IURLGenerator */
private $urlGenerator;
/** @var Permission */
private $permission;
/** @var BigBlueButton|null */
2020-05-16 17:14:17 +02:00
private $server;
/** @var Crypto */
private $crypto;
2020-09-22 13:51:47 +02:00
/** @var IEventDispatcher */
private $eventDispatcher;
2020-09-22 16:08:14 +02:00
/** @var IL10N */
private $l10n;
/** @var UrlHelper */
private $urlHelper;
2020-05-16 17:14:17 +02:00
public function __construct(
IConfig $config,
IURLGenerator $urlGenerator,
Permission $permission,
2020-09-22 13:51:47 +02:00
Crypto $crypto,
2020-09-22 16:08:14 +02:00
IEventDispatcher $eventDispatcher,
IL10N $l10n,
UrlHelper $urlHelper
2020-05-16 17:14:17 +02:00
) {
$this->config = $config;
$this->urlGenerator = $urlGenerator;
$this->permission = $permission;
$this->crypto = $crypto;
2020-09-22 13:51:47 +02:00
$this->eventDispatcher = $eventDispatcher;
2020-09-22 16:08:14 +02:00
$this->l10n = $l10n;
$this->urlHelper = $urlHelper;
2020-05-16 17:14:17 +02:00
}
private function getServer() {
2020-05-16 17:14:17 +02:00
if (!$this->server) {
$apiUrl = $this->config->getAppValue('bbb', 'api.url');
$secret = $this->config->getAppValue('bbb', 'api.secret');
$this->server = new BigBlueButton($apiUrl, $secret);
}
return $this->server;
}
/**
* Create join url.
*
* @return string join url
*/
public function createJoinUrl(Room $room, int $creationTime, string $displayname, ?string $uid = null) {
$password = $this->permission->isModerator($room, $uid) ? $room->moderatorPassword : $room->attendeePassword;
2020-05-16 17:14:17 +02:00
$joinMeetingParams = new JoinMeetingParameters($room->uid, $displayname, $password);
$joinMeetingParams->setCreationTime($creationTime);
$joinMeetingParams->setJoinViaHtml5(true);
$joinMeetingParams->setRedirect(true);
$joinMeetingParams->setGuest($uid === null);
2020-05-16 17:14:17 +02:00
if ($uid) {
$joinMeetingParams->setUserId($uid);
// $joinMeetingParams->setAvatarURL();
}
return $this->getServer()->getJoinMeetingURL($joinMeetingParams);
}
/**
* Create meeting room.
*
* @return int creation time
*/
public function createMeeting(Room $room, Presentation $presentation = null) {
2020-05-16 17:14:17 +02:00
$bbb = $this->getServer();
2020-06-10 13:53:46 +02:00
$meetingParams = $this->buildMeetingParams($room, $presentation);
2020-05-16 17:14:17 +02:00
try {
2020-06-10 13:53:46 +02:00
$response = $bbb->createMeeting($meetingParams);
2020-05-16 17:14:17 +02:00
} catch (\Exception $e) {
2020-06-10 13:53:46 +02:00
throw new \Exception('Can not process create request: ' . $bbb->getCreateMeetingUrl($meetingParams));
2020-05-16 17:14:17 +02:00
}
if (!$response->success()) {
throw new \Exception('Can not create meeting');
}
2020-09-22 13:51:47 +02:00
if ($response->getMessageKey() !== 'duplicateWarning') {
$this->eventDispatcher->dispatch(MeetingStartedEvent::class, new MeetingStartedEvent($room));
}
2020-05-16 17:14:17 +02:00
return $response->getCreationTime();
}
private function buildMeetingParams(Room $room, Presentation $presentation = null): CreateMeetingParameters {
2020-05-16 17:14:17 +02:00
$createMeetingParams = new CreateMeetingParameters($room->uid, $room->name);
$createMeetingParams->setAttendeePassword($room->attendeePassword);
$createMeetingParams->setModeratorPassword($room->moderatorPassword);
$createMeetingParams->setRecord($room->record);
$createMeetingParams->setAllowStartStopRecording($room->record);
$createMeetingParams->setLogoutUrl($this->urlGenerator->getBaseUrl());
$mac = $this->crypto->calculateHMAC($room->uid);
$endMeetingUrl = $this->urlGenerator->linkToRouteAbsolute('bbb.hook.meetingEnded', ['token' => $room->uid, 'mac' => $mac]);
$createMeetingParams->setEndCallbackUrl($endMeetingUrl);
$recordingReadyUrl = $this->urlGenerator->linkToRouteAbsolute('bbb.hook.recordingReady', ['token' => $room->uid, 'mac' => $mac]);
$createMeetingParams->setRecordingReadyCallbackUrl($recordingReadyUrl);
$invitationUrl = $this->urlHelper->linkToInvitationAbsolute($room);
2020-09-22 16:08:14 +02:00
$createMeetingParams->setModeratorOnlyMessage($this->l10n->t('To invite someone to the meeting, send them this link: %s', [$invitationUrl]));
2020-05-16 17:14:17 +02:00
if (!empty($room->welcome)) {
$createMeetingParams->setWelcomeMessage($room->welcome);
}
if ($room->maxParticipants > 0) {
$createMeetingParams->setMaxParticipants($room->maxParticipants);
}
if ($presentation !== null && $presentation->isValid()) {
$createMeetingParams->addPresentation($presentation->getUrl(), null, $presentation->getFilename());
}
if ($room->access === Room::ACCESS_WAITING_ROOM) {
$createMeetingParams->setGuestPolicyAskModerator();
}
2020-05-16 17:14:17 +02:00
return $createMeetingParams;
}
public function getRecording(string $recordId) {
$recordingParams = new GetRecordingsParameters();
$recordingParams->setRecordId($recordId);
$recordingParams->setState('any');
$response = $this->getServer()->getRecordings($recordingParams);
if (!$response->success()) {
throw new \Exception('Could not process get recording request');
}
$records = $response->getRecords();
if (count($records) === 0) {
throw new \Exception('Found no record with given id');
}
return $this->recordToArray($records[0]);
}
public function getRecordings(Room $room) {
$recordingParams = new GetRecordingsParameters();
$recordingParams->setMeetingId($room->uid);
$recordingParams->setState('processing,processed,published,unpublished');
$response = $this->getServer()->getRecordings($recordingParams);
if (!$response->success()) {
throw new \Exception('Could not process get recordings request');
}
$records = $response->getRecords();
return array_map(function ($record) {
return $this->recordToArray($record);
}, $records);
}
public function deleteRecording(string $recordingId): bool {
$deleteParams = new DeleteRecordingsParameters($recordingId);
$response = $this->getServer()->deleteRecordings($deleteParams);
return $response->isDeleted();
}
private function recordToArray(Record $record) {
return [
'id' => $record->getRecordId(),
'meetingId' => $record->getMeetingId(),
'name' => $record->getName(),
'published' => $record->isPublished(),
'state' => $record->getState(),
'startTime' => $record->getStartTime(),
'participants' => $record->getParticipantCount(),
'type' => $record->getPlaybackType(),
'length' => $record->getPlaybackLength(),
'url' => $record->getPlaybackUrl(),
'metas' => $record->getMetas(),
];
}
public function check($url, $secret) {
$server = new BigBlueButton($url, $secret);
$meetingParams = new IsMeetingRunningParameters('foobar');
try {
$response = $server->isMeetingRunning($meetingParams);
if (!$response->success() && !$response->failed()) {
return 'invalid-url';
}
if (!$response->success()) {
return 'invalid-secret';
}
return 'success';
} catch (\Exception $e) {
return 'invalid-url';
}
}
public function getVersion($url = null) {
$server = $url === null ? $this->getServer() : new BigBlueButton($url, '');
return $server->getApiVersion()->getVersion();
}
public function isRunning(Room $room): bool {
$isMeetingRunningParams = new IsMeetingRunningParameters($room->getUid());
$response = $this->getServer()->isMeetingRunning($isMeetingRunningParams);
return $response->success() && $response->isRunning();
}
2020-05-16 17:14:17 +02:00
}