NAME
JSORB - Javascript Object Request Broker
SYNOPSIS
use JSORB;
use JSORB::Server::Simple;
use JSORB::Dispatcher::Path;
use JSORB::Reflector::Package;
use JSORB::Client::Compiler::Javascript;
# create some code to expose over RPC
{
package Math::Simple;
use Moose;
sub add { $_[0] + $_[1] }
}
# Set up a simple JSORB server
JSORB::Server::Simple->new(
port => 8080,
dispatcher => JSORB::Dispatcher::Path->new(
namespace => JSORB::Reflector::Package->new(
# tell JSORB to introspect the package
introspector => Math::Simple->meta,
# add some type information
# about the procedure
procedure_list => [
{ name => 'add', spec => [ ('Int', 'Int') => 'Int' ] }
]
)->namespace
)
)->run;
## Now you can ...
## go to the URL directly
http://localhost:8080/?method=/math/simple/add¶ms=[2,2]
# and get back a response
{ "jsonrpc" : "2.0", "result" : 2 }
## compile your own Javascript client
## library for use in a web page ...
my $c = JSORB::Client::Compiler::Javascript->new;
$c->compile(
namespace => $namespace,
to => [ 'webroot', 'js', 'MathSimple.js' ]
);
# and in your JS
var math = new Math.Simple ( 'http://localhost:8080' );
math.add( 2, 2, function (result) { alert(result) } );
## or use the more low level
## JSORB client library directly
var c = new JSORB.Client ({
base_url : 'http://localhost:8080/',
})
c.call({
method : '/math/simple/add',
params : [ 2, 2 ]
}, function (result) {
alert(result)
});
DESCRIPTION
__
__ /\ \
/\_\ ____ ___ _ __ \ \ \____
\/\ \ /',__\ / __`\ /\`'__\ \ \ '__`\
\ \ \ /\__, `\/\ \L\ \\ \ \/ \ \ \L\ \
_\ \ \ \/\____/\ \____/ \ \_\ \ \_,__/
/\ \_\ \ \/___/ \/___/ \/_/ \/___/
\ \____/
\/___/
DISCLAIMER
This is a VERY VERY early release of this module, and while it is quite functional, this module should in no way be seen as complete. You are more then welcome to experiment and play around with this module, but don't come crying to me if it accidently deletes your MP3 collection, kills the neighbors dog and causes the large hadron collider to create a black hole that swallows up all of existence tearing you molecule from molecule along the event horizon for all eternity.
GOAL
The goal of this module is to provide a cleaner and more formalized way to do AJAX programming using JSON-RPC in the flavor of Object Request Brokers.
FUTURE PLANS
Currently this is more focused on RPC calls between Perl on the server side and Javascript on the client side. Eventually we will have a Perl client and possibly some servers written in other languages as well.
GETTING STARTED
The documentation is very sparse and I apologize for that, but the test suite has a lot of good stuff to read and there is a couple neat things in the example directory. If you want to know more about the Javascript end there are tests for that as well. As this module matures more the docs will improve, but as mentioned above, it is still pretty new and we have big plans for its future.
BUGS
All complex software has bugs lurking in it, and this module is no exception. If you find a bug please either email me, or add the bug to cpan-RT.
AUTHOR
Stevan Little <stevan.little@iinteractive.com>
COPYRIGHT AND LICENSE
Copyright 2008-2010 Infinity Interactive, Inc.
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.