Introduction and History¶
Welcome to Pecan, a lean Python web framework inspired by CherryPy, TurboGears, and Pylons. Pecan was originally created by the developers of ShootQ while working at Pictage.
Pecan was created to fill a void in the Python web-framework world – a very lightweight framework that provides object-dispatch style routing. Pecan does not aim to be a “full stack” framework, and therefore includes no out of the box support for things like sessions or databases (although tutorials are included for integrating these yourself in just a few lines of code). Pecan instead focuses on HTTP itself.
Although it is lightweight, Pecan does offer an extensive feature set for building HTTP-based applications, including:
Object-dispatch for easy routing
Full support for REST-style controllers
Extensible security framework
Extensible template language support
Extensible JSON support
Easy Python-based configuration
Narrative Documentation¶
- Installation
- Creating Your First Pecan Application
- Controllers and Routing
- Interacting with the Request and Response Object
- Templating in Pecan
- Writing RESTful Web Services with Generic Controllers
- Writing RESTful Web Services with RestController
- Configuring Pecan Applications
- Security and Authentication
- Pecan Hooks
- JSON Serialization
- Context/Thread-Locals vs. Explicit Argument Passing
- Command Line Pecan
- Developing Pecan Applications Locally
- Deploying Pecan in Production
- Logging
- Testing Pecan Applications
Cookbook and Common Patterns¶
API Documentation¶
Pecan’s source code is well documented using Python docstrings and comments. In addition, we have generated API documentation from the docstrings here:
pecan.core
– Pecan Corepecan.commands
– Pecan Commandspecan.configuration
– Pecan Configuration Enginepecan.decorators
– Pecan Decoratorspecan.deploy
– Pecan Deploypecan.hooks
– Pecan Hookspecan.middleware.debug
– Pecan Debugging Middlewarepecan.jsonify
– PecanJSON
Supportpecan.rest
– PecanREST
Controllerpecan.routing
– Pecan Routingpecan.secure
– Pecan Secure Controllerspecan.templating
– Pecan Templatingpecan.testing
– Pecan Testingpecan.util
– Pecan Utils
Change History¶
License¶
The Pecan framework and the documentation is BSD Licensed:
Copyright (c) <2010>, Pecan Framework
All rights reserved.
Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:
* Redistributions of source code must retain the above copyright
notice, this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
notice, this list of conditions and the following disclaimer in the
documentation and/or other materials provided with the distribution.
* Neither the name of the <organization> nor the
names of its contributors may be used to endorse or promote products
derived from this software without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.