Весь сир-бор через те, що можливості REST в Magento просто жалюгідні.
На сьогодні Magento підтримує всі найбільш поширені способи доступу до API сайтів: REST, XML-RPC, SOAP.
Magento SOAP/XML-RPC API дає вам можливість керувати своїми магазинами електронної комерції, забезпечуючи методи для роботи з ресурсами, такими як клієнти, категорій, продукти і замовлення.
Про SOAP можна говорити багато і довго.
Для мене основними мінусами стали складність протоколу і відсутність вбудованої підтримки в Ruby.
Натомість стандарт XML-RPC зачарував мене своєю надзвичайною простотою.
В базову поставку Ruby вже входить бібліотека для роботи з XML-RPC, відповідно вам не доведеться замислюватися про структуру запитів і обробку відповідей в XML.
Тому саме XML-RPC в основному і буде присвячена ця стаття.
Не буду зупинятися на питанні, що таке XML-RPC і навіщо він потрібен. У мережі багато статей на цю тему.
Просто постараюся коротко показати, яким простим способом можливе створення клієнта до XML-RPC веб-сервісу на Ruby.
require 'xmlrpc/client' config = { api_user: 'user', api_key: 'secret', host: 'example.com', path: '/api/xmlrpc', port: 80, } client = XMLRPC::Client.new(config[:host], config[:path], config[:port]) # If somestuff requires api authentification, # we should get session token session = client.call('login', config[:api_user], config[:api_key]) parent_id = 1 store_view = 1 client.call('call', session, 'catalog_category.tree', [parent_id , store_view]) # If you don't need the session anymore client.call('endSession', session)
Все просто: ми підключаємося до сервера, отримуємо ключ сесії і виконуємо запити.
Документацію по всіх запитах Magento API можна знайти на офіційному сайті.
XML-RPC підтримується тільки першою версією Magento API.