brotherton-erpnext/public/web.py

80 lines
2.0 KiB
Python
Raw Normal View History

2012-06-15 08:30:06 +00:00
#!/usr/bin/env python
2012-07-12 13:11:12 +00:00
# ERPNext - web based ERP (http://erpnext.com)
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
from __future__ import unicode_literals
2012-06-15 08:30:06 +00:00
"""
return a dynamic page from website templates
all html pages except login-page.html get generated here
2012-06-15 08:30:06 +00:00
"""
import cgi, cgitb, os, sys
cgitb.enable()
# import libs
sys.path.append('..')
import conf
sys.path.append('../lib/py')
sys.path.append(conf.modules_path)
def init():
2012-06-15 08:30:06 +00:00
import webnotes
webnotes.form = cgi.FieldStorage(keep_blank_values=True)
for key in webnotes.form.keys():
webnotes.form_dict[key] = webnotes.form.getvalue(key)
webnotes.connect()
def respond():
import webnotes
2012-06-19 08:45:13 +00:00
try:
if 'page' in webnotes.form_dict:
html = get_html(webnotes.form_dict['page'])
2012-06-19 08:45:13 +00:00
else:
# show home page
html = get_html('index')
2012-06-19 08:45:13 +00:00
except Exception, e:
html = get_html('404')
print "Content-Type: text/html"
print
print html.encode('utf-8')
def get_html(page_name):
2012-07-12 13:11:12 +00:00
import website.utils
page_name = website.utils.scrub_page_name(page_name)
2012-07-12 13:11:12 +00:00
comments = get_comments(page_name)
2012-07-12 13:11:12 +00:00
import website.web_cache
html = website.web_cache.get_html(page_name, comments)
return html
2012-07-12 13:11:12 +00:00
def get_comments(page_name):
import webnotes
if page_name == '404':
comments = """error: %s""" % webnotes.getTraceback()
else:
comments = """page: %s""" % page_name
return comments
2012-06-15 08:30:06 +00:00
if __name__=="__main__":
init()
2012-07-12 13:11:12 +00:00
respond()