Dear Magento friends,

Last time, we have started with Widgets in the last topic of Advanced Features. Have you enjoyed it? This week, we will continue with API functions.

You may probably know that API is one of the most important things to developers and, Magento provides API functions to allow developers to work with Magento from a third party system. To explore it in more details, why not start reading right now?

1. Magento Core API

On version 1.5, Magento API supports two API protocols: SOAP and XML-RPC, of which SOAP is the default.

To connect with Magento SOAP web services, you can use these links for your SOAP client:

1http://magentosite/index.php/api/soap/?wsdl
2http://magentosite/index.php/api/?wsdl

This is an example of SOAP client code written in PHP:

01$client = new SoapClient('http://magentosite/index.php/api/soap/?wsdl');
02 
03// get sessionId before call Magento Core API function
04$sessionId = $client->login('apiUser', 'apiKey');
05 
06$result = $client->call($sessionId, 'order.list');
07$result = $client->call($sessionId, '.', 'arg1');
08$result = $client->call($sessionId, '.', array('arg1', 'arg2', 'arg3'));
09$result = $client->multiCall($sessionId, array(
10array('.'),
11array('.', 'arg1'),
12array('.', array('arg1', 'arg2'))
13));
14 
15// If you don't need the session anymore
16$client->endSession($sessionId);

To connect with Magento XML-RPC web services, you need to use this link for your XML-RPC client:

1http://magentosite/index.php/api/xmlrpc/

Please look at an example code using XML-RPC client:

01$client = new Zend_XmlRpc_Client('http://magentosite/index.php/api/xmlrpc/');
02 
03// get sessionId before call Magento Core API function
04$sessionId = $client->call('login', array('username' => 'apiUser', 'password' => 'apiKey'));
05 
06$result = $client->call('call', array($sessionId, '.'));
07$result = $client->call('call', array($sessionId, '.', 'arg1'));
08$result = $client->call('call', array($sessionId, '.', array('arg1', 'arg2', 'arg3')));
09$result = $client->call('multiCall', array($sessionId, array(
10array('.'),
11array('.', 'arg1'),
12array('.', array('arg1', 'arg2'))
13)));
14 
15// If you don't need the session anymore
16$client->call('endSession', array($sessionId));

Magento Core API allows you to manage customers, categories, products, sales, checkout process, countries and regions. For the full list of core API methods, we can visit . In that post, I have an example using Magento API method customer.info, this code below:

01$client = new Zend_XmlRpc_Client('http://magentohost/api/xmlrpc/');
02 
03// get sessionId before call Magento Core API function
04$sessionId = $client->call('login', array('username' => 'apiUser', 'password' => 'apiKey'));
05 
06$result = $client->call('call', array($sessionId, 'customer.info', '1'));
07 
08print_r($result);
09 
10// If you don't need the session anymore
11$client->call('endSession', array($sessionId));

And then, the result will be:

01Array
02(
03[customer_id] => 1
04[created_at] => 2007-08-30 23:23:13
05[updated_at] => 2008-08-08 12:28:24
06[increment_id] => 000000001
07[store_id] => 1
08[website_id] => 1
09[firstname] => John
10[lastname] => Doe
11[email] => john.doe@example.com
12[password_hash] => 2049484a4020ed15d0e4238db22977d5:eg
13[default_billing] => 274
14[default_shipping] => 274
15[created_in] =>
16[group_id] => 1
17[prefix] =>
18[middlename] =>
19[suffix] =>
20[dob] =>
21[taxvat] =>
22[confirmation] =>
23[gender] =>
24)

2. Create your own API

You may know how to use Magento API, but when you develop a Magento module, you may do not know how to add your custom API method for working on Magento. This topic will help you to implement that.

First of all, you need to declare your API method with system by adding code in file api.xml on etc folder of your module. This file has similar code to:

01<!--?xml version="1.0"?--></p>
02&lt;[custom_resource] translate="title" module="[custom_module]"&gt;
03 
04[custom_resource]
05[custom_module]/[your_model]
06 
07&lt;[method] translate="title" module="[custom_module]"&gt;
08 
09[method]
10[custom_resource]/[method]
11<!--&#91;method&#93;-->
12 
13<!-- Example a fault response -->
14 
15<code>100</code>
16Invalid data. View details in error message
17 
18<!--&#91;custom_resource&#93;-->
19 
20&lt;[custom_resource] translate="title" module="[custom_module]"&gt;
21 
222000
23&lt;[method] translate="title" module="[custom_module]"&gt;
24 
25<!--&#91;method&#93;-->
26<!--&#91;custom_resource&#93;-->

Then you need to declare your module model in config.xml file and write your model as an adapter for API method above:

01<!--?php</p--></p>
02class [Your_Module]_Model_[your_model] extends Mage_Api_Model_Resource_Abstract
03{
04public function [method]() {
05// put adapter code here
06try {
07...
08} catch (Exception $e) {
09// fault with the code tag data_invalid
10$this-&gt;_fault('data_invalid', $e-&gt;getMessage());
11}
12}
13}

Hope this is helpful for you to understand the Magento API.

Have a good time and see you again soon!

Author

Why Magestore? We believe in building a meaningful & long-term relationship with you.

Write A Comment