NetConnection-polyfill brings Flash's NetConnection to modern JavaScript applications running on a browser which supports Flash plugin.
With NetConnection you can establish a real-time two-way communication between your browser application made in JS and an AMS or Wowza server over RTMP protocol.
NetConnection-polyfill implements NetConnection interface in JavaScript. Although, it still needs flash to work.
When a new instance of a NetConnection is created in your JS application, NetConnection-polyfill will create a "transparent" flash object where the actual instance of NetConnection will be created.
The JS interface transparently access to the variables and methods of the NetConnection instance inside the flash object so you can implement your own logic without worrying about flash at all.
npm install netconnection-polyfill --save
NetConnection-polyfill is a framework-agnostic library. Once installed and included in your web application it can be accessed as a global class.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>My NetConnection app</title>
</head>
<body>
<script src="node_modules/netconnection-polyfill.js"></script>
<script>
(function(){
// Tell NetConnection where to find the SWF binary
NetConnection.swf = './node_modules/netconnection-polyfill.swf';
let nc = new NetConnection();
// Listen to netStatus events
nc.addEventListener('netStatus', (event) => {
switch (event.info.code) {
case 'NetConnection.Connect.Success':
console.log('My app is now connected to the RTMP server');
break;
case 'NetConnection.Connect.Rejected':
console.error('My app was rejected by the RTMP server');
break;
}
});
// Wait until the interface is ready
nc.one('ready', () => {
console.log('NetConnection is ready');
// You can pass arguments to connect call
nc.connect('rtmp://my.server.com/live/instance', 'user', 'password');
});
})();
</script>
</body>
</html>
Once the connection is established, you can call server-side methods to send commands to the server.
let nc = new NetConnection();
nc.addEventListener('netStatus', (event) => {
switch (event.info.code) {
case 'NetConnection.Connect.Success':
// Call a method in your server-side application
nc.call('sendMessage', 'Message to RTMP application');
break;
case 'NetConnection.Connect.Rejected':
console.error('Connection was rejected');
break;
}
});
nc.one('ready', () => {
nc.connect('rtmp://my.server.com/live/instance');
});
The magic of NetConnection is to either the web application being able to call server-side methods and the server-side application call methods in client-side.
class MyClient {
// This method can be called by the server to send messages to your application
onMessage(message) {
console.log(`RTMP Server says ${message}`);
}
}
let nc = new NetConnection();
nc.client = new MyClient();
nc.one('ready', () => {
nc.connect('rtmp://my.server.com/live/instance');
});
NetConneciton-polyfill implements the properties and methods of Flash's NetConnection class that might make sense to expose to a JavaScript application.
Following documentation shows a short description of NetConnection's properties and methods. For more details about its usage visit Adobe's documentation
client: Object
Indicates the object on which callback methods are invoked. The default is this NetConnection instance. If you set the client property to another object, callback methods will be invoked on that object.
connected: Boolean [read-only]
Indicates whether the application is connected to a server through a persistent RTMP connection (true) or not (false).
connectedProxyType: String [read-only]
he proxy type used to make a successful connection to Flash Media Server.
farID: String [read-only]
A value chosen substantially by Flash Media Server, unique to this connection.
farNonce: String [read-only]
A value chosen substantially by Flash Media Server, unique to this connection.
maxPeerConnections: Number
The total number of inbound and outbound peer connections that this instance of Flash Player allows.
nearID: String [read-only]
A value chosen substantially by this Flash Player, unique to this connection.
nearNonce: String [read-only]
A value chosen substantially by this Flash Player or Adobe AIR instance, unique to this connection.
objectEncoding: Number
The object encoding for this NetConnection instance.
protocol: String [read-only]
The protocol used to establish the connection.
proxyType: String
Determines which fallback methods are tried if an initial connection attempt to Flash Media Server fails.
unconnectedPeerStreams: Array [read-only]
An object that holds all of the peer subscriber NetStream objects that are not associated with publishing NetStream objects.
uri: String [read-only]
The URI passed to the NetConnection.connect() method.
usingTLS: Boolean [read-only]
Indicates whether a secure connection was made using native Transport Layer Security (TLS) rather than HTTPS.
addHeader(operation: String, mustUnderstand: Boolean, param: Object): void
Adds a context header to the Action Message Format (AMF) packet structure.
call(command: String, ...arguments): void
Calls a command or method on Flash Media Server or on an application server running Flash Remoting.
close():void
Closes the connection that was opened locally or to the server and dispatches a netStatus event with a code property of NetConnection.Connect.Closed.
connect(command: String, ...arguments): void
Creates a two-way connection to an application on Flash Media Server or to Flash Remoting, or creates a two-way network endpoint for RTMFP peer-to-peer group communication.
NetConnection extends EventTarget with additionally aliases:
on(type: String, handler: Function):void
Alias for addEventListener
one(type: String, handler: Function): void
Subscribes to given event just once.
off(type: String, handler: Function):void
Alias for removeEventListener*
trigger(event: String|Event): void
Alias for dispatchEvent
ready
Dispatched when NetConnection interface is ready to be used. Only when this event is fired the properties and methods can be accessed.
asyncError
Dispatched when an exception is thrown asynchronously — that is, from native asynchronous code.
ioError
Dispatched when an input or output error occurs that causes a network operation to fail.
netStatus
Dispatched when a NetConnection object is reporting its status or error condition. See: NetStatusEvent.info for more details about the possible netStatus codes.
securityError
Dispatched if a call to NetConnection.call() attempts to connect to a server outside the caller's security sandbox.
Flash is about to die indeed. However, RTMP protocol is still the most used protocol to feed live streaming.
If you want to create an application to control and/or monitor an AMS or Wowza application you have to do it over RTMP protocol which nowadays is not possible with only JavaScript.
NetConnection-polyfill is intended to fill this little gap. It is the lightest and simplest flash-dependant library possible to manage a real-time connection with a Media Server over RTMP with JavaScript.
- Improve static options
- Tests
- Changelog
- Contributing guidelines