chrome.socket
Description: |
Use the chrome.socket API to send and receive data over the
network using TCP and UDP connections. Note: Starting with Chrome 33,
this API is deprecated in favor of the sockets.udp, sockets.tcp and
sockets.tcpServer APIs.
|
Availability: |
Stable since Chrome 24.
|
Permissions: |
{"socket": ["rule1", "rule2"]}
For example: {"socket": ["tcp-connect:*:*"]} means connecting on any port of any host. See Network Communications for rule syntax.
|
Learn More: |
Network Communications
Build Apps with Sencha ExtJS Chrome Apps Office Hours: Networking APIs Chrome Apps Office Hours: Controlling an AR ParrotDrone |
Summary
Types | |
---|---|
SocketType | |
WriteInfo | |
Methods | |
create −
chrome.socket.create( SocketType type, object options, function callback)
| |
destroy −
chrome.socket.destroy(integer socketId)
| |
connect −
chrome.socket.connect(integer socketId, string hostname, integer port, function callback)
| |
bind −
chrome.socket.bind(integer socketId, string address, integer port, function callback)
| |
disconnect −
chrome.socket.disconnect(integer socketId)
| |
read −
chrome.socket.read(integer socketId, integer bufferSize, function callback)
| |
write −
chrome.socket.write(integer socketId, ArrayBuffer data, function callback)
| |
recvFrom −
chrome.socket.recvFrom(integer socketId, integer bufferSize, function callback)
| |
sendTo −
chrome.socket.sendTo(integer socketId, ArrayBuffer data, string address, integer port, function callback)
| |
listen −
chrome.socket.listen(integer socketId, string address, integer port, integer backlog, function callback)
| |
accept −
chrome.socket.accept(integer socketId, function callback)
| |
setKeepAlive −
chrome.socket.setKeepAlive(integer socketId, boolean enable, integer delay, function callback)
| |
setNoDelay −
chrome.socket.setNoDelay(integer socketId, boolean noDelay, function callback)
| |
getInfo −
chrome.socket.getInfo(integer socketId, function callback)
| |
getNetworkList −
chrome.socket.getNetworkList(function callback)
| |
joinGroup −
chrome.socket.joinGroup(integer socketId, string address, function callback)
| |
leaveGroup −
chrome.socket.leaveGroup(integer socketId, string address, function callback)
| |
setMulticastTimeToLive −
chrome.socket.setMulticastTimeToLive(integer socketId, integer ttl, function callback)
| |
setMulticastLoopbackMode −
chrome.socket.setMulticastLoopbackMode(integer socketId, boolean enabled, function callback)
| |
getJoinedGroups −
chrome.socket.getJoinedGroups(integer socketId, function callback)
|
Types
SocketType
Enum |
---|
"tcp" ,
or "udp"
|
WriteInfo
properties | ||
---|---|---|
integer | bytesWritten | The number of bytes sent, or a negative error code. |
Methods
create
chrome.socket.create( SocketType type, object options, function callback)
Creates a socket of the specified type that will connect to the specified remote machine.
Parameters | ||||||||
---|---|---|---|---|---|---|---|---|
SocketType | type |
The type of socket to create. Must be tcp or udp .
|
||||||
object | (optional) options | The socket options. | ||||||
function | callback |
Called when the socket has been created.
The callback parameter should be a function that looks like this: function(object createInfo) {...};
|
destroy
chrome.socket.destroy(integer socketId)
Destroys the socket. Each socket created should be destroyed after use.
Parameters | ||
---|---|---|
integer | socketId | The socketId. |
connect
chrome.socket.connect(integer socketId, string hostname, integer port, function callback)
Connects the socket to the remote machine (for a tcp
socket). For a udp
socket, this sets the default address which packets are sent to and read from for read()
and write()
calls.
Parameters | |||||
---|---|---|---|---|---|
integer | socketId | The socketId. | |||
string | hostname | The hostname or IP address of the remote machine. | |||
integer | port | The port of the remote machine. | |||
function | callback |
Called when the connection attempt is complete.
The callback parameter should be a function that looks like this: function(integer result) {...};
|
bind
chrome.socket.bind(integer socketId, string address, integer port, function callback)
Binds the local address for socket. Currently, it does not support TCP socket.
Parameters | |||||
---|---|---|---|---|---|
integer | socketId | The socketId. | |||
string | address | The address of the local machine. | |||
integer | port | The port of the local machine. | |||
function | callback |
Called when the bind attempt is complete.
The callback parameter should be a function that looks like this: function(integer result) {...};
|
disconnect
chrome.socket.disconnect(integer socketId)
Disconnects the socket. For UDP sockets, disconnect
is a non-operation but is safe to call.
Parameters | ||
---|---|---|
integer | socketId | The socketId. |
read
chrome.socket.read(integer socketId, integer bufferSize, function callback)
Reads data from the given connected socket.
Parameters | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
integer | socketId | The socketId. | |||||||||
integer | (optional) bufferSize | The read buffer size. | |||||||||
function | callback |
Delivers data that was available to be read without blocking.
The callback parameter should be a function that looks like this: function(object readInfo) {...};
|
write
chrome.socket.write(integer socketId, ArrayBuffer data, function callback)
Writes data on the given connected socket.
Parameters | |||||
---|---|---|---|---|---|
integer | socketId | The socketId. | |||
ArrayBuffer | data | The data to write. | |||
function | callback |
Called when the write operation completes without blocking or an error occurs.
The callback parameter should be a function that looks like this: function( WriteInfo writeInfo) {...};
|
recvFrom
chrome.socket.recvFrom(integer socketId, integer bufferSize, function callback)
Receives data from the given UDP socket.
Parameters | |||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
integer | socketId | The socketId. | |||||||||||||||
integer | (optional) bufferSize | The receive buffer size. | |||||||||||||||
function | callback |
Returns result of the recvFrom operation.
The callback parameter should be a function that looks like this: function(object recvFromInfo) {...};
|
sendTo
chrome.socket.sendTo(integer socketId, ArrayBuffer data, string address, integer port, function callback)
Sends data on the given UDP socket to the given address and port.
Parameters | |||||
---|---|---|---|---|---|
integer | socketId | The socketId. | |||
ArrayBuffer | data | The data to write. | |||
string | address | The address of the remote machine. | |||
integer | port | The port of the remote machine. | |||
function | callback |
Called when the send operation completes without blocking or an error occurs.
The callback parameter should be a function that looks like this: function( WriteInfo writeInfo) {...};
|
listen
chrome.socket.listen(integer socketId, string address, integer port, integer backlog, function callback)
This method applies to TCP sockets only. Listens for connections on the specified port and address. This effectively makes this a server socket, and client socket functions (connect, read, write) can no longer be used on this socket.
Parameters | |||||
---|---|---|---|---|---|
integer | socketId | The socketId. | |||
string | address | The address of the local machine. | |||
integer | port | The port of the local machine. | |||
integer | (optional) backlog | Length of the socket's listen queue. | |||
function | callback |
Called when listen operation completes.
The callback parameter should be a function that looks like this: function(integer result) {...};
|
accept
chrome.socket.accept(integer socketId, function callback)
This method applies to TCP sockets only. Registers a callback function to be called when a connection is accepted on this listening server socket. Listen must be called first. If there is already an active accept callback, this callback will be invoked immediately with an error as the resultCode.
Parameters | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
integer | socketId | The socketId. | |||||||||
function | callback |
The callback is invoked when a new socket is accepted.
The callback parameter should be a function that looks like this: function(object acceptInfo) {...};
|
setKeepAlive
chrome.socket.setKeepAlive(integer socketId, boolean enable, integer delay, function callback)
Enables or disables the keep-alive functionality for a TCP connection.
Parameters | |||||
---|---|---|---|---|---|
integer | socketId | The socketId. | |||
boolean | enable | If true, enable keep-alive functionality. | |||
integer | (optional) delay | Set the delay seconds between the last data packet received and the first keepalive probe. Default is 0. | |||
function | callback |
Called when the setKeepAlive attempt is complete.
The callback parameter should be a function that looks like this: function(boolean result) {...};
|
setNoDelay
chrome.socket.setNoDelay(integer socketId, boolean noDelay, function callback)
Sets or clears TCP_NODELAY
for a TCP connection. Nagle's algorithm will be disabled when TCP_NODELAY
is set.
Parameters | |||||
---|---|---|---|---|---|
integer | socketId | The socketId. | |||
boolean | noDelay | If true, disables Nagle's algorithm. | |||
function | callback |
Called when the setNoDelay attempt is complete.
The callback parameter should be a function that looks like this: function(boolean result) {...};
|
getInfo
chrome.socket.getInfo(integer socketId, function callback)
Retrieves the state of the given socket.
Parameters | |||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
integer | socketId | The socketId. | |||||||||||||||||||||
function | callback |
Called when the state is available.
The callback parameter should be a function that looks like this: function(object result) {...};
|
getNetworkList
chrome.socket.getNetworkList(function callback)
Retrieves information about local adapters on this system.
Parameters | ||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
function | callback |
Called when local adapter information is available.
The callback parameter should be a function that looks like this: function(array of object result) {...};
|
joinGroup
chrome.socket.joinGroup(integer socketId, string address, function callback)
Join the multicast group and start to receive packets from that group. The socket must be of UDP type and must be bound to a local port before calling this method.
Parameters | |||||
---|---|---|---|---|---|
integer | socketId | The socketId. | |||
string | address | The group address to join. Domain names are not supported. | |||
function | callback |
Called when the join group operation is done with an integer parameter indicating the platform-independent error code.
The callback parameter should be a function that looks like this: function(integer result) {...};
|
leaveGroup
chrome.socket.leaveGroup(integer socketId, string address, function callback)
Leave the multicast group previously joined using joinGroup
. It's not necessary to leave the multicast group before destroying the socket or exiting. This is automatically called by the OS.
Leaving the group will prevent the router from sending multicast datagrams to the local host, presuming no other process on the host is still joined to the group.
Parameters | |||||
---|---|---|---|---|---|
integer | socketId | The socketId. | |||
string | address | The group address to leave. Domain names are not supported. | |||
function | callback |
Called when the leave group operation is done with an integer parameter indicating the platform-independent error code.
The callback parameter should be a function that looks like this: function(integer result) {...};
|
setMulticastTimeToLive
chrome.socket.setMulticastTimeToLive(integer socketId, integer ttl, function callback)
Set the time-to-live of multicast packets sent to the multicast group.
Calling this method does not require multicast permissions.
Parameters | |||||
---|---|---|---|---|---|
integer | socketId | The socketId. | |||
integer | ttl | The time-to-live value. | |||
function | callback |
Called when the configuration operation is done.
The callback parameter should be a function that looks like this: function(integer result) {...};
|
setMulticastLoopbackMode
chrome.socket.setMulticastLoopbackMode(integer socketId, boolean enabled, function callback)
Set whether multicast packets sent from the host to the multicast group will be looped back to the host.
Note: the behavior of setMulticastLoopbackMode
is slightly different between Windows and Unix-like systems. The inconsistency happens only when there is more than one application on the same host joined to the same multicast group while having different settings on multicast loopback mode. On Windows, the applications with loopback off will not RECEIVE the loopback packets; while on Unix-like systems, the applications with loopback off will not SEND the loopback packets to other applications on the same host. See MSDN: http://goo.gl/6vqbj
Calling this method does not require multicast permissions.
Parameters | |||||
---|---|---|---|---|---|
integer | socketId | The socketId. | |||
boolean | enabled | Indicate whether to enable loopback mode. | |||
function | callback |
Called when the configuration operation is done.
The callback parameter should be a function that looks like this: function(integer result) {...};
|
getJoinedGroups
chrome.socket.getJoinedGroups(integer socketId, function callback)
Get the multicast group addresses the socket is currently joined to.
Parameters | |||||
---|---|---|---|---|---|
integer | socketId | The socketId. | |||
function | callback |
Called with an array of strings of the result.
The callback parameter should be a function that looks like this: function(array of string groups) {...};
|