Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(359)

Unified Diff: talk/examples/android/src/org/appspot/apprtc/RoomParametersFetcher.java

Issue 1235563006: Move talk/examples/* to webrtc/examples. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: 201508051337 Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: talk/examples/android/src/org/appspot/apprtc/RoomParametersFetcher.java
diff --git a/talk/examples/android/src/org/appspot/apprtc/RoomParametersFetcher.java b/talk/examples/android/src/org/appspot/apprtc/RoomParametersFetcher.java
deleted file mode 100644
index b14d2d4f210ce51f247ad7ec15b8ea67b3074bec..0000000000000000000000000000000000000000
--- a/talk/examples/android/src/org/appspot/apprtc/RoomParametersFetcher.java
+++ /dev/null
@@ -1,239 +0,0 @@
-/*
- * libjingle
- * Copyright 2014 Google Inc.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are met:
- *
- * 1. Redistributions of source code must retain the above copyright notice,
- * this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright notice,
- * this list of conditions and the following disclaimer in the documentation
- * and/or other materials provided with the distribution.
- * 3. The name of the author may not be used to endorse or promote products
- * derived from this software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
- * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
- * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
- * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
- * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
- * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
- * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
- * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
- * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-
-package org.appspot.apprtc;
-
-import org.appspot.apprtc.AppRTCClient.SignalingParameters;
-import org.appspot.apprtc.util.AsyncHttpURLConnection;
-import org.appspot.apprtc.util.AsyncHttpURLConnection.AsyncHttpEvents;
-
-import android.util.Log;
-
-import org.json.JSONArray;
-import org.json.JSONException;
-import org.json.JSONObject;
-import org.webrtc.IceCandidate;
-import org.webrtc.PeerConnection;
-import org.webrtc.SessionDescription;
-
-import java.io.IOException;
-import java.io.InputStream;
-import java.net.HttpURLConnection;
-import java.net.URL;
-import java.util.LinkedList;
-import java.util.Scanner;
-
-/**
- * AsyncTask that converts an AppRTC room URL into the set of signaling
- * parameters to use with that room.
- */
-public class RoomParametersFetcher {
- private static final String TAG = "RoomRTCClient";
- private static final int TURN_HTTP_TIMEOUT_MS = 5000;
- private final RoomParametersFetcherEvents events;
- private final String roomUrl;
- private final String roomMessage;
- private AsyncHttpURLConnection httpConnection;
-
- /**
- * Room parameters fetcher callbacks.
- */
- public static interface RoomParametersFetcherEvents {
- /**
- * Callback fired once the room's signaling parameters
- * SignalingParameters are extracted.
- */
- public void onSignalingParametersReady(final SignalingParameters params);
-
- /**
- * Callback for room parameters extraction error.
- */
- public void onSignalingParametersError(final String description);
- }
-
- public RoomParametersFetcher(String roomUrl, String roomMessage,
- final RoomParametersFetcherEvents events) {
- this.roomUrl = roomUrl;
- this.roomMessage = roomMessage;
- this.events = events;
- }
-
- public void makeRequest() {
- Log.d(TAG, "Connecting to room: " + roomUrl);
- httpConnection = new AsyncHttpURLConnection(
- "POST", roomUrl, roomMessage,
- new AsyncHttpEvents() {
- @Override
- public void onHttpError(String errorMessage) {
- Log.e(TAG, "Room connection error: " + errorMessage);
- events.onSignalingParametersError(errorMessage);
- }
-
- @Override
- public void onHttpComplete(String response) {
- roomHttpResponseParse(response);
- }
- });
- httpConnection.send();
- }
-
- private void roomHttpResponseParse(String response) {
- Log.d(TAG, "Room response: " + response);
- try {
- LinkedList<IceCandidate> iceCandidates = null;
- SessionDescription offerSdp = null;
- JSONObject roomJson = new JSONObject(response);
-
- String result = roomJson.getString("result");
- if (!result.equals("SUCCESS")) {
- events.onSignalingParametersError("Room response error: " + result);
- return;
- }
- response = roomJson.getString("params");
- roomJson = new JSONObject(response);
- String roomId = roomJson.getString("room_id");
- String clientId = roomJson.getString("client_id");
- String wssUrl = roomJson.getString("wss_url");
- String wssPostUrl = roomJson.getString("wss_post_url");
- boolean initiator = (roomJson.getBoolean("is_initiator"));
- if (!initiator) {
- iceCandidates = new LinkedList<IceCandidate>();
- String messagesString = roomJson.getString("messages");
- JSONArray messages = new JSONArray(messagesString);
- for (int i = 0; i < messages.length(); ++i) {
- String messageString = messages.getString(i);
- JSONObject message = new JSONObject(messageString);
- String messageType = message.getString("type");
- Log.d(TAG, "GAE->C #" + i + " : " + messageString);
- if (messageType.equals("offer")) {
- offerSdp = new SessionDescription(
- SessionDescription.Type.fromCanonicalForm(messageType),
- message.getString("sdp"));
- } else if (messageType.equals("candidate")) {
- IceCandidate candidate = new IceCandidate(
- message.getString("id"),
- message.getInt("label"),
- message.getString("candidate"));
- iceCandidates.add(candidate);
- } else {
- Log.e(TAG, "Unknown message: " + messageString);
- }
- }
- }
- Log.d(TAG, "RoomId: " + roomId + ". ClientId: " + clientId);
- Log.d(TAG, "Initiator: " + initiator);
- Log.d(TAG, "WSS url: " + wssUrl);
- Log.d(TAG, "WSS POST url: " + wssPostUrl);
-
- LinkedList<PeerConnection.IceServer> iceServers =
- iceServersFromPCConfigJSON(roomJson.getString("pc_config"));
- boolean isTurnPresent = false;
- for (PeerConnection.IceServer server : iceServers) {
- Log.d(TAG, "IceServer: " + server);
- if (server.uri.startsWith("turn:")) {
- isTurnPresent = true;
- break;
- }
- }
- // Request TURN servers.
- if (!isTurnPresent) {
- LinkedList<PeerConnection.IceServer> turnServers =
- requestTurnServers(roomJson.getString("turn_url"));
- for (PeerConnection.IceServer turnServer : turnServers) {
- Log.d(TAG, "TurnServer: " + turnServer);
- iceServers.add(turnServer);
- }
- }
-
- SignalingParameters params = new SignalingParameters(
- iceServers, initiator,
- clientId, wssUrl, wssPostUrl,
- offerSdp, iceCandidates);
- events.onSignalingParametersReady(params);
- } catch (JSONException e) {
- events.onSignalingParametersError(
- "Room JSON parsing error: " + e.toString());
- } catch (IOException e) {
- events.onSignalingParametersError("Room IO error: " + e.toString());
- }
- }
-
- // Requests & returns a TURN ICE Server based on a request URL. Must be run
- // off the main thread!
- private LinkedList<PeerConnection.IceServer> requestTurnServers(String url)
- throws IOException, JSONException {
- LinkedList<PeerConnection.IceServer> turnServers =
- new LinkedList<PeerConnection.IceServer>();
- Log.d(TAG, "Request TURN from: " + url);
- HttpURLConnection connection = (HttpURLConnection) new URL(url).openConnection();
- connection.setConnectTimeout(TURN_HTTP_TIMEOUT_MS);
- connection.setReadTimeout(TURN_HTTP_TIMEOUT_MS);
- int responseCode = connection.getResponseCode();
- if (responseCode != 200) {
- throw new IOException("Non-200 response when requesting TURN server from "
- + url + " : " + connection.getHeaderField(null));
- }
- InputStream responseStream = connection.getInputStream();
- String response = drainStream(responseStream);
- connection.disconnect();
- Log.d(TAG, "TURN response: " + response);
- JSONObject responseJSON = new JSONObject(response);
- String username = responseJSON.getString("username");
- String password = responseJSON.getString("password");
- JSONArray turnUris = responseJSON.getJSONArray("uris");
- for (int i = 0; i < turnUris.length(); i++) {
- String uri = turnUris.getString(i);
- turnServers.add(new PeerConnection.IceServer(uri, username, password));
- }
- return turnServers;
- }
-
- // Return the list of ICE servers described by a WebRTCPeerConnection
- // configuration string.
- private LinkedList<PeerConnection.IceServer> iceServersFromPCConfigJSON(
- String pcConfig) throws JSONException {
- JSONObject json = new JSONObject(pcConfig);
- JSONArray servers = json.getJSONArray("iceServers");
- LinkedList<PeerConnection.IceServer> ret =
- new LinkedList<PeerConnection.IceServer>();
- for (int i = 0; i < servers.length(); ++i) {
- JSONObject server = servers.getJSONObject(i);
- String url = server.getString("urls");
- String credential =
- server.has("credential") ? server.getString("credential") : "";
- ret.add(new PeerConnection.IceServer(url, "", credential));
- }
- return ret;
- }
-
- // Return the contents of an InputStream as a String.
- private static String drainStream(InputStream in) {
- Scanner s = new Scanner(in).useDelimiter("\\A");
- return s.hasNext() ? s.next() : "";
- }
-
-}

Powered by Google App Engine
This is Rietveld 408576698