NAME
jBilling::Client::SOAP - Communicate with jBilling
VERSION
Version 0.01
SYNOPSIS
This module acts as an interface for functionality exposed by the jBilling SOAP API.
Initialise the library use jBilling::Client::SOAP; my $jb = jBilling::Client::SOAP-
new(); $jb->getAPI( 'username' => 'yourusername', 'password' => 'yourpassword', 'url' => 'http://yourservername:yourserverport/jbilling/services/api' ); # Initialise the API >
Load an existing order from jBilling my $order = jBilling::Client::SOAP::OrderWS-
new( 'jbilling' => $jb, # The Client connection to jBilling 'id' => 25300 # Specify the ID which we want to load )->retrieve; # Retrieve the order details from jBilling >
Create a new order my $newOrder = jBilling::Client::SOAP::OrderWS-
new('jbilling' => $jb, 'period' => '200', 'billingTypeId' => '2', 'currencyId' => '110', 'userId' => '122', 'activeSince' => '2015-01-31', 'notes' => 'Some Order notes from the API');
# Create some OrderLines
my $ol = jBilling::Client::SOAP::OrderLineWS->new('useItem' => 'true',
'itemId' => 2103, # MAKE SURE THIS ITEM MATCHES AN ITEM YOUR SYSTEM!
'typeId' => 1, # Item
'quantity' => 1,
'description' => "test from perl api",
);
my $ol1 = jBilling::Client::SOAP::OrderLineWS->new('useItem' => 'true',
'itemId' => '2102', # MAKE SURE THIS ITEM MATCHES AN ITEM YOUR SYSTEM!
'typeId' => 1, # Item
'quantity' => 1,
'description' => "Another test from perl api"
);
# And some Metafields
my $retailer = jBilling::Client::SOAP::MetaFieldValueWS->new(
'fieldName' => 'retailer',
'stringValue' => 'Test Retailer',
);
my $orderno = jBilling::Client::SOAP::MetaFieldValueWS->new(
'fieldName' => 'Order Number',
'stringValue' => 'TestOrderNo'
);
# add our order lines to the order
$newOrder->orderLines(\@OrderLines);
$newOrder->metaFields(\@metafields);
$newOrder->save; # Returns orderId on success
>
SUBROUTINES/METHODS
getAPI
This method initiates a SOAP::Lite object for later re-use
new
Constructs the jBilling::Client::SOAP object
load
Responsible for calling the jBilling API for load routines. Used internally only