summary refs log tree commit diff
diff options
context:
space:
mode:
authorPaul "LeoNerd" Evans <paul@matrix.org>2015-02-24 15:49:14 +0000
committerPaul "LeoNerd" Evans <paul@matrix.org>2015-03-12 16:24:50 +0000
commite07fc62833dbbfc9dda7c344f194fc070cfc587f (patch)
tree0fe7a3275d6b3a17524b174899a27596eff2b6b5
parentCommandline option to enable metrics system (diff)
downloadsynapse-e07fc62833dbbfc9dda7c344f194fc070cfc587f.tar.xz
A trivial 'hello world'-style resource on /_synapse/metrics, with optional commandline flag
-rwxr-xr-xsynapse/app/homeserver.py7
-rw-r--r--synapse/metrics/resource.py37
2 files changed, 44 insertions, 0 deletions
diff --git a/synapse/app/homeserver.py b/synapse/app/homeserver.py
index 5df4ba23ab..9747f7a015 100755
--- a/synapse/app/homeserver.py
+++ b/synapse/app/homeserver.py
@@ -147,6 +147,13 @@ class SynapseHomeServer(HomeServer):
         else:
             self.root_resource = Resource()
 
+        if self.get_config().enable_metrics:
+            from synapse.metrics.resource import (
+                MetricsResource, METRICS_PREFIX
+            )
+
+            desired_tree.append((METRICS_PREFIX, MetricsResource(self)))
+
         # ideally we'd just use getChild and putChild but getChild doesn't work
         # unless you give it a Request object IN ADDITION to the name :/ So
         # instead, we'll store a copy of this mapping so we can actually add
diff --git a/synapse/metrics/resource.py b/synapse/metrics/resource.py
new file mode 100644
index 0000000000..b480484624
--- /dev/null
+++ b/synapse/metrics/resource.py
@@ -0,0 +1,37 @@
+# -*- coding: utf-8 -*-
+# Copyright 2015 OpenMarket Ltd
+#
+# 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.
+
+from twisted.web.resource import Resource
+from twisted.web.server import NOT_DONE_YET
+
+
+METRICS_PREFIX = "/_synapse/metrics"
+
+
+class MetricsResource(Resource):
+    isLeaf = True
+
+    def __init__(self, hs):
+        Resource.__init__(self) # Resource is old-style, so no super()
+
+        self.hs = hs
+
+    def render_GET(self, request):
+        response = "Hello, world!"
+
+        request.setHeader("Content-Type", "text/plain")
+        request.setHeader("Content-Length", str(len(response)))
+
+        return response