Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
30942f6
[ADD] attachment_unindex_content: Module to disable file indexation
ebirbe Oct 29, 2019
a68a0da
[UPD] Update attachment_unindex_content.pot
oca-travis Nov 1, 2019
ee9b9da
[ADD] icon.png
OCA-git-bot Nov 1, 2019
b200e5c
[IMP] attachment_unindex_content: black, isort, prettier
randall-vx Jul 3, 2021
34e8013
[MIG] attachment_unindex_content: Migration to 13.0
randall-vx Jul 3, 2021
7b3b1d9
[UPD] Update attachment_unindex_content.pot
oca-travis Jul 7, 2021
3f12ba1
[UPD] README.rst
OCA-git-bot Jul 7, 2021
cfc03b8
[MIG] attachment_unindex_content: Migration to 14.0
randall-vx Jul 13, 2021
b923205
[UPD] Update attachment_unindex_content.pot
oca-travis Jul 27, 2021
3d95dba
[UPD] README.rst
OCA-git-bot Jul 27, 2021
996b07a
Added translation using Weblate (Catalan)
ofonseca-pyming Feb 14, 2022
99a599a
Added translation using Weblate (Spanish (Argentina))
ibuioli Mar 27, 2022
16f07c1
Translated using Weblate (Spanish (Argentina))
ibuioli Mar 27, 2022
9f6baec
[FIX] attachment_unindex_content: unsupported param on _index method
luisg123v Sep 28, 2022
f7c7237
[UPD] README.rst
OCA-git-bot Sep 28, 2022
3117ca1
attachment_unindex_content 14.0.1.0.1
OCA-git-bot Sep 28, 2022
abd9ede
[MIG] attachment_unindex_content: Migration to 16.0
Rodrigosu-Vauxoo Feb 23, 2023
62eb515
[UPD] Update attachment_unindex_content.pot
Mar 2, 2023
c480782
[UPD] README.rst
OCA-git-bot Mar 2, 2023
a8d8dc8
Update translation files
weblate Mar 2, 2023
5a6b253
[UPD] README.rst
OCA-git-bot Sep 3, 2023
7eec46e
Update translation files
weblate Oct 9, 2023
8c17f46
Added translation using Weblate (Spanish)
Ivorra78 Dec 7, 2023
3319b35
Translated using Weblate (Spanish)
Ivorra78 Dec 7, 2023
bd663cc
Added translation using Weblate (Italian)
mymage Jan 2, 2024
0866034
Translated using Weblate (Italian)
mymage Jan 2, 2024
eab205a
[IMP] attachment_unindex_content: pre-commit auto fixes
Kimkhoi3010 Oct 7, 2024
14270a8
[MIG] attachment_unindex_content: Migration to 18.0
Kimkhoi3010 Oct 7, 2024
2a8f523
[UPD] Update attachment_unindex_content.pot
Nov 28, 2024
94d13d1
[BOT] post-merge updates
OCA-git-bot Nov 28, 2024
6d2fb1c
[IMP] attachment_unindex_content: pre-commit auto fixes
moylop260 Feb 12, 2026
60a1f97
[19.0][MIG] attachment_unindex_content: Migration to 19.0.
moylop260 Feb 12, 2026
d563ede
[REF] attachment_unindex_content: Add unittest
moylop260 Feb 13, 2026
6e52974
[FIX] attachment_unindex_content: Add missing `attachment_indexation`…
moylop260 Feb 13, 2026
33e67a4
[IMP] attachment_unindex_content: Update only rows with null values
moylop260 Feb 13, 2026
14f4266
[REF] checklog-odoo: Suppress noisy WARNING from attachment_indexatio…
moylop260 Feb 13, 2026
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
135 changes: 135 additions & 0 deletions attachment_unindex_content/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,135 @@
.. image:: https://odoo-community.org/readme-banner-image
:target: https://odoo-community.org/get-involved?utm_source=readme
:alt: Odoo Community Association

==========================
Attachment Unindex Content
==========================

..
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! This file is generated by oca-gen-addon-readme !!
!! changes will be overwritten. !!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! source digest: sha256:ac1a360bceb47e15c6cc5ae92a37b94fa4fbfbcbbd53fd45c7333d5e845d5294
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png
:target: https://odoo-community.org/page/development-status
:alt: Beta
.. |badge2| image:: https://img.shields.io/badge/license-AGPL--3-blue.png
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fserver--tools-lightgray.png?logo=github
:target: https://github.com/OCA/server-tools/tree/19.0/attachment_unindex_content
:alt: OCA/server-tools
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
:target: https://translation.odoo-community.org/projects/server-tools-19-0/server-tools-19-0-attachment_unindex_content
:alt: Translate me on Weblate
.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png
:target: https://runboat.odoo-community.org/builds?repo=OCA/server-tools&target_branch=19.0
:alt: Try me on Runboat

|badge1| |badge2| |badge3| |badge4| |badge5|

This module disables the indexation of attachments content.

Attachment model has a field called 'index_content' where the content of
the attachment is read and stored directly in the database. This field
is useful in order to search content of a file. But most of cases it is
not used, so, you can install this module in order to:

- **Avoid Duplicating Data:** Because indexation extracts text content
from files and put it on the database in order it could be searched,
but this implies you have the file data in your ``filestore``
directory, and also part (or sometimes all) of that data in your
database too.
- **Improve Performance:** Since not all indexed files are plain text,
they require extra process to read them.

Maybe you could try to uninstall modules like ``document`` in order to
disable its indexation features, but you could face the uninstallation
of other modules that could be useful for you (e.g, ``hr_recruitment``
depends on that).

But even if you don't have ``document`` installed, you'd still have
plain text content indexation by default. As you can see in this SQL
query results, indexation is active even without it:

|SQL Query result showing indexed content|

Using this module you will not require to uninstall any module to
disable the attachment content indexation, because we directly disable
it at ``ir.attachment`` base.

Also, after the installation, the ``index_content`` field on attachments
already recorded in database will be cleared.

.. |SQL Query result showing indexed content| image:: https://user-images.githubusercontent.com/442938/67894113-45d27a80-fb2e-11e9-9a22-ba43d8b444c5.png
:target: https://user-images.githubusercontent.com/442938/67894113-45d27a80-fb2e-11e9-9a22-ba43d8b444c5.png

**Table of contents**

.. contents::
:local:

Bug Tracker
===========

Bugs are tracked on `GitHub Issues <https://github.com/OCA/server-tools/issues>`_.
In case of trouble, please check there if your issue has already been reported.
If you spotted it first, help us to smash it by providing a detailed and welcomed
`feedback <https://github.com/OCA/server-tools/issues/new?body=module:%20attachment_unindex_content%0Aversion:%2019.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_.

Do not contact contributors directly about support or help with technical issues.

Credits
=======

Authors
-------

* Vauxoo

Contributors
------------

- Moises López <moylop260@vauxoo.com>
- Erick Birbe <erick@vauxoo.com>
- Khoi (Kien Kim) <khoikk@trobz.com>

Other credits
-------------



Maintainers
-----------

This module is maintained by the OCA.

.. image:: https://odoo-community.org/logo.png
:alt: Odoo Community Association
:target: https://odoo-community.org

OCA, or the Odoo Community Association, is a nonprofit organization whose
mission is to support the collaborative development of Odoo features and
promote its widespread use.

.. |maintainer-moylop260| image:: https://github.com/moylop260.png?size=40px
:target: https://github.com/moylop260
:alt: moylop260
.. |maintainer-ebirbe| image:: https://github.com/ebirbe.png?size=40px
:target: https://github.com/ebirbe
:alt: ebirbe
.. |maintainer-luisg123v| image:: https://github.com/luisg123v.png?size=40px
:target: https://github.com/luisg123v
:alt: luisg123v

Current `maintainers <https://odoo-community.org/page/maintainer-role>`__:

|maintainer-moylop260| |maintainer-ebirbe| |maintainer-luisg123v|

This module is part of the `OCA/server-tools <https://github.com/OCA/server-tools/tree/19.0/attachment_unindex_content>`_ project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
2 changes: 2 additions & 0 deletions attachment_unindex_content/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
from . import models
from .hooks import post_init_hook
19 changes: 19 additions & 0 deletions attachment_unindex_content/__manifest__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
# © 2019 Vauxoo (<http://www.vauxoo.com/>)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).

{
"name": "Attachment Unindex Content",
"summary": "Disable indexing of attachments",
"version": "19.0.1.0.0",
"author": "Vauxoo, Odoo Community Association (OCA)",
"website": "https://github.com/OCA/server-tools",
"maintainers": [
"moylop260",
"ebirbe",
"luisg123v",
],
"license": "AGPL-3",
"category": "Tools",
"depends": ["attachment_indexation"],
"post_init_hook": "post_init_hook",
}
8 changes: 8 additions & 0 deletions attachment_unindex_content/hooks.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
def post_init_hook(env):
"""Clear the indexed data for records already in database"""
env.cr.execute(
"""
UPDATE ir_attachment SET index_content=NULL
WHERE index_content IS NOT NULL
"""
)
31 changes: 31 additions & 0 deletions attachment_unindex_content/i18n/attachment_unindex_content.pot
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * attachment_unindex_content
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 19.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2026-02-13 04:26+0000\n"
"PO-Revision-Date: 2026-02-13 04:26+0000\n"
"Last-Translator: \n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"

#. module: attachment_unindex_content
#: model:ir.model,name:attachment_unindex_content.model_ir_attachment
msgid "Attachment"
msgstr ""

#. module: attachment_unindex_content
#: model:ir.model.fields,field_description:attachment_unindex_content.field_ir_attachment__display_name
msgid "Display Name"
msgstr ""

#. module: attachment_unindex_content
#: model:ir.model.fields,field_description:attachment_unindex_content.field_ir_attachment__id
msgid "ID"
msgstr ""
31 changes: 31 additions & 0 deletions attachment_unindex_content/i18n/ca.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * attachment_unindex_content
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 14.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2026-02-13 04:26+0000\n"
"Last-Translator: Automatically generated\n"
"Language-Team: none\n"
"Language: ca\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: nplurals=2; plural=n != 1;\n"

#. module: attachment_unindex_content
#: model:ir.model,name:attachment_unindex_content.model_ir_attachment
msgid "Attachment"
msgstr ""

#. module: attachment_unindex_content
#: model:ir.model.fields,field_description:attachment_unindex_content.field_ir_attachment__display_name
msgid "Display Name"
msgstr ""

#. module: attachment_unindex_content
#: model:ir.model.fields,field_description:attachment_unindex_content.field_ir_attachment__id
msgid "ID"
msgstr ""
33 changes: 33 additions & 0 deletions attachment_unindex_content/i18n/es.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * attachment_unindex_content
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 16.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2026-02-13 04:26+0000\n"
"PO-Revision-Date: 2023-12-07 18:34+0000\n"
"Last-Translator: Ivorra78 <informatica@totmaterial.es>\n"
"Language-Team: none\n"
"Language: es\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: nplurals=2; plural=n != 1;\n"
"X-Generator: Weblate 4.17\n"

#. module: attachment_unindex_content
#: model:ir.model,name:attachment_unindex_content.model_ir_attachment
msgid "Attachment"
msgstr "Archivo Adjunto"

#. module: attachment_unindex_content
#: model:ir.model.fields,field_description:attachment_unindex_content.field_ir_attachment__display_name
msgid "Display Name"
msgstr ""

#. module: attachment_unindex_content
#: model:ir.model.fields,field_description:attachment_unindex_content.field_ir_attachment__id
msgid "ID"
msgstr ""
33 changes: 33 additions & 0 deletions attachment_unindex_content/i18n/es_AR.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * attachment_unindex_content
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 14.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2026-02-13 04:26+0000\n"
"PO-Revision-Date: 2022-03-28 01:17+0000\n"
"Last-Translator: Ignacio Buioli <ibuioli@gmail.com>\n"
"Language-Team: none\n"
"Language: es_AR\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: nplurals=2; plural=n != 1;\n"
"X-Generator: Weblate 4.3.2\n"

#. module: attachment_unindex_content
#: model:ir.model,name:attachment_unindex_content.model_ir_attachment
msgid "Attachment"
msgstr "Adjunto"

#. module: attachment_unindex_content
#: model:ir.model.fields,field_description:attachment_unindex_content.field_ir_attachment__display_name
msgid "Display Name"
msgstr "Mostrar Nombre"

#. module: attachment_unindex_content
#: model:ir.model.fields,field_description:attachment_unindex_content.field_ir_attachment__id
msgid "ID"
msgstr ""
33 changes: 33 additions & 0 deletions attachment_unindex_content/i18n/it.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * attachment_unindex_content
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 16.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2026-02-13 04:26+0000\n"
"PO-Revision-Date: 2024-01-02 16:34+0000\n"
"Last-Translator: mymage <stefano.consolaro@mymage.it>\n"
"Language-Team: none\n"
"Language: it\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: nplurals=2; plural=n != 1;\n"
"X-Generator: Weblate 4.17\n"

#. module: attachment_unindex_content
#: model:ir.model,name:attachment_unindex_content.model_ir_attachment
msgid "Attachment"
msgstr "Allegato"

#. module: attachment_unindex_content
#: model:ir.model.fields,field_description:attachment_unindex_content.field_ir_attachment__display_name
msgid "Display Name"
msgstr ""

#. module: attachment_unindex_content
#: model:ir.model.fields,field_description:attachment_unindex_content.field_ir_attachment__id
msgid "ID"
msgstr ""
1 change: 1 addition & 0 deletions attachment_unindex_content/models/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from . import ir_attachment
12 changes: 12 additions & 0 deletions attachment_unindex_content/models/ir_attachment.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
# 2019 Vauxoo (<http://www.vauxoo.com/>)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).

from odoo import api, models


class IrAttachment(models.Model):
_inherit = "ir.attachment"

@api.model
def _index(self, *args, **kwargs):
return False
3 changes: 3 additions & 0 deletions attachment_unindex_content/pyproject.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
[build-system]
requires = ["whool"]
build-backend = "whool.buildapi"
3 changes: 3 additions & 0 deletions attachment_unindex_content/readme/CONTRIBUTORS.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
- Moises López \<<moylop260@vauxoo.com>\>
- Erick Birbe \<<erick@vauxoo.com>\>
- Khoi (Kien Kim) \<<khoikk@trobz.com>\>
Empty file.
31 changes: 31 additions & 0 deletions attachment_unindex_content/readme/DESCRIPTION.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
This module disables the indexation of attachments content.

Attachment model has a field called 'index_content' where the content of
the attachment is read and stored directly in the database. This field
is useful in order to search content of a file. But most of cases it is
not used, so, you can install this module in order to:

- **Avoid Duplicating Data:** Because indexation extracts text content
from files and put it on the database in order it could be searched,
but this implies you have the file data in your `filestore` directory,
and also part (or sometimes all) of that data in your database too.
- **Improve Performance:** Since not all indexed files are plain text,
they require extra process to read them.

Maybe you could try to uninstall modules like `document` in order to
disable its indexation features, but you could face the uninstallation
of other modules that could be useful for you (e.g, `hr_recruitment`
depends on that).

But even if you don't have `document` installed, you'd still have plain
text content indexation by default. As you can see in this SQL query
results, indexation is active even without it:

[![SQL Query result showing indexed content](https://user-images.githubusercontent.com/442938/67894113-45d27a80-fb2e-11e9-9a22-ba43d8b444c5.png)](https://user-images.githubusercontent.com/442938/67894113-45d27a80-fb2e-11e9-9a22-ba43d8b444c5.png)

Using this module you will not require to uninstall any module to
disable the attachment content indexation, because we directly disable
it at `ir.attachment` base.

Also, after the installation, the `index_content` field on attachments
already recorded in database will be cleared.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading