Skip to Content
Odoo Menu
  • Zaloguj się
  • Wypróbuj za darmo
  • Aplikacje
    Finanse
    • Księgowość
    • Fakturowanie
    • Wydatki
    • Arkusz kalkulacyjny (BI)
    • Dokumenty
    • Podpisy
    Sprzedaż
    • CRM
    • Sprzedaż
    • PoS Sklep
    • PoS Restauracja
    • Subskrypcje
    • Wypożyczalnia
    Strony Internetowe
    • Kreator Stron Internetowych
    • eCommerce
    • Blog
    • Forum
    • Czat na Żywo
    • eLearning
    Łańcuch dostaw
    • Magazyn
    • Produkcja
    • PLM
    • Zakupy
    • Konserwacja
    • Jakość
    Zasoby Ludzkie
    • Pracownicy
    • Rekrutacja
    • Urlopy
    • Ocena pracy
    • Polecenia Pracownicze
    • Flota
    Marketing
    • Marketing Społecznościowy
    • E-mail Marketing
    • SMS Marketing
    • Wydarzenia
    • Automatyzacja Marketingu
    • Ankiety
    Usługi
    • Projekt
    • Ewidencja czasu pracy
    • Usługi Terenowe
    • Helpdesk
    • Planowanie
    • Spotkania
    Produktywność
    • Dyskusje
    • Zatwierdzenia
    • IoT
    • VoIP
    • Wiedza
    • WhatsApp
    Aplikacje trzecich stron Studio Odoo Odoo Cloud Platform
  • Branże
    Sprzedaż detaliczna
    • Księgarnia
    • Sklep odzieżowy
    • Sklep meblowy
    • Sklep spożywczy
    • Sklep z narzędziami
    • Sklep z zabawkami
    Żywienie i hotelarstwo
    • Bar i Pub
    • Restauracja
    • Fast Food
    • Pensjonat
    • Dystrybutor napojów
    • Hotel
    Agencja nieruchomości
    • Agencja nieruchomości
    • Biuro architektoniczne
    • Budowa
    • Zarządzanie nieruchomościami
    • Ogrodnictwo
    • Stowarzyszenie właścicieli nieruchomości
    Doradztwo
    • Biuro księgowe
    • Partner Odoo
    • Agencja marketingowa
    • Kancelaria prawna
    • Agencja rekrutacyjna
    • Audyt i certyfikacja
    Produkcja
    • Tekstylia
    • Metal
    • Meble
    • Jedzenie
    • Browar
    • Prezenty firmowe
    Zdrowie & Fitness
    • Klub sportowy
    • Salon optyczny
    • Centrum fitness
    • Praktycy Wellness
    • Apteka
    • Salon fryzjerski
    Transakcje
    • Złota rączka
    • Wsparcie Sprzętu IT
    • Systemy energii słonecznej
    • Szewc
    • Firma sprzątająca
    • Usługi HVAC
    Inne
    • Organizacja non-profit
    • Agencja Środowiskowa
    • Wynajem billboardów
    • Fotografia
    • Leasing rowerów
    • Sprzedawca oprogramowania
    Przeglądaj wszystkie branże
  • Community
    Ucz się
    • Samouczki
    • Dokumentacja
    • Certyfikacje
    • Szkolenie
    • Blog
    • Podcast
    Pomóż w nauce innym
    • Program Edukacyjny
    • Scale Up! Gra biznesowa
    • Odwiedź Odoo
    Skorzystaj z oprogramowania
    • Pobierz
    • Porównaj edycje
    • Wydania
    Współpracuj
    • Github
    • Forum
    • Wydarzenia
    • Tłumaczenia
    • Zostań partnerem
    • Usługi dla partnerów
    • Zarejestruj swoją firmę rachunkową
    Skorzystaj z usług
    • Znajdź partnera
    • Znajdź księgowego
    • Spotkaj się z doradcą
    • Usługi wdrożenia
    • Opinie klientów
    • Wsparcie
    • Aktualizacje
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Zaplanuj demo
  • Cennik
  • Pomoc
Musisz się zarejestrować, aby móc wchodzić w interakcje z tą społecznością.
Wszystkie posty Osoby Odznaki
Tagi (Zobacz wszystko)
odoo accounting v14 pos v15
O tym forum
Musisz się zarejestrować, aby móc wchodzić w interakcje z tą społecznością.
Wszystkie posty Osoby Odznaki
Tagi (Zobacz wszystko)
odoo accounting v14 pos v15
O tym forum
Pomoc

Create an invoice from a sales order using XML-RPC (Python)

Zaprenumeruj

Otrzymaj powiadomienie o aktywności w tym poście

To pytanie dostało ostrzeżenie
many2manysales.orderjournal_entry
2 Odpowiedzi
10334 Widoki
Awatar
Ahmad S

Hi, I'm following the external APIs documentation : https://www.odoo.com/documentation/13.0/webservices/odoo.html

to implement our companies requirements. I'm required to create a sales order and automatically create an invoice after that. The sales order part is done but I cant seem to be able to attach the Invoice to the Sales order

I've tried linking it via the 'invoice_ids' field but the documentation does not mention how to provide a many2many field in it. here is the code:


    many2manyInvoice =  [(4, invoice_id)]   

    common = xmlrpc.client.ServerProxy('{}/xmlrpc/2/common'.format(url))
    print(common)

    #Admin user Id
    uid = common.authenticate(db, username, password, {})
    
    models = xmlrpc.client.ServerProxy('{}/xmlrpc/2/object'.format(url))

    models.execute_kw(db, uid, password, 'sale.order', 'write', [[sales_order_id],     {'invoice_ids':many2manyInvoice}])


The response returned is 200 , but nothing is happening on the sales order level. I think its the way. I think its the way that I defined the field that might be incorrect.

Can someone help with this issue ? Thanks in advance




0
Awatar
Odrzuć
Awatar
Aditya Irri
Najlepsza odpowiedź

This might help you

@app.route('/createInvoice', methods=['POST'])
def createInvoice():
    try:
        models = xmlrpc.client.ServerProxy('{}/xmlrpc/2/object'.format(url))
        data = request.get_json()
        if not data:
            return jsonify({'message': 'No data received.'}), 400
        
        sale_order_id = int(data.get('sale_order_id'))
        product_id = int(data.get('product_variant_id'))
        
        if not sale_order_id or not product_id:
            return jsonify({'message': 'Invalid input data.'}), 400
        
        # Fetch data related to the sale order
        sale_order_data = models.execute_kw(db, uid, password, 'sale.order', 'read', 
                                            [sale_order_id], 
                                            {'fields': ['partner_id', 'invoice_status', 'name', 'order_line', 'picking_ids']})
        
        if not sale_order_data:
            return jsonify({'message': 'Sale order not found.'}), 404
        
        invoice_id = None
        
        # Iterate through each picking related to the sale order
        for picking_line in sale_order_data[0].get('picking_ids', []):
            picking_line_data = models.execute_kw(db, uid, password, 'stock.picking', 'search_read', 
                                                [[['id', '=', int(picking_line)],['product_id','=', int(product_id)]]], {})
            # If picking data is found
            if picking_line_data:
                stock_picking_validate = models.execute_kw(db, uid, password, 'stock.picking', 'button_validate', [[picking_line]])
        
        # Iterate through each line of the sale order
        for lineId in sale_order_data[0].get('order_line', []):
            sale_order_line = models.execute_kw(db, uid, password, 'sale.order.line', 'search_read', 
                                                [[["id", "=", lineId],['product_id','=', product_id]]], {})
            if sale_order_line:
                # Generate invoice for the sale order line
                current_date = datetime.now().strftime('%Y-%m-%d')
                context = {
                    'move_type': 'out_invoice',
                    'partner_id': sale_order_data[0]['partner_id'][0],
                    'invoice_origin': sale_order_data[0]['name'],
                    'invoice_date': current_date,
                    'partner_bank_id': 164, #Keep your bank ID
                    'l10n_in_gst_treatment': 'consumer', #Keep your GST treatment (Consumer or Supplier)
                    'ref': '',
                    'l10n_in_type_id': 1, #Eway Bill Document type - ID
                    'l10n_in_mode': '1', #Mode Of Transport - ID
                    'l10n_in_distance': 11, #Distance travelled by vehicle
                    'l10n_in_vehicle_type': 'R', #Vehicle Type - Char
                    'l10n_in_vehicle_no': 'AP00AA0000' #Vehicle Number - Char
                }
                # Create invoice in the system
                invoice_id = models.execute_kw(db, uid, password, 'account.move', 'create', [context])
                invoice_lines = []
                # Populate invoice lines
                for lineId in sale_order_data[0].get('order_line', []):
                    sale_order_line = models.execute_kw(db, uid, password, 'sale.order.line', 'read', [lineId], {})
                    invoice_lines.append((0, 0, {
                        'move_id': int(invoice_id),
                        'product_id': int(sale_order_line[0]['product_id'][0]),
                        'quantity': float(sale_order_line[0]['product_uom_qty']),
                        'price_unit': float(sale_order_line[0]['price_unit']),
                        'name': sale_order_line[0]['name']
                    }))
                # Write invoice lines to the invoice
                models.execute_kw(db, uid, password, 'account.move', 'write', [invoice_id, {'invoice_line_ids': invoice_lines}])
                # Post the invoice
                models.execute_kw(db, uid, password, 'account.move', 'action_post', [invoice_id])
                # Find the invoice line ID
                inv_line_id = models.execute_kw(db, uid, password, 'account.move.line', 'search', 
                                                 [[['product_id', '=', sale_order_line[0]['product_id'][0]], 
                                                   ['move_id', '=', invoice_id], 
                                                   ['quantity', '=', sale_order_line[0]['product_uom_qty']]]])
                # Update sale order line with invoice line and invoice status
                models.execute_kw(db, uid, password, 'sale.order.line', 'write', 
                                  [lineId, {'invoice_lines': [(4, inv_line_id[0])], 'invoice_status': 'invoiced'}])
                # Update sale order with invoice ID and invoice status
                models.execute_kw(db, uid, password, 'sale.order', 'write', 
                                  [[sale_order_id], {'invoice_ids': [(4, invoice_id)], 'invoice_status': 'invoiced'}])
                # Return response based on whether invoice was created or not
                if invoice_id:
                    return jsonify({'invoice_id': invoice_id, 'message':'Invoice created successfully.'}), 200
                else:
                    return jsonify({'message': 'No invoice created for the given conditions.'}), 200
        
        # If no invoice was created
        return jsonify({'message': 'No invoice created.'}), 404
        
    except Exception as e:
        print(f"An error occurred: {e}")
        return jsonify({'message': 'An error occurred while processing the request.'}), 500


0
Awatar
Odrzuć
Awatar
Jainesh Shah(Aktiv Software)
Najlepsza odpowiedź

Hi Ahmad,

invoice_id = 279777

sale_id = 16


sale_id = models.execute_kw(db, uid, password, 'sale.order', 'search_read', [[

['id', '=', 16]]], {'fields': ['order_line']})



for line in sale_id[0]['order_line']:


sale_line_id = models.execute_kw(db, uid, password, 'sale.order.line', 'search_read', [[

['id', '=', line]]], {'fields': ['product_template_id', 'product_uom_qty']})


product_id = models.execute_kw(db, uid, password, 'product.product', 'search', [[

['product_tmpl_id', '=', sale_line_id[0]['product_template_id'][0]]]])


inv_line_id = models.execute_kw(db, uid, password, 'account.move.line', 'search', [[

['product_id', '=', product_id[0]], 

['move_id', '=', 279777], 

['quantity', '=', sale_line_id[0]['product_uom_qty']]]])

if inv_line_id:

models.execute_kw(db, uid, password, 'sale.order.line', 'write', [line,

{'invoice_lines':[(4, inv_line_id[0])]}])

Regards,




Email:      odoo@aktivsoftware.com  

Skype: kalpeshmaheshwari

   

0
Awatar
Odrzuć
Podoba Ci się ta dyskusja? Dołącz do niej!

Stwórz konto dzisiaj, aby cieszyć się ekskluzywnymi funkcjami i wchodzić w interakcje z naszą wspaniałą społecznością!

Zarejestruj się
Powiązane posty Odpowiedzi Widoki Czynność
Adding Multiple products in Sales order line?
many2many sales.order
Awatar
2
gru 18
10629
(((Oficial~ C.O.P.A!@!Ecuador)))¿Cómo puedo llamar a Copa Airlines desde Ecuador?
sales.order
Awatar
0
gru 25
43
Best Way To Journal Employee Capital Investment
journal_entry
Awatar
Awatar
Awatar
2
lip 25
2532
Transform Quotations to sales orders or invoices in a bulk action
sales.order
Awatar
Awatar
Awatar
3
lut 25
3850
Orden de venta borrada por error
sales.order
Awatar
Awatar
1
gru 24
3190
Społeczność
  • Samouczki
  • Dokumentacja
  • Forum
Open Source
  • Pobierz
  • Github
  • Runbot
  • Tłumaczenia
Usługi
  • Hosting Odoo.sh
  • Wsparcie
  • Aktualizacja
  • Indywidualne rozwiązania
  • Edukacja
  • Znajdź księgowego
  • Znajdź partnera
  • Zostań partnerem
O nas
  • Nasza firma
  • Zasoby marki
  • Skontaktuj się z nami
  • Oferty pracy
  • Wydarzenia
  • Podcast
  • Blog
  • Klienci
  • Informacje prawne • Prywatność
  • Bezpieczeństwo Odoo
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español Svenska ภาษาไทย Türkçe українська Tiếng Việt

Odoo to pakiet aplikacji biznesowych typu open source, które zaspokoją wszystkie potrzeby Twojej firmy: CRM, eCommerce, księgowość, inwentaryzacja, punkt sprzedaży, zarządzanie projektami itp.

Unikalną wartością Odoo jest to, że jest jednocześnie bardzo łatwe w użyciu i w pełni zintegrowane.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now