Skip to content

Commit

Permalink
perf: use get_cached_value instead of db.get_value in controllers (
Browse files Browse the repository at this point in the history
…#32776)

(cherry picked from commit 4efc947)
  • Loading branch information
DaizyModi authored and mergify[bot] committed Nov 7, 2022
1 parent 3d2e8c7 commit 34ca17a
Show file tree
Hide file tree
Showing 5 changed files with 29 additions and 25 deletions.
22 changes: 13 additions & 9 deletions erpnext/controllers/accounts_controller.py
Expand Up @@ -227,7 +227,7 @@ def validate_deferred_income_expense_account(self):
for item in self.get("items"):
if item.get("enable_deferred_revenue") or item.get("enable_deferred_expense"):
if not item.get(field_map.get(self.doctype)):
default_deferred_account = frappe.db.get_value(
default_deferred_account = frappe.get_cached_value(
"Company", self.company, "default_" + field_map.get(self.doctype)
)
if not default_deferred_account:
Expand Down Expand Up @@ -676,15 +676,15 @@ def set_other_charges(self):

def validate_enabled_taxes_and_charges(self):
taxes_and_charges_doctype = self.meta.get_options("taxes_and_charges")
if frappe.db.get_value(taxes_and_charges_doctype, self.taxes_and_charges, "disabled"):
if frappe.get_cached_value(taxes_and_charges_doctype, self.taxes_and_charges, "disabled"):
frappe.throw(
_("{0} '{1}' is disabled").format(taxes_and_charges_doctype, self.taxes_and_charges)
)

def validate_tax_account_company(self):
for d in self.get("taxes"):
if d.account_head:
tax_account_company = frappe.db.get_value("Account", d.account_head, "company")
tax_account_company = frappe.get_cached_value("Account", d.account_head, "company")
if tax_account_company != self.company:
frappe.throw(
_("Row #{0}: Account {1} does not belong to company {2}").format(
Expand Down Expand Up @@ -929,7 +929,9 @@ def make_exchange_gain_loss_gl_entries(self, gl_entries):
party_account = self.credit_to if is_purchase_invoice else self.debit_to
party_type = "Supplier" if is_purchase_invoice else "Customer"

gain_loss_account = frappe.db.get_value("Company", self.company, "exchange_gain_loss_account")
gain_loss_account = frappe.get_cached_value(
"Company", self.company, "exchange_gain_loss_account"
)
if not gain_loss_account:
frappe.throw(
_("Please set default Exchange Gain/Loss Account in Company {}").format(self.get("company"))
Expand Down Expand Up @@ -1026,7 +1028,7 @@ def update_against_document_in_jv(self):
else self.grand_total
),
"outstanding_amount": self.outstanding_amount,
"difference_account": frappe.db.get_value(
"difference_account": frappe.get_cached_value(
"Company", self.company, "exchange_gain_loss_account"
),
"exchange_gain_loss": flt(d.get("exchange_gain_loss")),
Expand Down Expand Up @@ -1394,7 +1396,7 @@ def set_total_advance_paid(self):
@property
def company_abbr(self):
if not hasattr(self, "_abbr"):
self._abbr = frappe.db.get_value("Company", self.company, "abbr")
self._abbr = frappe.get_cached_value("Company", self.company, "abbr")

return self._abbr

Expand Down Expand Up @@ -1780,7 +1782,7 @@ def set_inter_company_account(self):
"""

if self.is_internal_transfer() and not self.unrealized_profit_loss_account:
unrealized_profit_loss_account = frappe.db.get_value(
unrealized_profit_loss_account = frappe.get_cached_value(
"Company", self.company, "unrealized_profit_loss_account"
)

Expand Down Expand Up @@ -1895,7 +1897,9 @@ def check_finance_books(self, item, asset):

@frappe.whitelist()
def get_tax_rate(account_head):
return frappe.db.get_value("Account", account_head, ["tax_rate", "account_name"], as_dict=True)
return frappe.get_cached_value(
"Account", account_head, ["tax_rate", "account_name"], as_dict=True
)


@frappe.whitelist()
Expand All @@ -1904,7 +1908,7 @@ def get_default_taxes_and_charges(master_doctype, tax_template=None, company=Non
return {}

if tax_template and company:
tax_template_company = frappe.db.get_value(master_doctype, tax_template, "company")
tax_template_company = frappe.get_cached_value(master_doctype, tax_template, "company")
if tax_template_company == company:
return

Expand Down
6 changes: 3 additions & 3 deletions erpnext/controllers/sales_and_purchase_return.py
Expand Up @@ -326,7 +326,7 @@ def make_return_doc(doctype: str, source_name: str, target_doc=None):
from erpnext.stock.doctype.serial_no.serial_no import get_serial_nos

company = frappe.db.get_value("Delivery Note", source_name, "company")
default_warehouse_for_sales_return = frappe.db.get_value(
default_warehouse_for_sales_return = frappe.get_cached_value(
"Company", company, "default_warehouse_for_sales_return"
)

Expand All @@ -340,11 +340,11 @@ def set_missing_values(source, target):

# look for Print Heading "Credit Note"
if not doc.select_print_heading:
doc.select_print_heading = frappe.db.get_value("Print Heading", _("Credit Note"))
doc.select_print_heading = frappe.get_cached_value("Print Heading", _("Credit Note"))

elif doctype == "Purchase Invoice":
# look for Print Heading "Debit Note"
doc.select_print_heading = frappe.db.get_value("Print Heading", _("Debit Note"))
doc.select_print_heading = frappe.get_cached_value("Print Heading", _("Debit Note"))

for tax in doc.get("taxes") or []:
if tax.charge_type == "Actual":
Expand Down
20 changes: 10 additions & 10 deletions erpnext/controllers/stock_controller.py
Expand Up @@ -57,7 +57,7 @@ def make_gl_entries(self, gl_entries=None, from_repost=False):
make_reverse_gl_entries(voucher_type=self.doctype, voucher_no=self.name)

provisional_accounting_for_non_stock_items = cint(
frappe.db.get_value(
frappe.get_cached_value(
"Company", self.company, "enable_provisional_accounting_for_non_stock_items"
)
)
Expand Down Expand Up @@ -200,7 +200,7 @@ def get_gl_entries(
elif self.get("is_internal_supplier"):
warehouse_asset_account = warehouse_account[item_row.get("warehouse")]["account"]

expense_account = frappe.db.get_value("Company", self.company, "default_expense_account")
expense_account = frappe.get_cached_value("Company", self.company, "default_expense_account")

gl_list.append(
self.get_gl_dict(
Expand Down Expand Up @@ -235,7 +235,7 @@ def get_gl_entries(

if warehouse_with_no_account:
for wh in warehouse_with_no_account:
if frappe.db.get_value("Warehouse", wh, "company"):
if frappe.get_cached_value("Warehouse", wh, "company"):
frappe.throw(
_(
"Warehouse {0} is not linked to any account, please mention the account in the warehouse record or set default inventory account in company {1}."
Expand Down Expand Up @@ -449,15 +449,15 @@ def update_inventory_dimensions(self, row, sl_dict) -> None:

# Get value based on doctype name
if not sl_dict.get(dimension.target_fieldname):
fieldname = frappe.get_cached_value(
"DocField", {"parent": self.doctype, "options": dimension.fetch_from_parent}, "fieldname"
fieldname = next(
(
field.fieldname
for field in frappe.get_meta(self.doctype).fields
if field.options == dimension.fetch_from_parent
),
None,
)

if not fieldname:
fieldname = frappe.get_cached_value(
"Custom Field", {"dt": self.doctype, "options": dimension.fetch_from_parent}, "fieldname"
)

if fieldname and self.get(fieldname):
sl_dict[dimension.target_fieldname] = self.get(fieldname)

Expand Down
2 changes: 1 addition & 1 deletion erpnext/controllers/taxes_and_totals.py
Expand Up @@ -1056,7 +1056,7 @@ def set_account_currency(self):
company_currency = erpnext.get_company_currency(self.doc.company)
for d in self.doc.get(self.tax_field):
if not d.account_currency:
account_currency = frappe.db.get_value("Account", d.expense_account, "account_currency")
account_currency = frappe.get_cached_value("Account", d.expense_account, "account_currency")
d.account_currency = account_currency or company_currency

def set_exchange_rate(self):
Expand Down
4 changes: 2 additions & 2 deletions erpnext/controllers/trends.py
Expand Up @@ -80,7 +80,7 @@ def get_data(filters, conditions):
if conditions.get("trans") == "Quotation" and filters.get("group_by") == "Customer":
cond += " and t1.quotation_to = 'Customer'"

year_start_date, year_end_date = frappe.db.get_value(
year_start_date, year_end_date = frappe.get_cached_value(
"Fiscal Year", filters.get("fiscal_year"), ["year_start_date", "year_end_date"]
)

Expand Down Expand Up @@ -275,7 +275,7 @@ def get_period_date_ranges(period, fiscal_year=None, year_start_date=None):
from dateutil.relativedelta import relativedelta

if not year_start_date:
year_start_date, year_end_date = frappe.db.get_value(
year_start_date, year_end_date = frappe.get_cached_value(
"Fiscal Year", fiscal_year, ["year_start_date", "year_end_date"]
)

Expand Down

0 comments on commit 34ca17a

Please sign in to comment.