I recently had a chance to demo OpenSpan, which is one of the tools that you can consider for bringing those legacy apps into the modern age of composite applications. If you're like many, you have multiple, disparate apps - Windows, legacy, Web, whatever - operating as functional silos... Mashups can help you eliminate re-keying of data between apps...

Sandy Kemsley, Contributor

May 21, 2008

4 Min Read

I recently had a chance to demo OpenSpan, which is one of the tools that you can consider for bringing those legacy apps into the modern age of composite applications. A big problem with the existing user environment is that it has multiple, disparate applications - Windows, legacy, Web, whatever - that operate as non-integrated, functional silos. This requires re-keying of data between applications, or copy and paste if the user is particularly sophisticated. I see this all the time with my clients, and I'm constantly working with them to find improvements that reduce double keying.

In OpenSpan Studio, the visual design environment, you add a Windows (including terminal emulator or even DOS window) or Web application that you want to integrate, then use the interrogation tool to individually interrogate each individual Windows object (e.g., button) or Web page object (e.g., text box, hyperlink) to automatically create interfaces to those objects: a very sophisticated form of screen-scraping, if you will. However, you can also capture the events that occur with those objects, such as a button being clicked, and cause that to invoke actions or transfer data to other objects in other applications. Even bookmarks in MS-Word documents show up as entry/access points in the Studio environment.Within a couple of minutes, OpenSpan built and executed a simple example using the Windows calculator and the Google home page: whenever you hit the M+ button in Calculator, it transferred the contents of the calculator to Google and executed a search on it. This is more than the simple pushing of buttons that you typically find in old-style screen-scraping however; it actually hooks the message queue of the application to allow it to intercept any UI event, which means that other events in other applications can be triggered based on any detected event in the interrogated application. This effectively lets you extend the functionality of an existing application without changing it.

A more complex example interrogated rates on the FedEx Website to bring results back to Excel, or to bring them back and compare them with UPS rates in a custom UI form that was built right in the Studio environment. You don't have to build a UI in their environment: you can use Visual Studio or some other application builder instead, or build .Net controls in another environment and consume them in the OpenSpan Studio (which is a .Net environment).

As you would expect from an integration environment, it can also introspect and integrate any Web service based on the WSDL, but it can also encapsulate any solution that you create within OpenSpan and expose it as a service, albeit running on the local desktop: a very cool way to service-enable legacy applications. That means that you can make "Web" service wrappers around green-screen or legacy Windows applications, exposing them through a SOAP interface, allowing them to be called from any development/mashup environment.

The integrations and applications defined in Studio are saved to an XML file, which is consumed by the lightweight runtime environment, OpenSpan Integrator; it can launch any applications as required or on startup, and manage the integration between them (which was created in Studio). You can use this to do single sign-on - although not in as secure a fashion as dedicated SSO applications - and can even call services between native desktop applications and virtual environments (e.g., a client service within Citrix). Although the Integrator needs to be running in order to access the integrations via SOAP calls, it can run completely in stealth mode, allowing other applications to call it as if it were a true Web service.

You can also integrate databases, which lets you make database calls based on what's happening on the screen in order to create analytics that never existed before. As with all other aspects of the integration, these are based only on events that happen in the user interface, but that still has the potential to give you a lot more than what you might have now in your legacy applications.I recently had a chance to demo OpenSpan, which is one of the tools that you can consider for bringing those legacy apps into the modern age of composite applications. If you're like many, you have multiple, disparate apps - Windows, legacy, Web, whatever - operating as functional silos... Mashups can help you eliminate re-keying of data between apps...

About the Author(s)

Sandy Kemsley

Contributor

is a systems architect and analyst who specializes in BPM and Enterprise 2.0.

Never Miss a Beat: Get a snapshot of the issues affecting the IT industry straight to your inbox.

You May Also Like


More Insights