1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129
|
# ======================================================================
#
# Copyright (C) 2000-2001 Paul Kulchenko (paulclinger@yahoo.com)
# SOAP::Lite is free software; you can redistribute it
# and/or modify it under the same terms as Perl itself.
#
# $Id: IO.pm,v 1.3 2001/08/11 19:09:57 paulk Exp $
#
# ======================================================================
package SOAP::Transport::IO;
use strict;
use vars qw($VERSION);
$VERSION = eval sprintf("%d.%s", q$Name: release-0_52-public $ =~ /-(\d+)_([\d_]+)/);
use IO::File;
use SOAP::Lite;
# ======================================================================
package SOAP::Transport::IO::Server;
use strict;
use Carp ();
use vars qw(@ISA);
@ISA = qw(SOAP::Server);
sub new {
my $self = shift;
unless (ref $self) {
my $class = ref($self) || $self;
$self = $class->SUPER::new(@_);
}
return $self;
}
sub BEGIN {
no strict 'refs';
my %modes = (in => '<', out => '>');
for my $method (keys %modes) {
my $field = '_' . $method;
*$method = sub {
my $self = shift->new;
return $self->{$field} unless @_;
my $file = shift;
if (defined $file && !ref $file && !defined fileno($file)) {
my $name = $file;
open($file = new IO::File, $modes{$method} . $name) or Carp::croak "$name: $!";
}
$self->{$field} = $file;
return $self;
}
}
}
sub handle {
my $self = shift->new;
$self->in(*STDIN)->out(*STDOUT) unless defined $self->in;
my $in = $self->in;
my $out = $self->out;
my $result = $self->SUPER::handle(join '', <$in>);
no strict 'refs'; print {$out} $result if defined $out;
}
# ======================================================================
1;
__END__
=head1 NAME
SOAP::Transport::IO - Server side IO support for SOAP::Lite
=head1 SYNOPSIS
use SOAP::Transport::IO;
SOAP::Transport::IO::Server
# you may specify as parameters for new():
# -> new( in => 'in_file_name' [, out => 'out_file_name'] )
# -> new( in => IN_HANDLE [, out => OUT_HANDLE] )
# -> new( in => *IN_HANDLE [, out => *OUT_HANDLE] )
# -> new( in => \*IN_HANDLE [, out => \*OUT_HANDLE] )
# -- OR --
# any combinations
# -> new( in => *STDIN, out => 'out_file_name' )
# -> new( in => 'in_file_name', => \*OUT_HANDLE )
# -- OR --
# use in() and/or out() methods
# -> in( *STDIN ) -> out( *STDOUT )
# -- OR --
# use default (when nothing specified):
# in => *STDIN, out => *STDOUT
# don't forget, if you want to accept parameters from command line
# \*HANDLER will be understood literally, so this syntax won't work
# and server will complain
-> new(@ARGV)
# specify path to My/Examples.pm here
-> dispatch_to('/Your/Path/To/Deployed/Modules', 'Module::Name', 'Module::method')
-> handle
;
=head1 DESCRIPTION
=head1 COPYRIGHT
Copyright (C) 2000-2001 Paul Kulchenko. All rights reserved.
This library is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.
=head1 AUTHOR
Paul Kulchenko (paulclinger@yahoo.com)
=cut
|