Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
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
6 changes: 6 additions & 0 deletions setup/stock_warehouse_security/setup.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
import setuptools

setuptools.setup(
setup_requires=['setuptools-odoo'],
odoo_addon=True,
)
125 changes: 125 additions & 0 deletions stock_warehouse_security/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,125 @@
========================
Stock Warehouse Security
========================

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

.. |badge1| image:: https://img.shields.io/badge/maturity-Alpha-red.png
:target: https://odoo-community.org/page/development-status
:alt: Alpha
.. |badge2| image:: https://img.shields.io/badge/licence-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%2Fstock--logistics--warehouse-lightgray.png?logo=github
:target: https://github.com/OCA/stock-logistics-warehouse/tree/16.0/stock_warehouse_security
:alt: OCA/stock-logistics-warehouse
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
:target: https://translation.odoo-community.org/projects/stock-logistics-warehouse-16-0/stock-logistics-warehouse-16-0-stock_warehouse_security
: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/stock-logistics-warehouse&target_branch=16.0
:alt: Try me on Runboat

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

With this module you are able to set a restricted list of allowed
warehouses that user can see and operate with.

This module is inspired from the experiences of
`stock_warehouse_security <https://github.com/akretion/stock-logistics-warehouse/tree/12-muli-wh-security/stock_warehouse_security/>`__
on version 12.0 but has some key differences on user experience:

- In this module there is no new groups, user is able to see allowed
warehouses only or all if not set.
- So in this module there is no "current warehouse" concept on user ( in
v12.0 that module was based on
`base_multi_warehouse <https://github.com/akretion/stock-logistics-warehouse/tree/12-base-multi_warehouse/base_multi_warehouse>`__
which allowed users to switch between warehouses).

.. IMPORTANT::
This is an alpha version, the data model and design can change at any time without warning.
Only for development or testing purpose, do not use in production.
`More details on development status <https://odoo-community.org/page/development-status>`_

**Table of contents**

.. contents::
:local:

Usage
=====

Each user administrators is able to defined allowed warehouse.

No warehouse define in such list means no restrictions.

Known issues / Roadmap
======================

- test make sure default warehouse can still be set if user also sales
goods but processus is not unit-tested
- Add unitest test to ensure transit goods between warehouses still
working

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

Bugs are tracked on `GitHub Issues <https://github.com/OCA/stock-logistics-warehouse/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/stock-logistics-warehouse/issues/new?body=module:%20stock_warehouse_security%0Aversion:%2016.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
-------

* Akretion
* Pierre Verkest

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

- `Foodles <https://www.foodles.co>`__

- Pierre Verkest <pierreverkest84@gmail.com>

- Florian da Costa <florian.dacosta@akretion.com>

- `Tecnativa <https://www.tecnativa.com>`__:

- Christian Ramos

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-petrus-v| image:: https://github.com/petrus-v.png?size=40px
:target: https://github.com/petrus-v
:alt: petrus-v

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

|maintainer-petrus-v|

This module is part of the `OCA/stock-logistics-warehouse <https://github.com/OCA/stock-logistics-warehouse/tree/16.0/stock_warehouse_security>`_ project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
1 change: 1 addition & 0 deletions stock_warehouse_security/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from . import models
23 changes: 23 additions & 0 deletions stock_warehouse_security/__manifest__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
# Copyright (C) 2019 Akretion
# Copyright 2022 Foodles (http://www.foodles.co).
# @author Pierre Verkest <pierreverkest84@gmail.com>
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
{
"name": "Stock Warehouse Security",
"version": "16.0.1.0.0",
"category": "Warehouse Management",
"website": "https://github.com/OCA/stock-logistics-warehouse",
"author": "Akretion, Pierre Verkest, Odoo Community Association (OCA)",
"maintainers": ["petrus-v"],
"license": "AGPL-3",
"installable": True,
"summary": "Restrict user access in multi-warehouse environment",
"depends": [
"stock",
],
"data": [
"security/stock_security.xml",
"views/res_users.xml",
],
"development_status": "Alpha",
}
45 changes: 45 additions & 0 deletions stock_warehouse_security/i18n/fr.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * stock_warehouse_security
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 16.0\n"
"Report-Msgid-Bugs-To: \n"
"Last-Translator: \n"
"Language-Team: \n"
"Language: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"

#. module: stock_warehouse_security
#: model:ir.model.fields,field_description:stock_warehouse_security.field_res_users__warehouse_ids
msgid "Allowed Warehouses"
msgstr "Entrepôts autorisés"

#. module: stock_warehouse_security
#: model_terms:ir.ui.view,arch_db:stock_warehouse_security.view_users_form
msgid "Multi Warehouse"
msgstr "Multi entrepôt"

#. module: stock_warehouse_security
#: model:ir.model,name:stock_warehouse_security.model_product_product
msgid "Product Variant"
msgstr ""

#. module: stock_warehouse_security
#: model:ir.model,name:stock_warehouse_security.model_res_users
#, fuzzy
msgid "User"
msgstr "Utilisateurs"

#~ msgid "Display Name"
#~ msgstr "Nom affiché"

#~ msgid "ID"
#~ msgstr "ID"

#~ msgid "Last Modified on"
#~ msgstr "Dernière modification le"
37 changes: 37 additions & 0 deletions stock_warehouse_security/i18n/it.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * stock_warehouse_security
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 18.0\n"
"Report-Msgid-Bugs-To: \n"
"PO-Revision-Date: 2025-11-10 10:04+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 5.10.4\n"

#. module: stock_warehouse_security
#: model:ir.model.fields,field_description:stock_warehouse_security.field_res_users__warehouse_ids
msgid "Allowed Warehouses"
msgstr "Magazzini consentiti"

#. module: stock_warehouse_security
#: model_terms:ir.ui.view,arch_db:stock_warehouse_security.view_users_form
msgid "Multi Warehouse"
msgstr "Magazzini multipli"

#. module: stock_warehouse_security
#: model:ir.model,name:stock_warehouse_security.model_product_product
msgid "Product Variant"
msgstr "Variante prodotto"

#. module: stock_warehouse_security
#: model:ir.model,name:stock_warehouse_security.model_res_users
msgid "User"
msgstr "Utente"
44 changes: 44 additions & 0 deletions stock_warehouse_security/i18n/stock_multi_warehouse_security.pot
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * stock_warehouse_security
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 16.0\n"
"Report-Msgid-Bugs-To: \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: stock_warehouse_security
#: model:ir.model.fields,field_description:stock_warehouse_security.field_res_users__warehouse_ids
msgid "Allowed Warehouses"
msgstr ""

#. module: stock_warehouse_security
#: model:ir.model.fields,field_description:stock_warehouse_security.field_res_users__display_name
msgid "Display Name"
msgstr ""

#. module: stock_warehouse_security
#: model:ir.model.fields,field_description:stock_warehouse_security.field_res_users__id
msgid "ID"
msgstr ""

#. module: stock_warehouse_security
#: model:ir.model.fields,field_description:stock_warehouse_security.field_res_users____last_update
msgid "Last Modified on"
msgstr ""

#. module: stock_warehouse_security
#: model_terms:ir.ui.view,arch_db:stock_warehouse_security.view_users_form
msgid "Multi Warehouse"
msgstr ""

#. module: stock_warehouse_security
#: model:ir.model,name:stock_warehouse_security.model_res_users
msgid "Users"
msgstr ""
34 changes: 34 additions & 0 deletions stock_warehouse_security/i18n/stock_warehouse_security.pot
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * stock_warehouse_security
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 18.0\n"
"Report-Msgid-Bugs-To: \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: stock_warehouse_security
#: model:ir.model.fields,field_description:stock_warehouse_security.field_res_users__warehouse_ids
msgid "Allowed Warehouses"
msgstr ""

#. module: stock_warehouse_security
#: model_terms:ir.ui.view,arch_db:stock_warehouse_security.view_users_form
msgid "Multi Warehouse"
msgstr ""

#. module: stock_warehouse_security
#: model:ir.model,name:stock_warehouse_security.model_product_product
msgid "Product Variant"
msgstr ""

#. module: stock_warehouse_security
#: model:ir.model,name:stock_warehouse_security.model_res_users
msgid "User"
msgstr ""
2 changes: 2 additions & 0 deletions stock_warehouse_security/models/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
from . import res_users
from . import product
21 changes: 21 additions & 0 deletions stock_warehouse_security/models/product.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
# Copyright 2025 Tecnativa - Christian Ramos
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
from odoo import models


class Product(models.Model):
_inherit = "product.product"

def _get_domain_locations_new(self, location_ids):
if self.env.user.warehouse_ids:
location_ids = set(
self.env["stock.location"]
.search(
[
("warehouse_id", "in", self.env.user.warehouse_ids.ids),
("id", "in", list(location_ids)),
]
)
.ids
)
return super()._get_domain_locations_new(location_ids)
21 changes: 21 additions & 0 deletions stock_warehouse_security/models/res_users.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
# Copyright (C) 2019 Akretion
# Copyright 2022 Foodles (http://www.foodles.co).
# @author Pierre Verkest <pierreverkest84@gmail.com>
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).

from odoo import api, fields, models


class ResUsers(models.Model):
_inherit = "res.users"

warehouse_ids = fields.Many2many(
"stock.warehouse",
string="Allowed Warehouses",
)

@api.model
def _get_invalidation_fields(self):
res = super()._get_invalidation_fields()
res.add("warehouse_ids")
return res
3 changes: 3 additions & 0 deletions stock_warehouse_security/pyproject.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
[build-system]
requires = ["whool"]
build-backend = "whool.buildapi"
8 changes: 8 additions & 0 deletions stock_warehouse_security/readme/CONTRIBUTORS.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
- [Foodles](https://www.foodles.co)

> - Pierre Verkest \<pierreverkest84@gmail.com\>

- Florian da Costa \<florian.dacosta@akretion.com\>
- [Tecnativa](https://www.tecnativa.com):

- Christian Ramos
13 changes: 13 additions & 0 deletions stock_warehouse_security/readme/DESCRIPTION.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
With this module you are able to set a restricted list of allowed
warehouses that user can see and operate with.

This module is inspired from the experiences of
[stock_warehouse_security](https://github.com/akretion/stock-logistics-warehouse/tree/12-muli-wh-security/stock_warehouse_security/)
on version 12.0 but has some key differences on user experience:

- In this module there is no new groups, user is able to see allowed
warehouses only or all if not set.
- So in this module there is no "current warehouse" concept on user ( in
v12.0 that module was based on
[base_multi_warehouse](https://github.com/akretion/stock-logistics-warehouse/tree/12-base-multi_warehouse/base_multi_warehouse)
which allowed users to switch between warehouses).
Loading