Passa al contenuto
Odoo Menu
  • Accedi
  • Provalo gratis
  • App
    Finanze
    • Contabilità
    • Fatturazione
    • Note spese
    • Fogli di calcolo (BI)
    • Documenti
    • Firma
    Vendite
    • CRM
    • Vendite
    • Punto vendita Negozio
    • Punto vendita Ristorante
    • Abbonamenti
    • Noleggi
    Siti web
    • Configuratore sito web
    • E-commerce
    • Blog
    • Forum
    • Live chat
    • E-learning
    Supply chain
    • Magazzino
    • Produzione
    • PLM
    • Acquisti
    • Manutenzione
    • Qualità
    Risorse umane
    • Dipendenti
    • Assunzioni
    • Ferie
    • Valutazioni
    • Referral dipendenti
    • Parco veicoli
    Marketing
    • Social marketing
    • E-mail marketing
    • SMS marketing
    • Eventi
    • Marketing automation
    • Sondaggi
    Servizi
    • Progetti
    • Fogli ore
    • Assistenza sul campo
    • Helpdesk
    • Pianificazione
    • Appuntamenti
    Produttività
    • Comunicazioni
    • Approvazioni
    • IoT
    • VoIP
    • Knowledge
    • WhatsApp
    App di terze parti Odoo Studio Piattaforma cloud Odoo
  • Settori
    Retail
    • Libreria
    • Negozio di abbigliamento
    • Negozio di arredamento
    • Alimentari
    • Ferramenta
    • Negozio di giocattoli
    Cibo e ospitalità
    • Bar e pub
    • Ristorante
    • Fast food
    • Pensione
    • Grossista di bevande
    • Hotel
    Agenzia immobiliare
    • Agenzia immobiliare
    • Studio di architettura
    • Edilizia
    • Gestione immobiliare
    • Impresa di giardinaggio
    • Associazione di proprietari immobiliari
    Consulenza
    • Società di contabilità
    • Partner Odoo
    • Agenzia di marketing
    • Studio legale
    • Selezione del personale
    • Audit e certificazione
    Produzione
    • Tessile
    • Metallo
    • Arredamenti
    • Alimentare
    • Birrificio
    • Ditta di regalistica aziendale
    Benessere e sport
    • Club sportivo
    • Negozio di ottica
    • Centro fitness
    • Centro benessere
    • Farmacia
    • Parrucchiere
    Commercio
    • Tuttofare
    • Hardware e assistenza IT
    • Ditta di installazione di pannelli solari
    • Calzolaio
    • Servizi di pulizia
    • Servizi di climatizzazione
    Altro
    • Organizzazione non profit
    • Ente per la tutela ambientale
    • Agenzia di cartellonistica pubblicitaria
    • Studio fotografico
    • Punto noleggio di biciclette
    • Rivenditore di software
    Carica tutti i settori
  • Community
    Apprendimento
    • Tutorial
    • Documentazione
    • Certificazioni 
    • Formazione
    • Blog
    • Podcast
    Potenzia la tua formazione
    • Programma educativo
    • Scale Up! Business Game
    • Visita Odoo
    Ottieni il software
    • Scarica
    • Versioni a confronto
    • Note di versione
    Collabora
    • Github
    • Forum
    • Eventi
    • Traduzioni
    • Diventa nostro partner
    • Servizi per partner
    • Registra la tua società di contabilità
    Ottieni servizi
    • Trova un partner
    • Trova un contabile
    • Incontra un esperto
    • Servizi di implementazione
    • Testimonianze dei clienti
    • Supporto
    • Aggiornamenti
    GitHub Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Richiedi una demo
  • Prezzi
  • Aiuto

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

  • CRM
  • e-Commerce
  • Contabilità
  • Magazzino
  • PoS
  • Progetti
  • MRP
All apps
È necessario essere registrati per interagire con la community.
Tutti gli articoli Persone Badge
Etichette (Mostra tutto)
odoo accounting v14 pos v15
Sul forum
È necessario essere registrati per interagire con la community.
Tutti gli articoli Persone Badge
Etichette (Mostra tutto)
odoo accounting v14 pos v15
Sul forum
Assistenza

How to access Worksheet details via JSON RPC API

Iscriviti

Ricevi una notifica quando c'è un'attività per questo post

La domanda è stata contrassegnata
projectapitaskproject.task
2 Risposte
2494 Visualizzazioni
Avatar
Jimi

Hello,

I'm currently building a pipeline to integrate Odoo with one of my services. As part of this, I need to access the content of the worksheet linked to a project task.

I've been exploring the JSON-RPC API, but I’m having trouble retrieving the actual content of the worksheet. So far, I can only retrieve the worksheet template, its ID, and the count — but not the detailed content (e.g., text fields or values entered in the worksheet by users).

My goal is to add a button on the task dashboard that triggers a webhook. This webhook should launch an API call to retrieve all relevant task information, including the associated worksheet content.

Has anyone done something similar or knows how to access the worksheet data through the API?

Thanks in advance!

0
Avatar
Abbandona
Avatar
Jimi
Autore Risposta migliore

Thank you for the help. I manage to figure it out

0
Avatar
Abbandona
Avatar
Christoph Farnleitner
Risposta migliore

Depends on what worksheet data means exactly.

If you're talking about the fields defined within a worksheet, you'll have to go for ir.model.fields. If you're after the actual data entered into such a worksheet, you have to go for 'that worksheet model'.

A working example for both cases:

import xmlrpc.client

url = 'https://subdomain.odoo.com'
db = 'dbname'
username = 'username'
password = 'password'

# Worksheet Templates are defined on Projects (project.project)
# and can be overridden on Tasks (project.task).
# Below example just goes by the task, but the same concept can
# be applied to project.project worksheet_template_id as well.
_task_id = 42

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

# optional: perform additional search within the known task(s)
task_id = models.execute_kw(db, uid, password, 'project.task', 'search', [[['id', '=', _task_id]]])
print(f'task_id: {task_id}')
# result:
# task_id: [42]

# read the task data and receive 'fields' - here we're interested
# in the worksheet_template_id assigned to that task:
tasks = models.execute_kw(db, uid, password, 'project.task', 'read', [task_id], {'fields': ['worksheet_template_id']})
print(f'tasks: {tasks}')
# result:
# tasks: [{'id': 42, 'worksheet_template_id':
# [1, 'Default Worksheet']}]

# optional: perform additional search within the known worksheet
# templates; in case you've been searching for multiple tasks
# and have receveived multiple worksheet templates. at the end
# it just boils down to whether or not you want to / need to
# apply list comprehensions; for the sake of simplicity i'm just
# looking for the first worksheet template received:
worksheet_template_id = models.execute_kw(db, uid, password, 'worksheet.template', 'search', [[['id', '=', tasks[0].get('worksheet_template_id')[0]]]])
print(f'worksheet_template_id: {worksheet_template_id}')
# result:
# worksheet_template_id: [1]

# read the worksheet template data and receive 'fields' - here
# we're interested in the model_id. this is the model
# (ir.model record) that actually holds all the fields defined:
worksheet_templates = models.execute_kw(db, uid, password, 'worksheet.template', 'read', [worksheet_template_id], {'fields': ['model_id']})
print(f'worksheet_templates: {worksheet_templates}')
# result:
# worksheet_templates: [{'id': 1, 'model_id':
# [714, 'Default Worksheet']}]

# search for the fields assigned to that model:
worksheet_template_field_ids = models.execute_kw(db, uid, password, 'ir.model.fields', 'search', [[['model_id', '=', worksheet_templates[0].get('model_id')[0]]]])
print(f'worksheet_template_field_ids: {worksheet_template_field_ids}')
# result:
# worksheet_template_field_ids: [9922, 9921, 9920, 9919, 9924,
# 9923, 9917, 9918, 9916, 12565]

# read the fields data and receive 'fields' - this is just a
# reduced example returning only the name of the fields.
# highly depends on what information of the field definition
# your're interested in:
worksheet_template_fields = models.execute_kw(db, uid, password, 'ir.model.fields', 'read', [worksheet_template_field_ids], {'fields': ['name']})
print(f'worksheet_template_fields: {worksheet_template_fields}')
# result:
# worksheet_template_fields: [{'id': 9922, 'name': 'create_date'},
# {'id': 9921, 'name': 'create_uid'},
# {'id': 9920, 'name': 'display_name'},
# {'id': 9919, 'name': 'id'},
# {'id': 9924, 'name': 'write_date'},
# {'id': 9923, 'name': 'write_uid'},
# {'id': 9917, 'name': 'x_comments'},
# {'id': 9918, 'name': 'x_name'},
# {'id': 9916, 'name': 'x_project_task_id'},
# {'id': 12565, 'name': 'x_studio_a_field'}]

# now, since we know the worksheet template and the task, we
# can search for the actually filled up worksheet; again,
# limit the search if and as necessary:
filled_worksheet_ids = models.execute_kw(db, uid, password, 'x_project_task_worksheet_template_1', 'search', [[['x_project_task_id', '=', tasks[0].get('id')]]])
print(filled_worksheet_ids: {filled_worksheet_ids}')
# result:
# filled_worksheet_ids: [1]

# finally, fetch the user input for the worksheet:
worksheet_field_values = models.execute_kw(db, uid, password, 'x_project_task_worksheet_template_1', 'read', [filled_worksheet_ids])
print(f'worksheet_field_values: {worksheet_field_values}')
# result:
# worksheet_field_value_ids: [{'id': 1, 'display_name':
# 'S00001 - Installation',
# 'create_uid': [2, 'Administrator'],
# 'create_date': '2025-06-23 21:20:13',
# 'write_uid': [2, 'Administrator'],
# 'write_date': '2025-06-23 21:20:13',
# 'x_studio_a_field': 'a user input',
# 'x_project_task_id': [
# 3, 'S00001 - Installation'],
# 'x_comments': '<p>some random comment
# entered in the worksheet</p>',
# 'x_name': 'S00001 - Installation'}]


Please note that this is an example and not a production-ready setup. It is supposed to showcases how worksheet data is linked to a task.
You definitely want to make sure that errors, missing or empty values/records etc. are handled appropriately (and double-check in case I've mixed up a id with a template-id).


As a summary:

  1. get the Worksheet Template for the Project Task
  2. find the actual model and fields defining the Worksheet Template
  3. get the user input from the worksheet


0
Avatar
Abbandona
Ti stai godendo la conversazione? Non leggere soltanto, partecipa anche tu!

Crea un account oggi per scoprire funzionalità esclusive ed entrare a far parte della nostra fantastica community!

Registrati
Post correlati Risposte Visualizzazioni Attività
Show tasks in kanban view of the project module
project task kanban project.task
Avatar
Avatar
1
feb 22
3703
How to hide sub task from clients
project task tasks project.task
Avatar
0
mag 21
2910
v16 Tasks visibility
project task
Avatar
Avatar
1
giu 23
4219
Create a user who can only see project and task menu Risolto
project task
Avatar
Avatar
1
nov 22
4646
How to update the progress in the tasks in project Risolto
project task projects project.task project task
Avatar
Avatar
1
ott 22
3440
Community
  • Tutorial
  • Documentazione
  • Forum
Open source
  • Scarica
  • Github
  • Runbot
  • Traduzioni
Servizi
  • Hosting Odoo.sh
  • Supporto
  • Aggiornamenti
  • Sviluppi personalizzati
  • Formazione
  • Trova un contabile
  • Trova un partner
  • Diventa nostro partner
Chi siamo
  • La nostra azienda
  • Branding
  • Contattaci
  • Lavora con noi
  • Eventi
  • Podcast
  • Blog
  • Clienti
  • Note legali • Privacy
  • Sicurezza
الْعَرَبيّة 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 è un gestionale di applicazioni aziendali open source pensato per coprire tutte le esigenze della tua azienda: CRM, Vendite, E-commerce, Magazzino, Produzione, Fatturazione elettronica, Project Management e molto altro.

Il punto di forza di Odoo è quello di offrire un ecosistema unico di app facili da usare, intuitive e completamente integrate tra loro.

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