You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
122 lines
3.6 KiB
122 lines
3.6 KiB
# ======================================================================
|
|
#
|
|
# 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 ([email protected])
|
|
|
|
=cut
|