Difference between revisions of "Livelets.as"

From Organic Design wiki
m
({{legacy}})
 
(26 intermediate revisions by the same user not shown)
Line 1: Line 1:
 +
{{legacy}}
 +
<as>
 
// Extension:Livelets
 
// Extension:Livelets
 
// - See http://www.mediawiki.org/wiki/Extension:Livelets for installation and usage details
 
// - See http://www.mediawiki.org/wiki/Extension:Livelets for installation and usage details
// - Licenced under LGPL (http://www.gnu.org/copyleft/lesser.html){{as}}{{#security:*|dev}}{{#security:view|*}}
+
// - Licenced under LGPL (http://www.gnu.org/copyleft/lesser.html)
 +
 
 +
// All this needs to do is unintelligently route incoming update messages to the recipient livelets by id
 +
// - each message can just be update:id1,id2,id3,id4... which executes the $wgLiveletsUpdate code for each id
 +
// - remember that the SWF binary needs to be served from livelets.pl
  
 
class live {
 
class live {
  
 +
// Properties
 
static var app : live;
 
static var app : live;
 
var socket    : XMLSocket;
 
var socket    : XMLSocket;
  
 +
// Entry point
 +
static function main(mc) {
 +
app = new live();
 +
}
 +
 +
// Constructor
 
function live() {
 
function live() {
  
// Dynamics (called each frame)
+
// Initialise objects
onEnterFrame = function() {
+
this.socket        = new XMLSocket();
// if (!this.connected && ++this.ctr%250 == 1) this.peerConnect('organicdesign.co.nz',1729);
+
_root.connected   = false;
};
+
_root.ctr         = 1;
 +
_root.onEnterFrame = this.reduce;
 +
_root.log          = this.log;
  
// Connect to our host to establish stream
+
// When connected, send login info
socket.peerConnect = function(domain,port) {
+
socket.onConnect = function(success) {
if (socket.connect(domain,port))
+
if (_root.connected = success) {
log('Connecting to '+domain+':'+port);
+
_root.log('Connected.');
else log('Could not initialise connection!');
+
// request a dedicated peerd child spawn to handle this stream
};
+
_root.request('/connect/peer/interface');
 +
}
 +
else {
 +
_root.log('Connection failed!');
 +
_root.log('Will retry soon...');
 +
}
 +
};
  
// When connected, send login info
+
// Decode incoming message
socket.onConnect = function(success) {
+
socket.onData = function(data) {
if (this.connected = success) {
+
_root.log('Message received:');
log('Connected.');
+
_root.log(data);
// request a dedicated peerd child spawn to handle this stream
+
};
this.request('/connect/peer/interface');
 
}
 
else {
 
log('Connection failed!');
 
log('Will retry soon...');
 
}
 
};
 
  
// Decode incoming message
+
socket.onClose = function() {
socket.onData = function(data) {
+
_root.connected = false;
log('Message received:');
+
_root.log('Connection closed!');
log(data);
+
_root.ctr = 1;
};
+
_root.log('Will retry soon...');
 +
};
  
socket.onClose = function() {
+
}
this.connected = false;
 
log('Connection closed!');
 
this.ctr = 1;
 
log('Will retry soon...');
 
};
 
  
// Send a message to the associated peer
+
function log(entry) {
socket.request = function(request) {
+
return entry;
log('Sending message: "'+request+'"');
+
}
this.send('GET '+request+' HTTP/1.1'+String.fromCharCode(13,10,13,10));
 
};
 
  
// Create new socket
+
// Called periodically (per frame)
this.socket = new XMLSocket();
+
function reduce() {
socket.connected = false;
+
// if (!this.socket.connected && ++this.ctr%250 == 1) this.peerConnect('organicdesign.co.nz',1729);
 +
}
  
}
+
// Connect to our host to establish stream
 +
function peerConnect(domain,port) {
 +
if (this.socket.connect(domain,port)) log('Connecting to '+domain+':'+port);
 +
else this.log('Could not initialise connection!');
 +
}
  
// entry point
+
// Send a message to the associated peer
static function main(mc) {
+
function request(request) {
app = new live();
+
this.log('Sending message: "'+request+'"');
 +
this.socket.send('GET '+request+' HTTP/1.1'+String.fromCharCode(13,10,13,10));
 
}
 
}
 
 
}
 
}
 +
</as>
 +
[[Category:Livelets]]

Latest revision as of 10:11, 14 March 2009

Legacy.svg Legacy: This article describes a concept that has been superseded in the course of ongoing development on the Organic Design wiki. Please do not develop this any further or base work on this concept, now this page is for historic record only.

<as> // Extension:Livelets // - See http://www.mediawiki.org/wiki/Extension:Livelets for installation and usage details // - Licenced under LGPL (http://www.gnu.org/copyleft/lesser.html)

// All this needs to do is unintelligently route incoming update messages to the recipient livelets by id // - each message can just be update:id1,id2,id3,id4... which executes the $wgLiveletsUpdate code for each id // - remember that the SWF binary needs to be served from livelets.pl

class live {

// Properties static var app : live; var socket  : XMLSocket;

// Entry point static function main(mc) { app = new live(); }

// Constructor function live() {

// Initialise objects this.socket = new XMLSocket(); _root.connected = false; _root.ctr = 1; _root.onEnterFrame = this.reduce; _root.log = this.log;

// When connected, send login info socket.onConnect = function(success) { if (_root.connected = success) { _root.log('Connected.'); // request a dedicated peerd child spawn to handle this stream _root.request('/connect/peer/interface'); } else { _root.log('Connection failed!'); _root.log('Will retry soon...'); } };

// Decode incoming message socket.onData = function(data) { _root.log('Message received:'); _root.log(data); };

socket.onClose = function() { _root.connected = false; _root.log('Connection closed!'); _root.ctr = 1; _root.log('Will retry soon...'); };

}

function log(entry) { return entry; }

// Called periodically (per frame) function reduce() { // if (!this.socket.connected && ++this.ctr%250 == 1) this.peerConnect('organicdesign.co.nz',1729); }

// Connect to our host to establish stream function peerConnect(domain,port) { if (this.socket.connect(domain,port)) log('Connecting to '+domain+':'+port); else this.log('Could not initialise connection!'); }

// Send a message to the associated peer function request(request) { this.log('Sending message: "'+request+'"'); this.socket.send('GET '+request+' HTTP/1.1'+String.fromCharCode(13,10,13,10)); } } </as>