- OnTap
Infobox Software
name = onTap
caption = "Features Without Fixtures"
genre =web application framework
developer = S. Isaac Dealey|source_model =Open source
latest_release_version = 3.2b
latest_release_date = Sep 24, 2008
operating system =Cross-platform
licence = OpenBSD
website = [http://on.tapogee.com on.tapogee.com]!
Web server
- ! ColdFusion MX7The onTap framework is a free SOA and "full stack"
web application framework for ColdFusion.In addition to providing an MVC controller like most other ColdFusion frameworks, it also includes an array of APIs for
rapid application development , includinge-mail ,HTML abstraction (and associatedDHTML widgets such as 503C compliant tabsets), AJAX, application branding and customization, form management andi18n internationalization features.License
The onTap framework is distributed using the
OpenBSD [http://www.openbsd.org/policy.html license] .Several of the early versions of the framework (prior to version 2.0) were released under the Lesser GPL. The LGPL had been chosen specifically for the purpose of allowing commercial software to be written using the framework as a starting-point. The OpenBSD license was later adopted for its even less restrictive terms, allowing commercial projects based on the framework to encrypt their own proprietary source code (which was not allowed by the LGPL).
Philosophy
The onTap framework has several [http://ontap.wikispaces.com/Project+Goals key goals] :
* Speed and improve
rapid application development (RAD) by simplifying common or tedious web development tasks as well as providing convenient methods of accomplishing very complex tasks such as and/or keyword search filtering (this example is from theobject-relational mapping (ORM) tool which has split into a separate project called [http://www.datafaucet.com DataFaucet ORM] ). The use ofsyntactic sugar is a primary method of achieving this goal.
* Enable better integration and collaboration between separate applications provided by different authors via aservice-oriented architecture (SOA). The long-term goal is a software ecosystem similar to add-ons for theMozilla Firefox browser in which plugin applications can be one-click installed via the existing browser-based interface.
* Enable easier customization ofSoftware as a service (SaaS) applications by separating client customizations into their own directory structures thereby reducing conflicts between potentially incompatible customization requests. This is being described as a [http://ontap.wikispaces.com/Virtual+Private+Applications+%28VPA%29 virtual private application (VPA)] as an analogy to theweb hosting termvirtual private server (VPS).These goals are similar to and overlap the intent of
agile software development methodologies or theAgile Manifesto seeking a "lightweight" method of software development that can produce versatile working software very quickly.To meet the objective of simplifying and improving the RAD process, the framework's core principles include
Convention over Configuration (CoC) and Don't Repeat Yourself (DRY). One example of CoC and DRY principles can be found in the framework's form features. The form tools allow programmers to omit most of the code required to create common CRUD forms by relying on the database as the single point of truth for information about the type of data managed by the form. The following are examples of a form as created using the CFML native cfform tag as compared to using the onTap framework's CoC / DRY concepts for CRUD forms.ample Code
The following code sample shows how many ColdFusion forms are written:
The following code sample shows how the same form could be written using the onTap framework's
XHTML syntax (syntactic sugar ) in combination with the [http://www.datafaucet.com DataFaucet ORM] plugin to speed development. This code anticipates the intent of the code in the previous sample by using a conventional relationship between database columns and form input elements. These two code samples produce an approximately similar result with mostly semantic differences in operation. This supports the philosophy of CoC because the programmer only needs to specify the value of an input element (or its default) or the type of validation (date, numeric, required, etc.) in atypical cases in which the input doesn't mirror the structure of the database.History
Isaac Dealey began working on a
content management system (CMS) in late 1998 following his first ColdFusion job at MCI WorldCom. The CMS transitioned through several names eventually becoming known as Tapestry (not to be confused with the Tapestry framework for Java). Isaac later abandoned the CMS but not before releasing an open source API for ColdFusion development called the Tapestry Application Programming Interface (TAPI) not to be confused with theTelephony Application Programming Interface (TAPI). The design of this early version focused on use within an existing application and within several months Isaac decided that the system requirements to support this strategy were too limiting. This lead to the first release of the onTap framework (a complex clip of "on Tapestry") as an alternative to TAPI in August 2003. In spite of the fact that the name onTap shares pronunciation with a colloquial description ofdraught beer (which is often said to be "on tap"), the name engenders less confusion than either the TAPI acronym or the original CMS' name Tapestry.Website
Some time between August 2003 and August 2004, an official website for the framework launched at fusiontap.com. In March 2007, Nick Tong and Kola Oyedeji [http://www.cfframeworks.com/blog/index.cfm/2007/3/8/Isaac-Dealey-talks-about-the-onTap-framework interviewed Isaac] for a
podcast about the framework on the [http://www.cfframeworks.com cfFrameworks website] . Shortly after the interview, Isaac canceled the website'sdedicated hosting service for personal reasons and the domain was subsequently purchased by domain scalpers. This created confusion in the following months with some people thinking the framework project might have been abandoned.In December 2007 Isaac submitted the onTap framework and several related projects to the open source development community RIAForge.org, an alternative to
SourceForge specifically for projects based on Adobe software platforms.A new official site is now at http://on.tapogee.com starting in August 2008.
External links
* [http://www.sitepoint.com/blogs/2008/08/25/isaac-dealey-on-the-ontap-framework/ SitePoint interview blog with Kay Smoljak] - this article was a featured highlight on the SitePoint home page on Aug 25th, 2008
* [http://coldfusion.sys-con.com/read/176194.htm ColdFusion Developer's Journal Special "Frameworks" Focus Issue article]
* [http://www.cfframeworks.com/blog/index.cfm/2007/3/8/Isaac-Dealey-talks-about-the-onTap-framework cfFrameworks.com interview podcast]
* [http://coolskool.blog-city.com/ontap.htm Kola Oyedeji : 8 things you didn't know about the onTap framework]
* [http://www.pbell.com/index.cfm/2007/3/22/Rethinking-the-Data-Access-Layer Discussion of ORM techniques used in onTap with Peter Bell]
* [http://www.coldfusionjedi.com/index.cfm/2008/5/22/BlogCFC-and-Galleon-updates Ray Camden's blog notice about ports of Galleon forums to several frameworks including the onTap framework]ee also
*
Comparison of web application frameworks
Wikimedia Foundation. 2010.