No puede seleccionar más de 25 temas Los temas deben comenzar con una letra o número, pueden incluir guiones ('-') y pueden tener hasta 35 caracteres de largo.
 
 
 
 
 
 

137 líneas
3.6 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.utils
  7. import frappe.async
  8. import frappe.sessions
  9. import frappe.utils.file_manager
  10. import frappe.desk.form.run_method
  11. from frappe.utils.response import build_response
  12. from werkzeug.wrappers import Response
  13. def handle():
  14. """handle request"""
  15. cmd = frappe.local.form_dict.cmd
  16. data = None
  17. if cmd!='login':
  18. data = execute_cmd(cmd)
  19. if data:
  20. if isinstance(data, Response):
  21. # method returns a response object, pass it on
  22. return data
  23. # add the response to `message` label
  24. frappe.response['message'] = data
  25. return build_response("json")
  26. def execute_cmd(cmd, from_async=False):
  27. """execute a request as python module"""
  28. for hook in frappe.get_hooks("override_whitelisted_methods", {}).get(cmd, []):
  29. # override using the first hook
  30. cmd = hook
  31. break
  32. try:
  33. method = get_attr(cmd)
  34. except:
  35. frappe.respond_as_web_page(title='Invalid Method', html='Method not found',
  36. indicator_color='red', http_status_code=404)
  37. return
  38. if from_async:
  39. method = method.queue
  40. is_whitelisted(method)
  41. return frappe.call(method, **frappe.form_dict)
  42. def is_whitelisted(method):
  43. # check if whitelisted
  44. if frappe.session['user'] == 'Guest':
  45. if (method not in frappe.guest_methods):
  46. frappe.msgprint(_("Not permitted"))
  47. raise frappe.PermissionError('Not Allowed, {0}'.format(method))
  48. if method not in frappe.xss_safe_methods:
  49. # strictly sanitize form_dict
  50. # escapes html characters like <> except for predefined tags like a, b, ul etc.
  51. for key, value in frappe.form_dict.items():
  52. if isinstance(value, basestring):
  53. frappe.form_dict[key] = frappe.utils.sanitize_html(value)
  54. else:
  55. if not method in frappe.whitelisted:
  56. frappe.msgprint(_("Not permitted"))
  57. raise frappe.PermissionError('Not Allowed, {0}'.format(method))
  58. @frappe.whitelist(allow_guest=True)
  59. def version():
  60. return frappe.__version__
  61. @frappe.whitelist()
  62. def runserverobj(method, docs=None, dt=None, dn=None, arg=None, args=None):
  63. frappe.desk.form.run_method.runserverobj(method, docs=docs, dt=dt, dn=dn, arg=arg, args=args)
  64. @frappe.whitelist(allow_guest=True)
  65. def logout():
  66. frappe.local.login_manager.logout()
  67. frappe.db.commit()
  68. @frappe.whitelist(allow_guest=True)
  69. def web_logout():
  70. frappe.local.login_manager.logout()
  71. frappe.db.commit()
  72. frappe.respond_as_web_page(_("Logged Out"), _("You have been successfully logged out"),
  73. indicator_color='green')
  74. @frappe.whitelist(allow_guest=True)
  75. def run_custom_method(doctype, name, custom_method):
  76. """cmd=run_custom_method&doctype={doctype}&name={name}&custom_method={custom_method}"""
  77. doc = frappe.get_doc(doctype, name)
  78. if getattr(doc, custom_method, frappe._dict()).is_whitelisted:
  79. frappe.call(getattr(doc, custom_method), **frappe.local.form_dict)
  80. else:
  81. frappe.throw(_("Not permitted"), frappe.PermissionError)
  82. @frappe.whitelist()
  83. def uploadfile():
  84. try:
  85. if frappe.form_dict.get('from_form'):
  86. try:
  87. ret = frappe.utils.file_manager.upload()
  88. except frappe.DuplicateEntryError:
  89. # ignore pass
  90. ret = None
  91. frappe.db.rollback()
  92. else:
  93. if frappe.form_dict.get('method'):
  94. method = frappe.get_attr(frappe.form_dict.method)
  95. is_whitelisted(method)
  96. ret = method()
  97. except Exception:
  98. frappe.errprint(frappe.utils.get_traceback())
  99. ret = None
  100. return ret
  101. def get_attr(cmd):
  102. """get method object from cmd"""
  103. if '.' in cmd:
  104. method = frappe.get_attr(cmd)
  105. else:
  106. method = globals()[cmd]
  107. frappe.log("method:" + cmd)
  108. return method
  109. @frappe.whitelist()
  110. def ping():
  111. return "pong"