Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with
or
.
Download ZIP
Browse files

Created a pylon project and merged the code into it.

  • Loading branch information...
commit a8cddd7b2e45b0297d3b5961b9e08e7f3ffcc964 1 parent 2d17cfd
@jbohman authored
Showing with 907 additions and 12 deletions.
  1. +3 −0  MANIFEST.in
  2. +1 −1  config.yaml
  3. +72 −0 development.ini
  4. +19 −0 docs/index.txt
  5. +276 −0 ez_setup.py
  6. +10 −0 logsandra.egg-info/PKG-INFO
  7. +44 −0 logsandra.egg-info/SOURCES.txt
  8. +1 −0  logsandra.egg-info/dependency_links.txt
  9. +7 −0 logsandra.egg-info/entry_points.txt
  10. +1 −0  logsandra.egg-info/not-zip-safe
  11. +2 −0  logsandra.egg-info/paster_plugins.txt
  12. +2 −0  logsandra.egg-info/requires.txt
  13. +1 −0  logsandra.egg-info/top_level.txt
  14. +0 −1  logsandra/__init__.py
  15. +60 −0 logsandra/config/deployment.ini_tmpl
  16. +43 −0 logsandra/config/environment.py
  17. +67 −0 logsandra/config/middleware.py
  18. +27 −0 logsandra/config/routing.py
  19. 0  logsandra/controllers/__init__.py
  20. +44 −0 logsandra/controllers/error.py
  21. +13 −0 logsandra/controllers/index.py
  22. 0  logsandra/lib/__init__.py
  23. +18 −0 logsandra/lib/app_globals.py
  24. +15 −0 logsandra/lib/base.py
  25. +7 −0 logsandra/lib/helpers.py
  26. 0  logsandra/model/__init__.py
  27. 0  logsandra/monitor/monitor.py
  28. +1 −0  logsandra/public/test.html
  29. +16 −0 logsandra/templates/base.html
  30. +5 −0 logsandra/templates/index.html
  31. +34 −0 logsandra/tests/__init__.py
  32. 0  logsandra/tests/functional/__init__.py
  33. 0  logsandra/tests/test_models.py
  34. +14 −0 logsandra/websetup.py
  35. +16 −10 logsandra/logsandra.py → run.py
  36. +31 −0 setup.cfg
  37. +36 −0 setup.py
  38. +21 −0 test.ini
View
3  MANIFEST.in
@@ -0,0 +1,3 @@
+include logsandra/config/deployment.ini_tmpl
+recursive-include logsandra/public *
+recursive-include logsandra/templates *
View
2  config.yaml
@@ -4,7 +4,7 @@ ident: 'Logsandra Example Server 1'
# Webservice
webservice_enabled: True
webservice_address: localhost
-webservice_port: 8080
+webservice_port: 5000
# Cassandra cluster to connect to
cassandra_address: localhost
View
72 development.ini
@@ -0,0 +1,72 @@
+#
+# logsandra - Pylons development environment configuration
+#
+# The %(here)s variable will be replaced with the parent directory of this file
+#
+[DEFAULT]
+debug = true
+# Uncomment and replace with the address which should receive any error reports
+#email_to = you@yourdomain.com
+smtp_server = localhost
+error_email_from = paste@localhost
+
+[server:main]
+use = egg:Paste#http
+host = 127.0.0.1
+port = 5000
+
+[app:main]
+use = egg:logsandra
+full_stack = true
+static_files = true
+
+cache_dir = %(here)s/data
+beaker.session.key = logsandra
+beaker.session.secret = somesecret
+
+# If you'd like to fine-tune the individual locations of the cache data dirs
+# for the Cache data, or the Session saves, un-comment the desired settings
+# here:
+#beaker.cache.data_dir = %(here)s/data/cache
+#beaker.session.data_dir = %(here)s/data/sessions
+
+# WARNING: *THE LINE BELOW MUST BE UNCOMMENTED ON A PRODUCTION ENVIRONMENT*
+# Debug mode will enable the interactive debugging tool, allowing ANYONE to
+# execute malicious code after an exception is raised.
+#set debug = false
+
+
+# Logging configuration
+[loggers]
+keys = root, routes, logsandra
+
+[handlers]
+keys = console
+
+[formatters]
+keys = generic
+
+[logger_root]
+level = INFO
+handlers = console
+
+[logger_routes]
+level = INFO
+handlers =
+qualname = routes.middleware
+# "level = DEBUG" logs the route matched and routing variables.
+
+[logger_logsandra]
+level = DEBUG
+handlers =
+qualname = logsandra
+
+[handler_console]
+class = StreamHandler
+args = (sys.stderr,)
+level = NOTSET
+formatter = generic
+
+[formatter_generic]
+format = %(asctime)s,%(msecs)03d %(levelname)-5.5s [%(name)s] [%(threadName)s] %(message)s
+datefmt = %H:%M:%S
View
19 docs/index.txt
@@ -0,0 +1,19 @@
+logsandra
++++++++++
+
+This is the main index page of your documentation. It should be written in
+`reStructuredText format <http://docutils.sourceforge.net/rst.html>`_.
+
+You can generate your documentation in HTML format by running this command::
+
+ setup.py pudge
+
+For this to work you will need to download and install `buildutils`_,
+`pudge`_, and `pygments`_. The ``pudge`` command is disabled by
+default; to ativate it in your project, run::
+
+ setup.py addcommand -p buildutils.pudge_command
+
+.. _buildutils: http://pypi.python.org/pypi/buildutils
+.. _pudge: http://pudge.lesscode.org/
+.. _pygments: http://pygments.org/
View
276 ez_setup.py
@@ -0,0 +1,276 @@
+#!python
+"""Bootstrap setuptools installation
+
+If you want to use setuptools in your package's setup.py, just include this
+file in the same directory with it, and add this to the top of your setup.py::
+
+ from ez_setup import use_setuptools
+ use_setuptools()
+
+If you want to require a specific version of setuptools, set a download
+mirror, or use an alternate download directory, you can do so by supplying
+the appropriate options to ``use_setuptools()``.
+
+This file can also be run as a script to install or upgrade setuptools.
+"""
+import sys
+DEFAULT_VERSION = "0.6c9"
+DEFAULT_URL = "http://pypi.python.org/packages/%s/s/setuptools/" % sys.version[:3]
+
+md5_data = {
+ 'setuptools-0.6b1-py2.3.egg': '8822caf901250d848b996b7f25c6e6ca',
+ 'setuptools-0.6b1-py2.4.egg': 'b79a8a403e4502fbb85ee3f1941735cb',
+ 'setuptools-0.6b2-py2.3.egg': '5657759d8a6d8fc44070a9d07272d99b',
+ 'setuptools-0.6b2-py2.4.egg': '4996a8d169d2be661fa32a6e52e4f82a',
+ 'setuptools-0.6b3-py2.3.egg': 'bb31c0fc7399a63579975cad9f5a0618',
+ 'setuptools-0.6b3-py2.4.egg': '38a8c6b3d6ecd22247f179f7da669fac',
+ 'setuptools-0.6b4-py2.3.egg': '62045a24ed4e1ebc77fe039aa4e6f7e5',
+ 'setuptools-0.6b4-py2.4.egg': '4cb2a185d228dacffb2d17f103b3b1c4',
+ 'setuptools-0.6c1-py2.3.egg': 'b3f2b5539d65cb7f74ad79127f1a908c',
+ 'setuptools-0.6c1-py2.4.egg': 'b45adeda0667d2d2ffe14009364f2a4b',
+ 'setuptools-0.6c2-py2.3.egg': 'f0064bf6aa2b7d0f3ba0b43f20817c27',
+ 'setuptools-0.6c2-py2.4.egg': '616192eec35f47e8ea16cd6a122b7277',
+ 'setuptools-0.6c3-py2.3.egg': 'f181fa125dfe85a259c9cd6f1d7b78fa',
+ 'setuptools-0.6c3-py2.4.egg': 'e0ed74682c998bfb73bf803a50e7b71e',
+ 'setuptools-0.6c3-py2.5.egg': 'abef16fdd61955514841c7c6bd98965e',
+ 'setuptools-0.6c4-py2.3.egg': 'b0b9131acab32022bfac7f44c5d7971f',
+ 'setuptools-0.6c4-py2.4.egg': '2a1f9656d4fbf3c97bf946c0a124e6e2',
+ 'setuptools-0.6c4-py2.5.egg': '8f5a052e32cdb9c72bcf4b5526f28afc',
+ 'setuptools-0.6c5-py2.3.egg': 'ee9fd80965da04f2f3e6b3576e9d8167',
+ 'setuptools-0.6c5-py2.4.egg': 'afe2adf1c01701ee841761f5bcd8aa64',
+ 'setuptools-0.6c5-py2.5.egg': 'a8d3f61494ccaa8714dfed37bccd3d5d',
+ 'setuptools-0.6c6-py2.3.egg': '35686b78116a668847237b69d549ec20',
+ 'setuptools-0.6c6-py2.4.egg': '3c56af57be3225019260a644430065ab',
+ 'setuptools-0.6c6-py2.5.egg': 'b2f8a7520709a5b34f80946de5f02f53',
+ 'setuptools-0.6c7-py2.3.egg': '209fdf9adc3a615e5115b725658e13e2',
+ 'setuptools-0.6c7-py2.4.egg': '5a8f954807d46a0fb67cf1f26c55a82e',
+ 'setuptools-0.6c7-py2.5.egg': '45d2ad28f9750e7434111fde831e8372',
+ 'setuptools-0.6c8-py2.3.egg': '50759d29b349db8cfd807ba8303f1902',
+ 'setuptools-0.6c8-py2.4.egg': 'cba38d74f7d483c06e9daa6070cce6de',
+ 'setuptools-0.6c8-py2.5.egg': '1721747ee329dc150590a58b3e1ac95b',
+ 'setuptools-0.6c9-py2.3.egg': 'a83c4020414807b496e4cfbe08507c03',
+ 'setuptools-0.6c9-py2.4.egg': '260a2be2e5388d66bdaee06abec6342a',
+ 'setuptools-0.6c9-py2.5.egg': 'fe67c3e5a17b12c0e7c541b7ea43a8e6',
+ 'setuptools-0.6c9-py2.6.egg': 'ca37b1ff16fa2ede6e19383e7b59245a',
+}
+
+import sys, os
+try: from hashlib import md5
+except ImportError: from md5 import md5
+
+def _validate_md5(egg_name, data):
+ if egg_name in md5_data:
+ digest = md5(data).hexdigest()
+ if digest != md5_data[egg_name]:
+ print >>sys.stderr, (
+ "md5 validation of %s failed! (Possible download problem?)"
+ % egg_name
+ )
+ sys.exit(2)
+ return data
+
+def use_setuptools(
+ version=DEFAULT_VERSION, download_base=DEFAULT_URL, to_dir=os.curdir,
+ download_delay=15
+):
+ """Automatically find/download setuptools and make it available on sys.path
+
+ `version` should be a valid setuptools version number that is available
+ as an egg for download under the `download_base` URL (which should end with
+ a '/'). `to_dir` is the directory where setuptools will be downloaded, if
+ it is not already available. If `download_delay` is specified, it should
+ be the number of seconds that will be paused before initiating a download,
+ should one be required. If an older version of setuptools is installed,
+ this routine will print a message to ``sys.stderr`` and raise SystemExit in
+ an attempt to abort the calling script.
+ """
+ was_imported = 'pkg_resources' in sys.modules or 'setuptools' in sys.modules
+ def do_download():
+ egg = download_setuptools(version, download_base, to_dir, download_delay)
+ sys.path.insert(0, egg)
+ import setuptools; setuptools.bootstrap_install_from = egg
+ try:
+ import pkg_resources
+ except ImportError:
+ return do_download()
+ try:
+ pkg_resources.require("setuptools>="+version); return
+ except pkg_resources.VersionConflict, e:
+ if was_imported:
+ print >>sys.stderr, (
+ "The required version of setuptools (>=%s) is not available, and\n"
+ "can't be installed while this script is running. Please install\n"
+ " a more recent version first, using 'easy_install -U setuptools'."
+ "\n\n(Currently using %r)"
+ ) % (version, e.args[0])
+ sys.exit(2)
+ else:
+ del pkg_resources, sys.modules['pkg_resources'] # reload ok
+ return do_download()
+ except pkg_resources.DistributionNotFound:
+ return do_download()
+
+def download_setuptools(
+ version=DEFAULT_VERSION, download_base=DEFAULT_URL, to_dir=os.curdir,
+ delay = 15
+):
+ """Download setuptools from a specified location and return its filename
+
+ `version` should be a valid setuptools version number that is available
+ as an egg for download under the `download_base` URL (which should end
+ with a '/'). `to_dir` is the directory where the egg will be downloaded.
+ `delay` is the number of seconds to pause before an actual download attempt.
+ """
+ import urllib2, shutil
+ egg_name = "setuptools-%s-py%s.egg" % (version,sys.version[:3])
+ url = download_base + egg_name
+ saveto = os.path.join(to_dir, egg_name)
+ src = dst = None
+ if not os.path.exists(saveto): # Avoid repeated downloads
+ try:
+ from distutils import log
+ if delay:
+ log.warn("""
+---------------------------------------------------------------------------
+This script requires setuptools version %s to run (even to display
+help). I will attempt to download it for you (from
+%s), but
+you may need to enable firewall access for this script first.
+I will start the download in %d seconds.
+
+(Note: if this machine does not have network access, please obtain the file
+
+ %s
+
+and place it in this directory before rerunning this script.)
+---------------------------------------------------------------------------""",
+ version, download_base, delay, url
+ ); from time import sleep; sleep(delay)
+ log.warn("Downloading %s", url)
+ src = urllib2.urlopen(url)
+ # Read/write all in one block, so we don't create a corrupt file
+ # if the download is interrupted.
+ data = _validate_md5(egg_name, src.read())
+ dst = open(saveto,"wb"); dst.write(data)
+ finally:
+ if src: src.close()
+ if dst: dst.close()
+ return os.path.realpath(saveto)
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+def main(argv, version=DEFAULT_VERSION):
+ """Install or upgrade setuptools and EasyInstall"""
+ try:
+ import setuptools
+ except ImportError:
+ egg = None
+ try:
+ egg = download_setuptools(version, delay=0)
+ sys.path.insert(0,egg)
+ from setuptools.command.easy_install import main
+ return main(list(argv)+[egg]) # we're done here
+ finally:
+ if egg and os.path.exists(egg):
+ os.unlink(egg)
+ else:
+ if setuptools.__version__ == '0.0.1':
+ print >>sys.stderr, (
+ "You have an obsolete version of setuptools installed. Please\n"
+ "remove it from your system entirely before rerunning this script."
+ )
+ sys.exit(2)
+
+ req = "setuptools>="+version
+ import pkg_resources
+ try:
+ pkg_resources.require(req)
+ except pkg_resources.VersionConflict:
+ try:
+ from setuptools.command.easy_install import main
+ except ImportError:
+ from easy_install import main
+ main(list(argv)+[download_setuptools(delay=0)])
+ sys.exit(0) # try to force an exit
+ else:
+ if argv:
+ from setuptools.command.easy_install import main
+ main(argv)
+ else:
+ print "Setuptools version",version,"or greater has been installed."
+ print '(Run "ez_setup.py -U setuptools" to reinstall or upgrade.)'
+
+def update_md5(filenames):
+ """Update our built-in md5 registry"""
+
+ import re
+
+ for name in filenames:
+ base = os.path.basename(name)
+ f = open(name,'rb')
+ md5_data[base] = md5(f.read()).hexdigest()
+ f.close()
+
+ data = [" %r: %r,\n" % it for it in md5_data.items()]
+ data.sort()
+ repl = "".join(data)
+
+ import inspect
+ srcfile = inspect.getsourcefile(sys.modules[__name__])
+ f = open(srcfile, 'rb'); src = f.read(); f.close()
+
+ match = re.search("\nmd5_data = {\n([^}]+)}", src)
+ if not match:
+ print >>sys.stderr, "Internal error!"
+ sys.exit(2)
+
+ src = src[:match.start(1)] + repl + src[match.end(1):]
+ f = open(srcfile,'w')
+ f.write(src)
+ f.close()
+
+
+if __name__=='__main__':
+ if len(sys.argv)>2 and sys.argv[1]=='--md5update':
+ update_md5(sys.argv[2:])
+ else:
+ main(sys.argv[1:])
+
+
+
+
+
+
View
10 logsandra.egg-info/PKG-INFO
@@ -0,0 +1,10 @@
+Metadata-Version: 1.0
+Name: logsandra
+Version: 0.1dev
+Summary: UNKNOWN
+Home-page: UNKNOWN
+Author: UNKNOWN
+Author-email: UNKNOWN
+License: UNKNOWN
+Description: UNKNOWN
+Platform: UNKNOWN
View
44 logsandra.egg-info/SOURCES.txt
@@ -0,0 +1,44 @@
+MANIFEST.in
+README
+setup.cfg
+setup.py
+logsandra/__init__.py
+logsandra/logsandra.py
+logsandra/websetup.py
+logsandra.egg-info/PKG-INFO
+logsandra.egg-info/SOURCES.txt
+logsandra.egg-info/dependency_links.txt
+logsandra.egg-info/entry_points.txt
+logsandra.egg-info/not-zip-safe
+logsandra.egg-info/paster_plugins.txt
+logsandra.egg-info/requires.txt
+logsandra.egg-info/top_level.txt
+logsandra/config/__init__.py
+logsandra/config/deployment.ini_tmpl
+logsandra/config/environment.py
+logsandra/config/middleware.py
+logsandra/config/routing.py
+logsandra/controllers/__init__.py
+logsandra/controllers/error.py
+logsandra/lib/__init__.py
+logsandra/lib/app_globals.py
+logsandra/lib/base.py
+logsandra/lib/helpers.py
+logsandra/model/__init__.py
+logsandra/monitor/__init__.py
+logsandra/monitor/monitor.py
+logsandra/monitor/test.py
+logsandra/monitor/parsers/__init__.py
+logsandra/monitor/parsers/clf.py
+logsandra/monitor/watchers/__init__.py
+logsandra/monitor/watchers/inotify.py
+logsandra/monitor/watchers/standard.py
+logsandra/public/bg.png
+logsandra/public/favicon.ico
+logsandra/public/index.html
+logsandra/public/pylons-logo.gif
+logsandra/tests/__init__.py
+logsandra/tests/test_models.py
+logsandra/tests/functional/__init__.py
+logsandra/utils/__init__.py
+logsandra/utils/daemon.py
View
1  logsandra.egg-info/dependency_links.txt
@@ -0,0 +1 @@
+
View
7 logsandra.egg-info/entry_points.txt
@@ -0,0 +1,7 @@
+
+ [paste.app_factory]
+ main = logsandra.config.middleware:make_app
+
+ [paste.app_install]
+ main = pylons.util:PylonsInstaller
+
View
1  logsandra.egg-info/not-zip-safe
@@ -0,0 +1 @@
+
View
2  logsandra.egg-info/paster_plugins.txt
@@ -0,0 +1,2 @@
+PasteScript
+Pylons
View
2  logsandra.egg-info/requires.txt
@@ -0,0 +1,2 @@
+Pylons>=1.0
+Jinja2
View
1  logsandra.egg-info/top_level.txt
@@ -0,0 +1 @@
+logsandra
View
1  logsandra/__init__.py
@@ -1 +0,0 @@
-VERSION = (0, 1)
View
60 logsandra/config/deployment.ini_tmpl
@@ -0,0 +1,60 @@
+#
+# logsandra - Pylons configuration
+#
+# The %(here)s variable will be replaced with the parent directory of this file
+#
+[DEFAULT]
+debug = true
+email_to = you@yourdomain.com
+smtp_server = localhost
+error_email_from = paste@localhost
+
+[server:main]
+use = egg:Paste#http
+host = 0.0.0.0
+port = 5000
+
+[app:main]
+use = egg:logsandra
+full_stack = true
+static_files = true
+
+cache_dir = %(here)s/data
+beaker.session.key = logsandra
+beaker.session.secret = ${app_instance_secret}
+app_instance_uuid = ${app_instance_uuid}
+
+# If you'd like to fine-tune the individual locations of the cache data dirs
+# for the Cache data, or the Session saves, un-comment the desired settings
+# here:
+#beaker.cache.data_dir = %(here)s/data/cache
+#beaker.session.data_dir = %(here)s/data/sessions
+
+# WARNING: *THE LINE BELOW MUST BE UNCOMMENTED ON A PRODUCTION ENVIRONMENT*
+# Debug mode will enable the interactive debugging tool, allowing ANYONE to
+# execute malicious code after an exception is raised.
+set debug = false
+
+
+# Logging configuration
+[loggers]
+keys = root
+
+[handlers]
+keys = console
+
+[formatters]
+keys = generic
+
+[logger_root]
+level = INFO
+handlers = console
+
+[handler_console]
+class = StreamHandler
+args = (sys.stderr,)
+level = NOTSET
+formatter = generic
+
+[formatter_generic]
+format = %(asctime)s %(levelname)-5.5s [%(name)s] [%(threadName)s] %(message)s
View
43 logsandra/config/environment.py
@@ -0,0 +1,43 @@
+"""Pylons environment configuration"""
+import os
+
+from jinja2 import Environment, FileSystemLoader
+from pylons.configuration import PylonsConfig
+
+import logsandra.lib.app_globals as app_globals
+import logsandra.lib.helpers
+from logsandra.config.routing import make_map
+
+def load_environment(global_conf, app_conf):
+ """Configure the Pylons environment via the ``pylons.config``
+ object
+ """
+ config = PylonsConfig()
+
+ # Pylons paths
+ root = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
+ paths = dict(root=root,
+ controllers=os.path.join(root, 'controllers'),
+ static_files=os.path.join(root, 'public'),
+ templates=[os.path.join(root, 'templates')])
+
+ # Initialize config with the basic options
+ config.init_app(global_conf, app_conf, package='logsandra', paths=paths)
+
+ config['routes.map'] = make_map(config)
+ config['pylons.app_globals'] = app_globals.Globals(config)
+ config['pylons.h'] = logsandra.lib.helpers
+
+ # Setup cache object as early as possible
+ import pylons
+ pylons.cache._push_object(config['pylons.app_globals'].cache)
+
+
+ # Create the Jinja2 Environment
+ jinja2_env = Environment(loader=FileSystemLoader(paths['templates']))
+ config['pylons.app_globals'].jinja2_env = jinja2_env
+
+ # CONFIGURATION OPTIONS HERE (note: all config options will override
+ # any Pylons config options)
+
+ return config
View
67 logsandra/config/middleware.py
@@ -0,0 +1,67 @@
+"""Pylons middleware initialization"""
+from beaker.middleware import SessionMiddleware
+from paste.cascade import Cascade
+from paste.registry import RegistryManager
+from paste.urlparser import StaticURLParser
+from paste.deploy.converters import asbool
+from pylons.middleware import ErrorHandler, StatusCodeRedirect
+from pylons.wsgiapp import PylonsApp
+from routes.middleware import RoutesMiddleware
+
+from logsandra.config.environment import load_environment
+
+def make_app(global_conf, full_stack=True, static_files=True, **app_conf):
+ """Create a Pylons WSGI application and return it
+
+ ``global_conf``
+ The inherited configuration for this application. Normally from
+ the [DEFAULT] section of the Paste ini file.
+
+ ``full_stack``
+ Whether this application provides a full WSGI stack (by default,
+ meaning it handles its own exceptions and errors). Disable
+ full_stack when this application is "managed" by another WSGI
+ middleware.
+
+ ``static_files``
+ Whether this application serves its own static files; disable
+ when another web server is responsible for serving them.
+
+ ``app_conf``
+ The application's local configuration. Normally specified in
+ the [app:<name>] section of the Paste ini file (where <name>
+ defaults to main).
+
+ """
+ # Configure the Pylons environment
+ config = load_environment(global_conf, app_conf)
+
+ # The Pylons WSGI app
+ app = PylonsApp(config=config)
+
+ # Routing/Session Middleware
+ app = RoutesMiddleware(app, config['routes.map'], singleton=False)
+ app = SessionMiddleware(app, config)
+
+ # CUSTOM MIDDLEWARE HERE (filtered by error handling middlewares)
+
+ if asbool(full_stack):
+ # Handle Python exceptions
+ app = ErrorHandler(app, global_conf, **config['pylons.errorware'])
+
+ # Display error documents for 401, 403, 404 status codes (and
+ # 500 when debug is disabled)
+ if asbool(config['debug']):
+ app = StatusCodeRedirect(app)
+ else:
+ app = StatusCodeRedirect(app, [400, 401, 403, 404, 500])
+
+ # Establish the Registry for this application
+ app = RegistryManager(app)
+
+ if asbool(static_files):
+ # Serve static files
+ static_app = StaticURLParser(config['pylons.paths']['static_files'])
+ app = Cascade([static_app, app])
+ app.config = config
+ return app
View
27 logsandra/config/routing.py
@@ -0,0 +1,27 @@
+"""Routes configuration
+
+The more specific and detailed routes should be defined first so they
+may take precedent over the more generic routes. For more information
+refer to the routes manual at http://routes.groovie.org/docs/
+"""
+from routes import Mapper
+
+def make_map(config):
+ """Create, configure and return the routes Mapper"""
+ map = Mapper(directory=config['pylons.paths']['controllers'],
+ always_scan=config['debug'])
+ map.minimization = False
+ map.explicit = False
+
+ # The ErrorController route (handles 404/500 error pages); it should
+ # likely stay at the top, ensuring it can always be resolved
+ map.connect('/error/{action}', controller='error')
+ map.connect('/error/{action}/{id}', controller='error')
+
+ # CUSTOM ROUTES HERE
+
+ map.connect('index', '/', controller='index', action='index')
+ map.connect('/{controller}/{action}')
+ map.connect('/{controller}/{action}/{id}')
+
+ return map
View
0  logsandra/controllers/__init__.py
No changes.
View
44 logsandra/controllers/error.py
@@ -0,0 +1,44 @@
+import cgi
+
+from paste.urlparser import PkgResourcesParser
+from pylons.middleware import error_document_template
+from webhelpers.html.builder import literal
+
+from logsandra.lib.base import BaseController
+
+class ErrorController(BaseController):
+ """Generates error documents as and when they are required.
+
+ The ErrorDocuments middleware forwards to ErrorController when error
+ related status codes are returned from the application.
+
+ This behaviour can be altered by changing the parameters to the
+ ErrorDocuments middleware in your config/middleware.py file.
+
+ """
+ def document(self):
+ """Render the error document"""
+ request = self._py_object.request
+ resp = request.environ.get('pylons.original_response')
+ content = literal(resp.body) or cgi.escape(request.GET.get('message', ''))
+ page = error_document_template % \
+ dict(prefix=request.environ.get('SCRIPT_NAME', ''),
+ code=cgi.escape(request.GET.get('code', str(resp.status_int))),
+ message=content)
+ return page
+
+ def img(self, id):
+ """Serve Pylons' stock images"""
+ return self._serve_file('/'.join(['media/img', id]))
+
+ def style(self, id):
+ """Serve Pylons' stock stylesheets"""
+ return self._serve_file('/'.join(['media/style', id]))
+
+ def _serve_file(self, path):
+ """Call Paste's FileApp (a WSGI application) to serve the file
+ at the specified path
+ """
+ request = self._py_object.request
+ request.environ['PATH_INFO'] = '/%s' % path
+ return PkgResourcesParser('pylons', 'pylons')(request.environ, self.start_response)
View
13 logsandra/controllers/index.py
@@ -0,0 +1,13 @@
+import logging
+
+from pylons import request, response, session, tmpl_context as c, url
+from pylons.controllers.util import abort, redirect
+
+from logsandra.lib.base import BaseController, render
+
+log = logging.getLogger(__name__)
+
+class IndexController(BaseController):
+
+ def index(self):
+ return render('/index.html')
View
0  logsandra/lib/__init__.py
No changes.
View
18 logsandra/lib/app_globals.py
@@ -0,0 +1,18 @@
+"""The application's Globals object"""
+
+from beaker.cache import CacheManager
+from beaker.util import parse_cache_config_options
+
+class Globals(object):
+ """Globals acts as a container for objects available throughout the
+ life of the application
+
+ """
+
+ def __init__(self, config):
+ """One instance of Globals is created during application
+ initialization and is available during requests via the
+ 'app_globals' variable
+
+ """
+ self.cache = CacheManager(**parse_cache_config_options(config))
View
15 logsandra/lib/base.py
@@ -0,0 +1,15 @@
+"""The base Controller API
+
+Provides the BaseController class for subclassing.
+"""
+from pylons.controllers import WSGIController
+from pylons.templating import render_jinja2 as render
+
+class BaseController(WSGIController):
+
+ def __call__(self, environ, start_response):
+ """Invoke the Controller"""
+ # WSGIController.__call__ dispatches to the Controller method
+ # the request is routed to. This routing information is
+ # available in environ['pylons.routes_dict']
+ return WSGIController.__call__(self, environ, start_response)
View
7 logsandra/lib/helpers.py
@@ -0,0 +1,7 @@
+"""Helper functions
+
+Consists of functions to typically be used within templates, but also
+available to Controllers. This module is available to templates as 'h'.
+"""
+# Import helpers as desired, or define your own, ie:
+#from webhelpers.html.tags import checkbox, password
View
0  logsandra/model/__init__.py
No changes.
View
0  logsandra/monitor/monitor.py 100755 → 100644
File mode changed
View
1  logsandra/public/test.html
@@ -0,0 +1 @@
+Testing...
View
16 logsandra/templates/base.html
@@ -0,0 +1,16 @@
+<!DOCTYPE html>
+<html>
+ <head>
+ <meta charset="utf-8">
+ <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
+ <title>Logsandra</title>
+ </head>
+ <body>
+
+ <h1>Logsandra</h1>
+ <div id="content">
+ {% block content %}{% endblock %}
+ </div>
+
+ </body>
+</html>
View
5 logsandra/templates/index.html
@@ -0,0 +1,5 @@
+{%- extends "base.html" %}
+
+{% block content %}
+Hello World!
+{% endblock %}
View
34 logsandra/tests/__init__.py
@@ -0,0 +1,34 @@
+"""Pylons application test package
+
+This package assumes the Pylons environment is already loaded, such as
+when this script is imported from the `nosetests --with-pylons=test.ini`
+command.
+
+This module initializes the application via ``websetup`` (`paster
+setup-app`) and provides the base testing objects.
+"""
+from unittest import TestCase
+
+from paste.deploy import loadapp
+from paste.script.appinstall import SetupCommand
+from pylons import url
+from routes.util import URLGenerator
+from webtest import TestApp
+
+import pylons.test
+
+__all__ = ['environ', 'url', 'TestController']
+
+# Invoke websetup with the current config file
+SetupCommand('setup-app').run([pylons.test.pylonsapp.config['__file__']])
+
+environ = {}
+
+class TestController(TestCase):
+
+ def __init__(self, *args, **kwargs):
+ wsgiapp = pylons.test.pylonsapp
+ config = wsgiapp.config
+ self.app = TestApp(wsgiapp)
+ url._push_object(URLGenerator(config['routes.map'], environ))
+ TestCase.__init__(self, *args, **kwargs)
View
0  logsandra/tests/functional/__init__.py
No changes.
View
0  logsandra/tests/test_models.py
No changes.
View
14 logsandra/websetup.py
@@ -0,0 +1,14 @@
+"""Setup the logsandra application"""
+import logging
+
+import pylons.test
+
+from logsandra.config.environment import load_environment
+
+log = logging.getLogger(__name__)
+
+def setup_app(command, conf, vars):
+ """Place any commands to setup logsandra here"""
+ # Don't reload the app if it was loaded under the testing environment
+ if not pylons.test.pylonsapp:
+ load_environment(conf.global_conf, conf.local_conf)
View
26 logsandra/logsandra.py → run.py 100644 → 100755
@@ -1,3 +1,4 @@
+#!/usr/bin/env python
# Global imports
import sys
import os
@@ -6,17 +7,17 @@
import multiprocessing
import logging
+from cherrypy import wsgiserver
+from paste.deploy import loadapp
+
# Local imports
-import monitor
-import config
-import utils
-from utils.daemon import Daemon
+from logsandra import monitor, config, utils
+from logsandra.utils.daemon import Daemon
class Application(Daemon):
def monitor(self):
- print 'Starting monitor service...'
m = monitor.Monitor(self.settings, False)
m.run()
@@ -32,14 +33,19 @@ def run(self):
sys.exit(1)
# Start monitor process
+ print 'Starting monitor service...'
self.monitor_process = multiprocessing.Process(target=self.monitor)
self.monitor_process.start()
- print 'Starting web service...'
-
- self.running = True
- while self.running:
- time.sleep(10)
+ # Start web process
+ print 'Starting web service...'
+ wsgi_app = loadapp('config:/home/tote/coding/cassandra/logsandra/development.ini')
+ d = wsgiserver.WSGIPathInfoDispatcher({'/': wsgi_app})
+ server = wsgiserver.CherryPyWSGIServer((self.settings['webservice_address'], int(self.settings['webservice_port'])), d)
+ try:
+ server.start()
+ except KeyboardInterrupt:
+ server.stop()
if __name__ == '__main__':
View
31 setup.cfg
@@ -0,0 +1,31 @@
+[egg_info]
+tag_build = dev
+tag_svn_revision = true
+
+[easy_install]
+find_links = http://www.pylonshq.com/download/
+
+[nosetests]
+with-pylons = test.ini
+
+# Babel configuration
+[compile_catalog]
+domain = logsandra
+directory = logsandra/i18n
+statistics = true
+
+[extract_messages]
+add_comments = TRANSLATORS:
+output_file = logsandra/i18n/logsandra.pot
+width = 80
+
+[init_catalog]
+domain = logsandra
+input_file = logsandra/i18n/logsandra.pot
+output_dir = logsandra/i18n
+
+[update_catalog]
+domain = logsandra
+input_file = logsandra/i18n/logsandra.pot
+output_dir = logsandra/i18n
+previous = true
View
36 setup.py
@@ -0,0 +1,36 @@
+try:
+ from setuptools import setup, find_packages
+except ImportError:
+ from ez_setup import use_setuptools
+ use_setuptools()
+ from setuptools import setup, find_packages
+
+setup(
+ name='logsandra',
+ version='0.1',
+ description='',
+ author='',
+ author_email='',
+ url='',
+ install_requires=[
+ "Pylons>=1.0",
+ "Jinja2",
+ ],
+ setup_requires=["PasteScript>=1.6.3"],
+ packages=find_packages(exclude=['ez_setup']),
+ include_package_data=True,
+ test_suite='nose.collector',
+ package_data={'logsandra': ['i18n/*/LC_MESSAGES/*.mo']},
+ #message_extractors={'logsandra': [
+ # ('**.py', 'python', None),
+ # ('public/**', 'ignore', None)]},
+ zip_safe=False,
+ paster_plugins=['PasteScript', 'Pylons'],
+ entry_points="""
+ [paste.app_factory]
+ main = logsandra.config.middleware:make_app
+
+ [paste.app_install]
+ main = pylons.util:PylonsInstaller
+ """,
+)
View
21 test.ini
@@ -0,0 +1,21 @@
+#
+# logsandra - Pylons testing environment configuration
+#
+# The %(here)s variable will be replaced with the parent directory of this file
+#
+[DEFAULT]
+debug = true
+# Uncomment and replace with the address which should receive any error reports
+#email_to = you@yourdomain.com
+smtp_server = localhost
+error_email_from = paste@localhost
+
+[server:main]
+use = egg:Paste#http
+host = 127.0.0.1
+port = 5000
+
+[app:main]
+use = config:development.ini
+
+# Add additional test specific configuration options as necessary.
Please sign in to comment.
Something went wrong with that request. Please try again.