Webszolgáltatások

A webszolgáltatás modul közös felületet kínál minden webszolgáltatáshoz:

  • XML-RPC

  • JSON-RPC

Az üzleti objektumok elérhetők az elosztott objektum mechanizmuson keresztül is. Mindegyik módosítható az ügyfél felületen keresztül kontextuális nézetekkel.

Az Odoo elérhető XML-RPC/JSON-RPC interfészeken keresztül, amelyekhez számos nyelven léteznek könyvtárak.

XML-RPC Könyvtár

A következő példa egy Python 3 program, amely az xmlrpc.client könyvtárral lép kapcsolatba egy Odoo szerverrel:

import xmlrpc.client

root = 'http://%s:%d/xmlrpc/' % (HOST, PORT)

uid = xmlrpc.client.ServerProxy(root + 'common').login(DB, USER, PASS)
print("Logged in as %s (uid: %d)" % (USER, uid))

# Create a new note
sock = xmlrpc.client.ServerProxy(root + 'object')
args = {
    'color' : 8,
    'memo' : 'This is a note',
    'create_uid': uid,
}
note_id = sock.execute(DB, uid, PASS, 'note.note', 'create', args)

Exercise

Új szolgáltatás hozzáadása az ügyfélhez

Írjon egy Python programot, amely képes XML-RPC kéréseket küldeni egy Odoo-t futtató PC-hez (az Önéhez vagy az oktatóéhez). Ennek a programnak meg kell jelenítenie az összes ülést és azok megfelelő ülőhelyszámát. Emellett létre kell hoznia egy új ülést az egyik kurzushoz.

Lásd még

  • Külső API: Az XML-RPC részletes oktatóanyaga, példákkal több programozási nyelven.

JSON-RPC Könyvtár

A következő példa egy Python 3 program, amely egy Odoo szerverrel kommunikál a standard Python könyvtárak urllib.request és json segítségével. Ez a példa feltételezi, hogy a Productivity alkalmazás (note) telepítve van:

import json
import random
import urllib.request

HOST = 'localhost'
PORT = 8069
DB = 'openacademy'
USER = 'admin'
PASS = 'admin'

def json_rpc(url, method, params):
    data = {
        "jsonrpc": "2.0",
        "method": method,
        "params": params,
        "id": random.randint(0, 1000000000),
    }
    req = urllib.request.Request(url=url, data=json.dumps(data).encode(), headers={
        "Content-Type":"application/json",
    })
    reply = json.loads(urllib.request.urlopen(req).read().decode('UTF-8'))
    if reply.get("error"):
        raise Exception(reply["error"])
    return reply["result"]

def call(url, service, method, *args):
    return json_rpc(url, "call", {"service": service, "method": method, "args": args})

# log in the given database
url = "http://%s:%s/jsonrpc" % (HOST, PORT)
uid = call(url, "common", "login", DB, USER, PASS)

# create a new note
args = {
    'color': 8,
    'memo': 'This is another note',
    'create_uid': uid,
}
note_id = call(url, "object", "execute", DB, uid, PASS, 'note.note', 'create', args)

A példák könnyen adaptálhatók XML-RPC-ről JSON-RPC-re.

Megjegyzés

Számos magas szintű API létezik különböző nyelveken, amelyek lehetővé teszik az Odoo rendszerek elérését anélkül, hogy kifejezetten XML-RPC-n vagy JSON-RPC-n keresztül kellene menni, mint például: