/weiyu

微雨 -- "light rain", yet another Python Web framework

Primary LanguagePython

weiyu

https://sourcegraph.com/api/repos/github.com/xen0n/weiyu/counters/views.png https://sourcegraph.com/api/repos/github.com/xen0n/weiyu/counters/views-24h.png?no-count=1

weiyu is a Web development framework for Python. Highly modular and configurable, weiyu strives to empower developers with convenience and productivity.

NOTE weiyu is considered alpha quality, with its adoption basically non-existent besides the author's several projects. Do not use in production for now!

Features

  • Configuration driven
    • Supports YAML and JSON as config file defaulting to YAML
    • Allows inter-mixing of supported formats by means of including
  • NoSQL storage
    • Riak
    • Redis
    • MongoDB (not actively tested)
  • Flexible URL routing
    • Route with either regexes or exact startswith matches
    • Concise URL routing definition syntax, with Vim syntax coloring! Check out examples/hello and vim-support/ for details.
    • Support for scoped reverse URL resolution (documentation needed)
  • Cache integration
  • Frontend technologies

The framework provides integration with the following packages:

  • Caches
    • python-memcached
    • redis
  • Database
    • pymongo
    • redis
    • riak
  • Server interfaces
    • WSGI
    • tornado
    • gevent-socketio
  • Session management
    • Beaker
    • redis
  • Templating engine
  • Miscellaneous
    • ultrajson

CPython 2.7 and PyPy are supported, with support for CPython 3.2 and above considered experimental. Any help is appreciated.

Licenses

  • GPLv3+
  • Public domain for examples/

The project contains code from other libraries; copyright notices are attached to the respective source files.

  • helpers/regex_helper.py: Taken from Django, BSD-licensed.
  • helpers/metaprogramming.py: Contains code from formencode, PSF-licensed. Also contains user-contributed code from StackOverflow which is licensed under cc-by-sa 3.0 according to StackOverflow policy.

Installation

weiyu is registered in PyPI, but for the moment directly installing from the official repository is recommended as the development is constantly in flux. Also you get the full set of examples this way.

To install from the official repo:

$ git clone https://github.com/xen0n/weiyu.git
$ cd weiyu/
(installing using distribute)
$ ./setup.py develop
(or manually setting up the link)
$ pwd > /path/to/your/site-packages/weiyu.pth

To install via pip:

$ pip install weiyu

Both will not install most of the dependencies. While the deps can be controlled individually using flags like weiyu[mako,riak,redis], requirements files have been provided to allow quick install of all possible dependencies.:

$ pip install -r requirements.txt

Note

PyPy users would have to use the other requirement file, requirements.pypy.txt, which basically has the optional C accelerator modules stripped out.

Known issues

  • gevent-socketio integration is not directly usable on PyPy. However, with the latest version of PyPy and some hacks, the performance can become really awesome!
  • The NoSQL DB mapper is somewhat lacking in capabilities, help appreciated.

Community

  • Mailing list
    • weiyu-cn at groups.google.com (Main language: Chinese)

Why the name?

The name comes from Lin Jiang Xian (trad: 臨江仙/simp: 临江仙) by Yan Jidao, a poet of the Song dynasty. The referenced sentence is 去年春恨卻來時,落花人獨立,微雨燕雙飛. Its pronunciation is like "WE-you", if not using the correct vowel for "yu".

Examples

Some examples are provided in the examples/ directory. Check them out to get a feeling of working with weiyu.