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.
 
 
 
 
 
 

124 rivejä
3.4 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, os, json
  5. from frappe.modules import get_module_path, scrub_dt_dn
  6. from frappe.utils import get_datetime_str
  7. def import_files(module, dt=None, dn=None, force=False, pre_process=None):
  8. if type(module) is list:
  9. out = []
  10. for m in module:
  11. out.append(import_file(m[0], m[1], m[2], force=force, pre_process=pre_process))
  12. return out
  13. else:
  14. return import_file(module, dt, dn, force=force, pre_process=pre_process)
  15. def import_file(module, dt, dn, force=False, pre_process=None):
  16. """Sync a file from txt if modifed, return false if not updated"""
  17. path = get_file_path(module, dt, dn)
  18. ret = import_file_by_path(path, force, pre_process=pre_process)
  19. return ret
  20. def get_file_path(module, dt, dn):
  21. dt, dn = scrub_dt_dn(dt, dn)
  22. path = os.path.join(get_module_path(module),
  23. os.path.join(dt, dn, dn + ".json"))
  24. return path
  25. def import_file_by_path(path, force=False, data_import=False, pre_process=None):
  26. frappe.flags.in_import = True
  27. try:
  28. docs = read_doc_from_file(path)
  29. except IOError:
  30. print path + " missing"
  31. return
  32. if docs:
  33. if not isinstance(docs, list):
  34. docs = [docs]
  35. for doc in docs:
  36. if not force:
  37. # check if timestamps match
  38. db_modified = frappe.db.get_value(doc['doctype'], doc['name'], 'modified')
  39. if db_modified and doc.get('modified')==get_datetime_str(db_modified):
  40. return False
  41. original_modified = doc.get("modified")
  42. import_doc(doc, force=force, data_import=data_import, pre_process=pre_process)
  43. if original_modified:
  44. # since there is a new timestamp on the file, update timestamp in
  45. if doc["doctype"] == doc["name"] and doc["name"]!="DocType":
  46. frappe.db.sql("""update tabSingles set value=%s where field="modified" and doctype=%s""",
  47. (original_modified, doc["name"]))
  48. else:
  49. frappe.db.sql("update `tab%s` set modified=%s where name=%s" % \
  50. (doc['doctype'], '%s', '%s'),
  51. (original_modified, doc['name']))
  52. frappe.flags.in_import = False
  53. return True
  54. def read_doc_from_file(path):
  55. doc = None
  56. if os.path.exists(path):
  57. with open(path, 'r') as f:
  58. try:
  59. doc = json.loads(f.read())
  60. except ValueError:
  61. print "bad json: {0}".format(path)
  62. raise
  63. else:
  64. raise IOError, '%s missing' % path
  65. return doc
  66. ignore_values = {
  67. "Report": ["disabled"],
  68. "Print Format": ["disabled"]
  69. }
  70. ignore_doctypes = ["Page Role", "DocPerm"]
  71. def import_doc(docdict, force=False, data_import=False, pre_process=None):
  72. frappe.flags.in_import = True
  73. docdict["__islocal"] = 1
  74. doc = frappe.get_doc(docdict)
  75. if pre_process:
  76. pre_process(doc)
  77. ignore = []
  78. if frappe.db.exists(doc.doctype, doc.name):
  79. old_doc = frappe.get_doc(doc.doctype, doc.name)
  80. if doc.doctype in ignore_values and not force:
  81. # update ignore values
  82. for key in ignore_values.get(doc.doctype) or []:
  83. doc.set(key, old_doc.get(key))
  84. # update ignored docs into new doc
  85. for df in doc.meta.get_table_fields():
  86. if df.options in ignore_doctypes and not force:
  87. doc.set(df.fieldname, [])
  88. ignore.append(df.options)
  89. # delete old
  90. frappe.delete_doc(doc.doctype, doc.name, force=1, ignore_doctypes=ignore, for_reload=True)
  91. doc.flags.ignore_children_type = ignore
  92. doc.flags.ignore_links = True
  93. if not data_import:
  94. doc.flags.ignore_validate = True
  95. doc.flags.ignore_permissions = True
  96. doc.flags.ignore_mandatory = True
  97. doc.insert()
  98. frappe.flags.in_import = False