AMF-Connection
view release on metacpan or search on metacpan
[1] http://en.wikipedia.org/wiki/Action_Message_Format
See public github repo http://github.com/areggiori/AMF-Connection
INSTALLATION
To install this module type the following:
perl Makefile.PL
make
make test
make install
DEPENDENCIES
This module requires these other modules and libraries:
Storable::AMF ( for serialisation/deserialisation of AMF )
LWP::UserAgent ( for RPC services over HTTP/S POST )
COPYRIGHT AND LICENCE
- tests
- more documentation
- more testing
- look into results/class mapping
lib/AMF/Connection.pm view on Meta::CPAN
AMF0 and AMF3 support is provided using the Storable::AMF module. While HTTP/S requestes to the AMF endpoint are carried out using the LWP::UserAgent module. The requests are sent using the HTTP POST method as AMF0 encoded data by default. AMF3 encod...
If encoding is set to AMF3 the Flex Messaging framework is used on returned responses content (I.e. objects casted to "flex.messaging.messages.AcknowledgeMessage" and "flex.messaging.messages.ErrorMessage" are returned).
Simple batch requests and responses is provided also.
See the sample usage synopsis above to start using the module.
=head1 DATE TYPE SUPPORT
The latest 0.79 version of Storable::AMF added basic date support with the new_date() and perl_date() utilitiy functions. This is just great. Internally an AMF Date Type represents a timestamp in milliseconds since the epoch in UTC ("neutral") timezo...
use Storable::AMF qw(new_date perl_date);
and make sure any date passed to an AMF::Connection as parameter is encoded with new_date().
=head2 OPEN ISSUES AND SHORTCOMINGS
There is still an issue when arbitrary Date structures are returned from an AMF server to an AMF::Connection (E.g. as part of values of structured AMF Objects). In this case, the AMF::Connection does not try to reparse the Perl object structure retur...
All this means that an AMF::Connection client application can not rely on those Date returned by the server as being Perl timestamps (seconds since the epoch) and will need explicitly call perl_date() or divide the timestamp by 1000 *explicitly*.
lib/AMF/Connection/InputStream.pm view on Meta::CPAN
my @int = unpack("n",$block);
return $int[0];
};
sub readDouble {
my ($class) = @_;
my $double = $class->readBuffer(8);
my @testEndian = unpack("C*",pack("S*",256));
my $bigEndian = !$testEndian[1]==1;
$double = reverse($double)
if($bigEndian);
my @double = unpack("d",$double);
return $double[0];
};
sub readLong {
my ($class) = @_;
lib/AMF/Connection/OutputStream.pm view on Meta::CPAN
sub writeInt {
my ($class, $int) = @_;
$class->{'stream'}.=pack("n",$int);
};
sub writeDouble {
my ($class, $double) = @_;
my $bin = pack("d",$double);
my @testEndian = unpack("C*",pack("S*",256));
my $bigEndian = !$testEndian[1]==1;
$bin = reverse($bin)
if ($bigEndian);
$class->{'stream'}.=$bin;
};
sub writeLong {
my ($class, $long) = @_;
$class->{'stream'}.=pack("N",$long);
t/00_load.t view on Meta::CPAN
# Before `make install' is performed this script should be runnable with
# `make test'. After `make install' it should work as `perl AMF-Connection.t'
#########################
# change 'tests => 1' to 'tests => last_test_to_print';
use Test::More tests => 1;
BEGIN { use_ok('AMF::Connection') };
#########################
# Insert your test code below, the Test::More module is use()ed here so read
# its man page ( perldoc Test::More ) for help writing this test script.
( run in 0.268 second using v1.01-cache-2.11-cpan-3cd7ad12f66 )