From: Simo Sorce Date: Thu, 29 May 2014 13:38:18 +0000 (-0400) Subject: Add optional field to allow pasting the metadata X-Git-Tag: v0.2.5~9 X-Git-Url: http://git.cascardo.info/?p=cascardo%2Fipsilon.git;a=commitdiff_plain;h=5c0898a8e0fa977911fde7c24123f834e4792948 Add optional field to allow pasting the metadata This way a user can avoid copying the metadata file arund but paste the content straight from a terminal window. Signed-off-by: Simo Sorce --- diff --git a/ipsilon/providers/saml2/admin.py b/ipsilon/providers/saml2/admin.py index 552d655..5d97126 100755 --- a/ipsilon/providers/saml2/admin.py +++ b/ipsilon/providers/saml2/admin.py @@ -23,6 +23,7 @@ from ipsilon.providers.saml2.provider import ServiceProvider from ipsilon.providers.saml2.provider import ServiceProviderCreator from ipsilon.providers.saml2.provider import InvalidProviderId import re +import requests VALID_IN_NAME = r'[^\ a-zA-Z0-9]' @@ -73,11 +74,25 @@ class NewSPAdminPage(Page): return self.form_new(message, message_type) name = value - elif key == 'meta': + elif key == 'metatext': + if len(value) > 0: + meta = value + elif key == 'metafile': if hasattr(value, 'content_type'): meta = value.fullvalue() else: self._debug("Invalid format for 'meta'") + elif key == 'metaurl': + if len(value) > 0: + try: + r = requests.get(value) + r.raise_for_status() + meta = r.content + except Exception, e: # pylint: disable=broad-except + self._debug("Failed to fetch metadata: " + repr(e)) + message = "Failed to fetch metadata: " + repr(e) + message_type = "error" + return self.form_new(message, message_type) if name and meta: try: diff --git a/templates/admin/providers/saml2_sp_new.html b/templates/admin/providers/saml2_sp_new.html index 46e4906..b3cef19 100644 --- a/templates/admin/providers/saml2_sp_new.html +++ b/templates/admin/providers/saml2_sp_new.html @@ -17,10 +17,24 @@
- - Metadata file: +
+ - OR - +
+ + +
+ - OR - +
+ +
+ +