2014-12-16 15:54:29 +00:00
|
|
|
##########################################################################
|
|
|
|
#
|
|
|
|
# pgAdmin 4 - PostgreSQL Tools
|
|
|
|
#
|
|
|
|
# Copyright (C) 2013 - 2014, The pgAdmin Development Team
|
|
|
|
# This software is released under the PostgreSQL Licence
|
|
|
|
#
|
2014-12-16 18:10:07 +00:00
|
|
|
# pgAdmin4.py - Main application entry point
|
2014-12-16 15:54:29 +00:00
|
|
|
#
|
|
|
|
##########################################################################
|
|
|
|
|
|
|
|
import logging
|
2014-12-16 17:14:48 +00:00
|
|
|
import os, sys
|
|
|
|
from flask import Flask
|
|
|
|
from time import time, ctime
|
2014-12-16 15:54:29 +00:00
|
|
|
|
|
|
|
# We need to include the root directory in sys.path to ensure that we can
|
|
|
|
# find everything we need when running in the standalone runtime.
|
|
|
|
sys.path.append(os.path.dirname(__file__))
|
|
|
|
|
|
|
|
# Configuration settings
|
2014-12-16 17:14:48 +00:00
|
|
|
import config
|
2013-06-21 22:21:11 +00:00
|
|
|
|
2014-12-16 15:54:29 +00:00
|
|
|
# Setup the app object
|
2014-12-16 18:10:07 +00:00
|
|
|
app = Flask(__name__, static_url_path='')
|
2013-10-04 16:12:10 +00:00
|
|
|
|
2014-12-17 15:27:54 +00:00
|
|
|
##########################################################################
|
2014-12-16 15:54:29 +00:00
|
|
|
# Setup logging and log the application startup
|
2014-12-17 15:27:54 +00:00
|
|
|
##########################################################################
|
2014-12-16 17:14:48 +00:00
|
|
|
|
2014-12-17 15:27:54 +00:00
|
|
|
# Add SQL level logging, and set the base logging level
|
2014-12-16 15:54:29 +00:00
|
|
|
logging.addLevelName(25, 'SQL')
|
2014-12-16 17:14:48 +00:00
|
|
|
app.logger.setLevel(logging.DEBUG)
|
|
|
|
|
2014-12-17 12:44:07 +00:00
|
|
|
# We also need to update the handler on the webserver in order to see request.
|
|
|
|
# Setting the level prevents werkzeug from setting up it's own stream handler
|
|
|
|
# thus ensuring all the logging goes through the pgAdmin logger.
|
2014-12-16 18:21:26 +00:00
|
|
|
logger = logging.getLogger('werkzeug')
|
2014-12-17 12:44:07 +00:00
|
|
|
logger.setLevel(logging.INFO)
|
2014-12-16 18:21:26 +00:00
|
|
|
|
2014-12-16 17:14:48 +00:00
|
|
|
# File logging
|
|
|
|
fh = logging.FileHandler(config.LOG_FILE)
|
|
|
|
fh.setLevel(config.FILE_LOG_LEVEL)
|
|
|
|
fh.setFormatter(logging.Formatter(config.FILE_LOG_FORMAT))
|
|
|
|
app.logger.addHandler(fh)
|
2014-12-16 18:21:26 +00:00
|
|
|
logger.addHandler(fh)
|
2014-12-16 17:14:48 +00:00
|
|
|
|
|
|
|
# Console logging
|
|
|
|
ch = logging.StreamHandler()
|
|
|
|
ch.setLevel(config.CONSOLE_LOG_LEVEL)
|
|
|
|
ch.setFormatter(logging.Formatter(config.CONSOLE_LOG_FORMAT))
|
|
|
|
app.logger.addHandler(ch)
|
2014-12-16 18:21:26 +00:00
|
|
|
logger.addHandler(ch)
|
2014-12-16 17:14:48 +00:00
|
|
|
|
2014-12-17 12:44:07 +00:00
|
|
|
app.logger.info('################################################################################')
|
2014-12-17 12:52:43 +00:00
|
|
|
app.logger.info('Starting %s v%s...', config.APP_NAME, config.APP_VERSION)
|
2014-12-17 12:44:07 +00:00
|
|
|
app.logger.info('################################################################################')
|
2014-12-16 15:54:29 +00:00
|
|
|
|
2014-12-16 12:53:09 +00:00
|
|
|
# The main index page
|
|
|
|
@app.route("/")
|
|
|
|
def index():
|
2013-10-04 16:31:08 +00:00
|
|
|
|
2014-12-16 12:53:09 +00:00
|
|
|
output = """
|
2013-06-21 22:21:11 +00:00
|
|
|
Today is <b>%s</b>
|
|
|
|
<br />
|
2014-12-16 12:53:09 +00:00
|
|
|
<i>This is Flask-generated HTML.</i>
|
2013-06-21 22:21:11 +00:00
|
|
|
<br /><br />
|
2014-12-17 12:52:43 +00:00
|
|
|
<a href="http://www.pgadmin.org/">%s v%s</a>""" % (ctime(time()), config.APP_NAME, config.APP_VERSION)
|
2013-06-21 22:21:11 +00:00
|
|
|
|
2014-12-16 12:53:09 +00:00
|
|
|
return output
|
2013-10-04 16:12:10 +00:00
|
|
|
|
2014-12-16 12:53:09 +00:00
|
|
|
# A special URL used to "ping" the server
|
|
|
|
@app.route("/ping")
|
|
|
|
def ping():
|
|
|
|
return "PING"
|
2013-10-04 16:12:10 +00:00
|
|
|
|
2014-12-17 15:27:54 +00:00
|
|
|
##########################################################################
|
|
|
|
# Server starup
|
|
|
|
##########################################################################
|
|
|
|
|
2013-10-04 16:12:10 +00:00
|
|
|
# Start the web server. The port number should have already been set by the
|
|
|
|
# runtime if we're running in desktop mode, otherwise we'll just use the
|
2014-12-16 12:53:09 +00:00
|
|
|
# Flask default.
|
|
|
|
if 'PGADMIN_PORT' in globals():
|
2014-12-16 17:14:48 +00:00
|
|
|
app.logger.debug('PGADMIN_PORT set in the runtime environment to %s', PGADMIN_PORT)
|
2014-12-16 12:53:09 +00:00
|
|
|
server_port = PGADMIN_PORT
|
|
|
|
else:
|
2014-12-16 17:14:48 +00:00
|
|
|
app.logger.debug('PGADMIN_PORT is not set in the runtime environment, using default of %s', config.DEFAULT_SERVER_PORT)
|
|
|
|
server_port = config.DEFAULT_SERVER_PORT
|
2014-12-16 12:53:09 +00:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
try:
|
|
|
|
app.run(port=server_port)
|
|
|
|
except IOError:
|
2014-12-16 17:14:48 +00:00
|
|
|
app.logger.error("Error starting the web server: %s", sys.exc_info())
|
2014-12-16 12:53:09 +00:00
|
|
|
|