Skip to Content
Odoo Meniu
  • Autentificare
  • Try it free
  • Aplicații
    Finanțe
    • Contabilitate
    • Facturare
    • Cheltuieli
    • Spreadsheet (BI)
    • Documente
    • Semn
    Vânzări
    • CRM
    • Vânzări
    • POS Shop
    • POS Restaurant
    • Abonamente
    • Închiriere
    Site-uri web
    • Constructor de site-uri
    • eCommerce
    • Blog
    • Forum
    • Live Chat
    • eLearning
    Lanț Aprovizionare
    • Inventar
    • Producție
    • PLM
    • Achiziție
    • Maintenance
    • Calitate
    Resurse Umane
    • Angajați
    • Recrutare
    • Time Off
    • Evaluări
    • Referințe
    • Flotă
    Marketing
    • Social Marketing
    • Marketing prin email
    • SMS Marketing
    • Evenimente
    • Automatizare marketing
    • Sondaje
    Servicii
    • Proiect
    • Foi de pontaj
    • Servicii de teren
    • Centru de asistență
    • Planificare
    • Programări
    Productivitate
    • Discuss
    • Aprobări
    • IoT
    • VoIP
    • Knowledge
    • WhatsApp
    Aplicații Terțe Odoo Studio Platforma Odoo Cloud
  • Industrii
    Retail
    • Book Store
    • Magazin de îmbrăcăminte
    • Magazin de Mobilă
    • Magazin alimentar
    • Magazin de materiale de construcții
    • Magazin de jucării
    Food & Hospitality
    • Bar and Pub
    • Restaurant
    • Fast Food
    • Guest House
    • Distribuitor de băuturi
    • Hotel
    Proprietate imobiliara
    • Real Estate Agency
    • Firmă de Arhitectură
    • Construcție
    • Estate Managament
    • Grădinărit
    • Asociația Proprietarilor de Proprietăți
    Consultanta
    • Firma de Contabilitate
    • Partener Odoo
    • Agenție de marketing
    • Law firm
    • Atragere de talente
    • Audit & Certification
    Producție
    • Textil
    • Metal
    • Mobilier
    • Mâncare
    • Brewery
    • Cadouri corporate
    Health & Fitness
    • Club Sportiv
    • Magazin de ochelari
    • Centru de Fitness
    • Wellness Practitioners
    • Farmacie
    • Salon de coafură
    Trades
    • Handyman
    • IT Hardware and Support
    • Asigurare socială de stat
    • Cizmar
    • Servicii de curățenie
    • HVAC Services
    Altele
    • Organizație nonprofit
    • Agenție de Mediu
    • Închiriere panouri publicitare
    • Fotografie
    • Închiriere biciclete
    • Asigurare socială
    Browse all Industries
  • Comunitate
    Învăță
    • Tutorials
    • Documentație
    • Certificări
    • Instruire
    • Blog
    • Podcast
    Empower Education
    • Program Educațional
    • Scale Up! Business Game
    • Visit Odoo
    Obține Software-ul
    • Descărcare
    • Compară Edițiile
    • Lansări
    Colaborați
    • Github
    • Forum
    • Evenimente
    • Translations
    • Devino Partener
    • Services for Partners
    • Înregistrează-ți Firma de Contabilitate
    Obține Servicii
    • Găsește un Partener
    • Găsiți un contabil
    • Meet an advisor
    • Servicii de Implementare
    • Referințe ale clienților
    • Suport
    • Actualizări
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Obține un demo
  • Prețuri
  • Ajutor

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

  • CRM
  • e-Commerce
  • Contabilitate
  • Inventar
  • PoS
  • Proiect
  • MRP
All apps
Trebuie să fiți înregistrat pentru a interacționa cu comunitatea.
All Posts Oameni Insigne
Etichete (View all)
odoo accounting v14 pos v15
Despre acest forum
Trebuie să fiți înregistrat pentru a interacționa cu comunitatea.
All Posts Oameni Insigne
Etichete (View all)
odoo accounting v14 pos v15
Despre acest forum
Suport

How to access Worksheet details via JSON RPC API

Abonare

Primiți o notificare când există activitate la acestă postare

Această întrebare a fost marcată
projectapitaskproject.task
2 Răspunsuri
2447 Vizualizări
Imagine profil
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
Imagine profil
Abandonează
Imagine profil
Jimi
Autor Cel mai bun răspuns

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

0
Imagine profil
Abandonează
Imagine profil
Christoph Farnleitner
Cel mai bun răspuns

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
Imagine profil
Abandonează
Enjoying the discussion? Don't just read, join in!

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

Înscrie-te
Related Posts Răspunsuri Vizualizări Activitate
Show tasks in kanban view of the project module
project task kanban project.task
Imagine profil
Imagine profil
1
feb. 22
3692
How to hide sub task from clients
project task tasks project.task
Imagine profil
0
mai 21
2902
v16 Tasks visibility
project task
Imagine profil
Imagine profil
1
iun. 23
4216
Create a user who can only see project and task menu Rezolvat
project task
Imagine profil
Imagine profil
1
nov. 22
4644
How to update the progress in the tasks in project Rezolvat
project task projects project.task project task
Imagine profil
Imagine profil
1
oct. 22
3424
Comunitate
  • Tutorials
  • Documentație
  • Forum
Open Source
  • Descărcare
  • Github
  • Runbot
  • Translations
Servicii
  • Hosting Odoo.sh
  • Suport
  • Actualizare
  • Custom Developments
  • Educație
  • Găsiți un contabil
  • Găsește un Partener
  • Devino Partener
Despre Noi
  • Compania noastră
  • Active de marcă
  • Contactați-ne
  • Locuri de muncă
  • Evenimente
  • Podcast
  • Blog
  • Clienți
  • Aspecte juridice • Confidențialitate
  • Securitate
الْعَرَبيّة 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 este o suită de aplicații de afaceri open source care acoperă toate nevoile companiei dvs.: CRM, comerț electronic, contabilitate, inventar, punct de vânzare, management de proiect etc.

Propunerea de valoare unică a Odoo este să fie în același timp foarte ușor de utilizat și complet integrat.

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