CSC/ECE 517 Fall 2010/ch2 2d aa

From Expertiza_Wiki
Jump to navigation Jump to search

2d. Scaffolding in Web application frameworks

Rails provides scaffolding for the rapid creation of prototype Web applications. So do many other languages. Write about scaffolds per se, covering the topic in general. For example, what are the main features of scaffolds today? How did scaffolds originate and evolve? Last year we did a very similar topic (you can search our wiki for "scaffold"). But last year's writers just described the various scaffolding frameworks consecutively. They didn't look at all of them and come up with a comprehensive description. You should write about the topic of scaffolding in general, referring to specific scaffolds as examples of certain concepts.

Scaffolding in Web Application frameworks

Introduction

In most of the web applications , irrespective of their complexity, major functionality boils down to accessing the underlying data and presenting them via the User Interface. The four basic functions involved with this data are Create, Read (or Retrieve), Update and Delete(or Destroy), collectively known as the CRUD functionality. Can this 'data', around which the application is centred, be used to build a rapid prototype of our application itself? The answer is 'Yes!' and we can do is through a technique called 'Scaffolding'. Such scaffolded applications can either be used ‘as-is’ or used as prototypes, which are further improvised by the developer. This technique is used by the web developers for rapid development.

‘Scaffolds’ are one of the Wow! factors of the ‘Ruby on rails’ shortened as 'Rails' framework. Ever since, the technique has been absorbed by a multitude of web application frameworks and each of them rendering its own flavor of it. Some of the well known frameworks are Grails,Monorail (.Net),CakePHP, ASP.NET Dynamic Data, Django.

Origin of Scaffolds

Scaffolding was a feature in Rails right from its initial versions. It was either through 'Dynamic scaffolding' in the 1.x versions or through 'Scaffold generation' in the later versions. Though we could not accurately point the 'Origin' of Scaffolds in the web application frameworks, it is worth noting that such a concept of 'rapid development' existed even before Rails and its counterparts existed. Oracle HTML DB renamed as Oracle Application Express is a quintessential example. This helps in reducing the development time of web based applications.However, such applications can be hosted only in an Oracle database as they were created using Oracle's tools.

Types of Scaffolds

Scaffolds could be classified under the following categories based on their functionality.

Scaffolds for generation of Web pages/UI screens

We have scaffolds that are well suited for the presentation logic, requiring only minimal inputs from the users. They also take care of the input validations of elemental components like textboxes, textareas , option buttons and so on. They help in the separation of the presentation logic from the entire application. One such powerful component-based web presentation framework,written in Java is Tapestry.1,2 3

Scaffolds for CRUD functions

'CRUD' functionality is the most elemental part of a scaffold based application. We need to describe the Database (tables and fields) and the pages for the CRUD functions are generated automatically. There are many CRUD scaffolding utilities available. Examples of such CRUD generators are PHP MySQL 1,MVC Scaffold Generator 2

Scaffolds for Generating Model-View-Controller

Most of the MVC based web application frameworks like Rails, Grails, have this feature.Just as we do for a CRUD generator, we need to provide the minimal information about the Data and generates the Model,Views and controllers for the same, and we have a running piece of code. In this way developer has a prototype to work with instead of writing the code from the scratch. This is what makes web application development, a breeze.

SEO Scaffolds

We also have scaffolds that can be used for Search Engine optimization. Gaia framework is a pragmatic, agile framework which provides SEO scaffolding facility. Through SEO scaffolding search engines and other non-flash users can access our site easily.

In Gaia, the SEO scaffolding option can be turned on by setting the Page node's SEO attribute value to True.


<page id="List" title="List of Items" src="List.swf" seo="true" />

An XHTML file with the name List of Items.html will be generated for this Gaia page.The XHTML file is parsed by larger number of browsers and code parsers, thereby increasing the number of internet users who view our sites.

Features of Scaffolds

Simplified web development

Scaffolding helps the developer to start development with a 'Running' piece of code. The developer can always improvise on the prototype to achieve the required functionality. They are well suited for people who are highly result-oriented to respond quickly to the client's demands. Ultimately, they are instrumental in making developer meet even critical deadlines. Using the Rails scaffold generator1, it takes only minutes to develop a prototype with basic 'CRUD' functions and a simple user interface.

Convention Over Configuration

For the scaffold generation, user is not expected give plethora of inputs related to the application. Rather, it follows 'Convention over configuration' i.e it adapts naming conventions to map class to database tables. This feature makes system development uniform, enabling any new developer to jump in and help more easily. At the same time, it is also very easy to override these conventions.In this way they give us the freedom of 'Code-refactoring'. In CakePHP, a popular web application framework,Model Classnames are singular and camelcased. The table names corresponding to model names are plural and underscored.2

Examples:

Model Names  : Employee,GraduateStudent,Person

Corresponding Tables  : Employees,Graduate_Students,People

Separation of concerns

'Separation of concerns' is one of the most important paradigms of software engineering and it has to be implemented right from the early stages of the development cycle. Most of the frameworks help us to achieve this through their code generating or scaffolding mechanisms. Symfony, Zend, Ruby on Rails and a lot more presents their own way of implementing this Separation of concerns in the applications developed using them.

Example: doctrine:build –all-classes in Symfony

Design Approach

The design approach implemented in scaffold is either the Top-down approach or the bottom-up approach.In the top-down approach we define a model and the scaffold generates the database schema for it.Grails uses domain classes to build the database and it also gives us fine control over the database schema through hibernate mapping6. In the bottom-up approach, we define the database at the schema level and the model is built automatically.The naming convention is in accordance with the database schema.Ruby-on-rails uses this design approach.

Conclusion

'Scaffolding' is a great way to start with the application, get a 'look and feel' of the application, but we need to refine-in, change the behavior to finally deliver a real-time application. But, how helpful are these scaffolds in real-time application development is still debatable. Some developers avoid scaffolds, as they might be limited to the auto-generated and impairs them when it comes to having a clear understanding of the code and system behind it.We find that scaffolds are discarded in most of the time.This is because, we generate scaffold by introspecting the database that are not semantically rich enough. Hence, we end up with a dumb scaffold that is too naive for production. By starting with richer meta data, we can end up with a scaffold that is at least 60-70% of the required application.

References

1. http://en.wikipedia.org/wiki/Scaffold_(programming)#Dynamic_scaffolding Dynamic Scaffolding

2. http://en.wikipedia.org/wiki/Ruby_on_Rails

3. http://www.gaiaflashframework.com/

4. http://swik.net/Rails/Rails+vs+Tapestry

5. http://osflash.org/open_source_flash_projects

6. http://www.rubyonrails.com/ Ruby on Rails official website, rubyonrails.com

7. http://dotnetslackers.com/articles/aspnet/AnArchitecturalViewOfTheASPNETMVCFramework.aspx

8. http://www.gaiaflashframework.com/wiki/index.php?title=SEO

9. http://en.wikipedia.org/wiki/Rapid_application_development