選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。
 
 
 
 
 
 

71 行
2.1 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 hmac
  5. import urllib
  6. from frappe import _
  7. import frappe
  8. import frappe.utils
  9. def get_signed_params(params):
  10. """Sign a url by appending `&_signature=xxxxx` to given params (string or dict).
  11. :param params: String or dict of parameters."""
  12. if not isinstance(params, basestring):
  13. params = urllib.urlencode(params)
  14. signature = hmac.new(params)
  15. signature.update(get_secret())
  16. return params + "&_signature=" + signature.hexdigest()
  17. def get_secret():
  18. return frappe.local.conf.get("secret") or str(frappe.db.get_value("User", "Administrator", "creation"))
  19. def verify_request():
  20. """Verify if the incoming signed request if it is correct."""
  21. query_string = frappe.local.flags.signed_query_string or \
  22. getattr(frappe.request, 'query_string', None) \
  23. valid = False
  24. if '&_signature=' in query_string:
  25. params, signature = query_string.split("&_signature=")
  26. given_signature = hmac.new(params.encode("utf-8"))
  27. given_signature.update(get_secret())
  28. valid = signature == given_signature.hexdigest()
  29. if not valid:
  30. frappe.respond_as_web_page(_("Invalid Link"),
  31. _("This link is invalid or expired. Please make sure you have pasted correctly."))
  32. return valid
  33. def get_url(cmd, params, nonce=None, secret=None):
  34. if not nonce:
  35. nonce = params
  36. signature = get_signature(params, nonce, secret)
  37. params['signature'] = signature
  38. return frappe.utils.get_url("".join(['api/method/', cmd, '?', urllib.urlencode(params)]))
  39. def get_signature(params, nonce, secret=None):
  40. params = "".join((frappe.utils.cstr(p) for p in params.values()))
  41. if not secret:
  42. secret = frappe.local.conf.get("secret") or "secret"
  43. signature = hmac.new(str(nonce))
  44. signature.update(secret)
  45. signature.update(params)
  46. return signature.hexdigest()
  47. def verify_using_doc(doc, signature, cmd):
  48. params = doc.get_signature_params()
  49. return signature == get_signature(params, doc.get_nonce())
  50. def get_url_using_doc(doc, cmd):
  51. params = doc.get_signature_params()
  52. return get_url(cmd, params, doc.get_nonce())