NAME
OpenERP::XMLRPC::Client - XMLRPC Client tweaked for OpenERP interaction.
SYNOPSIS
my $erp = OpenERP::XMLRPC::Client->new( dbname => 'terp', username => 'admin', password => 'admin', host => '127.0.0.1', port => '8069' )
my $partner_ids = $erp->object_execute( 'res.partner', 'search', [ 'name', 'ilke', 'abc' ] );
# READ a res.partner object
my $partner = $erp->read( 'res.partner', $id );
print "You Found Partner:" . $partner->{name} . "\n";
DESCRIPTION
I have tried to make this extendable so made use of moose roles to structure the calls to the different methods available from the openerp rpc.
This makes use of the MooseX::Role::XMLRPC::Client to communicate via rpc.
This module was built to be used by another OpenERP::XMLRPC::Simple and handles openerp specific rpc interactions. It could be used by something else to access openerp rpc services.
NAME
OpenERP::XMLRPC::Client - XML RPC Client for OpenERP
Parameters
username - string - openerp username (default: 'admin')
password - string - openerp password (default: 'admin')
dbname - string - openerp database name (default: 'terp')
host - string - openerp rpc server host (default: '127.0.0.1' )
port - string - openerp rpc server port (default: 8069)
proto - string - openerp protocol (default: http) .. untested anything else.
Attributes
openerp_uid - int - filled when the connection is logged in.
base_rpc_uri - string - used to hold uri the rpc is currently pointing to.
openerp_rpc - L<RPC::XML::Client> - Provided by L<MooseX::Role::XMLRPC::Client>
METHODS
These methods re-present the OpenERP XML RPC but in a slightly more user friendly way.
The methods have been tested using the 'res.partner' object name and the demo database provided when you install OpenERP.
BUILD
When the object is instanciated, this method is run. This calls openerp_login.
openerp_login
Logs the client in. Called automatically when the object is created.
openerp_logout
Basically a no-op.
object_execute
Low level method for making a call to the Open ERP server. Normally called by a wrapper function like create or read.
object_exec_workflow
Makes an 'exec_workflow' call to Open ERP.
report_report
Sends a 'report' call to Open ERP.
report_report_get
Sends a 'report_get' call to Open ERP.
change_uri
OpenERP makes methods available via different URI's, this method is used to change which URI the rpc client is pointing at.
Arguments: $_[0] - object ref. ($self) $_[1] - string (e.g. "xmlrpc/object") base uri path.
Returns: string - the old uri - the one this new one replaced.
read ( OBJECTNAME, [IDS] )
Can pass this a sinlge ID or an ARRAYREF of ID's, it will return an ARRAYREF of OBJECT records (HASHREF's).
Example: $partner = $erp->read('res.partner', 1 ); print "This is the returned record name:" . $partner->[0]->{name} . "\n";
$partners = $erp->read('res.partner', [1,2] );
print "This is the returned record 1:" . $partners->[0]->{name} . "\n";
print "This is the returned record 2:" . $partners->[1]->{name} . "\n";
Returns: ArrayRef of HashRef's - All the objects with IDs passed.
search ( OBJECTNAME, [ [ COLNAME, COMPARATOR, VALUE ] ] )
Used to search and return IDs of objects matching the searcgh.
Returns: ArrayRef of ID's - All the objects ID's matching the search.
Example: $results = $erp->search('res.partner', [ [ 'name', 'ilke', 'abc' ] ] ); print "This is the 1st ID found:" . $results->[0] . "\n";
create ( OBJECTNAME, { COLNAME => COLVALUE } )
Returns: ID - the ID of the object created.
Example: $new_id = $erp->create('res.partner', { 'name' => 'new company name' } );
update ( OBJECTNAME, ID, { COLNAME => COLVALUE } )
Returns: boolean - updated or not.
Example: $success = $erp->update('res.partner', 1, { 'name' => 'changed company name' } );
delete ( OBJECTNAME, ID )
Returns: boolean - deleted or not.
Example: $success = $erp->delete('res.partner', 1 );
field_info ( OBJECTNAME )
Returns: hash containing all field info, this contains field names and field types.
model_fields ( OBJECTNAME )
Returns: hash containing all the models fields.
get_defaults ( OBJECTNAME, [ FIELDS ] )
Returns: hash containing the default values for those fields.
search_detail ( OBJECTNAME, [ [ COLNAME, COMPARATOR, VALUE ] ], CONTEXT )
Used to search and read details on a perticular OBJECT. This uses 'search' to find IDs, then calls 'read' to get details on each ID returned.
Returns: ArrayRef of HashRef's - All the objects found with all their details.
Example: $results = $erp->search_detail('res.partner', [ [ 'name', 'ilke', 'abc' ] ] ); print "This is the 1st found record name:" . $results->[0]->{name} . "\n";
The CONTEXT
argument is optional. This allows a hasref containing the current search context to be provided, e.g.
my $results = $erp->search_detail(
'stock.location',
[
['usage' => '=' => 'internal']
],
{
active_id => $self->id,
active_ids => [$self->id],
active_model => 'product.product',
full => 1,
product_id => $self->id,
search_default_in_location => 1,
section_id => undef,
tz => undef,
}
)
read_single ( OBJECTNAME, ID )
Pass this a sinlge ID and get a single OBJECT record (HASHREF).
Example: $partner = $erp->read_single('res.partner', 1 ); print "This name of partner with ID 1:" . $partner->{name} . "\n";
Returns: HashRef - The objects data
SEE ALSO
AUTHOR
Benjamin Martin <ben@madeofpaper.co.uk> Colin Newell <colin@opusvl.com> Jon Allen (JJ) <jj@opusvl.com>
COPYRIGHT AND LICENSE
Copyright (C) 2010 OpusVL
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.