You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

185 lines
5.0 KiB

  1. # Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
  2. # MIT License. See license.txt
  3. from __future__ import unicode_literals
  4. import frappe
  5. from frappe import _
  6. import frappe.model
  7. import frappe.utils
  8. import json, os
  9. @frappe.whitelist()
  10. def get_list(doctype, fields=None, filters=None, order_by=None,
  11. limit_start=None, limit_page_length=20):
  12. return frappe.get_list(doctype, fields=fields, filters=filters, order_by=order_by,
  13. limit_start=limit_start, limit_page_length=limit_page_length, ignore_permissions=False)
  14. @frappe.whitelist()
  15. def get(doctype, name=None, filters=None):
  16. if filters and not name:
  17. name = frappe.db.get_value(doctype, json.loads(filters))
  18. if not name:
  19. raise Exception, "No document found for given filters"
  20. doc = frappe.get_doc(doctype, name)
  21. if not doc.has_permission("read"):
  22. raise frappe.PermissionError
  23. return frappe.get_doc(doctype, name).as_dict()
  24. @frappe.whitelist()
  25. def get_value(doctype, fieldname, filters=None, as_dict=True, debug=False):
  26. if not frappe.has_permission(doctype):
  27. frappe.throw(_("Not permitted"), frappe.PermissionError)
  28. try:
  29. filters = json.loads(filters)
  30. except ValueError:
  31. # name passed, not json
  32. pass
  33. try:
  34. fieldname = json.loads(fieldname)
  35. except ValueError:
  36. # name passed, not json
  37. pass
  38. return frappe.db.get_value(doctype, filters, fieldname, as_dict=as_dict, debug=debug)
  39. @frappe.whitelist()
  40. def set_value(doctype, name, fieldname, value):
  41. if fieldname!="idx" and fieldname in frappe.model.default_fields:
  42. frappe.throw(_("Cannot edit standard fields"))
  43. doc = frappe.db.get_value(doctype, name, ["parenttype", "parent"], as_dict=True)
  44. if doc and doc.parent and doc.parenttype:
  45. doc = frappe.get_doc(doc.parenttype, doc.parent)
  46. child = doc.getone({"doctype": doctype, "name": name})
  47. child.set(fieldname, value)
  48. else:
  49. doc = frappe.get_doc(doctype, name)
  50. df = doc.meta.get_field(fieldname)
  51. if df.fieldtype == "Read Only" or df.read_only:
  52. frappe.throw(_("Can not edit Read Only fields"))
  53. else:
  54. doc.set(fieldname, value)
  55. doc.save()
  56. return doc.as_dict()
  57. @frappe.whitelist()
  58. def insert(doc=None):
  59. if isinstance(doc, basestring):
  60. doc = json.loads(doc)
  61. if doc.get("parent") and doc.get("parenttype"):
  62. # inserting a child record
  63. parent = frappe.get_doc(doc.get("parenttype"), doc.get("parent"))
  64. parent.append(doc.get("parentfield"), doc)
  65. parent.save()
  66. return parent.as_dict()
  67. else:
  68. doc = frappe.get_doc(doc).insert()
  69. return doc.as_dict()
  70. @frappe.whitelist()
  71. def save(doc):
  72. if isinstance(doc, basestring):
  73. doc = json.loads(doc)
  74. doc = frappe.get_doc(doc).save()
  75. return doc.as_dict()
  76. @frappe.whitelist()
  77. def rename_doc(doctype, old_name, new_name, merge=False):
  78. new_name = frappe.rename_doc(doctype, old_name, new_name, merge=merge)
  79. return new_name
  80. @frappe.whitelist()
  81. def submit(doc):
  82. if isinstance(doc, basestring):
  83. doc = json.loads(doc)
  84. doc = frappe.get_doc(doc)
  85. doc.submit()
  86. return doc.as_dict()
  87. @frappe.whitelist()
  88. def cancel(doctype, name):
  89. wrapper = frappe.get_doc(doctype, name)
  90. wrapper.cancel()
  91. return wrapper.as_dict()
  92. @frappe.whitelist()
  93. def delete(doctype, name):
  94. frappe.delete_doc(doctype, name)
  95. @frappe.whitelist()
  96. def set_default(key, value, parent=None):
  97. """set a user default value"""
  98. frappe.db.set_default(key, value, parent or frappe.session.user)
  99. frappe.clear_cache(user=frappe.session.user)
  100. @frappe.whitelist()
  101. def make_width_property_setter(doc):
  102. if isinstance(doc, basestring):
  103. doc = json.loads(doc)
  104. if doc["doctype"]=="Property Setter" and doc["property"]=="width":
  105. frappe.get_doc(doc).insert(ignore_permissions = True)
  106. @frappe.whitelist()
  107. def bulk_update(docs):
  108. docs = json.loads(docs)
  109. failed_docs = []
  110. for doc in docs:
  111. try:
  112. ddoc = {key: val for key, val in doc.iteritems() if key not in ['doctype', 'docname']}
  113. doctype = doc['doctype']
  114. docname = doc['docname']
  115. doc = frappe.get_doc(doctype, docname)
  116. doc.update(ddoc)
  117. doc.save()
  118. except:
  119. failed_docs.append({
  120. 'doc': doc,
  121. 'exc': frappe.utils.get_traceback()
  122. })
  123. return {'failed_docs': failed_docs}
  124. @frappe.whitelist()
  125. def has_permission(doctype, docname, perm_type="read"):
  126. # perm_type can be one of read, write, create, submit, cancel, report
  127. return {"has_permission": frappe.has_permission(doctype, perm_type.lower(), docname)}
  128. @frappe.whitelist()
  129. def get_password(doctype, name, fieldname):
  130. frappe.only_for("System Manager")
  131. return frappe.get_doc(doctype, name).get_password(fieldname)
  132. @frappe.whitelist()
  133. def get_js(items):
  134. items = json.loads(items)
  135. out = []
  136. for src in items:
  137. src = src.strip("/").split("/")
  138. if ".." in src:
  139. frappe.throw(_("Invalid file path: {0}").format("/".join(src)))
  140. contentpath = os.path.join(frappe.local.sites_path, *src)
  141. with open(contentpath, "r") as srcfile:
  142. code = frappe.utils.cstr(srcfile.read())
  143. if frappe.local.lang != "en":
  144. messages = frappe.get_lang_dict("jsfile", contentpath)
  145. messages = json.dumps(messages)
  146. code += "\n\n$.extend(frappe._messages, {})".format(messages)
  147. out.append(code)
  148. return out