Namespace LrSocket

This namespace is used to send and receive data from other processes using sockets.

Example usage:

 local LrSocket = import "LrSocket"
local LrTasks = import "LrTasks"
import "LrTasks".startAsyncTask( function()
   LrFunctionContext.callWithContext( 'socket_remote', function( context )
    local running = true
    local sender = LrSocket.bind {
     functionContext = context,
     port = 0, -- (let the OS assign the port)
     mode = "send",
     onConnecting = function( socket, port )
      -- TODO
     end,
     onConnected = function( socket, port )
      -- TODO
     end,
     onMessage = function( socket, message )
      -- nothing, we don't expect to get any messages back from a send port
     end,
     onClosed = function( socket )
      running = false
     end,
     onError = function( socket, err )
      if err == "timeout" then
       socket:reconnect()
      end
     end,
    }
    sender:send( "Hello world" )
    while running do
     LrTasks.sleep( 1/2 ) -- seconds
    end
    sender:close()
   end )
end )

Summary

LrSocket.bind( params )
Opens a socket connection (on localhost) for either reading or writing operations.
Closes a socket connection.
Asks a socket to restablish its connection.
socket:send( message )
Sends a message via a "send" mode socket.
Reports the type of this object.

Functions

LrSocket.bind( params )
Opens a socket connection (on localhost) for either reading or writing operations.

First supported in version 6.0 of the Lightroom SDK.

The socket is automatically closed if the plug-in is disabled or removed by the user.

Parameters

1. params
(table) containing the following named parameters:
  • functionContext (LrFunctionContext) The function context.
  • plugin (_PLUGIN) Your plug-in object.
  • port (number) The port number to bind the socket to. If 0, the system automatically chooses a port.
  • mode (requred, string) Must be either "send", "receive". In "send" mode, calls to the controller's send method will send data out via the socket. In "receive" mode, data coming in from the socket will be reported via the callback function.
  • onConnecting (optional, function( socket, port )) called when the socket begins listing for a connection
  • onConnected (optional, function( socket, port)) called when the socket establishes a connection
  • onError (optional, function( socket, error)) called when the socket connection encounters an error (ex: "timeout" )
  • onMessage (optional, function( socket, message)) called when the socket receives a message
  • onClosed (optional, function( socket )) called when th socket connection closes

Return value

(table) A controller object with the methods:
  • send( message ): Sends string messages to the socket (mode must be "send").
  • reconnect(): tries to re-establish the socket connection (for example, call this after a "timeout" error to retry)
  • close(): closes the socket connection. After calling this, send and reconnect can no longer be called on this connection object.
socket:close()
Closes a socket connection.

First supported in version 6.0 of the Lightroom SDK.

socket:reconnect()
Asks a socket to restablish its connection.

First supported in version 6.0 of the Lightroom SDK.

socket:send( message )
Sends a message via a "send" mode socket.

First supported in version 6.0 of the Lightroom SDK.

Parameters

1. message
(string) Message to send.
socket:type()
Reports the type of this object.

First supported in version 6.0 of the Lightroom SDK.

Return value

(string) 'LrSocket'.