Click here to close now.

Welcome!

You will be redirected in 30 seconds or close now.

ColdFusion Authors: Yakov Fain, Maureen O'Gara, Nancy Y. Nee, Tad Anderson, Daniel Kaar

Related Topics: ColdFusion

ColdFusion: Article

Macromedia's DevNet Resource Kit: Just the Beginning

Macromedia's DevNet Resource Kit: Just the Beginning

What is the Macromedia DevNet Resource Kit, and how can I get it? As both a Macromedia DevNet Resource Kit (DRK) product manager, and the Macromedia Server Community Manager, I hear these questions often from both the online and offline ColdFusion communities. Starting with volume 3, the DRK has become extremely relevant to ColdFusion developers, and future volumes will be no exception.

The DRK is a developer resource that Macromedia releases quarterly containing components, extensions, utilities, sample applications, and reference materials for several Macromedia products. DRK volumes 1 and 2 heavily emphasized Macromedia Flash and Dreamweaver; however, the goal of DRK 3 was to provide the ColdFusion community with a comprehensive and diverse set of ColdFusion content, including ColdFusion components, user-defined functions, custom tags, sample applications, book chapters, and articles. And although I can't go into detail about future DRKs, I can say that DRK 3 is just the beginning.

ColdFusion content on DRK 3 is divided into three parts: custom tags and components, utilities, and sample applications. In this article, I discuss my favorite projects in each category.

Custom Tags and Components
DRK 3 contains several custom tags and components that are designed to be integrated into other ColdFusion projects or utilities. Rather than being standalone applications, they can be considered application building blocks.

The Calendar Component
The calendar component is a model of a single page in a calendar. All you have to do is set the month and the year, then call getPage to get back a two-dimensional array that models the columns and rows of a calendar page. The two-dimensional array will always have seven columns (for every day of the week) and the right number of rows for the specified month and year. The values of the elements in the two-dimensional array will either be the appropriate day of the month, or -1 when they fall outside of the month's range.

The calendar component is really designed to encapsulate the messy logic you need to render calendar pages in HTML. It has all the functions you need to quickly and easily add a calendar to your site.

The Init Custom Tag
The init tag is a sophisticated encapsulation technique many developers already use to initialize and configure their applications. Any code in the body of the init tag is only executed the first time the tag is encountered during the life span of the application, so it's a great place to put your applications' initialization routines, like defining application variables for data sources, parsing XML files, etc. It is thread-safe, but not entirely synchronized, so you can use it in your Application.cfm file without worrying about single-threading your application and dramatically slowing it down. The init tag also allows you to dynamically reevaluate any code in its body simply by passing a special query string parameter in to the page that contains the tag, so you can update your configuration without having to restart your server.

The Recordpager Custom Tag
The recordpager custom tag automatically generates linked page numbers to allow users to browse through multiple pages of records returned from a database query. It is used in circumstances where you want to limit the number of records to display on a single page, but still allow users to access the rest of the records on subsequent pages. The generated page numbers are linked to a page that you specify, or will automatically default to the current page since paging through record sets usually means making multiple requests to the same page. The recordpager tag will also automatically pass the specified page the record number that it should start with when displaying the next set of records, as well as optionally allow you to pass in a struct with name/value pairs that also need to be passed to other pages of query results. Finally, you can pass style class definitions in to the recordpager in order to adapt its look and feel to any application.

Utilities
DRK 3 contains a set of ColdFusion projects that are considered utilities, which means they are more extensive than just single tags and components, but are still designed to be integrated into larger projects. Here are two of my favorites:

Data File Access (DFA)
DFA allows ColdFusion developers to interact with XML and comma-delimited files (CSVs) as though they were database tables. The easiest and most flexible way to store and retrieve data in an application is to use a database and SQL; however for smaller projects, creating an entire database can be more hassle than it's worth. With DFA, you get all the advantages of using SQL to both save and retrieve data, but the underlying data structure is either an XML or CSV file.

Let's say you decide to put together a quick survey to allow your co-workers to vote on their favorite activity for a company picnic. You want to be able to save and retrieve the results quickly using SQL, but you might not want to go through the hassle of setting up a database. Using DFA, you can use a simple XML or CSV file to store your data while still being able to leverage the convenience of SQL. DFA even comes with the dfaQuery tag, which works almost exactly like the cfquery tag you are already accustomed to using.

Lindex (Lucene Indexing Engine)
One of the most powerful aspects of ColdFusion MX is that it is implemented almost entirely in Java. Writing utilities that leverage Java is less a matter of integrating ColdFusion MX and Java and more a matter of naturally using Java to extend ColdFusion. The fact that Java can be used so easily to extend ColdFusion means that developers can leverage all of the open-source Java projects out there, such as those being developed under the Apache Jakarta project.

DRK 3 contains a project called Lindex, which stands for Lucene Index. Lucene is an open-source Apache Jakarta project for creating and searching document collections. ColdFusion comes bundled with the Verity text search engine; however, the advantage of using Lindex to integrate Lucene into your applications is that since it is pure Java, it will run on any platform that ColdFusion MX runs on, including Macintosh OS X. That means you can develop and deploy your ColdFusion MX application on two separate platforms without having to worry about compatibility issues.

Lindex works almost identically to Verity in that you create collections which you then populate with text, HTML, PDF, and ColdFusion files. Lindex includes both a ColdFusion and a Java API, as well as an administrative interface very similar to the ColdFusion Verity interface.

Sample Applications
DRK 3 contains two sample ColdFusion applications. You can use the ColdFusion sample applications on the DRK to learn best practices and see examples of development techniques and principles, or you can simply install them for your own use.

Macromedia XML News Aggregator
The Macromedia XML News Aggregator, or MXNA, is an extremely useful application for gathering, parsing, storing, and displaying RSS news feeds. RSS, or Really Simple Syndication, is an XML format that many news sites and weblogs publish in order to allow RSS aggregators to syndicate their content. For example, my weblog (www.macromedia.com/go/cantrell) does not just contain an HTML version of my posts, but it also produces an XML version, as well (www.macromedia.com/go/ccantrell_rss). Anyone is welcome to use my RSS feed to either aggregate the content of my weblog locally on their computer, or to republish the content of my XML feed anywhere they want.

MXNA is based on the source code for the Web site fullasagoog.com, which is a very popular aggregator of Macromedia MX - related weblogs. The MXNA source code on DRK 3 has a very different look than fullasagoog, however, and has a few extra features. You can see a production version of MXNA focusing on Macromedia MX technologies, technology news, and Web development in general, running at www.macromedia.com/go/weblogs.

If you go to Macromedia's version of MXNA, you will find that we are aggregating somewhere in the neighborhood of 150 feeds. Imagine trying to keep up with 150 news sites and weblogs which make anywhere between one and probably a dozen posts a day. MXNA allows you to visit a single site, browse by category, and quickly find posts that are relevant to you.

Running your own version of MXNA will allow you to customize both your feeds and your categories. At Macromedia, we run one external version of MXNA (at the URL above) and one internal version which we use to aggregate things like internal project status reports. With MXNA, you can easily set up your own personal RSS aggregator, or launch your own RSS portal.

RSS 1.0 XML Feed Creation and Management Application (RSSify)
RSSify is a Rich Internet Application, or RIA, which means the user interface is implemented in Macromedia Flash MX while the back end is implemented as a ColdFusion component. RSSify is an excellent example of integrating Macromedia Flash and ColdFusion using Macromedia Flash Remoting in order to achieve a richer, more efficient user experience.

RSSify provides users with a simple and intuitive interface for creating and managing RSS XML feeds. The interface allows users to import, save, load, delete, and author RSS feeds, as well as publish them to a server where they can be made accessible to the rest of the world. The Macromedia Flash interface handles the creation and formatting of the XML document while the ColdFusion back end handles the persistence and publishing of the feeds. RSSify is perfect when you need to generate an RSS news feed (to be aggregated by MXNA, for instance), but you don't already have an automated process for doing so.

To find out more about these and other ColdFusion projects on DRK 3, visit the DRK 3 home page at www.macromedia.com/go/drk3. To find out more about how you can get DRK 3 and future versions of the DRK, visit the Macromedia DevNet subscription page at www.macromedia.com/devnet/ subscriptions.

Note: Portions of this article were originally published on the Macromedia DevNet Resource Kit, Volume 3.

More Stories By Christian Cantrell

Christian Cantrell is the Macromedia Server Community Manager. He has been developing large-scale, Web-based applications in ColdFusion, Java, JSP, and Macromedia Flash for the last five years. He is the author of numerous tutorials and white papers, and is coauthor of Flash Enabled: Flash Design & Development for Devices. Keep up with Christian by reading his blog at www.macromedia.com
/go/cantrell.

Comments (0)

Share your thoughts on this story.

Add your comment
You must be signed in to add a comment. Sign-in | Register

In accordance with our Comment Policy, we encourage comments that are on topic, relevant and to-the-point. We will remove comments that include profanity, personal attacks, racial slurs, threats of violence, or other inappropriate material that violates our Terms and Conditions, and will block users who make repeated violations. We ask all readers to expect diversity of opinion and to treat one another with dignity and respect.


@ThingsExpo Stories
Analytics is the foundation of smart data and now, with the ability to run Hadoop directly on smart storage systems like Cloudian HyperStore, enterprises will gain huge business advantages in terms of scalability, efficiency and cost savings as they move closer to realizing the potential of the Internet of Things. In his session at 16th Cloud Expo, Paul Turner, technology evangelist and CMO at Cloudian, Inc., will discuss the revolutionary notion that the storage world is transitioning from mere Big Data to smart data. He will argue that today’s hybrid cloud storage solutions, with commodity...
Cloud data governance was previously an avoided function when cloud deployments were relatively small. With the rapid adoption in public cloud – both rogue and sanctioned, it’s not uncommon to find regulated data dumped into public cloud and unprotected. This is why enterprises and cloud providers alike need to embrace a cloud data governance function and map policies, processes and technology controls accordingly. In her session at 15th Cloud Expo, Evelyn de Souza, Data Privacy and Compliance Strategy Leader at Cisco Systems, will focus on how to set up a cloud data governance program and s...
Roberto Medrano, Executive Vice President at SOA Software, had reached 30,000 page views on his home page - http://RobertoMedrano.SYS-CON.com/ - on the SYS-CON family of online magazines, which includes Cloud Computing Journal, Internet of Things Journal, Big Data Journal, and SOA World Magazine. He is a recognized executive in the information technology fields of SOA, internet security, governance, and compliance. He has extensive experience with both start-ups and large companies, having been involved at the beginning of four IT industries: EDA, Open Systems, Computer Security and now SOA.
The industrial software market has treated data with the mentality of “collect everything now, worry about how to use it later.” We now find ourselves buried in data, with the pervasive connectivity of the (Industrial) Internet of Things only piling on more numbers. There’s too much data and not enough information. In his session at @ThingsExpo, Bob Gates, Global Marketing Director, GE’s Intelligent Platforms business, to discuss how realizing the power of IoT, software developers are now focused on understanding how industrial data can create intelligence for industrial operations. Imagine ...
We certainly live in interesting technological times. And no more interesting than the current competing IoT standards for connectivity. Various standards bodies, approaches, and ecosystems are vying for mindshare and positioning for a competitive edge. It is clear that when the dust settles, we will have new protocols, evolved protocols, that will change the way we interact with devices and infrastructure. We will also have evolved web protocols, like HTTP/2, that will be changing the very core of our infrastructures. At the same time, we have old approaches made new again like micro-services...
Every innovation or invention was originally a daydream. You like to imagine a “what-if” scenario. And with all the attention being paid to the so-called Internet of Things (IoT) you don’t have to stretch the imagination too much to see how this may impact commercial and homeowners insurance. We’re beyond the point of accepting this as a leap of faith. The groundwork is laid. Now it’s just a matter of time. We can thank the inventors of smart thermostats for developing a practical business application that everyone can relate to. Gone are the salad days of smart home apps, the early chalkb...
Operational Hadoop and the Lambda Architecture for Streaming Data Apache Hadoop is emerging as a distributed platform for handling large and fast incoming streams of data. Predictive maintenance, supply chain optimization, and Internet-of-Things analysis are examples where Hadoop provides the scalable storage, processing, and analytics platform to gain meaningful insights from granular data that is typically only valuable from a large-scale, aggregate view. One architecture useful for capturing and analyzing streaming data is the Lambda Architecture, representing a model of how to analyze rea...
SYS-CON Events announced today that Vitria Technology, Inc. will exhibit at SYS-CON’s @ThingsExpo, which will take place on June 9-11, 2015, at the Javits Center in New York City, NY. Vitria will showcase the company’s new IoT Analytics Platform through live demonstrations at booth #330. Vitria’s IoT Analytics Platform, fully integrated and powered by an operational intelligence engine, enables customers to rapidly build and operationalize advanced analytics to deliver timely business outcomes for use cases across the industrial, enterprise, and consumer segments.
Today’s enterprise is being driven by disruptive competitive and human capital requirements to provide enterprise application access through not only desktops, but also mobile devices. To retrofit existing programs across all these devices using traditional programming methods is very costly and time consuming – often prohibitively so. In his session at @ThingsExpo, Jesse Shiah, CEO, President, and Co-Founder of AgilePoint Inc., discussed how you can create applications that run on all mobile devices as well as laptops and desktops using a visual drag-and-drop application – and eForms-buildi...
Containers and microservices have become topics of intense interest throughout the cloud developer and enterprise IT communities. Accordingly, attendees at the upcoming 16th Cloud Expo at the Javits Center in New York June 9-11 will find fresh new content in a new track called PaaS | Containers & Microservices Containers are not being considered for the first time by the cloud community, but a current era of re-consideration has pushed them to the top of the cloud agenda. With the launch of Docker's initial release in March of 2013, interest was revved up several notches. Then late last...
SYS-CON Events announced today that Dyn, the worldwide leader in Internet Performance, will exhibit at SYS-CON's 16th International Cloud Expo®, which will take place on June 9-11, 2015, at the Javits Center in New York City, NY. Dyn is a cloud-based Internet Performance company. Dyn helps companies monitor, control, and optimize online infrastructure for an exceptional end-user experience. Through a world-class network and unrivaled, objective intelligence into Internet conditions, Dyn ensures traffic gets delivered faster, safer, and more reliably than ever.
In their session at @ThingsExpo, Shyam Varan Nath, Principal Architect at GE, and Ibrahim Gokcen, who leads GE's advanced IoT analytics, focused on the Internet of Things / Industrial Internet and how to make it operational for business end-users. Learn about the challenges posed by machine and sensor data and how to marry it with enterprise data. They also discussed the tips and tricks to provide the Industrial Internet as an end-user consumable service using Big Data Analytics and Industrial Cloud.
The explosion of connected devices / sensors is creating an ever-expanding set of new and valuable data. In parallel the emerging capability of Big Data technologies to store, access, analyze, and react to this data is producing changes in business models under the umbrella of the Internet of Things (IoT). In particular within the Insurance industry, IoT appears positioned to enable deep changes by altering relationships between insurers, distributors, and the insured. In his session at @ThingsExpo, Michael Sick, a Senior Manager and Big Data Architect within Ernst and Young's Financial Servi...
Performance is the intersection of power, agility, control, and choice. If you value performance, and more specifically consistent performance, you need to look beyond simple virtualized compute. Many factors need to be considered to create a truly performant environment. In his General Session at 15th Cloud Expo, Harold Hannon, Sr. Software Architect at SoftLayer, discussed how to take advantage of a multitude of compute options and platform features to make cloud the cornerstone of your online presence.
Even as cloud and managed services grow increasingly central to business strategy and performance, challenges remain. The biggest sticking point for companies seeking to capitalize on the cloud is data security. Keeping data safe is an issue in any computing environment, and it has been a focus since the earliest days of the cloud revolution. Understandably so: a lot can go wrong when you allow valuable information to live outside the firewall. Recent revelations about government snooping, along with a steady stream of well-publicized data breaches, only add to the uncertainty
The explosion of connected devices / sensors is creating an ever-expanding set of new and valuable data. In parallel the emerging capability of Big Data technologies to store, access, analyze, and react to this data is producing changes in business models under the umbrella of the Internet of Things (IoT). In particular within the Insurance industry, IoT appears positioned to enable deep changes by altering relationships between insurers, distributors, and the insured. In his session at @ThingsExpo, Michael Sick, a Senior Manager and Big Data Architect within Ernst and Young's Financial Servi...
Docker is an excellent platform for organizations interested in running microservices. It offers portability and consistency between development and production environments, quick provisioning times, and a simple way to isolate services. In his session at DevOps Summit at 16th Cloud Expo, Shannon Williams, co-founder of Rancher Labs, will walk through these and other benefits of using Docker to run microservices, and provide an overview of RancherOS, a minimalist distribution of Linux designed expressly to run Docker. He will also discuss Rancher, an orchestration and service discovery platf...
PubNub on Monday has announced that it is partnering with IBM to bring its sophisticated real-time data streaming and messaging capabilities to Bluemix, IBM’s cloud development platform. “Today’s app and connected devices require an always-on connection, but building a secure, scalable solution from the ground up is time consuming, resource intensive, and error-prone,” said Todd Greene, CEO of PubNub. “PubNub enables web, mobile and IoT developers building apps on IBM Bluemix to quickly add scalable realtime functionality with minimal effort and cost.”
Sensor-enabled things are becoming more commonplace, precursors to a larger and more complex framework that most consider the ultimate promise of the IoT: things connecting, interacting, sharing, storing, and over time perhaps learning and predicting based on habits, behaviors, location, preferences, purchases and more. In his session at @ThingsExpo, Tom Wesselman, Director of Communications Ecosystem Architecture at Plantronics, will examine the still nascent IoT as it is coalescing, including what it is today, what it might ultimately be, the role of wearable tech, and technology gaps stil...
In the consumer IoT, everything is new, and the IT world of bits and bytes holds sway. But industrial and commercial realms encompass operational technology (OT) that has been around for 25 or 50 years. This grittier, pre-IP, more hands-on world has much to gain from Industrial IoT (IIoT) applications and principles. But adding sensors and wireless connectivity won’t work in environments that demand unwavering reliability and performance. In his session at @ThingsExpo, Ron Sege, CEO of Echelon, will discuss how as enterprise IT embraces other IoT-related technology trends, enterprises with i...