Skip to main content

Product classification and attribute constraints

Project description

Odoo Community Association

Product Class

Beta License: AGPL-3 OCA/product-attribute Translate me on Weblate Try me on Runboat

Product Class

This module introduces Product Classes for standardizing product setup and attribute management. It allows you to:

  1. Define Product Classes — Group related products into classes (e.g., “Furniture”, “Electronics”)

  2. Constrain Attributes per Class — Specify which attributes are allowed for each class

  3. Mark Required Attributes — Designate certain attributes as mandatory for products in that class

  4. Enforce Validation — Prevent products from using attributes outside their class or missing required attributes

Key Features

  • Bridge Model (``product.class.attribute.line``) — Manages the relationship between classes and attributes, storing both allowed attributes and a required flag

  • Strict Validation — Products assigned to a class must:

    • Use only attributes defined in that class

    • Provide values for all required attributes

  • UI Enforcement — Attribute selection in product forms is restricted by the class domain filter

  • Management Views — Full CRUD interface for product classes (Inventory > Configuration > Product Classes, Sales > Configuration > Product Classes)

Technical Architecture

  • product.class — Main product classification model

  • product.class.attribute.line — Bridge model linking classes to attributes with a required flag

  • product.attribute (inherited) — Extended with reverse one-to-many to track which classes use it

  • product.template (inherited) — Added class validation and computed required-attribute tracking

Table of contents

Usage

Usage

1. Create a Product Class

Navigation: Inventory → Configuration → Product Classes (or Sales → Configuration → Product Classes)

  1. Click Create button

  2. Enter a Product Class Name (e.g., “Chairs”)

  3. In the Attributes section:

    • Click Add a line

    • Select an Attribute from the dropdown

    • Check Required if products of this class must define this attribute

    • Repeat to add more attributes

  4. Click Save

Example: “Furniture” Class

Attribute

Required

Notes

Color

All furniture must have a color

Size

Sizes vary by product

Material

Optional (not all items specify)

Finish

Optional polish/coating

2. Assign a Product to a Class

Navigation: Inventory → Products → Products

  1. Create or edit a product

  2. Find the Product Class field in the Attributes & Variants tab (added by this module)

  3. Select the class (e.g., “Furniture”)

  4. The form will now restrict Attributes to only those allowed by the class

3. Add Attribute Lines to a Classed Product

Once a class is selected, you can add attribute lines:

  1. Go to the Attributes & Variants tab

  2. In Attribute Lines, click Add a line

  3. The Attribute field dropdown is now filtered to show only class-allowed attributes

  4. Select an attribute and provide values

  5. Validation will fail if:

    • You select an attribute not in the class → Error: “has attribute lines that do not belong”

    • You leave out a required attribute → Error: “is missing required attributes”

4. Remove an Attribute from a Class

Scenario: Your “Furniture” class allowed “Color” but wants to retire it.

  1. Navigate to the class

  2. In Attributes, find the “Color” line and delete it

  3. Odoo will raise an error if products in this class still use Color

    • Fix: Remove Color from all products in the class first, then retry the class update

Workflow Example

Step 1: Set Up “Chairs” Class

  • Color (required)

  • Size (required)

  • Leg Material (optional)

Step 2: Create a “Wooden Chair” Product

  • Assign class: “Chairs”

  • Add attribute “Color” = Red (satisfies required)

  • Add attribute “Size” = Large (satisfies required)

  • Add attribute “Leg Material” = Oak (optional, still valid)

  • Save ✓ Success

Step 3: Try Invalid Assignment

  • Assign class: “Chairs”

  • Add attribute “Color” = Blue (satisfies required)

  • Try to save without Size → Error: “is missing required attributes for the selected class ‘Chairs’: Size”

  • Add Size = Medium

  • Save ✓ Success

Class Attribute Line Model

The bridge model product.class.attribute.line stores:

Field

Type

Purpose

class_id

Many2one

Product class (required, cascade delete)

attribute_id

Many2one

Product attribute (required)

required

Boolean

If true, products must define it

Constraint: A class cannot configure the same attribute twice (unique on class_id + attribute_id).

Constraints & Validations

  1. Class Constraint (_check_attribute_ids_used_by_products)

    • Prevents removing an attribute from a class if products still use it

    • Error: “Cannot remove attributes used in products assigned to class…”

  2. Product Constraint (_check_class_attributes)

    • Ensures all attribute lines belong to the class

    • Ensures all required attributes are defined

    • Error: “Product ‘…’ has attribute lines that do not belong to the selected class ‘…’”

    • Error: “Product ‘…’ is missing required attributes for the selected class ‘…’”

Advanced: Access Control

  • User (base.group_user): Can create/read/write product classes and their attributes

  • System/Admin (base.group_system): Full CRUD including delete

Product class attribute lines follow the same access rules.

Bug Tracker

Bugs are tracked on GitHub 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.

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

Credits

Authors

  • Camptocamp

Maintainers

This module is maintained by the OCA.

Odoo Community Association

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.

Current maintainers:

Ricardoalso ivantodorovich

This module is part of the OCA/product-attribute project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file odoo_addon_product_class-19.0.1.0.0.3-py3-none-any.whl.

File metadata

File hashes

Hashes for odoo_addon_product_class-19.0.1.0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 14b11b11e710941754264e6f48f02d0f5fa65a6d55664ad5c41ff3384025cf34
MD5 e3f0dd44358938b17c7452143c75b22a
BLAKE2b-256 9e9d38cabe7c65f549bd8411d64060d6249d49f1753e4f4bde4c1221775799a3

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page