|
|
# ====================================================================== # # Copyright (C) 2000-2001 Paul Kulchenko ([email protected]) # SOAP::Lite is free software; you can redistribute it # and/or modify it under the same terms as Perl itself. # # $Id: SOAP::Transport::MAILTO.pm,v 0.51 2001/07/18 15:15:14 $ # # ======================================================================
package SOAP::Transport::MAILTO;
use strict; use vars qw($VERSION); $VERSION = '0.51';
use MIME::Lite; use URI;
# ======================================================================
package SOAP::Transport::MAILTO::Client;
use vars qw(@ISA); @ISA = qw(SOAP::Client);
sub DESTROY { SOAP::Trace::objects('()') }
sub new { my $self = shift;
unless (ref $self) { my $class = ref($self) || $self; my(@params, @methods); while (@_) { $class->can($_[0]) ? push(@methods, shift() => shift) : push(@params, shift) } $self = bless {@params} => $class; while (@methods) { my($method, $params) = splice(@methods,0,2); $self->$method(ref $params eq 'ARRAY' ? @$params : $params) } SOAP::Trace::objects('()'); } return $self; }
sub send_receive { my($self, %parameters) = @_; my($envelope, $endpoint, $action) = @parameters{qw(envelope endpoint action)};
$endpoint ||= $self->endpoint; my $uri = URI->new($endpoint); %parameters = (%$self, map {URI::Escape::uri_unescape($_)} map {split/=/,$_,2} split /[&;]/, $uri->query || '');
my $msg = MIME::Lite->new( To => $uri->to, Type => 'text/xml', Encoding => $parameters{Encoding} || 'base64', Data => $envelope, $parameters{From} ? (From => $parameters{From}) : (), $parameters{'Reply-To'} ? ('Reply-To' => $parameters{'Reply-To'}) : (), $parameters{Subject} ? (Subject => $parameters{Subject}) : (), ); $msg->replace('X-Mailer' => join '/', 'SOAP::Lite', 'Perl', SOAP::Transport::MAILTO->VERSION); $msg->add(SOAPAction => $action);
SOAP::Trace::transport($msg); SOAP::Trace::debug($msg->as_string); MIME::Lite->send(map {exists $parameters{$_} ? ($_ => $parameters{$_}) : ()} 'smtp', 'sendmail'); eval { local $SIG{__DIE__}; $MIME::Lite::AUTO_CC = 0; $msg->send }; (my $code = $@) =~ s/ at .*\n//;
$self->code($code); $self->message($code); $self->is_success(!defined $code || $code eq ''); $self->status($code);
return; }
# ======================================================================
1;
=head1 NAME
SOAP::Transport::MAILTO - Client side SMTP/sendmail support for SOAP::Lite
=head1 SYNOPSIS
use SOAP::Lite;
SOAP::Lite -> uri('http://soaplite.com/My/Examples') -> proxy('mailto:destination.email@address', smtp => 'smtp.server', From => 'your.email', Subject => 'SOAP message')
# or # -> proxy('mailto:destination.email@address?From=your.email&Subject=SOAP%20message', smtp => 'smtp.server')
# or if you want to send with sendmail # -> proxy('mailto:destination.email@address?From=your.email&Subject=SOAP%20message')
# or if your sendmail is in undiscoverable place # -> proxy('mailto:destination.email@address?From=your.email&Subject=SOAP%20message', sendmail => 'command to run your sendmail')
-> getStateName(12) ;
=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
|