Plugin Separate Process

From Second Life Wiki
Revision as of 09:26, 22 February 2007 by Dr Scofield (talk | contribs)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

local network port

a different approach that also looks quite interesting as it provides a lot of flexibility is to add just enough code to the SL client that it will forward all SL comms packets to a local network port and will accept packets to the SL grid but also to the view itself via that same local network port.

plugins would connect to that local network port and get to see all packets. also, they could inject packets both for the grid as well as for the viewer.

packet format

a unicode-based, "human-readable" encoding of the packets would allow us to use almost any computer language known to AV-kind: a shell script could be a plugin! one suggestion is to use XML format.

plugin lifecycle

plugin should only live for the duration of a session. a plugin starter in the client (in the worst case that could be done as a shell script wrapper around the SL client itself) that goes through a $HOME/.secondlife/plugin.d directory and starts all plugins in that directory in alphabetical order (00-plugin-1, 05-plugin-2, ...).

on shutdown the client will just send a "GOOD NIGHT" message out over the socket interface --- causing the plugins to shutdown.

making life harder for attack scripts

we can make the port number random: the client (or wrapper script) picks a random available port number, passes that in to the secondlife client (if we are using a wrapper), and also as a startup argument to the plugins.

in addition, we can generate a randomized password for each SL session and pass that in to the client and plugins and it becomes rather difficult to run an JS XMLHTTPRequest attack...

advantages

  • minimal code changes
  • very flexible: write your plugin in perl, python, java (fortran anyone?)

disadvantages

  • no filter: quite a bit of (local) traffic