Hello All,
In
openerp sometimes we need to update database value on basis
of some field value, we can direct do it but if we want to apply in
old data then we use sql query and we update but if there is
functional field which is not stored in database but you need to update data base on it. At that time we can do it by
xmlrpc.
Here, i defined
xmlrpc script in which if there is
Purchase order which is 'received' and 'invoiced' but still not in 'done' state by this script purchase order gone in 'done' state.
Purchase Order Done :
import xmlrpclib
import time
username = 'admin' #the user
pwd = 'a' #the password of the user
dbname = 'test' #the database
model = 'purchase.order' # model name
# Get the uid
sock_common = xmlrpclib.ServerProxy ('http://localhost:8069/xmlrpc/common')
uid = sock_common.login(dbname, username, pwd)
#replace localhost with the address of the server
sock = xmlrpclib.ServerProxy('http://localhost:8069/xmlrpc/object')
# argument passed to search
args = [('shipped', '=', True), ('state', 'not in', ['done']), ('invoice_method', 'in', ['manual','picking'])]
# search ids
ids = sock.execute(dbname, uid, pwd, model, 'search', args)
# READ functional field
ids_f = []
fields = ['invoiced']
po_ord = sock.execute(dbname, uid, pwd, model, 'read', ids, fields)
for re in po_ord :
if re['invoiced'] :
ids_f.append(re['id'])
# write state done
values = {'state':'done'}
results = sock.execute(dbname, uid, pwd, model, 'write', ids_f, values)
if ids_f :
print "Successfully applied records ",ids_f
else:
print "No records found to update"
>