def setup_app(command, conf, vars): """Place any commands to setup bind_config_manager 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) # Create the tables if they don't already exist Base.metadata.create_all(bind=Session.bind) #################### # load initial data #################### from bind_config_manager.model import User, Domain, Record, Event import hashlib Session.query(User).delete() Session.query(Record).delete() Session.query(Domain).delete() Session.query(Event).delete() u = User(username='******', password='******', is_admin=True, is_active=True) Session.add(u) u = User(username='******', password='******', is_admin=False, is_active=True) Session.add(u) d = Domain('master', 'example.com', 'ns1.example.com.', 'hostmaster.example.com.') Session.add(d) Session.commit() Session.add_all([ Record(d.id, 'NS', '@', 'ns1.example.com.'), Record(d.id, 'NS', '@', 'ns2.example.com.'), Record(d.id, 'MX', '@', 'mail.example.com.', priority=10), Record(d.id, 'MX', '@', 'mail2.example.com.', priority=20), Record(d.id, 'A', '@', '192.168.10.10'), Record(d.id, 'A', 'ns1', '192.168.1.10'), Record(d.id, 'A', 'ns2', '192.168.1.20'), Record(d.id, 'A', 'mail', '192.168.2.10'), Record(d.id, 'A', 'mail2', '192.168.2.20'), Record(d.id, 'A', 'www2', '192.168.10.20'), Record(d.id, 'CNAME', 'www', '@'), Record(d.id, 'CNAME', 'ftp', '@'), Record(d.id, 'CNAME', 'webmail', '@'), ]) d = Domain('master', '0.0.127.in-addr.arpa', 'ns1.linux.bogus.', 'hostmaster.linux.bogus.') Session.add(d) Session.commit() Session.add_all([ Record(d.id, 'NS', '@', 'ns.linux.bogus.'), Record(d.id, 'PTR', '1', 'localhost.'), ]) Session.commit()
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