bigbluebutton-Github/bbb-api-examples/PHP/bbb_api.inc.php
2010-02-18 11:05:30 +00:00

237 lines
8.3 KiB
PHP
Executable File

<!--
BigBlueButton - http://www.bigbluebutton.org
Copyright (c) 2008-2009 by respective authors (see below). All rights reserved.
BigBlueButton 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 3 of the License, or (at your option) any later
version.
BigBlueButton 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 BigBlueButton; if not, If not, see <http://www.gnu.org/licenses/>.
Author: DJP <DJP@architectes.org>
-->
<?
/*
REQUIREMENT
PHP.INI
allow_url_fopen = On
*/
require('bbb_api_conf.inc.php');
/*
* Create a meeting and return a URL to join it as moderator
*/
function getJoinURL($username, $meetingID, $welcome = '')
{
$base_url_create = BIGBLUEBUTTONURL."api/create?";
$base_url_join = BIGBLUEBUTTONURL."api/join?";
$voiceBridge = 70000 + rand(0, 9999);
//
// When creating a meeting, the 'name' parameter is the name of the meeting (not to be confused with
// the username). For example, the name could be "Fred's meeting" and the meetingID could be "ID-1234312".
//
// While name and meetinID could be different, we'll keep them the same. Why? Because calling api/create?
// with a previously used meetingID will return same meetingToken (regardless if the meeting is running or not).
//
// This means the first person to call getJoinURL with meetingID="Demo Meeting" will actually create the
// meeting. Subsequent calls will return the same meetingToken and thus subsequent users will join the same
// meeting.
//
// Note: We're hard-coding the password for moderator and attendee (viewer) for purposes of demo.
//
$params = 'name='.urlencode($meetingID).'&meetingID='.urlencode($meetingID).'&attendeePW='.ATTENDEEPW.'&moderatorPW='.MODERATORPW.'&voiceBridge='.$voiceBridge;
if (trim($welcome))
$params .= '&welcome='.urlencode($welcome);
$xml = simplexml_load_file($base_url_create.$params.'&checksum='.sha1($params.SALT));
if ($xml && $xml->returncode == 'SUCCESS' && $meetingToken = trim($xml->meetingToken))
{
$params = 'meetingToken='.$meetingToken.'&fullName='.urlencode($username).'&password='.MODERATORPW;
return ($base_url_join.$params.'&checksum='.sha1($params.SALT));
} else if ($xml)
return ($xml->messageKey.' : '.$xml->message);
else
return ('Unable to fetch URL '.$base_url_create.$params.'&checksum='.sha1($params.SALT));
}
/*
* getJoinURLViewer() -- Get the URL to join a meeting as viewer
*/
function getJoinURLViewer($username, $meetingToken, $welcome = '')
{
$base_url_join = BIGBLUEBUTTONURL."api/join?";
$params = 'meetingToken='.$meetingToken.'&fullName='.urlencode($username).'&password='.ATTENDEEPW;
return ($base_url_join.$params.'&checksum='.sha1($params.SALT));
}
/*
* getURLisMeetingRunning() -- return a URL that the client can use to poll for whether the given meeting is running
* Beware : check that BIGBLUEBUTTONURL is reachable internally from your PHP Web Application Server. (Hosts, firewall...)
*/
function getURLisMeetingRunning($meetingToken, $meetingID)
{
$base_url = BIGBLUEBUTTONURL."api/isMeetingRunning?";
$params = 'meetingToken='.$meetingToken.'&meetingID='.urlencode($meetingID);
return ($base_url.$params.'&checksum='.sha1($params.SALT));
}
/*
* isMeetingRunning() -- check the BigBlueButton server to see if the meeting is running (i.e. there is someone in the meeting)
*/
function isMeetingRunning($meetingToken, $meetingID)
{
$xml = simplexml_load_file(getURLisMeetingRunning($meetingToken, $meetingID));
if ($xml && $xml->returncode == 'SUCCESS')
return (($xml->running == 'TRUE')?true:false);
else
return (false);
}
/*
if (doc.getElementsByTagName("returncode").item(0).getTextContent()
.trim().equals("SUCCESS")) {
String meetingToken = "";
if (doc.getElementsByTagName("meetingToken").item(0) != null) {
meetingToken = doc.getElementsByTagName("meetingToken").item(0)
.getTextContent().trim();
}
//
// Now create a URL to join that meeting
//
String join_parameters = "meetingToken=" + meetingToken + "&fullName=" + urlEncode(username)
+ "&password=mp";
return base_url_join + join_parameters + "&checksum=" + checksum(join_parameters + salt);
}
return doc.getElementsByTagName("messageKey").item(0).getTextContent().trim()
+ ": " + doc.getElementsByTagName("message").item(0).getTextContent().trim();
//
// getURL() -- fetch a URL and return its contents as a String
//
public static String getURL(String url) {
StringBuffer response = null;
try {
URL u = new URL(url);
HttpURLConnection httpConnection = (HttpURLConnection) u
.openConnection();
httpConnection.setUseCaches(false);
httpConnection.setDoOutput(true);
httpConnection.setRequestMethod("GET");
httpConnection.connect();
int responseCode = httpConnection.getResponseCode();
if (responseCode == HttpURLConnection.HTTP_OK) {
InputStream input = httpConnection.getInputStream();
// Read server's response.
response = new StringBuffer();
Reader reader = new InputStreamReader(input, "UTF-8");
reader = new BufferedReader(reader);
char[] buffer = new char[1024];
for (int n = 0; n >= 0;) {
n = reader.read(buffer, 0, buffer.length);
if (n > 0)
response.append(buffer, 0, n);
}
input.close();
httpConnection.disconnect();
}
} catch (Exception e) {
e.printStackTrace();
}
if (response != null) {
return response.toString();
} else {
return "";
}
}
?>
public String getJoinURL(String username, String meetingID, String welcome) {
String base_url_create = BigBlueButtonURL + "api/create?";
String base_url_join = BigBlueButtonURL + "api/join?";
String welcome_param = "";
String checksum = "";
Random random = new Random();
Integer voiceBridge = 70000 + random.nextInt(9999);
if ( (welcome != null) && ! welcome.equals("")) {
welcome_param = "&welcome=" + urlEncode(welcome);
}
//
// When creating a meeting, the 'name' parameter is the name of the meeting (not to be confused with
// the username). For example, the name could be "Fred's meeting" and the meetingID could be "ID-1234312".
//
// While name and meetinID could be different, we'll keep them the same. Why? Because calling api/create?
// with a previously used meetingID will return same meetingToken (regardless if the meeting is running or not).
//
// This means the first person to call getJoinURL with meetingID="Demo Meeting" will actually create the
// meeting. Subsequent calls will return the same meetingToken and thus subsequent users will join the same
// meeting.
//
// Note: We're hard-coding the password for moderator and attendee (viewer) for purposes of demo.
//
String create_parameters = "name=" + urlEncode(meetingID) + "&meetingID=" + urlEncode(meetingID)
+ welcome_param + "&attendeePW=ap&moderatorPW=mp&voiceBridge="+voiceBridge;
Document doc = null;
try {
// Attempt to create a meeting using meetingID
String xml = getURL(base_url_create + create_parameters + "&checksum=" + checksum(create_parameters + salt) );
doc = parseXml(xml);
} catch (Exception e) {
e.printStackTrace();
}
if (doc.getElementsByTagName("returncode").item(0).getTextContent()
.trim().equals("SUCCESS")) {
String meetingToken = "";
if (doc.getElementsByTagName("meetingToken").item(0) != null) {
meetingToken = doc.getElementsByTagName("meetingToken").item(0)
.getTextContent().trim();
}
//
// Now create a URL to join that meeting
//
String join_parameters = "meetingToken=" + meetingToken + "&fullName=" + urlEncode(username)
+ "&password=mp";
return base_url_join + join_parameters + "&checksum=" + checksum(join_parameters + salt);
}
return doc.getElementsByTagName("messageKey").item(0).getTextContent().trim()
+ ": " + doc.getElementsByTagName("message").item(0).getTextContent().trim();
}
*/?>