summaryrefslogtreecommitdiff
path: root/addons/sale/security
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
commit3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch)
treea44932296ef4a9b71d5f010906253d8c53727726 /addons/sale/security
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/sale/security')
-rw-r--r--addons/sale/security/ir.model.access.csv58
-rw-r--r--addons/sale/security/sale_security.xml229
2 files changed, 287 insertions, 0 deletions
diff --git a/addons/sale/security/ir.model.access.csv b/addons/sale/security/ir.model.access.csv
new file mode 100644
index 00000000..45b5571c
--- /dev/null
+++ b/addons/sale/security/ir.model.access.csv
@@ -0,0 +1,58 @@
+id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
+access_sale_order,sale.order,model_sale_order,sales_team.group_sale_salesman,1,1,1,0
+access_sale_order_line,sale.order.line,model_sale_order_line,sales_team.group_sale_salesman,1,1,1,1
+access_sale_order_line_readonly,sale.order.line accountant,model_sale_order_line,account.group_account_readonly,1,0,0,0
+access_sale_order_line_accountant,sale.order.line accountant,model_sale_order_line,account.group_account_user,1,1,0,0
+access_sale_order_portal,sale.order.portal,sale.model_sale_order,base.group_portal,1,0,0,0
+access_sale_order_line_portal,sale.order.line.portal,sale.model_sale_order_line,base.group_portal,1,0,0,0
+access_account_move_manager,account_move manager,account.model_account_move,sales_team.group_sale_manager,1,0,0,0
+access_account_move_salesman,account_move salesman,account.model_account_move,sales_team.group_sale_salesman,1,0,0,0
+access_account_move_line_salesman,account_move_line salesman,account.model_account_move_line,sales_team.group_sale_salesman,1,0,0,0
+access_account_partial_reconcile_salesman,account_partial_reconcile salesman,account.model_account_partial_reconcile,sales_team.group_sale_salesman,1,0,0,0
+access_account_payment_term_salesman,account_payment_term salesman,account.model_account_payment_term,sales_team.group_sale_salesman,1,0,0,0
+access_account_account_tag_sale_salesman,account.account.tag.sale.salesman,account.model_account_account_tag,sales_team.group_sale_salesman,1,0,0,0
+access_account_account_type_sale_salesman,account.account.type.sale.salesman,account.model_account_account_type,sales_team.group_sale_salesman,1,0,0,0
+access_account_analytic_tag_sale_salesman,account.analytic.tag.sale.salesman,analytic.model_account_analytic_tag,sales_team.group_sale_salesman,1,0,0,0
+access_account_analytic_account_salesman,account_analytic_account salesman,analytic.model_account_analytic_account,sales_team.group_sale_salesman,1,1,1,0
+access_account_invoice_send_salesman,access.account.invoice.send.salesman,account.model_account_invoice_send,sales_team.group_sale_salesman,1,1,1,0
+access_sale_order_manager,sale.order.manager,model_sale_order,sales_team.group_sale_manager,1,1,1,1
+access_sale_order_readonly,sale.order.accountant,model_sale_order,account.group_account_readonly,1,0,0,0
+access_sale_order_accountant,sale.order.accountant,model_sale_order,account.group_account_user,1,1,0,0
+access_sale_report_salesman,sale.report,model_sale_report,sales_team.group_sale_salesman,1,1,1,0
+access_sale_report_manager,sale.report,model_sale_report,sales_team.group_sale_manager,1,1,1,1
+access_sale_account_journal,account.journal sale order.user,account.model_account_journal,sales_team.group_sale_salesman,1,0,0,0
+access_res_partner_sale_user,res.partner.sale.user,base.model_res_partner,sales_team.group_sale_salesman,1,0,0,0
+access_res_partner_sale_manager,res.partner.sale.manager,base.model_res_partner,sales_team.group_sale_manager,1,1,1,0
+access_product_template_sale_user,product.template sale use,product.model_product_template,sales_team.group_sale_salesman,1,0,0,0
+access_product_product_sale_user,product.product sale use,product.model_product_product,sales_team.group_sale_salesman,1,0,0,0
+access_account_tax_user,account.tax.user,account.model_account_tax,sales_team.group_sale_salesman,1,0,0,0
+access_uom_uom_user,uom.uom.user,uom.model_uom_uom,sales_team.group_sale_salesman,1,0,0,0
+access_product_pricelist_sale_user,product.pricelist.sale.user,product.model_product_pricelist,sales_team.group_sale_salesman,1,0,0,0
+access_account_account_salesman,account_account salesman,account.model_account_account,sales_team.group_sale_salesman,1,0,0,0
+access_uom_category_sale_manager,uom.category salemanager,uom.model_uom_category,sales_team.group_sale_manager,1,1,1,1
+access_uom_uom_sale_manager,uom.uom salemanager,uom.model_uom_uom,sales_team.group_sale_manager,1,1,1,1
+access_product_category_sale_manager,product.category salemanager,product.model_product_category,sales_team.group_sale_manager,1,1,1,1
+access_product_supplierinfo_user,product.supplierinfo.user,product.model_product_supplierinfo,sales_team.group_sale_salesman,1,0,0,0
+access_product_supplierinfo_sale_manager,product.supplierinfo salemanager,product.model_product_supplierinfo,sales_team.group_sale_manager,1,1,1,1
+access_product_pricelist_sale_manager,product.pricelist salemanager,product.model_product_pricelist,sales_team.group_sale_manager,1,1,1,1
+access_product_group_res_partner_sale_manager,res_partner group_sale_manager,base.model_res_partner,sales_team.group_sale_manager,1,1,1,0
+access_sale_order_invoicing_payments,sale.order,model_sale_order,account.group_account_invoice,1,1,0,0
+access_sale_order_line_invoicing_payments,sale.order.line,model_sale_order_line,account.group_account_invoice,1,1,0,0
+access_product_pricelist_item_sale_manager,product.pricelist.item salemanager,product.model_product_pricelist_item,sales_team.group_sale_manager,1,1,1,1
+access_product_template_sale_manager,product.template salemanager,model_product_template,sales_team.group_sale_manager,1,1,1,1
+access_product_product_sale_manager,product.product salemanager,model_product_product,sales_team.group_sale_manager,1,1,1,1
+access_product_attribute_sale_manager,product.attribute manager,product.model_product_attribute,sales_team.group_sale_manager,1,1,1,1
+access_product_attribute_value_sale_manager,product.attribute manager value,product.model_product_attribute_value,sales_team.group_sale_manager,1,1,1,1
+access_product_product_attribute_sale_manager,product.template.attribute manager value,product.model_product_template_attribute_value,sales_team.group_sale_manager,1,1,1,1
+access_product_product_attribute_custom_value_sale_manager,product.attribute.custom value manager,product.model_product_attribute_custom_value,sales_team.group_sale_salesman,1,1,1,1
+access_product_template_attribute_exclusion_sale_manager,product.attribute manager filter line,product.model_product_template_attribute_exclusion,sales_team.group_sale_manager,1,1,1,1
+access_product_template_attribute_line_sale_manager,product.attribute manager line,product.model_product_template_attribute_line,sales_team.group_sale_manager,1,1,1,1
+access_account_tax_sale_manager,account.tax sale manager,account.model_account_tax,sales_team.group_sale_salesman,1,0,0,0
+access_account_tax_group_sale_manager,account.tax.group sale manager,account.model_account_tax_group,sales_team.group_sale_salesman,1,0,0,0
+access_account_account_sale_manager,account.account sale manager,account.model_account_account,sales_team.group_sale_manager,1,0,0,0
+access_mail_activity_type_sale_manager,mail.activity.type.sale.manager,mail.model_mail_activity_type,sales_team.group_sale_manager,1,1,1,1
+access_report_all_channels_sales,access_report_all_channels_sales,model_report_all_channels_sales,sales_team.group_sale_manager,1,0,0,0
+access_sale_payment_acquirer_onboarding_wizard,access.sale.payment.acquirer.onboarding.wizard,model_sale_payment_acquirer_onboarding_wizard,base.group_system,1,1,1,0
+access_sale_advance_payment_inv,access.sale.advance.payment.inv,model_sale_advance_payment_inv,sales_team.group_sale_salesman,1,1,1,0
+access_sale_order_cancel,access.sale.order.cancel,model_sale_order_cancel,sales_team.group_sale_salesman,1,1,1,0
+access_payment_link_wizard_sale,access.payment.link.wizard.sale,model_payment_link_wizard,sales_team.group_sale_salesman,1,1,1,0
diff --git a/addons/sale/security/sale_security.xml b/addons/sale/security/sale_security.xml
new file mode 100644
index 00000000..b1afcab9
--- /dev/null
+++ b/addons/sale/security/sale_security.xml
@@ -0,0 +1,229 @@
+<?xml version="1.0" encoding="utf-8"?>
+<odoo>
+
+ <record id="base.group_multi_currency" model="res.groups">
+ <!--
+ Sales multi-currency is based on pricelists, if multi-currency is enabled,
+ enable pricelists.
+ -->
+ <field name="implied_ids" eval="[(4, ref('product.group_product_pricelist'))]"/>
+ </record>
+
+ <record id="group_auto_done_setting" model="res.groups">
+ <field name="name">Lock Confirmed Sales</field>
+ <field name="category_id" ref="base.module_category_hidden"/>
+ </record>
+
+ <record id="group_delivery_invoice_address" model="res.groups">
+ <field name="name">Addresses in Sales Orders</field>
+ <field name="category_id" ref="base.module_category_hidden"/>
+ </record>
+
+ <record id="group_warning_sale" model="res.groups">
+ <field name="name">A warning can be set on a product or a customer (Sale)</field>
+ <field name="category_id" ref="base.module_category_hidden"/>
+ </record>
+
+ <record id="group_proforma_sales" model="res.groups">
+ <field name="name">Pro-forma Invoices</field>
+ <field name="category_id" ref="base.module_category_hidden"/>
+ </record>
+
+ <record model="res.users" id="base.user_root">
+ <field eval="[(4,ref('base.group_partner_manager'))]" name="groups_id"/>
+ </record>
+
+ <record model="res.users" id="base.user_admin">
+ <field eval="[(4,ref('base.group_partner_manager'))]" name="groups_id"/>
+ </record>
+
+<data noupdate="1">
+ <!-- Multi - Company Rules -->
+
+ <record model="ir.rule" id="sale_order_comp_rule">
+ <field name="name">Sales Order multi-company</field>
+ <field name="model_id" ref="model_sale_order"/>
+ <field name="domain_force">[('company_id', 'in', company_ids)]</field>
+ </record>
+
+ <record model="ir.rule" id="sale_order_line_comp_rule">
+ <field name="name">Sales Order Line multi-company</field>
+ <field name="model_id" ref="model_sale_order_line"/>
+ <field name="domain_force">['|', ('company_id', '=', False), ('company_id', 'in', company_ids)]</field>
+ </record>
+
+ <record model="ir.rule" id="sale_order_report_comp_rule">
+ <field name="name">Sales Order Analysis multi-company</field>
+ <field name="model_id" ref="model_sale_report"/>
+ <field name="domain_force">['|',('company_id','=',False),('company_id', 'in', company_ids)]</field>
+ </record>
+
+ <!-- Payments -->
+ <record id="payment_transaction_salesman_rule" model="ir.rule">
+ <field name="name">Access every payment transaction</field>
+ <field name="model_id" ref="payment.model_payment_transaction"/>
+ <field name="domain_force">[(1, '=', 1)]</field>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman'))]"/>
+ </record>
+
+ <record id="payment_token_salesman_rule" model="ir.rule">
+ <field name="name">Access every payment token</field>
+ <field name="model_id" ref="payment.model_payment_token"/>
+ <field name="domain_force">[(1, '=', 1)]</field>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman'))]"/>
+ </record>
+
+ <!-- Portal Access Rules -->
+ <record id="sale_order_rule_portal" model="ir.rule">
+ <field name="name">Portal Personal Quotations/Sales Orders</field>
+ <field name="model_id" ref="sale.model_sale_order"/>
+ <field name="domain_force">[('message_partner_ids','child_of',[user.commercial_partner_id.id])]</field>
+ <field name="groups" eval="[(4, ref('base.group_portal'))]"/>
+ <field name="perm_unlink" eval="True"/>
+ <field name="perm_write" eval="True"/>
+ <field name="perm_read" eval="True"/>
+ <field name="perm_create" eval="False"/>
+ </record>
+
+ <record id="sale_order_line_rule_portal" model="ir.rule">
+ <field name="name">Portal Sales Orders Line</field>
+ <field name="model_id" ref="sale.model_sale_order_line"/>
+ <field name="domain_force">[('order_id.message_partner_ids','child_of',[user.commercial_partner_id.id])]</field>
+ <field name="groups" eval="[(4, ref('base.group_portal'))]"/>
+ </record>
+
+ <!-- Multi - Salesmen sales order assignation rules -->
+
+ <record id="sale_order_personal_rule" model="ir.rule">
+ <field name="name">Personal Orders</field>
+ <field ref="model_sale_order" name="model_id"/>
+ <field name="domain_force">['|',('user_id','=',user.id),('user_id','=',False)]</field>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman'))]"/>
+ </record>
+ <record id="sale_order_see_all" model="ir.rule">
+ <field name="name">All Orders</field>
+ <field ref="model_sale_order" name="model_id"/>
+ <field name="domain_force">[(1,'=',1)]</field>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman_all_leads'))]"/>
+ </record>
+
+ <record id="sale_order_report_personal_rule" model="ir.rule">
+ <field name="name">Personal Orders Analysis</field>
+ <field ref="model_sale_report" name="model_id"/>
+ <field name="domain_force">['|',('user_id','=',user.id),('user_id','=',False)]</field>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman'))]"/>
+ </record>
+
+ <record id="sale_order_report_see_all" model="ir.rule">
+ <field name="name">All Orders Analysis</field>
+ <field ref="model_sale_report" name="model_id"/>
+ <field name="domain_force">[(1,'=',1)]</field>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman_all_leads'))]"/>
+ </record>
+
+ <record id="sale_order_line_personal_rule" model="ir.rule">
+ <field name="name">Personal Order Lines</field>
+ <field ref="model_sale_order_line" name="model_id"/>
+ <field name="domain_force">['|',('salesman_id','=',user.id),('salesman_id','=',False)]</field>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman'))]"/>
+ </record>
+
+ <record id="sale_order_line_see_all" model="ir.rule">
+ <field name="name">All Orders Lines</field>
+ <field ref="model_sale_order_line" name="model_id"/>
+ <field name="domain_force">[(1,'=',1)]</field>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman_all_leads'))]"/>
+ </record>
+
+ <record id="account_invoice_report_rule_see_personal" model="ir.rule">
+ <field name="name">Personal Invoices Analysis</field>
+ <field name="model_id" ref="model_account_invoice_report"/>
+ <field name="domain_force">['|', ('invoice_user_id', '=', user.id), ('invoice_user_id', '=', False)]</field>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman'))]"/>
+ </record>
+
+ <record id="account_invoice_report_rule_see_all" model="ir.rule">
+ <field name="name">All Invoices Analysis</field>
+ <field name="model_id" ref="model_account_invoice_report"/>
+ <field name="domain_force">[(1, '=', 1)]</field>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman_all_leads'))]"/>
+ </record>
+
+ <!-- Payment transactions and tokens access rules -->
+
+ <record id="payment_transaction_salesman_rule" model="ir.rule">
+ <field name="name">Access every payment transaction</field>
+ <field name="model_id" ref="payment.model_payment_transaction"/>
+ <field name="domain_force">[(1, '=', 1)]</field>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman'))]"/>
+ </record>
+
+ <record id="payment_token_salesman_rule" model="ir.rule">
+ <field name="name">Access every payment token</field>
+ <field name="model_id" ref="payment.model_payment_token"/>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman'))]"/>
+ </record>
+
+ <!-- Multi - Salesmen invoice and account move assignation rules -->
+ <record id="account_invoice_rule_see_personal" model="ir.rule">
+ <field name="name">Personal Invoices</field>
+ <field name="model_id" ref="model_account_move"/>
+ <field name="domain_force">[('move_type', 'in', ('out_invoice', 'out_refund')), '|', ('invoice_user_id', '=', user.id), ('invoice_user_id', '=', False)]</field>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman'))]"/>
+ </record>
+
+ <record id="account_invoice_rule_see_all" model="ir.rule">
+ <field name="name">All Invoices</field>
+ <field name="model_id" ref="model_account_move"/>
+ <field name="domain_force">[('move_type', 'in', ('out_invoice', 'out_refund'))]</field>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman_all_leads'))]"/>
+ </record>
+
+ <record id="account_invoice_line_rule_see_personal" model="ir.rule">
+ <field name="name">Personal Invoice Lines</field>
+ <field name="model_id" ref="model_account_move_line"/>
+ <field name="domain_force">[('move_id.move_type', 'in', ('out_invoice', 'out_refund')), '|', ('move_id.invoice_user_id', '=', user.id), ('move_id.invoice_user_id', '=', False)]</field>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman'))]"/>
+ </record>
+
+ <record id="account_invoice_line_rule_see_all" model="ir.rule">
+ <field name="name">All Invoice Lines</field>
+ <field name="model_id" ref="model_account_move_line"/>
+ <field name="domain_force">[('move_id.move_type', 'in', ('out_invoice', 'out_refund'))]</field>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman_all_leads'))]"/>
+ </record>
+
+ <record id="account_invoice_send_rule_see_personal" model="ir.rule">
+ <field name="name">Personal Invoice Send and Print</field>
+ <field name="model_id" ref="account.model_account_invoice_send"/>
+ <field name="domain_force">[('invoice_ids.move_type', 'in', ('out_invoice', 'out_refund')), '|', ('invoice_ids.invoice_user_id', '=', user.id), ('invoice_ids.invoice_user_id', '=', False)]</field>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman'))]"/>
+ </record>
+
+ <record id="account_invoice_send_rule_see_all" model="ir.rule">
+ <field name="name">All Invoice Send and Print</field>
+ <field name="model_id" ref="account.model_account_invoice_send"/>
+ <field name="domain_force">[('invoice_ids.move_type', 'in', ('out_invoice', 'out_refund'))]</field>
+ <field name="groups" eval="[(4, ref('sales_team.group_sale_salesman_all_leads'))]"/>
+ </record>
+
+ <!-- Wizard access rules -->
+ <record id="sale_payment_acquirer_onboarding_wizard_rule" model="ir.rule">
+ <field name="name">Payment Acquier Onboarding Wizard Rule</field>
+ <field name="model_id" ref="model_sale_payment_acquirer_onboarding_wizard"/>
+ <field name="domain_force">[('create_uid', '=', user.id)]</field>
+ </record>
+
+ <record id="sale_advance_payment_inv_rule" model="ir.rule">
+ <field name="name">Sales Advance Payment Invoice Rule</field>
+ <field name="model_id" ref="model_sale_advance_payment_inv"/>
+ <field name="domain_force">[('create_uid', '=', user.id)]</field>
+ </record>
+
+ <record id="sale_order_cancel_rule" model="ir.rule">
+ <field name="name">Sales Order Cancel Rule</field>
+ <field name="model_id" ref="model_sale_order_cancel"/>
+ <field name="domain_force">[('create_uid', '=', user.id)]</field>
+ </record>
+</data>
+</odoo>