CSC/ECE 517 Fall 2010/ch2 2d aa: Difference between revisions
Line 32: | Line 32: | ||
=== Scaffolds for Generating Model-View-Controller === | === Scaffolds for Generating Model-View-Controller === | ||
Most of the [http://en.wikipedia.org/wiki/Model%E2%80%93View%E2%80%93Controller 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 | Most of the [http://en.wikipedia.org/wiki/Model%E2%80%93View%E2%80%93Controller 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 | ||
to generate the Model,Views and controllers for our application, 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. | |||
'''Example:''' | '''Example:''' | ||
Steps to generate an application in Rails: | |||
* Create a new 'Railsproject' | * Create a new 'Railsproject' | ||
* Click on 'generators' tab in the 'RadRails' perspective | * Click on 'generators' tab in the 'RadRails' perspective | ||
* Select 'Scaffold' from the 'Generator' combobox | * Select 'Scaffold' from the 'Generator' combobox | ||
* Give Parameters as Tablename Fieldname1:<type> Fieldname2:<type> Fieldname3:<type> and click 'Run Generator' button | * Give Parameters as Tablename Fieldname1:<type> Fieldname2:<type> Fieldname3:<type> and click 'Run Generator' button | ||
<pre> | |||
i.e User userid:string password:string type:string | i.e User userid:string password:string type:string | ||
</pre> | |||
* Once the application skeleton is created, Right click on the created application select Rake->db->migrate | * Once the application skeleton is created, Right click on the created application select Rake->db->migrate | ||
<pre> | |||
Model,View and Controller for 'Users' is created | Model,View and Controller for 'Users' is created | ||
</pre> | |||
* This creates an empty database with table 'Users' | * This creates an empty database with table 'Users' | ||
* Invoke the application through the URL which is http://localhost:<port number>/Users in this case | * Invoke the application through the URL which is http://localhost:<port number>/Users in this case | ||
In the skeleton generator, the developer can choose from any of the listed databases(sqlite3,sqlite2,frontbase,mysql,oracle,postgresql,sqlserver) and the code for it will automatically be generated. | In the skeleton generator, the developer can choose from any of the listed databases(sqlite3,sqlite2,frontbase,mysql,oracle,postgresql,sqlserver) and the code for it will automatically be generated. |
Revision as of 15:02, 22 September 2010
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 to generate the Model,Views and controllers for our application, 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.
Example:
Steps to generate an application in Rails:
- Create a new 'Railsproject'
- Click on 'generators' tab in the 'RadRails' perspective
- Select 'Scaffold' from the 'Generator' combobox
- Give Parameters as Tablename Fieldname1:<type> Fieldname2:<type> Fieldname3:<type> and click 'Run Generator' button
i.e User userid:string password:string type:string
- Once the application skeleton is created, Right click on the created application select Rake->db->migrate
Model,View and Controller for 'Users' is created
- This creates an empty database with table 'Users'
- Invoke the application through the URL which is http://localhost:<port number>/Users in this case
In the skeleton generator, the developer can choose from any of the listed databases(sqlite3,sqlite2,frontbase,mysql,oracle,postgresql,sqlserver) and the code for it will automatically be generated.
SEO Scaffolds
Scaffolds are not only for application prototype generation or for CRUD function generation.We also have scaffold engines in some frameworks,that can be used for Search Engine optimization. Gaia framework is a pragmatic, agile framework which provides this SEO scaffolding facility through its 'SEO scaffolding engine'. 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.As the XHTML file is parsed by larger number of browsers and code parsers, the number of internet users for such sites increases.
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 generator 1, 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 mapping 6. 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.Therefore, Scaffolds give a freedom to the developers to choose from either of the above mentioned approaches.
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