第21讲、Odoo 18 配置机制详解

news2025/6/8 8:42:59

Odoo 18 配置机制详解:res.config.settingsir.config_parameter 原理与实战指南

在现代企业信息化系统中,灵活且可维护的系统参数配置是模块开发的核心能力之一。Odoo 作为一款高度模块化的企业管理软件,其参数配置机制主要依赖于两个关键模型:res.config.settingsir.config_parameter

本文将系统梳理这两个模型的设计原理、典型应用场景及开发实践,并通过完整案例演示如何从 Python 到 XML 快速实现系统设置项,助力开发者高效构建可配置的 Odoo 模块。


一、核心模型原理

1. ir.config_parameter —— 系统参数存储模型

  • 作用:作为底层的键值对存储模型,负责持久化保存系统全局配置参数。

  • 模型名称ir.config_parameter

  • 表结构(简化)

    字段名类型描述
    keychar设置项唯一键
    valuetext设置项值,统一为字符串类型
  • 读写方式

# 读取配置值(如布尔型需自行判断)
value = self.env['ir.config_parameter'].sudo().get_param('my_module.my_setting') == 'True'

# 设置配置值
self.env['ir.config_parameter'].sudo().set_param('my_module.my_setting', 'True')

2. res.config.settings —— 系统设置表单模型

  • 作用:为管理员提供 UI 表单接口,便于读取和设置 ir.config_parameter
  • 模型名称res.config.settings(TransientModel,临时模型,数据不持久化)
  • 关键特性
    • 字段通过 config_parameter 属性与 ir.config_parameter.key 关联
    • 支持多种字段类型(Boolean、Char、Integer、Selection 等)
    • 设置项可直接在 Odoo 后台"设置"界面进行配置

二、典型应用场景

应用场景说明
功能开关启用/禁用模块功能(如"启用审批流程")
默认参数设定默认值(如"默认抄送邮箱"“默认负责人”)
第三方集成存储 API Key、Webhook URL 等外部对接参数
系统行为设置配置"数据保留天数""通知频率"等系统行为

三、开发流程实战

以"启用高级功能"为例,演示从字段定义到前端配置的完整开发流程。

1. 模块结构示例

my_module/
├── __init__.py
├── __manifest__.py
├── models/
│   ├── __init__.py
│   ├── res_config_settings.py
│   └── my_model.py
└── views/
    └── res_config_settings_views.xml

2. manifest 文件

my_module/__manifest__.py

{
    'name': 'My Module',
    'version': '1.0',
    'category': 'Tools',
    'summary': '演示 Odoo 配置机制',
    'depends': ['base'],
    'data': [
        'views/res_config_settings_views.xml',
    ],
    'installable': True,
    'application': False,
}

3. Python 字段定义

models/res_config_settings.py 中定义设置字段,并通过 config_parameter 绑定系统参数:

from odoo import models, fields

class ResConfigSettings(models.TransientModel):
    _inherit = 'res.config.settings'

    enable_advanced_feature = fields.Boolean(
        string="Enable Advanced Feature",
        help="启用后,将激活本模块的高级功能。",
        config_parameter='my_module.enable_advanced_feature'
    )

    default_manager = fields.Many2one(
        'res.users',
        string="Default Manager",
        help="新建任务时的默认负责人。",
        config_parameter='my_module.default_manager_id'
    )

4. XML 视图定义

views/res_config_settings_views.xml 中扩展设置页面,使字段在前端可见:

<?xml version="1.0" encoding="UTF-8"?>
<odoo>
    <record id="res_config_settings_view_form_my_module" model="ir.ui.view">
        <field name="name">res.config.settings.view.form.my.module</field>
        <field name="model">res.config.settings</field>
        <field name="inherit_id" ref="base.res_config_settings_view_form"/>
        <field name="arch" type="xml">
            <xpath expr="//div[@id='settings']" position="inside">
                <div class="app_settings_block" data-string="My Module Settings" string="My Module Settings">
                    <h2>My Module</h2>
                    <field name="enable_advanced_feature"/>
                    <field name="default_manager"/>
                </div>
            </xpath>
        </field>
    </record>
</odoo>

5. 业务代码中读取配置

my_module/models/my_model.py

from odoo import models

class MyModel(models.Model):
    _name = 'my.model'

    def do_something(self):
        enable = self.env['ir.config_parameter'].sudo().get_param('my_module.enable_advanced_feature')
        if enable == 'True':
            self._do_advanced()
        else:
            self._do_basic()

    def _do_advanced(self):
        # 高级功能实现
        pass

    def _do_basic(self):
        # 基础功能实现
        pass

四、进阶技巧与实用建议

1. 多公司参数隔离

Odoo 默认的 ir.config_parameter 参数是全局共享的。如需为每个公司单独配置参数,可通过拼接公司 ID 实现隔离:

company_id = self.env.company.id
param_key = f"my_module.feature_enabled_company_{company_id}"
self.env['ir.config_parameter'].sudo().set_param(param_key, 'True')

2. 类型转换建议

所有参数值均以字符串存储,读取时需根据实际类型转换:

# 读取整数类型参数
retry_count = int(self.env['ir.config_parameter'].sudo().get_param('my_module.retry_count') or 0)

五、常见问题与排查建议

问题解决方法
设置值后保存无效检查字段是否正确添加 config_parameter 属性
设置页面不显示字段检查 XML 是否正确继承并挂载到 res.config.settings
报错找不到字段重启 Odoo 并升级模块,清理缓存
多公司参数混乱使用公司 ID 拼接参数 key 或扩展公司字段

六、模型对比与总结

项目res.config.settingsir.config_parameter
模型类型TransientModelRegular Model
主要作用提供设置表单 UI 接口持久化存储配置值
是否持久化是(持久存储)
字段控制通过 config_parameter代码直接 set/get
典型用途用户界面参数配置业务逻辑读取系统参数

七、常用模板片段(可直接复用)

Python 字段定义

my_option = fields.Boolean(
    string="My Option",
    config_parameter='my_module.my_option'
)

XML 视图片段

<xpath expr="//div[@id='settings']" position="inside">
    <div class="app_settings_block" string="My Module">
        <field name="my_option"/>
    </div>
</xpath>


八、结语

通过合理利用 res.config.settingsir.config_parameter,Odoo 开发者能够为模块快速添加灵活的系统配置项,实现功能开关、参数定制和第三方集成等多样化需求。这不仅提升了模块的通用性和可维护性,也为企业系统的持续演进提供了坚实基础。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2403936.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【计算机网络】Linux下简单的TCP服务器(超详细)

服务端 创建套接字 &#x1f4bb;我们将TCP服务器封装成一个类&#xff0c;当我们定义出一个服务器对象后需要马上对服务器进行初始化&#xff0c;而初始化TCP服务器要做的第一件事就是创建套接字。 TCP服务器在调用socket函数创建套接字时&#xff0c;参数设置如下&#xff1…

最新Spring Security实战教程(十七)企业级安全方案设计 - 多因素认证(MFA)实现

&#x1f337; 古之立大事者&#xff0c;不惟有超世之才&#xff0c;亦必有坚忍不拔之志 &#x1f390; 个人CSND主页——Micro麦可乐的博客 &#x1f425;《Docker实操教程》专栏以最新的Centos版本为基础进行Docker实操教程&#xff0c;入门到实战 &#x1f33a;《RabbitMQ》…

html+css+js趣味小游戏~Cookie Clicker放置休闲(附源码)

下面是一个简单的记忆卡片配对游戏的完整代码&#xff0c;使用HTML、CSS和JavaScript实现&#xff1a; html <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"wid…

SDC命令详解:使用set_propagated_clock命令进行约束

相关阅读 SDC命令详解https://blog.csdn.net/weixin_45791458/category_12931432.html?spm1001.2014.3001.5482 目录 指定端口列表/集合 简单使用 注意事项 传播时钟是在进行了时钟树综合后&#xff0c;使用set_propagated_clock命令可以将一个理想时钟转换为传播时钟&#x…

win32相关(消息Hook)

消息Hook 要想实现消息Hook需要使用到三个相关的Api SetWindowsHookEx // 设置钩子CallNextHookEx // 将钩子信息传递到当前钩子链中的下一个子程序UnhookWindowsHookEx // 卸载钩子 我们编写的消息钩子需要将设置钩子的函数写到dll里面&#xff0c;当钩住一个线程后&#xff…

mysql 页的理解和实际分析

目录 页&#xff08;Page&#xff09;是 Innodb 存储引擎用于管理数据的最小磁盘单位B树的一般高度记录在页中的存储 innodb ibd文件innodb 页类型分析ibd文件查看数据表的行格式查看ibd文件 分析 ibd的第4个页&#xff1a;B-tree Node类型先分析File Header(38字节-描述页信息…

构建 MCP 服务器:第 2 部分 — 使用资源模板扩展资源

该图像是使用 AI 图像创建程序创建的。 这个故事是在多位人工智能助手的帮助下写成的。 这是构建MCP 服务器教程&#xff08;共四部分&#xff09;的第二部分。在第一部分中&#xff0c;我们使用基本资源创建了第一个 MCP 服务器。现在&#xff0c;我们将使用资源模板扩展服务…

【算法设计与分析】实验——汽车加油问题, 删数问题(算法实现:代码,测试用例,结果分析,算法思路分析,总结)

说明&#xff1a;博主是大学生&#xff0c;有一门课是算法设计与分析&#xff0c;这是博主记录课程实验报告的内容&#xff0c;题目是老师给的&#xff0c;其他内容和代码均为原创&#xff0c;可以参考学习&#xff0c;转载和搬运需评论吱声并注明出处哦。 4-1算法实现题 汽车…

【C++进阶篇】C++11新特性(下篇)

C函数式编程黑魔法&#xff1a;Lambda与包装器实战全解析 一. lambda表达式1.1 仿函数使用1.2 lambda表达式的语法1.3 lambda表达式使用1.3.1 传值和传引用捕捉1.3.2 隐式捕捉1.3.3 混合捕捉 1.4 lambda表达式原理1.5 lambda优点及建议 二. 包装器2.1 function2.2 bind绑定 三.…

全生命周期的智慧城市管理

前言 全生命周期的智慧城市管理。未来&#xff0c;城市将在 实现从基础设施建设、日常运营到数据管理的 全生命周期统筹。这将避免过去智慧城市建设 中出现的“碎片化”问题&#xff0c;实现资源的高效配 置和项目的协调发展。城市管理者将运用先进 的信息技术&#xff0c;如物…

echarts柱状图实现动态展示时报错

echarts柱状图实现动态展示时报错 1、问题&#xff1a; 在使用Echarts柱状图时&#xff0c;当数据量过多&#xff0c;x轴展示不下的时候&#xff0c;可以使用dataZoom实现动态展示。如下图所示&#xff1a; 但是当鼠标放在图上面滚动滚轮时或拖动滚动条时会报错&#xff0c;…

408第一季 - 数据结构 - 线性表

只能用C/C&#xff01; 顺序表 闲聊 线性表的逻辑顺序和物理顺序相同 都是1234 顺序表的优点&#xff1a; 随机访问&#xff0c;随机访问的意思是访问的时间 和位置没有关系&#xff0c;访问下标1和100一样的&#xff0c;更深层就是直接计算 a100 * 数组大小&#xff0c;随便…

第23讲、Odoo18 邮件系统整体架构

目录 Odoo 邮件系统整体架构邮件发送方式邮件模板配置SMTP 邮件服务器配置邮件发送过程开发中常见邮件发送需求常见问题排查提示与最佳实践完整示例&#xff1a;审批通过自动发邮件门户表单自动邮件通知案例邮件队列与异步发送邮件添加附件邮件日志与调试多语言邮件模板邮件安…

HarmonyOS:Counter计数器组件

一、概述 计数器组件&#xff0c;提供相应的增加或者减少的计数操作。 说明 该组件从API Version 7开始支持。后续版本如有新增内容&#xff0c;则采用上角标单独标记该内容的起始版本。 二、属性 除支持通用属性外&#xff0c;还支持以下属性。 enableInc enableInc(value: b…

sqlsugar WhereIF条件的大于等于和等于查出来的坑

一、如下图所示&#xff0c;当我用 .WhereIF(input.Plancontroltype > 0, u > u.Plancontroltype (DnjqPlancontroltype)input.Plancontroltype) 这里面用等于的时候&#xff0c;返回结果一条数据都没有。 上图中生成的SQL如下&#xff1a; SELECT id AS Id ,code AS …

Pandas 技术解析:从数据结构到应用场景的深度探索

序 我最早用Python做大数据项目时&#xff0c;接触最早的就是Pandas了。觉得对于IT技术人员而言&#xff0c;它是可以属于多场景的存在&#xff0c;因为它的本身就是数据驱动的技术生态中&#xff0c;对于软件工程师而言&#xff0c;它是快速构建数据处理管道的基石&#xff1…

数据库系统概论(十七)超详细讲解数据库规范化与五大范式(从函数依赖到多值依赖,再到五大范式,附带例题,表格,知识图谱对比带你一步步掌握)

数据库系统概论&#xff08;十七&#xff09;超详细讲解数据库规范化与五大范式&#xff08;从函数依赖到多值依赖&#xff0c;再到五大范式&#xff0c;附带例题&#xff0c;表格&#xff0c;知识图谱对比带你一步步掌握&#xff09; 前言一、为什么需要规范化1. 我们先想一个…

并发编程实战(生产者消费者模型)

在并发编程中使用生产者和消费者模式能够解决绝大多数的并发问题。该模式通过平衡生产线程和消费线程的工作能力来提高程序整体处理数据的速度。 生产者和消费者模式&#xff1a; 在线程的世界中生产者就是产生数据的线程&#xff0c;而消费者则是消费数据的线程。在多线程开…

git小乌龟不显示图标状态解决方案

第一步 在开始菜单的搜索处&#xff0c;输入regedit命令&#xff0c;打开注册表。 第二步 在注册表编辑器中&#xff0c;找到HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\ShellIconOverlayIdentifiers 这一项。 第三步 让Tortoise相关的项目排在前…

获取 OpenAI API Key

你可以按照以下步骤来获取 openai.api_key&#xff0c;用于调用 OpenAI 的 GPT-4、DALLE、Whisper 等 API 服务&#xff1a; &#x1f9ed; 获取 OpenAI API Key 的步骤&#xff1a; ✅ 1. 注册或登录 OpenAI 账号 打开 https://platform.openai.com/ 使用你的邮箱或 Google/…