Freed From Purgatory

In a previous post I mentioned I had started a new job with a local defense contractor after being pretty much self-employed since 1997.  I was brought on-board to lead an on-site effort supporting a high visibility Navy project after the original lead developer moved on.  Prior to being hired, I had what appeared to be a successful interview with the customer.  At least I thought he was the customer. Turns out the guy doing the interview is working for a competing contractor (just a slight conflict of interest) and acting as a proxy for the customer. Even though they approved the hire, and the money was there, they kept stalling.  We think the guy is holding out for his company to find somebody to fill the position. Meanwhile I toiled away at performing maintenance task and some data munging on a couple of seasoned Fusebox3 applications. We gave the customer a decision deadline which has now come and past. So I will not be working on the project I was hired for. Oh, very well.

The good news is that I got an interview for another high profile Navy project that is gaining momentum and will be going joint-service over the next couple years, as the U.S. Air Force, Army and Marine Corp adopt the program.  They have hired me and I start January 2.  I am really looking forward to the opportunity and feel confident I can bring something to the table.

One of the downers of working on large Government contracts like this is that they are slow to adopt new technology, due to the constraints imposed by the IT overlords.  I will get to experience all the wonders of Enterprise computing for the first time in my life. I already know that most of the tools I have grown to love will not be part of this endeavor, at least at first.  No more Eclipse/CFEclipse, they use Dreamweaver.  They are still at CFMX 6.1, and would eventually like to move to 7.02 or Scorpio, if they ever make the approved software list.

On the plus side, I have been given some side projects to do in my spare time, including building a new company intranet, so I will still get to play around with the cool stuff on my own time, however much of that there may be.

I do know that for the first time in ten years of so, I will be working on a contract that has 5 years worth of work on it. There is a lot to be said for that.

Another Satisfied FAQu Customer

I just received my first two Fusion Authority Quarterly Updates (FAQu, as it is affectionately called) from the folks at Fusion Authority.  I don't know why I wasn't paying attention when news about this publication was originally released, but I definitely missed the boat somehow.  After seeing  Peter Bell blog about it earlier this month (he's a contributor) I decided to take the plunge.

What can I say that hasn't already been said? FAQu has great packaging, great content, and great production.  I like the size and feel of the publications, which resemble soft-cover books, allowing them to be stacked on-end in your bookshelf.  They also appear to perfectly engineered to fit the top of the, er, john..., for those folk who enjoy an extended morning constitutional.  The advertising somehow stays out of the way, not interrupting your reading flow, unlike most other publications of this ilk.  The contributors are all top notch, and are covering the hot topics in the community right now.

Michael and Judith Dinowitz, et.al. have really done an excellent job on this effort. FAQu is a quality product with great content and well worth the subscription fee. 

Purgatory

I started a new job last week working for a local company as a senior CF developer.  The job I signed up for was supposed to be a high-vis project, with multiple applications written in CFMX 6.1/Fusebox 4.1, with plans to move to Fusebox 5.  I was looking forward to this, as I have been interested in taking a peek at Sean Corfield's work in FB5, which has gotten really good reviews. Plus it was supposed to give me an opportunity to work with a small team for the first time in a long...... time.  I was stoked.

However, as sometimes happens, things have stalled. My position is not 'turned on', and I don't mean that in the way you would want it to.  In the interim, I have been assigned to do some work on some other projects that need some attention.  For how long, I do not know.

Oh my heck.  

My worst fears have been realized. I have now inherited 3 projects left by my predecessor, all using different frameworks/versions and no documentation.  He left several weeks prior to my arrival, so there was no formal turnover, although I did get him on the phone for about 30 minutes.

The one I am working on now is a Fusebox 3 application without the Flip and Fusedocs.  The database is Access and there is a printed ER diagram, but no CASE tool, and no descriptions of what the tables are for, or what the fields mean. I know about what the application is supposed to do, but I don't understand the business domain at all, and I was forced to meet with the clients to discuss changes *before* I ever laid eyes on the application.  Yowza.

My next one is one that is 95% complete according to the former developer, and it is written in Model-Glue Unity.  Again, I have a rough idea of what it is supposed to do, but there is no formal documentation.

This company has a lot of CF developers, but they are spread out at client facilities, and there clearly has not been an effort to standardize anything where development is concerned.  Maybe I can help them with that.

On a positive note, I should get some good experience working with several flavors of Fusebox and Model-Glue Unity.  However, since the projects are already way down the road, the clients are starting to complain about late deliverables.

This is going to be painful for a while, I just know it.

Plum Redux

Development frameworks are a hot topic in the ColdFusion (or any development) community right now. Many consider them essential to developing maintainable, scalable applications. Other's decry community frameworks, arguing that they are crutches and add unnecessary complexity to solving their business problems.  I won't rehash these arguments (Google to your heart's content), but I will point out that there seems to be enough interest in CF frameworks, that Michael Smith and TeraTech are sponsoring a Frameworks Conference in February 2007. 

One framework that sadly won't be represented at the Frameworks Conference is Plum, and that's a shame, because I believe Plum rocks the house.

ColdFusion was originally a Windows-based, procedural, web development environment. When Macromedia acquired ColdFusion from Allaire and subsequently rebuilt it on the J2EE platform, we began to see the beginnings of the "javafication" of ColdFusion.  ColdFusion Components (CFCs; essentially object classes) were added and object-speak started to become pervasive in the community. This has really picked up steam recently, as many developers with Java backgrounds are moving to ColdFusion, bringing with them their best practices for Enterprise team development, Macbook Pros and Linux backends. We now have a slew of Object Oriented (OO) frameworks like Mach ii, Model-Glue Unity, ColdBox, etc. which have adopted the Model-View-Controller design pattern and use XML configuration files.  Even Fusebox, arguably the most widely adopted CF framework, has been morphing from a procedural framework into a OO hybrid.  Do I see this as a bad thing?  Not at all.  I see it as a necessity for ColdFusion to continue to evolve and be taken seriously in the Enterprise development space, which I believe must succeed for ColdFusion to have any long-term viability.

However, let's remember that CFML is *still* a procedural language, and not everyone wants to be an Enterprise psuedo-java developer. There are scores of smaller shops out there that run exclusively on Windows, and use ColdFusion to provide products and services for their customers, who have absolutely no interest in OOP, MVC, etc.  They are focused on getting their projects out the door as quickly and cost effectively as possible, and the luxury of studying and rewriting  their apps using MVC may not exist for them.

It is possible to write large, performant, scalable web applications with ColdFusion without going the down the java-lite route. If you're not into rolling your own, Plum will help do this for you, and very quickly.  Plum was originally an internal framework built by Adam and David Churvis at Productivity Enhancement.  For those of you who don't know, Adam and David co-authored the ColdFusion MX Bible, along with Charlie Arehart and Hal Helms. Their chapters on advanced database concepts and custom tag development are worth the price of the book alone. They are widely recognized for their database and scalability prowess, in addition to being excellent trainers. They espouse development best practices. Plum represents the best of their development and training philosophies.  And it is available to you as a development and/or learning tool, free of charge.

I have been using Plum as my main CF framework for about 3 years now (since the first alpha), and have built about 14 applications with it in that time. Most are not public facing (I do a lot of intranets), but some of these are outsourced projects for some well known companies including British Gas, Sun  Oil (Sunoco) and Merrill Lynch. I have not once encountered an error from one of these applications that wasn't directly induced by me or was a recognized bug in CF. 

You don't see a lot of traffic on the Plum mailing list nowadays, and I believe one of the reasons is because the framework core files are so bug free that you don't have a lot of problems. Another reason is because not many folks are adopting Plum anymore for various reasons.  Perhaps the foremost is that Adam and David are now focusing on Microsoft .NET technologies, and there are no immediate plans to further the development of the CFML version of Plum. It works fine now and there are only a couple of minor issues.  Other reasons include the fact that there is no support for MySQL or Postgres, and that the code generator is a Windows .NET application.

I plan on frequently blogging on Plum, if for no other reason that those of us in that community can share tips and tricks, show off some sites we have done, etc. There is a lot to talk about. We might even be able to address some of the shortcomings with the Churvises blessing down the road if there is interest.  So if you are a Plum afficionado, please stay tuned.

P.S. On a side note, I have just been hired as a full time developer working with a small team on a long term Fusebox project.  You can expect that I will be devoting some time on this blog comparing and contrasting the two frameworks and methodologies.

Papa's Got a Brand New Gig

I will be starting a new job on November 16th, under the employ of Sierra Management and Technologies, Inc.   The position is is for a senior/lead ColdFusion developer working on a project I can't talk about, or I will have to shoot both of us!

I am excited about the opportunity, and sad that I am having to leave KR Systems.  The people there are fantastic, and Gail and Dave Kelley are some of the most gracious folks I have ever had the pleasure of knowing. I will always treasure my memories of working there.

The new position with Sierra offers a lot of opportunity to be involved in a very high visibility program, and I will work as part of a development team for only the second time in my career.  I am moving out of my home office for the first time in 12 years. Whew!

While I don't know many of the specifics of the projects involved yet, I do know we will be using ColdFusion MX 6.1 running Fusebox 4.1.   I was originally told we were using version 5, but I later spoke to the developer I am replacing and he confirmed it is FB 4.1, although I am not sure whether they are using MVC or not.    I have never been a fan of Fusebox as an individual developer ; I always felt there was too much complexity for little return.   But I am vowing to keep an open mind here.  A lot of very highly respected developers/teams use Fusebox and it is prevalent in the Federal Government

So I have started woodshedding to begin coming up to speed. It will be a challenge, but a welcome one. I was starting to get slightly complacent and it will be nice to shake things up again.

MAX Scorpio (CF8) Preview

Some of the upcoming Scorpio (CF8) feature set is being blogged by attendees at the Adobe MAX conference in Las Vegas this week (maybe I'll be able to attend one of these someday, hopefully in Vegas, where my family resides). A couple of the more interesting tidbits: There will finally be a CFIMAGE tag for image manipulation. It will support some 40 functions or so, supporting resizing watermarks, CAPTCHA, and basic drawing functions to name a few. Some people are thrilled, although there have been thir-party-solutions available to do this for years. I have personally never built a system with this requirement, and I have been using CF since version 2. ColdFusion .Net Integration - Scorpio will provide much better integration with .NET making it easier to leverage MS Office products. You can interact with .NET now by using web services, but this new feature will allow you to use messaging, COM and a new service called Runtime Unification, which will allow you to invoke .NET components either locally or remotely (.NET runtime on different server). This will be sweet for those of us who work exclusively in Windows. It may also prevent some mindshare from leaving for the BlueDragon camp. Server Monitoring - There will be a built-in server/performanace monitor which will provide out-of-the box many of the capabilities which are currently provided by third-party products such as SeeFusion or FusionReactor Ben Forta has been asking CF developers for the past few months what they would like to see in a CF IDE. We may see an IDE for CF developers that has the spit and polish of FlexBuilder, including an interactive debugger, which is top-tier in my book. All of this doesn't seem to bode well for third-party CF tool developers who have invested a lot of resources to fill these niches.

CFEclipse 1.3 Beta Integrated with FlexBuilder

Dean Harmon, the Adobe engineer responsible for the CF ReportBuilder and FlexBuilder2 ColdFusion Application/Extension Wizards, has tweaked CFEclipse 1.3 to make it compatible with Eclipse 3.1.

This is a short-term godsend as far as I am concerned. Many of us updated our Eclipse builds to 3.2 to take advantage of some of the feature enhancements of CFEclipse 1.3, which would only run under 3.2. Because FlexBuilder2 was built using the Eclipse 3.1 platform, you were left with two options; either install and use the supported standalone version without CFEclipse 1.3, or install the FB2 plugin into the Eclipse 3.2 build and use it in an unsupported manner. Since FlexBuilder2 was just released a couple months ago, I opted for the former. This resulted in having to work in two different environments.

Dean's integration work now means you can access CFEclipse functionality while using the standalone FlexBuilder. This is a big deal if you are a ColdFusion developer trying to work with CFCs and remoting.

The updated CFEclipse build can be found here.

BlogCFC was created by Raymond Camden. This blog is running version 5.5.001.