Web2py Application Development Cookbook

Total Page:16

File Type:pdf, Size:1020Kb

Web2py Application Development Cookbook web2py Application Development Cookbo Over 110 recipes to master this full-stack Python web framework Mariano Reingart Bruno Cezar Rocha Jonathan Lundell Pablo Martin Mulone Michele Comitini Richard Gordon Massimo Di Pierro open source [ ] community experience distilled PUBLISHING*" BIRMINGHAM-MUMBAI Table of Contents Preface 1 Chapter 1: Deploying web2py 7 Introduction 7 Installing web2py on Windows (from source code) 8 Installing web2py in Ubuntu 10 Setting up a production deployment on Ubuntu 12 Running web2py with Apache, mod_proxy, and mod_rewrite 16 Running web2py with Lighttpd 23 Running web2py with Cherokee 26 Running web2py with Nginx and uWSGI 31 Running web2py on shared hosts using CGI 34 Running web2py on shared hosts with mod_proxy 35 Running web2py from a user-defined folder 36 Installing web2py as a service in Ubuntu 39 Running web2py with IIS as a proxy 39 Running web2py with ISAPI 45 Chapter 2: Building Your First Application 49 Introduction 50 Improving the scaffolding application 50 Building a simple contacts application 53 Building a Reddit clone 61 Building a Facebook clone 68 Using crud.archive 76 Converting an existing static site into a web2py application 78 Creating semi-static pages (flatpages) 79 Adding your custom logo 84 Table of Contents Creating menus and submenus 87 Customizing menus with icons 88 Creating a navigation bar 89 Using cookies to set the language 92 Designing modular applications 94 96 Speeding up downloads Chapter 3: Database Abstraction Layer 99 Introduction 99 Creating a new model 100 Creating a model from a CSV file 102 Batch upload of your data 104 Moving your data from one database to another 106 Creating a model from existing MySQL and PostgreSQL databases 107 Efficiently searching by tag 110 Accessing your database from multiple applications 112 Hierarchical category tree 114 Creating records on demand 116 OR, LIKE, BELONGS, and more on Google App Engine 117 Replacing slow virtual fields with DB views 121 Chapter 4: Advanced Forms 125 Introduction 126 Adding confirmation on form submit 127 Searching data dynamically 128 Embedding multiple forms in one page 130 Detecting and blocking concurrent updates 133 Creating a form wizard 134 De-normalizing data temporarily 136 Removing form labels 138 Using fileuploader.js 139 Uploading files using a LOADed component 142 Making image thumbnails from uploaded images 144 Monitoring upload progress 146 Auto tooltips in forms 148 Color picker widget 150 Shortening text fields 151 Creating multi-table forms 153 Creating a multi-table form with references 154 Creating a multi-table update form 156 Star rating widget 158 Hjl Table of Contents Chapter 5: Adding Ajax Effects 161 Introduction 161 Using jquery.multiselect.js 162 Creating a select_or_add widget 163 Using an autocompletion plugin 169 Creating a drop-down date selector 171 Improving the built-in ajax function 173 Using a slider to represent a number 174 Using jqGrid and web2py 175 Improving data tables with WebGrid 180 Ajaxing your search functions 183 Creating sparklines 187 Chapter 6: Using Third-party Libraries 191 Introduction 191 Customizing logging 191 Aggregating feeds 195 Displaying Tweets 197 Plotting with matplotlib 200 Extending PluginWiki with an RSS widget 203 Chapter 7: Web Services 207 Introduction 207 Consuming a web2py JSON service with JQuery 208 Consuming a JSON-RPC service 210 JSON-RPC from JavaScript 211 Making amf3 RPC calls from Flex using pyamf 220 PayPal integration in Web2py 222 PayPal web payments standard 235 Getting Flickr photos 243 Sending e-mails with Boto through Amazon Web Services (AWS) 245 Making GIS amps using mapscript 246 Google groups and Google code feeds reader 248 Creating SOAP web services 248 Chapter 8: Authentication and Authorization 253 Introduction 253 Customizing Auth 254 Using CAPTCHA on login failure 255 Using pyGravatar to get avatars for user profile pages 256 Multi-user and teacher modes 262 Authenticating with Facebook using OAuth 2.0 263 COD- Table of Contents Chapter 9: Routing Recipes 267 Introduction 267 Making cleaner URLs with routes.py 268 Creating a simple router 270 Adding a URL prefix 272 Associating applications with domains 272 Omitting the application name 273 Removing application name and controllers from URLs 274 Replacing underscores with hyphens in URLs 275 Mapping favicons.ico and robots.txt 275 Using URLs to specify the language 276 Chapter 10: Reporting Recipes 279 Introduction 279 Creating PDF reports 279 Creating PDF listings 282 Creating pdf labels, badges, and invoices 284 Chapter 11: Other Tips and Tricks 295 Introduction 295 Using PDB and the embedded web2py debugger 296 Debugging with Eclipse and PyDev 302 Updating web2py using a shell script 304 Creating a simple page statistics plugin 307 Rounding corners without images or JavaScript 308 Setting a cache.disk quota 310 Checking if web2py is running using cron 311 Building a Mercurial plugin 312 Building a pingback plugin 315 Changing views for mobile browsers 323 Background processing with a database queue 324 How to effectively use template blocks 327 Making standalone applications with web2py and wxPython 330 Index 335 -DD.
Recommended publications
  • Access Full Issue
    ISSN 2520-2073 (print) ISSN 2521-442X (online) TRAINING, LANGUAGE AND CULTURE ‘Tell me and I forget. Teach me and I remember. Involve me and I learn’ ‒ Benjamin Franklin Vol. 4 Issue 4 2020 Issue DOI: 10.22363/2521-442X-2020-4-4 The quarterly journal published by Peoples’ Friendship University of Russia (RUDN University) ISSN 2520-2073 (print) AIMS AND SCOPE TRAINING, LANGUAGE AND CULTURE ISSN 2521-442X (online) Training, Language and Culture (TLC) is a peer-reviewed journal that aims to promote and disseminate research spanning the spectrum of language and linguistics, education and culture studies with a special focus on professional communication and professional discourse. Editorial Board of A quarterly journal published by RUDN University Training, Language and Culture invites research-based articles, reviews and editorials covering issues of relevance for the scientific and professional communities. EDITORIAL BOARD Dr Elena N. Malyuga Peoples’ Friendship University of Russia (RUDN University), Moscow, Russian Federation FOCUS AREAS Barry Tomalin Glasgow Caledonian University London, London, UK Training, Language and Culture covers the following areas of scholarly interest: theoretical and practical perspectives in language and linguistics; Dr Michael McCarthy University of Nottingham, Nottingham, UK culture studies; interpersonal and intercultural professional communication; language and culture teaching and training, including techniques and Dr Robert O’Dowd University of León, León, Spain technology, testing and assessment. Dr Elsa Huertas Barros University of Westminster, London, UK Dr Olga V. Aleksandrova Lomonosov Moscow State University, Moscow, Russian Federation LICENSING Dr Lilia K. Raitskaya Moscow State Institute of International Relations (MGIMO University), Moscow, Russian Federation All articles and book reviews published in Training, Language and Culture are licensed under a Creative Commons Attribution 4.0 International Li- Dr Alex Krouglov University College London, London, UK cense (CC BY 4.0).
    [Show full text]
  • WEB2PY Enterprise Web Framework (2Nd Edition)
    WEB2PY Enterprise Web Framework / 2nd Ed. Massimo Di Pierro Copyright ©2009 by Massimo Di Pierro. All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted in any form or by any means, electronic, mechanical, photocopying, recording, scanning, or otherwise, except as permitted under Section 107 or 108 of the 1976 United States Copyright Act, without either the prior written permission of the Publisher, or authorization through payment of the appropriate per-copy fee to the Copyright Clearance Center, Inc., 222 Rosewood Drive, Danvers, MA 01923, (978) 750-8400, fax (978) 646-8600, or on the web at www.copyright.com. Requests to the Copyright owner for permission should be addressed to: Massimo Di Pierro School of Computing DePaul University 243 S Wabash Ave Chicago, IL 60604 (USA) Email: [email protected] Limit of Liability/Disclaimer of Warranty: While the publisher and author have used their best efforts in preparing this book, they make no representations or warranties with respect to the accuracy or completeness of the contents of this book and specifically disclaim any implied warranties of merchantability or fitness for a particular purpose. No warranty may be created ore extended by sales representatives or written sales materials. The advice and strategies contained herein may not be suitable for your situation. You should consult with a professional where appropriate. Neither the publisher nor author shall be liable for any loss of profit or any other commercial damages, including but not limited to special, incidental, consequential, or other damages. Library of Congress Cataloging-in-Publication Data: WEB2PY: Enterprise Web Framework Printed in the United States of America.
    [Show full text]
  • Desarrollo De Una Aplicación Web De Gestión Colaborativa Para Un Club De Triatlón
    Escola Tècnica Superior d’Enginyeria Informàtica Universitat Politècnica de València Desarrollo de una aplicación web de gestión colaborativa para un club de triatlón Trabajo Fin de Grado Grado en Ingeniería Informática Autor: Jose Enrique Pérez Rubio Tutor/a: Manuela Albert Albiol Victoria Torres Bosch 2016 - 2017 Desarrollo de una aplicación web de gestión colaborativa para un club de triatlón 2 Resumen Se ha desarrollado una intranet para sustituir el actual método de contacto y navegación de los usuarios el cual es un foro. La nueva aplicación cuenta con más funcionalidades que no estaban disponibles anteriormente. La página web está desarrollada en web2py, un framework de Python. Como patrón de diseño para la implementación se utilizará el conocido Modelo Vista Controlador (MVC), arquitectura estándar hoy en día el cual separa los datos y la lógica de las vistas del usuario. Este diseño facilita el desarrollo y mantenimiento de las aplicaciones. Palabras clave: triatlón, intranet, web2py, framework, Python. MCV Abstract This Intranet has been developed to replace the current users contact and navigation method, nowadays it is a forum. The new application has more functionality than previously available. This web page is developed in Python web2py’s framework. As design for the implementation we'll be using the Model View Controller (MVC), standard architecture because it separates the data and the logic from user's view. This design improves the development and maintenance of applications. Keywords: triathlon, intranet, web2py, framework, Python, MVC 3 Desarrollo de una aplicación web de gestión colaborativa para un club de triatlón Agradecimientos Antes de nada, me gustaría dar las gracias a: Mis padres, por alentarme a continuar mi educación y han trabajado siempre muy duro para poder brindarme la oportunidad que ellos nunca tuvieron para poder continuar mis estudios.
    [Show full text]
  • Donovan Buccat
    Donovan Buccat 2129 Doxey Drive, San Jose, CA | 707-673-7184 | [email protected] linkedin.com/in/donovan-buccat | github.com/donovanbuccat | donovanbuccat.com d WORK EXPERIENCE Splashtop – San Jose, CA Technical Support Engineer, Mar 2020 – Present • Resolved 4500+ cases for businesses and customers of various professional backgrounds. • Troubleshot issues concerning remote access technology to facilitate a smooth work from home experience. • Provided technical support for escalations and high profile cases until resolution. • Analyzed logs to debug software issues with the macOS, linux, iOS, and Android development teams. • Created reports using JIRA for various bugs and assisted with migrations for the web development team. PROJECTS TagRide Application Full Stack Dev, Jan 2019 – June 2019 • Created a proficient front-end design for a mobile ridesharing application for iOS and Android. • Designed HTTP methods for creating driver and passenger confirmations for the server. • Constructed backend to store driver profiles, photos, and documentation as objects in Azure Cloud storage. • Designed the login page so it could fit on all devices. • Built using C#, Xamarin, and ASP.NET. • Executed all of the proper protocols in Agile including planning, sprints, and sprint reviews on team of six. Astrology Website Full Stack Dev, Mar 2018 – June 2018 • Focused on crafting visual elements of the website and also the forum which allowed people to post about their astrology signs. • Integrated tagging feature for forum posts into backend which allowed posts to be filtered by custom tags. • Built backend using python database abstraction layer to primarily store forum posts, photos, and profiles. • Utilized PythonAnywhere for hosting the full stack web application in the cloud.
    [Show full text]
  • Why We Use Django Rather Than Flask in Asset Management System
    9 VI June 2021 https://doi.org/10.22214/ijraset.2021.35756 International Journal for Research in Applied Science & Engineering Technology (IJRASET) ISSN: 2321-9653; IC Value: 45.98; SJ Impact Factor: 7.429 Volume 9 Issue VI Jun 2021- Available at www.ijraset.com Why we use Django rather than Flask in Asset Management System Anuj Kumar Sewani1, Chhavi Jain2, Chirag Palliwal3, Ekta Yadav4, Hemant Mittal5 1,2,3,4U.G. Students, B.Tech, 5Assistant Professor, Dept. of Computer Science & Engineering, Global Institute of Technology, Jaipur Abstract: Python provide number of frameworks for web development and other applications by Django, Flask, Bottle, Web2py, CherryPy and many more. Frameworks are efficient and versatile to build, test and optimize software. A web framework is a collection of package or module which allows us to develop web applications or services. It provides a foundation on which software developers can built a functional program for a specific platform. The main purpose of this study about python framework is to analyze which is better framework among Django or flask for web development. The study implement a practical approach on PyCharm. The result of this study is - “Django is better than flask”. I. INTRODUCTION Asset management refers to the process of developing, operating, maintaining, and selling assets in a cost-effective manner. Most commonly used in finance, the term is used in reference to individuals or firms that manage assets on behalf of individuals or other entities. Asset Management System are used to manage all the assets of a company, we can use this software to manage assets in any field i.e.
    [Show full text]
  • 3 Overview of Landslide in India
    A SELECTED ANNOTATED BIBLIOGRAPHY AND BIBLIOGRAPHY ON LANDSLIDES IN INDIA Compiled by Surya Parkash and Anil Kathait NATIONAL INSTITUTE OF DISASTER MANAGEMENT Ministry of Home Affairs, Government of India 5-B, I.P. Estate, M.G. Road New Delhi – 110 002 Table of Contents S. No. Content Page No. Foreword ii Preface iii Acknowledgement iv 1. Background 1 2. About Landslides 2 3. Overview of Landslides in India 5 4. Annotated Bibliography 9 5. Bibliography 87 6. List of Publications / Periodicals related to landslides 109 7. Web links for landslide publications 111 8. Glossary 113 9. Index 115 i Foreword The document on “A Selected Annotated Bibliography and Bibliography on Landslides in India” is prepared to provide a source of inventory for those who are interested in the landslide subject or willing to do research on it. It is a compilation of the available literature and research work pursued on Indian landslides. American Psychological Association (APA) citation style, one of the most used citation method is used for the referring the research work. The annotated bibliography and bibliography are placed in alphabetical order. The document has been formulated by Dr. Surya Parkash, Associate Professor, NIDM. It is divided in two parts: annotated bibliography and bibliography. Annotated bibliography is provided with the summary of the research work carried by the researcher. NIDM acknowledges the valuable support from all resource persons and institutes for providing technical inputs on the document and reviewing the same at various stages of preparation and publication. ii Preface The contemplation of available literature or research work carried out on any subject facilitates in understanding that particular subject.
    [Show full text]
  • An Analysis of CSRF Defenses in Web Frameworks
    Where We Stand (or Fall): An Analysis of CSRF Defenses in Web Frameworks Xhelal Likaj Soheil Khodayari Giancarlo Pellegrino Saarland University CISPA Helmholtz Center for CISPA Helmholtz Center for Saarbruecken, Germany Information Security Information Security [email protected] Saarbruecken, Germany Saarbruecken, Germany [email protected] [email protected] Abstract Keywords Cross-Site Request Forgery (CSRF) is among the oldest web vul- CSRF, Defenses, Web Frameworks nerabilities that, despite its popularity and severity, it is still an ACM Reference Format: understudied security problem. In this paper, we undertake one Xhelal Likaj, Soheil Khodayari, and Giancarlo Pellegrino. 2021. Where We of the first security evaluations of CSRF defense as implemented Stand (or Fall): An Analysis of CSRF Defenses in Web Frameworks. In by popular web frameworks, with the overarching goal to identify Proceedings of ACM Conference (Conference’17). ACM, New York, NY, USA, additional explanations to the occurrences of such an old vulner- 16 pages. https://doi.org/10.1145/nnnnnnn.nnnnnnn ability. Starting from a review of existing literature, we identify 16 CSRF defenses and 18 potential threats agains them. Then, we 1 Introduction evaluate the source code of the 44 most popular web frameworks Cross-Site Request Forgery (CSRF) is among the oldest web vul- across five languages (i.e., JavaScript, Python, Java, PHP, andC#) nerabilities, consistently ranked as one of the top ten threats to covering about 5.5 million LoCs, intending to determine the imple- web applications [88]. Successful CSRF exploitations could cause re- mented defenses and their exposure to the identified threats. We mote code execution [111], user accounts take-over [85, 87, 90, 122], also quantify the quality of web frameworks’ documentation, look- or compromise of database integrity—to name only a few in- ing for incomplete, misleading, or insufficient information required stances.
    [Show full text]
  • A Presentation Service for Rapidly Building Interactive Collaborative Web Applications
    A Presentation Service for Rapidly Building Interactive Collaborative Web Applications SCIENTIA MANU E T MENTE A thesis submitted to the School of Computer Science University College University of New South Wales Australian Defence Force Academy for the degree of Doctor of Philosophy By Michael Joseph Sweeney 31 March 2008 c Copyright 2008 by Michael Joseph Sweeney i Certi¯cate of Originality I hereby declare that this submission is my own work and that, to the best of my knowledge and belief, it contains no material previously published or written by another person, nor material which to a substantial extent has been accepted for the award of any other degree or diploma at UNSW or any other educational institution, except where due acknowledgement is made in the thesis. Any contribution made to the research by colleagues, with whom I have worked at UNSW or elsewhere, during my candidature, is fully acknowledged. I also declare that the intellectual content of this thesis is the product of my own work, except to the extent that assistance from others in the project's design and conception or in style, presentation and linguistic expression is acknowledged. Michael Joseph Sweeney ii Abstract Web applications have become a large segment of the software development domain but their rapid rise in popularity has far exceeded the support in software engineer- ing. There are many tools and techniques for web application development, but the developer must still learn and use many complex protocols and languages. Products still closely bind data operations, business logic, and the user interface, limiting integration and interoperability.
    [Show full text]
  • Evaluation of Password Hashing Schemes in Open Source Web
    Evaluation of Password Hashing Schemes in Open Source Web Platforms Christoforos Ntantogian, Stefanos Malliaros, Christos Xenakis Department of Digital Systems, University of Piraeus, Piraeus, Greece {dadoyan, stefmal, xenakis}@unipi.gr Abstract: Nowadays, the majority of web platforms in the Internet originate either from CMS to easily deploy websites or by web applications frameworks that allow developers to design and implement web applications. Considering the fact that CMS are intended to be plug and play solutions and their main aim is to allow even non-developers to deploy websites, we argue that the default hashing schemes are not modified when deployed in the Internet. Also, recent studies suggest that even developers do not use appropriate hash functions to protect passwords, since they may not have adequate security expertise. Therefore, the default settings of CMS and web applications frameworks play an important role in the security of password storage. This paper evaluates the default hashing schemes of popular CMS and web application frameworks. First, we formulate the cost time of password guessing attacks and next we investigate the default hashing schemes of popular CMS and web applications frameworks. We also apply our framework to perform a comparative analysis of the cost time between the various CMS and web application frameworks. Finally, considering that intensive hash functions consume computational resources, we analyze hashing schemes from a different perspective. That is, we investigate if it is feasible and under what conditions to perform slow rate denial of service attacks from concurrent login attempts. Through our study we have derived a set of critical observations.
    [Show full text]
  • Business Uses for Python & IBM I
    Business uses for Python & IBM i Mike Pavlak – IT Strategist [email protected] A little background, please What is Python, really? ■ General purpose language ■ Easy to get started ■ Simple syntax ■ Great for integrations (glue between systems) ■ Access to C and other APIs ■ Infrastructure first, but applications, too 4 Historically… ■ Python was conceptualized by Guido Van Rossum in the late 1980’s ■ Rossum published the first version of Python code (0.9.0) in February of 1991 at the CWI(Centrum Wiskunde & Informatica) in the Netherlands, Amsterdam ■ Python is derived from the ABC programming language, which is a general purpose language that was also developed at CWI. ■ Rossum chose the name “Python” since he was a fan of Monty Python’s Flying Circus. ■ Python is now maintained by a core development team at the institute, although Rossum still holds a vital role in directing its progress and as leading “commitor”. 5 Python lineage ■ Python 1 – 1994 ■ Python 2 – 2000 (Not dead yet…) ▶2,7 – 2010 ■ Python 3 – 2008 ▶3.5 – 2015 ▶3.6.2 – July 2017 ▶3.7 ➔ ETA July 2018 6 Why use it? Academia ■ 1970’s ▶COBOL, Basic ■ 1980’s ▶Pascal, Delphi ■ 1990’s ▶Java ■ 2000 ▶Python & Open Source 8 Carnegie Mellon ■ School discovered that students understood OO ▶But could not build a logic loop to save their soul! ■ Robert Harper, professor of CS writes: “Object-oriented programming is eliminated entirely from the introductory curriculum, because it is both anti-modular and anti- parallel by its very nature, and hence unsuitable for a modern
    [Show full text]
  • Development of a Competition Web Service for Attitude Estimation Algorithms
    Development of a Competition Web Service for Attitude Estimation Algorithms Sam Osenieks u4677151 Supervised by Dr. Jochen Trumpf November 2013 A thesis submitted in part fulfilment of the degree of Bachelor of Engineering Department of Engineering Australian National University This thesis contains no material which has been accepted for the award of any other degree or diploma in any university. To the best of the author’s knowledge, it contains no material previously published or written by another person, except where due reference is made in the text. Sam Osenieks 1 November 2013 © Sam Osenieks ABSTRACT Attitude estimation algorithms can vary greatly, being based around various sensor measurements which relate to the intended application of an algorithm. As such, it can be difficult to find relevant attitude estimation algorithms to benchmark newly developed methods against, or to find an ideal existing solution for a given application. The goal of this work was to develop a competition web service which would allow researchers and engineers to more easily compare attitude estimation solutions. The system was designed to be robust and secure. It aims to supply a variety of functions and features to aid comparisons, all of which will be built about the concept of a leaderboard where attitude estimation algorithms are ranked against each other for given datasets and quality measures. This paper focuses on the design of such a system, along with a web proof of concept for some important features. i CONTENTS List of Figures ......................................................................................................................................................
    [Show full text]
  • Enterprise Web Framework This Document Is an Overview of New Features in 1.63
    web2py Enterprise Web Framework this document is an overview of new features in 1.63 Startup Interface Download and click! No Installation No Dependencies No Configuration Runs Everywhere including Google App Engine Web Based Admin Interface Login Manage Apps Create Apps Design Apps Test/Debug Mercurial Integration Web Based Admin Interface receive web2py announcements from twitter be notified of upgrades web2py Architecture Each app has its own database administrative interface welcome admin examples user app app app apps (scaffolding) gluon (session, request, response, cookies, security, template language, database abstraction layer, caching, errors, routes, upload/download streaming, internationalization, etc.) cherrypy wsgi web server handlers www mod_proxy cgi, fcgi, mod_python, mod_wsgi Web Based Admin Interface type “images” Web Based Admin Interface click to run The Scaffolding App click to go back The Scaffolding App App Authentication Custom Menu Quick Links The Scaffolding App click to EDIT Edit an App Metadata what is this app about? what is this license? Edit an App click to toggle Edit your Models click for database admin Models describe the “data representation” of you app db.py connects to DB, defines tables, Auth, Crud (edit this file to add tables) menu.py defines menus for the scaffoling app (can be removed if not needed) Edit your Controllers click to ajax shell or run doctests Controllers describe the workflow of your app default.py is the default (entry point) controller of your app appadmin.py defines a database administrative interface for your app (appadmin) click on [test] to run all doctests online Edit your Views adds ajax capabilities Each function in controller returns a dictionary that is rendered by a view file.
    [Show full text]