«читать» данные с несколькими идентификаторами из OpenERP, используя java с apache xml-rpc - PullRequest
1 голос
/ 02 февраля 2011

Привет! В настоящее время я пишу сервлет, используя Apache XML-RPC , подключающийся к OpenERP. Вокруг нет хороших ресурсов, и примеры на Java очень минималистичны и далеки от завершения на сайте OpenERP.

Кто-нибудь знает, где я могу найти API о том, как и что я могу вызвать на стороне OpenERP?

Я бы очень признателен за это !!!

Кроме того, я специально искал синтаксис о том, как "читать" данные, используя java, с вводом нескольких идентификаторов.

XmlRpcClient client = new XmlRpcClient();
XmlRpcClientConfigImpl clientConfig = new XmlRpcClientConfigImpl();
clientConfig.setEnabledForExtensions(true);
clientConfig.setServerURL(new URL(urlStringObject));
client.setConfig(clientConfig);

Object[] params2 = { "city", "name", "email", "create_date","write_date" };

Vector<Object> arg = new Vector<Object>();

arg.add(database);
arg.add(1);
arg.add(password);
arg.add("res.partner.address");
arg.add("read");
arg.add(9); // <- THE PYTHON SYNTAX SAYS input 'LIST OF IDS' here What is the Jave equivalent???
arg.add(params2);

HashMap ids = (HashMap) client.execute("execute", arg);

UPDATE

/* Search for all ids */
                xmlrpcConfigLogin.setServerURL(new URL(urlStringObject));
                Object[] searchQuery = new Object[] {"id", "!=", -1 };

                Vector queryVector = new Vector();
                queryVector.addElement(searchQuery);

                Object[] params = new Object[] { database, theloginId , password, tableName, "search", queryVector };
                Object[] po_ids = (Object[]) xmlrpcLogin.execute("execute", params);                

                /* Send Read Query */
                Object[] readQuery = {"name"};      

                Vector<Object> arg = new Vector<Object>();      
                arg.add(database);
                arg.add(1);
                arg.add(password);
                arg.add(tableName);
                arg.add("read");
                arg.add(po_ids);
                arg.add(readQuery);         

                HashMap globalMap = new HashMap();

                Object[] hm = (Object[]) xmlrpcLogin.execute("execute", arg);                                   
                for (Object object : hm) {
                    HashMap hash = (HashMap)object;                             
                    globalMap.put("name", hash.get("name"));              
                    _log.info(hash.get("name"));
                }       

Как вы можете видеть: он принимает Object [] из идентификаторов в качестве входных данных (po_ids)

1 Ответ

1 голос
/ 03 февраля 2011

Я предполагаю, что вы прочитали описание книги разработчиков XML-RPC . Я думаю, что это просто оболочка вокруг всех методов в классе ORM . Это вся документация, которую я видел. Кроме этого, я запускаю OpenERP в режиме отладки и ставлю точку останова в методе LocalService.__call__(), чтобы посмотреть, какие параметры клиент отправляет на сервер. (Это в server/bin/netsvc.py.) Я также видел, как разработчики просто регистрировали каждый запрос, поступающий через этот метод.

Что касается того, как делать вызовы в Java, я не знаком с XmlRpcClient API, но похоже, что он примет массив объектов для списка и, вероятно, все, что перечислимо. Посмотрите, полезно ли описание типов данных , и ознакомьтесь с учебником по . Он использует Vector для хранения параметра списка.

...