Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2)

Unified Diff: tools/telemetry/third_party/gsutilz/third_party/protorpc/protorpc/webapp/forms.py

Issue 1264873003: Add gsutil/third_party to telemetry/third_party/gsutilz/third_party. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Remove httplib2 Created 5 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: tools/telemetry/third_party/gsutilz/third_party/protorpc/protorpc/webapp/forms.py
diff --git a/tools/telemetry/third_party/gsutilz/third_party/protorpc/protorpc/webapp/forms.py b/tools/telemetry/third_party/gsutilz/third_party/protorpc/protorpc/webapp/forms.py
new file mode 100755
index 0000000000000000000000000000000000000000..65d3b969673750abe15fc335fa037db1420cd878
--- /dev/null
+++ b/tools/telemetry/third_party/gsutilz/third_party/protorpc/protorpc/webapp/forms.py
@@ -0,0 +1,163 @@
+#!/usr/bin/env python
+#
+# Copyright 2010 Google Inc.
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+
+"""Webapp forms interface to ProtoRPC services.
+
+This webapp application is automatically configured to work with ProtoRPCs
+that have a configured protorpc.RegistryService. This webapp is
+automatically added to the registry service URL at <registry-path>/forms
+(default is /protorpc/form) when configured using the
+service_handlers.service_mapping function.
+"""
+
+import os
+
+from .google_imports import template
+from .google_imports import webapp
+
+
+__all__ = ['FormsHandler',
+ 'ResourceHandler',
+
+ 'DEFAULT_REGISTRY_PATH',
+ ]
+
+_TEMPLATES_DIR = os.path.join(os.path.dirname(os.path.dirname(__file__)),
+ 'static')
+
+_FORMS_TEMPLATE = os.path.join(_TEMPLATES_DIR, 'forms.html')
+_METHODS_TEMPLATE = os.path.join(_TEMPLATES_DIR, 'methods.html')
+
+DEFAULT_REGISTRY_PATH = '/protorpc'
+
+
+class ResourceHandler(webapp.RequestHandler):
+ """Serves static resources without needing to add static files to app.yaml."""
+
+ __RESOURCE_MAP = {
+ 'forms.js': 'text/javascript',
+ 'jquery-1.4.2.min.js': 'text/javascript',
+ 'jquery.json-2.2.min.js': 'text/javascript',
+ }
+
+ def get(self, relative):
+ """Serve known static files.
+
+ If static file is not known, will return 404 to client.
+
+ Response items are cached for 300 seconds.
+
+ Args:
+ relative: Name of static file relative to main FormsHandler.
+ """
+ content_type = self.__RESOURCE_MAP.get(relative, None)
+ if not content_type:
+ self.response.set_status(404)
+ self.response.out.write('Resource not found.')
+ return
+
+ path = os.path.join(_TEMPLATES_DIR, relative)
+ self.response.headers['Content-Type'] = content_type
+ static_file = open(path)
+ try:
+ contents = static_file.read()
+ finally:
+ static_file.close()
+ self.response.out.write(contents)
+
+
+class FormsHandler(webapp.RequestHandler):
+ """Handler for display HTML/javascript forms of ProtoRPC method calls.
+
+ When accessed with no query parameters, will show a web page that displays
+ all services and methods on the associated registry path. Links on this
+ page fill in the service_path and method_name query parameters back to this
+ same handler.
+
+ When provided with service_path and method_name parameters will display a
+ dynamic form representing the request message for that method. When sent,
+ the form sends a JSON request to the ProtoRPC method and displays the
+ response in the HTML page.
+
+ Attribute:
+ registry_path: Read-only registry path known by this handler.
+ """
+
+ def __init__(self, registry_path=DEFAULT_REGISTRY_PATH):
+ """Constructor.
+
+ When configuring a FormsHandler to use with a webapp application do not
+ pass the request handler class in directly. Instead use new_factory to
+ ensure that the FormsHandler is created with the correct registry path
+ for each request.
+
+ Args:
+ registry_path: Absolute path on server where the ProtoRPC RegsitryService
+ is located.
+ """
+ assert registry_path
+ self.__registry_path = registry_path
+
+ @property
+ def registry_path(self):
+ return self.__registry_path
+
+ def get(self):
+ """Send forms and method page to user.
+
+ By default, displays a web page listing all services and methods registered
+ on the server. Methods have links to display the actual method form.
+
+ If both parameters are set, will display form for method.
+
+ Query Parameters:
+ service_path: Path to service to display method of. Optional.
+ method_name: Name of method to display form for. Optional.
+ """
+ params = {'forms_path': self.request.path.rstrip('/'),
+ 'hostname': self.request.host,
+ 'registry_path': self.__registry_path,
+ }
+ service_path = self.request.get('path', None)
+ method_name = self.request.get('method', None)
+
+ if service_path and method_name:
+ form_template = _METHODS_TEMPLATE
+ params['service_path'] = service_path
+ params['method_name'] = method_name
+ else:
+ form_template = _FORMS_TEMPLATE
+
+ self.response.out.write(template.render(form_template, params))
+
+ @classmethod
+ def new_factory(cls, registry_path=DEFAULT_REGISTRY_PATH):
+ """Construct a factory for use with WSGIApplication.
+
+ This method is called automatically with the correct registry path when
+ services are configured via service_handlers.service_mapping.
+
+ Args:
+ registry_path: Absolute path on server where the ProtoRPC RegsitryService
+ is located.
+
+ Returns:
+ Factory function that creates a properly configured FormsHandler instance.
+ """
+ def forms_factory():
+ return cls(registry_path)
+ return forms_factory

Powered by Google App Engine
This is Rietveld 408576698