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

Unified Diff: remoting/webapp/me2mom/host_session.js

Issue 8416007: Refactored web-app (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Added consistency comment. Moved debug log keyboard shortcut handling. Created 9 years, 2 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: remoting/webapp/me2mom/host_session.js
diff --git a/remoting/webapp/me2mom/host_session.js b/remoting/webapp/me2mom/host_session.js
new file mode 100644
index 0000000000000000000000000000000000000000..7dfb95a584b5769ac24850d8ce6fbddfb5f80b72
--- /dev/null
+++ b/remoting/webapp/me2mom/host_session.js
@@ -0,0 +1,116 @@
+// Copyright (c) 2011 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+/**
+ * @fileoverview
+ * Class handling creation and teardown of a remoting host session.
+ *
+ * This abstracts a <embed> element and controls the plugin which does the
+ * actual remoting work. There should be no UI code inside this class. It
+ * should be purely thought of as a controller of sorts.
+ */
+
+'use strict';
+
+/** @suppress {duplicate} */
+var remoting = remoting || {};
+
+/**
+ * @constructor
+ */
+remoting.HostSession = function() {
+ /** @private */
+ this.HOST_PLUGIN_ID_ = 'host-plugin-id';
+};
+
+/** @type {remoting.HostPlugin} */
+remoting.HostSession.prototype.plugin = null;
+
+// Note that these values are copied directly from host_script_object.h and
+// must be kept in sync.
Jamie 2011/10/27 20:41:36 I decided against having a type mapping like we ha
garykac 2011/10/27 22:32:39 OK
+/** @enum {number} */
+remoting.HostSession.State = {
+ UNKNOWN: -1,
+ DISCONNECTED: 0,
+ STARTING: 1,
+ REQUESTED_ACCESS_CODE: 2,
+ RECEIVED_ACCESS_CODE: 3,
+ CONNECTED: 4,
+ DISCONNECTING: 5,
+ ERROR: 6
+};
+
+/**
+ * Create the host plugin and initiate a connection.
+ * @param {Element} container The parent element to which to add the plugin.
+ * @param {string} email The user's email address.
+ * @param {string} accessToken A valid OAuth2 access token.
+ * @param {function(boolean):void} onNatTraversalPolicyChanged Callback
+ * for notification of changes to the NAT traversal policy.
+ * @param {function(remoting.HostSession.State):void} onStateChanged
+ * Callback for notifications of changes to the host plugin's state.
+ * @param {function(string):void} logDebugInfo Callback allowing the plugin
+ * to log messages to the debug log.
+ */
+remoting.HostSession.prototype.createPluginAndConnect =
+ function(container, email, accessToken,
+ onNatTraversalPolicyChanged, onStateChanged, logDebugInfo) {
+ this.plugin = /** @type {remoting.HostPlugin} */
+ document.createElement('embed');
+ this.plugin.type = remoting.PLUGIN_MIMETYPE;
+ this.plugin.id = this.HOST_PLUGIN_ID_;
+ // Hiding the plugin means it doesn't load, so make it size zero instead.
+ this.plugin.width = 0;
+ this.plugin.height = 0;
+ container.appendChild(this.plugin);
+ this.plugin.onNatTraversalPolicyChanged = onNatTraversalPolicyChanged;
+ this.plugin.onStateChanged = onStateChanged;
+ this.plugin.logDebugInfo = logDebugInfo;
+ this.plugin.localize(chrome.i18n.getMessage);
+ this.plugin.connect(email, 'oauth2:' + accessToken);
+};
+
+/**
+ * Get the access code generated by the host plugin. Valid only after the
+ * plugin state is RECEIVED_ACCESS_CODE.
+ * @return {string} The access code.
+ */
+remoting.HostSession.prototype.getAccessCode = function() {
+ return this.plugin.accessCode;
+};
+
+/**
+ * Get the lifetime for the access code. Valid only after the plugin state is
+ * RECEIVED_ACCESS_CODE.
+ * @return {number} The access code lifetime, in seconds.
+ */
+remoting.HostSession.prototype.getAccessCodeLifetime = function() {
+ return this.plugin.accessCodeLifetime;
+};
+
+/**
+ * Get the email address of the connected client. Valid only after the plugin
+ * state is CONNECTED.
+ * @return {string} The client's email address.
+ */
+remoting.HostSession.prototype.getClient = function() {
+ return this.plugin.client;
+};
+
+/**
+ * Disconnect the client.
+ * @return {void} Nothing.
+ */
+remoting.HostSession.prototype.disconnect = function() {
+ this.plugin.disconnect();
+};
+
+
+/**
+ * Remove the plugin element from the document.
+ * @return {void} Nothing.
+ */
+remoting.HostSession.prototype.removePlugin = function() {
+ this.plugin.parentNode.removeChild(this.plugin);
+};

Powered by Google App Engine
This is Rietveld 408576698