Odoo Help

Welcome!

This community is for beginners and experts willing to share their Odoo knowledge. It's not a forum to discuss ideas, but a knowledge base of questions and their answers.

2

Confirm Sales via python XML-RPC

By
Jorge Medina
on 11/15/13, 12:38 PM 11,186 views

Good Morning

I present my problem, we are starting to climb all sales of a company to OpenERP from the portal, which already does leaving sales as "draft", I'm trying to use python code with XML-RPC to confirm all and any their way to deliver the product, but my problem is that I find as deliver products automatically, this is the code that I have for this::

ventas_workflow.py

import xmlrpclib

1 CONFIGURATION

HOST = 'localhost' PORT = 8069 DB = 'GMM' USER = 'admin' PASS = '123456'

url = 'http://%s:%d/xmlrpc/'%(HOST,PORT) object_proxy = xmlrpclib.ServerProxy(url+'object') common_proxy = xmlrpclib.ServerProxy(url+'common')

2 LOGIN

uid = common_proxy.login(DB,USER,PASS) print "" print "Login %s (uid:%d)"%(USER,uid) print ""

METHODS

def execute(*args): return object_proxy.execute(DB, uid, PASS, *args)

def workflow(*args): return object_proxy.exec_workflow(DB,uid, PASS, *args)

3 DRAFT SALES SEARCH

so_ids = execute('sale.order', 'search', [('state','=','draft')])

4 CONFIRMED SALES

for so in so_ids:
print "Id Sale # %s"%(so) # confirm SOs workflow('sale.order', 'order_confirm', so)

5 INVOICE

so_ids = execute('sale.order', 'search', [('state','=','manual')])

6 CREATE INVOICE

for so in so_ids:
print "Id Sale # %s"%(so) # confirm SOs workflow('sale.order', 'manual_invoice', so)

7 INVOICE STATE DRAFT

ai_ids = execute('account.invoice', 'search', [('state','=','draft'), ('type','=','out_invoice')])

8 VALIDATE INVOICE

for ai in ai_ids:
print "Id Invoice # %s"%(ai) # confirm AIs workflow('account.invoice', 'invoice_open', ai)

9 GET OUTSTANDING BY DELIVERING PRODUCTS

spo_ids = execute('stock.picking.out', 'search', [('state','=','confirmed'), ('type','=','out')])

10 DELIVER PRODUCT

for spo in spo_ids: print "Id Picking out # %s"%(spo)
#workflow('stock.picking', 'action_assign', spo)

The process and does everything but can not find item 10 as running and do not know how to change the stock.picking of state "confirmed" to "assigned" because once in state "assigned" is used workflow "button_done" to deliver.

I hope you can advise me.

many Thanks

regards

Note: Google translation

Only use English on this site please. Thank you.

Roel Adriaans
on 11/16/13, 6:40 AM

Ok, thanks, one question, is there a Spanish forum Open ERP?, regards.

Jorge Medina
on 11/16/13, 12:50 PM

How to call other functions in standard object except orm methods using xmlrpc

Maniganda
on 4/25/14, 10:33 AM
3
Karthik Arumugam
On 9/3/15, 8:04 AM

Hi,

      I think this will help you in you case

      Follow this

     

import xmlrpclib
from pprint import pprint
url = 'http://localhost:8069'
db = 'v7_new_test'
username= 'admin'
password= 'test'
conn = xmlrpclib.ServerProxy('{0}/xmlrpc/common?db={1}'.format(url,db))

uid = conn.login(db,username,password)

models = xmlrpclib.ServerProxy('{0}/xmlrpc/object?db={1}'.format(url,db))


ids = [ your searched id(s) ]
x=models.execute_kw(db, uid, password, 'student.info.workflow','read',ids)
 
a = models.exec_workflow(db,uid,password,'student.info.workflow','check',ids[0])
 
x=models.execute_kw(db, uid, password, 'student.info.workflow','read',ids)
 







     

  

-1
Jorge Medina
On 4/28/14, 1:01 PM

good morning

What we had to do to solve this problem was to create a module for OpenERP , so you could use objects and use OpenERP Workflow together.

example:

claseprueba.py :

Import objects

import from openerp.osv osv , fields

claseprueba class ( osv.Model ) : _name = " claseprueba "

action_confirmaclaseprueba def (self, cr , uid , ids, context = None) : //Create object of purchase

self.pool.get purchase_obj = ( ' purchase.order ' )

//Create User object

self.pool.get res_user_obj = ( ' res.users ' )

//Obtained user

res_user_obj.browse res_user = (cr , uid , uid )

//you can access its properties

print res_user.login

//Create WorkFlow

wf_service = netsvc.LocalService ( "workflow" )

//Shopping Gets the draft company's existing user

purchase_obj.search order_ids = (cr , user_id , [( 'state' , '= ', ' draft' ) , ( ' company_id ', ' =', res_user.company_id.id )] )

//Walk

for order_id in order_ids :

//Confirm Purchase

wf_service.trg_validate ( user_id , ' purchase.order ' order_id ' purchase_confirm ' , cr)

//Validates Purchase

wf_service.trg_validate ( user_id , ' purchase.order ' order_id ' purchase_approve ' , cr)

This is an example , but will give you an idea where to start , you need to put the light and install in OpenERP , you have a button and run this method. You can use objects from OpenERP using this module.

regards

Your Answer

Please try to give a substantial answer. If you wanted to comment on the question or answer, just use the commenting tool. Please remember that you can always revise your answers - no need to answer the same question twice. Also, please don't forget to vote - it really helps to select the best questions and answers!

About This Community

This community is for professionals and enthusiasts of our products and services. Read Guidelines

Question tools

1 follower(s)

Stats

Asked: 11/15/13, 12:38 PM
Seen: 11186 times
Last updated: 9/8/15, 4:00 AM