Repository URL to install this package:
|
Version:
1.8.0-17108 ▾
|
brackets
/
opt
/
brackets
/
www
/
LiveDevelopment
/
MultiBrowserImpl
/
transports
/
NodeSocketTransport.js
|
|---|
/*
* Copyright (c) 2014 - present Adobe Systems Incorporated. All rights reserved.
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the "Software"),
* to deal in the Software without restriction, including without limitation
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
* and/or sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
* DEALINGS IN THE SOFTWARE.
*
*/
// This transport provides a WebSocket connection between Brackets and a live browser preview.
// This is just a thin wrapper around the Node extension (NodeSocketTransportDomain) that actually
// provides the WebSocket server and handles the communication. We also rely on an injected script in
// the browser for the other end of the transport.
define(function (require, exports, module) {
"use strict";
var FileUtils = require("file/FileUtils"),
EventDispatcher = require("utils/EventDispatcher"),
NodeDomain = require("utils/NodeDomain");
// The script that will be injected into the previewed HTML to handle the other side of the socket connection.
var NodeSocketTransportRemote = require("text!LiveDevelopment/MultiBrowserImpl/transports/remote/NodeSocketTransportRemote.js");
// The node extension that actually provides the WebSocket server.
var domainPath = FileUtils.getNativeBracketsDirectoryPath() + "/" + FileUtils.getNativeModuleDirectoryPath(module) + "/node/NodeSocketTransportDomain";
var NodeSocketTransportDomain = new NodeDomain("nodeSocketTransport", domainPath);
// This must match the port declared in NodeSocketTransportDomain.js.
// TODO: randomize this?
var SOCKET_PORT = 8123;
/**
* Returns the script that should be injected into the browser to handle the other end of the transport.
* @return {string}
*/
function getRemoteScript() {
return "<script>\n" +
NodeSocketTransportRemote +
"this._Brackets_LiveDev_Socket_Transport_URL = 'ws://localhost:" + SOCKET_PORT + "';\n" +
"</script>\n";
}
// Events
// We can simply retrigger the events we receive from the node domain directly, since they're in
// the same format expected by clients of the transport.
["connect", "message", "close"].forEach(function (type) {
NodeSocketTransportDomain.on(type, function () {
console.log("NodeSocketTransport - event - " + type + " - " + JSON.stringify(Array.prototype.slice.call(arguments, 1)));
// Remove the event object from the argument list.
exports.trigger(type, Array.prototype.slice.call(arguments, 1));
});
});
EventDispatcher.makeEventDispatcher(exports);
// Exports
exports.getRemoteScript = getRemoteScript;
// Proxy the node domain methods directly through, since they have exactly the same
// signatures as the ones we're supposed to provide.
["start", "send", "close"].forEach(function (method) {
exports[method] = function () {
var args = Array.prototype.slice.call(arguments);
args.unshift(method);
console.log("NodeSocketTransport - " + args);
NodeSocketTransportDomain.exec.apply(NodeSocketTransportDomain, args);
};
});
});