package FS::part_export::http; use base qw( FS::part_export ); use vars qw( %options %info ); use Tie::IxHash; tie %options, 'Tie::IxHash', 'method' => { label =>'Method', type =>'select', #options =>[qw(POST GET)], options =>[qw(POST)], default =>'POST' }, 'url' => { label => 'URL', default => 'http://', }, 'insert_data' => { label => 'Insert data', type => 'textarea', default => join("\n", 'DomainName $svc_x->domain', 'Email ( grep { $_ !~ /^(POST|FAX)$/ } $svc_x->cust_svc->cust_pkg->cust_main->invoicing_list)[0]', 'test 1', 'reseller $svc_x->cust_svc->cust_pkg->part_pkg->pkg =~ /reseller/i', ), }, 'delete_data' => { label => 'Delete data', type => 'textarea', default => join("\n", ), }, 'replace_data' => { label => 'Replace data', type => 'textarea', default => join("\n", ), }, 'suspend_data' => { label => 'Suspend data', type => 'textarea', default => join("\n", ), }, 'unsuspend_data' => { label => 'Unsuspend data', type => 'textarea', default => join("\n", ), }, 'success_regexp' => { label => 'Success Regexp', default => '', }, ; %info = ( 'svc' => 'svc_domain', 'desc' => 'Send an HTTP or HTTPS GET or POST request', 'options' => \%options, 'no_machine' => 1, 'notes' => <<'END' Send an HTTP or HTTPS GET or POST to the specified URL. For HTTPS support, Crypt::SSLeay or IO::Socket::SSL is required. END ); sub rebless { shift; } sub _export_insert { my $self = shift; $self->_export_command('insert', @_); } sub _export_delete { my $self = shift; $self->_export_command('delete', @_); } sub _export_suspend { my $self = shift; $self->_export_command('suspend', @_); } sub _export_unsuspend { my $self = shift; $self->_export_command('unsuspend', @_); } sub _export_command { my( $self, $action, $svc_x ) = ( shift, shift, shift ); return unless $self->option("${action}_data"); my $cust_main = $svc_x->cust_main or return; $self->http_queue( $svc_x->svcnum, $self->option('method'), $self->option('url'), $self->option('success_regexp'), map { /^\s*(\S+)\s+(.*)$/ or /()()/; my( $field, $value_expression ) = ( $1, $2 ); my $value = eval $value_expression; die $@ if $@; ( $field, $value ); } split(/\n/, $self->option("${action}_data") ) ); } sub _export_replace { my( $self, $new, $old ) = ( shift, shift, shift ); return unless $self->option('replace_data'); my $new_cust_main = $new->cust_main or return; my $cust_main = $new_cust_main; #so folks can use $new_cust_main or $cust_main $self->http_queue( $new->svcnum, $self->option('method'), $self->option('url'), $self->option('success_regexp'), map { /^\s*(\S+)\s+(.*)$/ or /()()/; my( $field, $value_expression ) = ( $1, $2 ); my $value = eval $value_expression; die $@ if $@; ( $field, $value ); } split(/\n/, $self->option('replace_data') ) ); } sub http_queue { my($self, $svcnum) = (shift, shift); my $queue = new FS::queue { 'job' => "FS::part_export::http::http" }; $queue->svcnum($svcnum) if $svcnum; $queue->insert( @_ ); } sub http { my($method, $url, $success_regexp, @data) = @_; $method = lc($method); eval "use LWP::UserAgent;"; die "using LWP::UserAgent: $@" if $@; eval "use HTTP::Request::Common;"; die "using HTTP::Request::Common: $@" if $@; my $ua = LWP::UserAgent->new; #my $response = $ua->$method( # $url, \%data, # 'Content-Type'=>'application/x-www-form-urlencoded' #); my $req = HTTP::Request::Common::POST( $url, \@data ); my $response = $ua->request($req); die $response->error_as_HTML if $response->is_error; if(length($success_regexp) > 1) { my $response_content = $response->content; die $response_content unless $response_content =~ /$success_regexp/; } } 1;