NAME

Jamila - Perl extension for JSON Approach to Make Integration Linking Applications

SYNOPSIS

1. Receive Mode:
1.1 Perl sample(testJamila.pl)
 #!/usr/bin/perl
 use strict;
 package Smp;
 sub echo($$)
 {
   my($sClass, $sPrm) = @_;
   return "Welcome to Jamila! ( $sPrm )";
 }
 package main;
 use Jamila;
 Jamila->proc('Smp');

1.2 Call from JavaScript
 var oJmR  = new Jamila(
                      '/cgi-bin/jamila/testJamila.pl',
                      null, null,
                      function(sMsg) { alert("ERROR:" + sMsg);});
alert(oJmR.call('echo', 'Call FROM JavaScript' ));

var oLocal = {
   echo: function (sPrm) { return "LOCAL CALL:" + sPrm;},
};
var oJmL  = new Jamila(oLocal,
                      null, null,
                      function(sMsg) { alert("ERROR:" + sMsg);});
alert(oJmL.call('echo', 'Call FROM JavaScript(LOCAL)' ));

2. Call Mode:
 use strict;
 package SmpLocal;
 sub echo($$)
 {
   my($sClass, $sPrm) = @_;
   return "LOCAL: Welcome to Jamila! ( $sPrm )";
 }
 
 package main;
 use Jamila;
 use Data::Dumper;
 #(1) Call Remote
 my $oJm = Jamila->new(
   'http://hippo2000.atnifty.com/cgi-bin/jamila/testJamila.pl');
 print $oJm->call('echo', 'Test for Remote') . "\n";
 
 #(2) Call Local
 my $oJmL = Jamila->new(bless {}, 'SmpLocal');
 print $oJmL->call('echo', 'How is local?') . "\n";

DESCRIPTION

Jamila is yet another RPC using JSON and HTTP(CGI). Jamila stands for JSON Approach to Make Integration Linking Applications.

Jamila has 2 modes; recieve and call.

proc

Jamila->proc(I<$sModule>);

In receive mode, this is the only method to call. When this method is called, Jamila will get parameters from CGI parameters. And it will call the function specified in a parameter.

new

I<$oJml> = Jamila->new(I<$sUrl>);

Constructor for call mode. You can set $sUrl as a URL or a local object.

call

I<$oJml>->call(I<$sUrl>);

If you set a URL in "new" method, "call" will POST to that URL. If you set a local object in "new" method, "call" will perform a function of the specified object.

SEE ALSO

This distribution has sample HTML + JavaScript and perl script.

- 1. Put jamila.html and Jamila.js into a htdocs/jamila directory. - 2. Put testJamila.pl into a cgi-bin/jamila directory. And set to run that script. - 3. Run perl function from jamila.html

AUTHOR

KAWAI,Takanori <kwitknr@cpan.org>

COPYRIGHT AND LICENSE

Copyright (C) 2009 by KAWAI,Takanori

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.10.0 or, at your option, any later version of Perl 5 you may have available.