#kpages
kpages is mini helper for tornado,Contains the address routing management,tornado and app config management, mongodb, redis connection management and other functions; these supports can help you quickly build a web application.
1. input command: kpages_init.py projectname # projectname: you project name, default is kpages_project
2. set you RequestHandler action dir
python apprun.py or ./apprun.py
Params
config=CONFIG set config for server
port=PORT set http port for server
debug Debug mode.
ndebug No Debug mode.
you can run script kpages_web.py in you app root dir (version >= 0.8.0.dev)
python service.py 或 ./service.py
Params
config=CONFIG set config for server
port=PORT set http port for server
debug Debug mode.
ndebug No Debug mode.
channel set channel for redis mq
you can run script kpages_service.py in you app root dir (version >= 0.8.0.dev)
##How to router
restful/index.py(add @url to class , kpages will route url to this handler)
from kpages import url
@url(r'/',0)
@url(r'/home',2)
class HomeHandler(RequestHandler):
def get(self):
self.write('hello word')
##setting.py
#config for tornado and you app, use __conf__.xxxx to get you config value
ACTION_DIR = 'restful'
DEBUG = True
PORT= 8989
from kpages import run
def callback(app):
pass
if __name__ == '__main__':
run(callback)
from kpages import get_context, LogicContext,mongo_conv
with LogicContext():
db = get_context().get_mongo()
cache = get_context().get_redis()
lst = list(db['table'].find().limit(10))
lst = mongo_conv(lst)
from kpages import ContextHandler
@url(r'/context/demo')
class DemoHandler(ContextHandler,tornado.web.RequestHandler):
def get(self):
db = get_context().get_mongo('dbname')
val = self.session(key)
self.session(key,val)
kpages_tool.py --test test_label.LabelCase.test_update :test test_update method
kpages_tool.py --test test_label.LabelCase :test methods in LabelCase class
kpages_tool.py --test test_label :test methods in test_label.py
kpages_tool.py --test all :test methods in app's __conf__.UTEST_DIR
kpages_tool.py --doc all : auto gen all restful api to apis.md with markdown
1. kpages can auto find Ui_Module's subclass in ACTION_DIR
2. you can use {% module dir_modulename_classname() %} to call Ui Module
Demo Code
Class Demo(tornado.web.UIModule):
def render(self,name):
return self.render('<h1>Hello world:{0}</h1>'.format(name))
Template code
{% module Demo('kpages') %}
3. @reg_ui_method in ACTION_DIR's files, to apply Ui methods
Demo code
@reg_ui_method(name='testmethod',intro='demo for ui method')
def add(self,a,b):
return a+b
Template code
{{ add(3,4) }}