Skip to Content
Odoo Menú
  • Registra entrada
  • Prova-ho gratis
  • Aplicacions
    Finances
    • Comptabilitat
    • Facturació
    • Despeses
    • Full de càlcul (IA)
    • Documents
    • Signatura
    Vendes
    • CRM
    • Vendes
    • Punt de venda per a botigues
    • Punt de venda per a restaurants
    • Subscripcions
    • Lloguer
    Imatges de llocs web
    • Creació de llocs web
    • Comerç electrònic
    • Blog
    • Fòrum
    • Xat en directe
    • Aprenentatge en línia
    Cadena de subministrament
    • Inventari
    • Fabricació
    • PLM
    • Compres
    • Manteniment
    • Qualitat
    Recursos humans
    • Empleats
    • Reclutament
    • Absències
    • Avaluacions
    • Recomanacions
    • Flota
    Màrqueting
    • Màrqueting Social
    • Màrqueting per correu electrònic
    • Màrqueting per SMS
    • Esdeveniments
    • Automatització del màrqueting
    • Enquestes
    Serveis
    • Projectes
    • Fulls d'hores
    • Servei de camp
    • Suport
    • Planificació
    • Cites
    Productivitat
    • Converses
    • Validacions
    • IoT
    • VoIP
    • Coneixements
    • WhatsApp
    Aplicacions de tercers Odoo Studio Plataforma d'Odoo al núvol
  • Sectors
    Comerç al detall
    • Llibreria
    • Botiga de roba
    • Botiga de mobles
    • Botiga d'ultramarins
    • Ferreteria
    • Botiga de joguines
    Food & Hospitality
    • Bar i pub
    • Restaurant
    • Menjar ràpid
    • Guest House
    • Distribuïdor de begudes
    • Hotel
    Immobiliari
    • Agència immobiliària
    • Estudi d'arquitectura
    • Construcció
    • Gestió immobiliària
    • Jardineria
    • Associació de propietaris de béns immobles
    Consultoria
    • Empresa comptable
    • Partner d'Odoo
    • Agència de màrqueting
    • Bufet d'advocats
    • Captació de talent
    • Auditoria i certificació
    Fabricació
    • Textile
    • Metal
    • Mobles
    • Menjar
    • Brewery
    • Regals corporatius
    Salut i fitness
    • Club d'esport
    • Òptica
    • Centre de fitness
    • Especialistes en benestar
    • Farmàcia
    • Perruqueria
    Trades
    • Servei de manteniment
    • Hardware i suport informàtic
    • Sistemes d'energia solar
    • Shoe Maker
    • Serveis de neteja
    • Instal·lacions HVAC
    Altres
    • Nonprofit Organization
    • Agència del medi ambient
    • Lloguer de panells publicitaris
    • Fotografia
    • Lloguer de bicicletes
    • Distribuïdors de programari
    Browse all Industries
  • Comunitat
    Aprèn
    • Tutorials
    • Documentació
    • Certificacions
    • Formació
    • Blog
    • Pòdcast
    Potenciar l'educació
    • Programa educatiu
    • Scale-Up! El joc empresarial
    • Visita Odoo
    Obtindre el programari
    • Descarregar
    • Comparar edicions
    • Novetats de les versions
    Col·laborar
    • GitHub
    • Fòrum
    • Esdeveniments
    • Traduccions
    • Converteix-te en partner
    • Services for Partners
    • Registra la teva empresa comptable
    Obtindre els serveis
    • Troba un partner
    • Troba un comptable
    • Contacta amb un expert
    • Serveis d'implementació
    • Referències del client
    • Suport
    • Actualitzacions
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Programar una demo
  • Preus
  • Ajuda

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • CRM
  • e-Commerce
  • Comptabilitat
  • Inventari
  • PoS
  • Projectes
  • MRP
All apps
You need to be registered to interact with the community.
All Posts People Badges
Etiquetes (View all)
odoo accounting v14 pos v15
About this forum
You need to be registered to interact with the community.
All Posts People Badges
Etiquetes (View all)
odoo accounting v14 pos v15
About this forum
Ajuda

How to run a Scheduled Action in Multiple Companies?

Subscriure's

Get notified when there's activity on this post

This question has been flagged
4 Respostes
6071 Vistes
Avatar
Jonah Barrett

This is in Odoo V13 enterprise.


I have a scheduled action that gets data from Customer Invoices and then creates a new invoice based off of that data. We have multiple companies in our Odoo database and I would like the scheduled action to run for each of the companies, what is the best way to do this?


Example of what I have so far:

For some reason the new invoices can be seen from all the companies and will error if it is opened from the wrong company even though it is visible.

for company in self.env["res.company"].search([]):
            # Find all the invoices from the last month
            monthly_invoices = (
                self.with_context(force_company=company.id)
                .env["account.move"]
                .sudo()
                .search(
                    [
                        ...
                        ("company_id.id", "=", company.id),
                    ]
                )
            )
            groups = ...
            # Create the new invoices from the groups
            for customer, invoices in groups.items():
                if invoices:  # Must have invoices
                    new_invoice = (
                        self.with_context(force_company=company.id)
                        .env["account.move"]
                        .sudo()
                        .create(
                            {
                                ...
                                "company_id": company.id,
                            }
                        )
                    )
0
Avatar
Descartar
Sehrish

Hint: http://learnopenerp.blogspot.com/2020/05/how-to-create-scheduled-action-in-odoo.html

Jonah Barrett
Autor

That does not help with my issue, this is code already run by a scheduled action. My issue isn't that I don't know how to create a scheduled action but I don't know the best way for a scheduled action to affect records in multiple companies cleanly.

Avatar
Jonah Barrett
Autor Best Answer

I believe I figured it out, I am not sure if this is the best way to go about this but it seems to work fine.

To make it clear, I will break it down a bit further here.

The Initial Problem

I have multiple companies set up in Odoo and I want to run a scheduled action that will apply to each company. The issue was that if I set the user in the scheduled action to OdooBot (user 1) it had the context of company 1, and only company 1.


Running the scheduled action as OdooBot will give access to records from all companies. This is perfect for reading information from records but extra steps will have to be taken to write to specific companies.


The Solution

This is inside the method that the scheduled action calls, I can give more details to the scheduled action and the code not found below on request.


def scheduled_action_method(self):
    for company in self.env['res.company'].search([]):    
        company_env = self.env.with_context(force_company=company.id)                           searched_recordset = company_env.search([...])                           new_record = company_env.write({..})

This is code is meant to show the principle, I can share my actual code here as well if it would be beneficial to someone.

If anyone has any suggestions on how this could be improved, let me know.

Thanks

3
Avatar
Descartar
Avatar
Roland van Eeden
Best Answer

Another solution is to change the field 'Scheduled User' to 'OdooBot' (you can only change this field by export and import).

OdooBot can access all data of all the companies, so that the scheduled action should be applied to all the companies.

It worked for me to extract info from sale orders of different companies. 

2
Avatar
Descartar
Enjoying the discussion? Don't just read, join in!

Create an account today to enjoy exclusive features and engage with our awesome community!

Registrar-se
Community
  • Tutorials
  • Documentació
  • Fòrum
Codi obert
  • Descarregar
  • GitHub
  • Runbot
  • Traduccions
Serveis
  • Allotjament a Odoo.sh
  • Suport
  • Actualització
  • Desenvolupaments personalitzats
  • Educació
  • Troba un comptable
  • Troba un partner
  • Converteix-te en partner
Sobre nosaltres
  • La nostra empresa
  • Actius de marca
  • Contacta amb nosaltres
  • Llocs de treball
  • Esdeveniments
  • Pòdcast
  • Blog
  • Clients
  • Informació legal • Privacitat
  • Seguretat
الْعَرَبيّة 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 ภาษาไทย Türkçe українська Tiếng Việt

Odoo és un conjunt d'aplicacions empresarials de codi obert que cobreix totes les necessitats de la teva empresa: CRM, comerç electrònic, comptabilitat, inventari, punt de venda, gestió de projectes, etc.

La proposta única de valor d'Odoo és ser molt fàcil d'utilitzar i estar totalment integrat, ambdues alhora.

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