Currently, some business-oriented applications are configured to support some level of implementation by a separate, external application. For example, certain accounting applications provide functionality that is made accessible to users of a separate, external application, such as a customer management application. Conceivably, this extension of functionality could also or alternatively go in the other direction, for example, where functionality of a customer management application is made accessible to users of an accounting application.
A first application configured to implement functionality of a second application can run into problems when a new version of the second application is released. For example, the first application may not be configured to completely support the new version of the second application. In many cases, the first application must be updated or re-released to accommodate the new version of the second application.
Taken in the context of an external application configured to implement functionality of a business application, the external application can run into problems when newer versions of the business application are released. For example, a new version of the business application may support functionality and/or a database schema that are unfamiliar or unrecognizable to the external application. Under circumstances such as these, it is currently not uncommon for the external application to be updated or re-released to accommodate the release of one or more version updates.
The discussion above is merely provided for general background information and is not intended for use as an aid in determining the scope of the claimed subject matter.
A system for supporting version management is provided. The system includes a first application having a plurality of versions. Each of the plurality of versions is associated with a separate a version-specific assembly. A loader is configured to load one of the version-specific assemblies, the assembly then being utilized as a basis for deriving an object from a database associated with the first application. The object is provided to a second application, typically in response to a corresponding request.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended for use as an aid in determining the scope of the claimed subject matter. The claimed subject matter is not limited to implementations that solve any or all disadvantages noted in the background.
The precise implementation of applications 102 and 104, at least in terms of the computing device or hardware environment from which each application is made accessible, is not critical to the present invention. Both applications may be made accessible from the same computing device. Each application may be accessible from a separate device. One application may operate on a client machine with the other made accessible on a server machine. Communication between the applications may be local in nature or may be remotely accomplished through any network means such as, but not limited to, a local area network, a wide area network, or, more specifically, the Internet. The noted options are not provided by limitation but instead are provided simply to reinforce that all variations are to be considered within the scope of the present invention.
For the purpose of illustration, it is assumed that a first version (V1) of business application 104 was released and subsequently followed by release of a second version (V2). It is also assumed that, to the extent that application 102 provides access to functionality associated with application 104, that access extends to V1 features but falls short of complete access to V2 features. For example, it might be that only V1 was available when application 102 was constructed. Under these circumstances, application 102 is less than likely to have been equipped with full support for all V2 features.
Application 104 is shown in
External application 102 includes support 112 for accessing V1 data and/or functionality. As is shown, support 112 includes information 114 related to the location(s) where V1 assemblies 106 are located. External application 102 also includes support 116 for V1 interfaces such as, but not necessarily limited to, user interface components associated with the first version of business application 104. External application 102 lacks complete support for accessing V2 data and/or functionality, and also lacks support for at least some V2 interfaces.
Accordingly, the first version of business application 104 illustratively supports functionality and/or a database schema that are at least partially unfamiliar or unrecognizable to external application 102. As a remedy, application 102 could be updated or re-released to accommodate the release of the second version of application 104. For example, application 102 could be updated with support for V2 interfaces and/or support for accessing V2 data types and/or functionality, including information related to the location(s) of V2 assemblies 126. This is one way to address version updating. A different remedy will now be described in relation to
For environment 200, it is assumed that a first version (V1) of business application 104 was released and subsequently followed by release of a second version (V2), which was then followed by a release of “x” additional versions, where the variable x generally represents an unlimited number of additional versions. Within
The first version of application 204 (block 205) is shown in
A plurality of VX assemblies 240 are incorporated into a collection of VX data 242. This alternate configuration is intended to demonstrate that any of the described assemblies (e.g., 220, 230, etc.) can be, contrary to their depiction in the drawings, incorporated into a database, such as, but not limited to, their associated version database. Assemblies 240 are configured to support access to VX data 242 and/or certain VX functionality. Data 242 illustratively reflects (e.g., is formatted in accordance with) a VX database schema 244. Different versions of application 204 need not necessarily implement different database schema. The contrast in schemas is simply provided as an example of what might not be supported by application 202 as application 204 changes from one version to the next.
In contrast to system 100, system 200 includes a loader 270. Loader 270 is a mechanism configured to support integration of an external application with business application 204. Loader 270 enables an entity, such as an independent software vendor, to integrate with application 204 on a version-independent basis.
Loader 270 includes communication interfaces 272 that support communication with an external application, such as, in the illustrated example, application 202. It is through interfaces 272 that the external application gains access to a support component 274, which is, generally speaking, a way to access application 204 data and/or functionality in a generally version-independent manner. In one embodiment, support component 274 includes information related to the location or locations where V1 assemblies 220, V2 assemblies 230 and VX assemblies 240 are stored. In another embodiment, support component 274 includes means for accessing information related to the location or locations where the assemblies are stored (e.g., the location information is stored outside of the loader itself). The assemblies themselves include methods for the retrieval of data from databases 222, 232 and 242, respectively. Such methods might include, but certainly are not limited to, methods geared toward launching forms, launching reports, creating entities, saving entities, etc.
A given set of application 204 assemblies (e.g., one of assemblies 220, 230 or 240) is illustratively compatible with previous versions of the application interfaces. For example, V2 assemblies 230 are compatible with V1 interfaces 214. Application 204 objects can therefore be cast in accordance with any version of interfaces up to the present or latest version.
Accordingly, in one embodiment, external application 202 can be compiled using any version of the application 204 interfaces. Then, when application 204 objects are instantiated, there is no need for application 202 to know the location and version of the application 204 assemblies. Instead, loader 270 is configured to retrieve the assemblies that are associated with the relevant database or databases. When loader 270 returns an object that it has instantiated from the assembly that corresponds to the applicable database version, that object can be cast by application 202 in accordance with the latest available version of the application 204 interfaces (only V1 interfaces 214 are available in the illustrated case). Thus, the loader abstracts away from finding an “appropriate” version and enables application 202 to connect to any version of application 204 without having to recompile and/or re-release application 202.
An additional example may help to further one's understanding of the described application loader and related functionality. One can imagine a scenario wherein an external application (i.e., a calling application) is built during the timeframe of a second version of a business application with which the loader is affiliated. The external application illustratively is statically bound to V1 and V2 interfaces and does not ‘know’ anything about future methods (V3+). However, further methods will support the V1 and V2 interfaces.
To continue the example, the external application now uses the loader to connect to a database associated with a third version of the business application. The loader locates and loads related V3 assemblies. The loader then returns objects from these assemblies. The returned objects can be cast to any of the V1, V2 or V3 interface versions. Since the calling application (i.e., the external application) is only binding to V1 and V2 interfaces, it can only cast to V1 and V2 and use the methods from these versions.
In yet another example, a calling application (i.e., an external application) is built during the timeframe of a third version of a business application with which the loader is affiliated. The external application illustratively is statically bound to V3 interfaces and does not ‘know’ anything about V1 or V2 interfaces. The external application now uses the loader to connect to a database associated with a second version of the business application. The loader locates and loads related V2 assemblies. The loader then returns objects from these assemblies. The returned objects implement only V1 or V2 interface versions. If the calling application tries to cast the returned objects to V3 interfaces, it will illustratively fail (e.g., triggering an invalid cast exception) because the object do not implement V3 interfaces. In one embodiment, the external application is equipped to respond to this cast conflict. In one embodiment, a type check is performed prior to casting in order to anticipate and address problems that may arise.
For obvious reasons, the functionality of loader 270 is dependent on having access to appropriate assemblies. In accordance with one embodiment, loader 270 is configured to trigger an exception in instances where the assembly version required for a given database cannot be located (e.g., when that particular version of the business application has not been installed). In one embodiment, the calling application (i.e., the external application) is configured to catch those exceptions and obtain (e.g., through use of the loader) a redistributable package that will install the required version.
In one embodiment, when the business application is updated (e.g., when a new version is released), loader 270 need not be significantly changed, or even changed at all. For example, after a new version is registered, loader 270 may automatically discover and implement it. For example, in one embodiment, loader 270 is configured to access a listing of available versions and/or a listing of where associated assemblies are located. Therefore, extending the functionality of loader 270 may be as simple as adding new version information to the listing or listings, rather than making substantial changes to the loader itself. This is not to say that the loader cannot be updated, it simply can be configured to require little or no updating upon each new release.
In accordance with one embodiment, a loader such as loader 270, is distributed by a sponsor of a business application as a software utility. The loader is made available, for example, to a person or entity that plans to develop an external application designed to integrate with the business application. In one embodiment, the loader is independent of the business application such that new version of the loader can be released independent of the business application. Applications that use the loader illustratively bind to the loader interface (e.g., interfaces 272) rather than the actual loader in order to be abstracted from subsequent implementation changes.
Architecture 400 differs from environment 200 in that it shows an implicit interface 420 between application 404 and loader 418. Interface 420 represents the methods and means for supporting communication between loader 418 and application 404. The interface is shown as being “implicit” because it need not necessarily be a set of formal interfaces. The interaction between loader 418 and application 404 dos not necessarily require such a channel of communication.
Architecture 400 also differs from environment 200 in that business application 404 is shown to include a reports factory 406, a forms factory 408 and a software development kit (SDK) 410. Components 406, 408 and 410 are illustratively associated with assemblies exposed to loader 418. The SDK 410 is illustratively configured to support a developer of an external application (e.g., application 402) in terms of accomplishing an integration of application 404 functionality. Application objects 416 are derived from the reports factory 406, the forms factory 408, SDK 410 and/or a database of application data 412. Objects 416 are passed, in response to calls from application 402, by loader 418, through interface 414, to application 402 in a manner consistent with the application independent processing described in relation to
Those skilled in the art will appreciate that there are many different ways in which the described loader mechanism can be installed, implemented, maintained, etc. The present description will now turn to a set of specific examples. Of course, these examples are provided in the spirit of providing a complete explanation of the present invention. Those skilled in the art will appreciate that the scope of the present invention extends well beyond the specific examples provided herein.
In accordance with one embodiment, utilization of a loader as described herein begins with loading a loader assembly and obtaining a loader object. In one embodiment, certainly not by limitation, the loader assembly is installed to the Global Assembly Cache (GAC) and is loaded by its strong name.
Once installed, the loader can illustratively be used to connect to any database associated with the business application affiliated with the loader. The loader will then, as described herein, facilitate the return appropriate version-specific objects. The loader interface illustratively provides a method for retrieving the assemblies (e.g., the forms factory assemblies, the reports factor assemblies, etc.) for a given database. In one embodiment, the method also has overloads that take a configuration-object or the database and server name. The calling application will call the loader to get the business application objects.
In accordance with one embodiment, the loader is not strongly bound to any version of the affiliated business application and returns objects directly without type casting them. The calling application illustratively type-checks and casts the objects appropriately.
In one embodiment, the loader implements a LoaderException class. Since the loader is calling methods on the business application objects themselves it can illustratively throw both LoaderExceptions and BusinessApplicationExceptions. Since calling applications should not be binding statically to the loader assembly or business application assemblies but only to the interface assemblies, they illustratively will catch ApplicationExceptions when using the loader and then type cast it to either SmallBusinessExceptions or LoaderExceptions.
In one embodiment, certainly not by limitation, the LoaderExceptions are defined by the following:
As has been alluded to herein, a database generally can only be opened by a version of the business application that supports the same schema version. So when connecting to a given database the loader illustratively provides methods for retrieving a redistributable package that can be installed by the user (or the calling application). In one embodiment, a calling application can get the redistributable by calling a method of the interface that creates the file locally and returns the full path. It is then up to the application to launch a process and run the package or message to the user where to install the package from.
A simple example of how the loader is used will now be provided. The example assumes that the application assembly is statically bound to the loader interface assembly (ILoader.dll) and all business application assemblies of the desired version (BussAppIAPI.dll, BussAppIU.dll, etc.). It should be noted that “SmallBusinessInstance” is an example of a business application assembly. The example is as follows:
Examples of interfaces, certainly not by limitation will now be provided. An example configuration interface is as follows:
An example connector interface is as follows:
An example loader interface is as follows:
In one embodiment, a loader interface includes a “launcher” method configured to launch the version of the application that corresponds to a particular database. For example, the launcher method will illustratively launch the application with the database open that is passed in to the method.
In one embodiment, an application objects interface is implemented and is illustratively an object that is returned from the loader. This interface illustratively includes the properties for getting certain particular object such as, but not limited to, FormsFactory objects, ReportsEngine objects, etc. For example,
The advantage of this type of interface is that it will abstract the caller from the implementation of those objects. For example, before using ApplicationInstance, there needs to be a call on a LogOn method, and before using the FormsFactory, there needs to be a call on Initialize. These methods are illustratively called automatically by the Loader so that the caller isn't required to know about the implementation detail. Further, changes can be made to the implementation without causing disruption. This is an additional level of abstraction.
Embodiments are operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well-known computing systems, environments, and/or configurations that may be suitable for use with various embodiments include, but are not limited to, personal computers, server computers, hand-held or laptop devices, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, telephony systems, distributed computing environments that include any of the above systems or devices, and the like.
Embodiments have been described herein in the general context of computer-executable instructions, such as program modules, being executed by a computer. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. Embodiments can be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules can be located on both (or either) local and remote computer storage media including memory storage devices.
With reference to
Computer 510 typically includes a variety of computer readable media. Computer readable media can be any available media that can be accessed by computer 510 and includes both volatile and nonvolatile media, removable and non-removable media. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. Computer storage media includes volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by computer 610. Communication media typically embodies computer readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. Combinations of any of the above should also be included within the scope of computer readable media.
The system memory 530 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 531 and random access memory (RAM) 532. A basic input/output system 533 (BIOS), containing the basic routines that help to transfer information between elements within computer 510, such as during start-up, is typically stored in ROM 531. RAM 532 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 520. By way of example, and not limitation,
The computer 510 may also include other removable/non-removable volatile/nonvolatile computer storage media. By way of example only,
The drives and their associated computer storage media discussed above and illustrated in
A user may enter commands and information into the computer 510 through input devices such as a keyboard 562 and a pointing device 561, such as a mouse, trackball or touch pad. Other input devices (not shown) may include a joystick, game pad, microphone, satellite dish, scanner, or the like. These and other input devices are often connected to the processing unit 520 through a user input interface 560 that is coupled to the system bus, but may be connected by other interface and bus structures, such as a parallel port, game port or a universal serial bus (USB). A monitor 591 or other type of display device is also connected to the system bus 521 via an interface, such as a video interface 590. In addition to the monitor, computers may also include other peripheral output devices such as speakers 597 and printer 596, which may be connected through an output peripheral interface 595.
The computer 510 is operated in a networked environment using logical connections to one or more remote computers, such as a remote computer 580. The logical connection depicted in
By way of example, and not limitation,
It is worth emphasizing that inclusion of a payment interface entity 112 in the payment process is not critical to the present invention. A system including entity 112 is provided as but one example of a system within the scope of the present invention. Any system wherein application 102 communicates with a payment provider, whether directly or indirectly through another entity or entities, is within the scope of the present invention. It is interesting that submission identifier information is preserved to the bank or banks. The path taken to the bank or banks is not critical to the present invention. All such paths are within the scope of the invention, whether specifically described herein or not.
Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims.
Number | Name | Date | Kind |
---|---|---|---|
5815661 | Gosling | Sep 1998 | A |
5875435 | Brown | Feb 1999 | A |
5978834 | Simonoff | Nov 1999 | A |
6052527 | Delcourt | Apr 2000 | A |
6078322 | Siminoff et al. | Jun 2000 | A |
6101328 | Bakshi et al. | Aug 2000 | A |
6119130 | Nguyen et al. | Sep 2000 | A |
6363362 | Burfield et al. | Mar 2002 | B1 |
6370682 | Eckardt | Apr 2002 | B1 |
6529909 | Bowman-Amuah | Mar 2003 | B1 |
6665677 | Wotring et al. | Dec 2003 | B1 |
6671853 | Burkett et al. | Dec 2003 | B1 |
6725453 | Lucas et al. | Apr 2004 | B1 |
6810429 | Walsh et al. | Oct 2004 | B1 |
6826568 | Bernstein et al. | Nov 2004 | B2 |
6826750 | Curtis et al. | Nov 2004 | B1 |
6853997 | Wotring et al. | Feb 2005 | B2 |
6862616 | Tompkins | Mar 2005 | B1 |
6862735 | Slaughter | Mar 2005 | B1 |
6898604 | Ballinger et al. | May 2005 | B1 |
6986148 | Johnson, Jr. | Jan 2006 | B2 |
7013306 | Turba et al. | Mar 2006 | B1 |
7031956 | Lee et al. | Apr 2006 | B1 |
7065560 | Erickson et al. | Jun 2006 | B2 |
7069562 | Kushnirskiy et al. | Jun 2006 | B2 |
7130863 | Diab | Oct 2006 | B2 |
7158967 | Turba et al. | Jan 2007 | B1 |
7158990 | Guo et al. | Jan 2007 | B1 |
7178142 | Bennett et al. | Feb 2007 | B2 |
7194679 | Green | Mar 2007 | B1 |
7418456 | Charlet et al. | Aug 2008 | B2 |
7441185 | Coulson et al. | Oct 2008 | B2 |
7458073 | Darling et al. | Nov 2008 | B1 |
7539701 | Sethi | May 2009 | B2 |
7779402 | Abernethy et al. | Aug 2010 | B2 |
20020019972 | Grier et al. | Feb 2002 | A1 |
20020078437 | Grassman et al. | Jun 2002 | A1 |
20020156814 | Ho | Oct 2002 | A1 |
20030018658 | Suermondt et al. | Jan 2003 | A1 |
20030046317 | Cseri et al. | Mar 2003 | A1 |
20030097433 | Park | May 2003 | A1 |
20030130845 | Poplawski | Jul 2003 | A1 |
20030159135 | Hiller et al. | Aug 2003 | A1 |
20030192036 | Karkare | Oct 2003 | A1 |
20030216990 | Star | Nov 2003 | A1 |
20040044965 | Toyama et al. | Mar 2004 | A1 |
20040049736 | Al-Azzawe et al. | Mar 2004 | A1 |
20040054626 | Fuentes | Mar 2004 | A1 |
20040143791 | Ito et al. | Jul 2004 | A1 |
20040153462 | Bardwell | Aug 2004 | A1 |
20040181753 | Michaelides | Sep 2004 | A1 |
20040199876 | Ethier et al. | Oct 2004 | A1 |
20040230569 | Rys et al. | Nov 2004 | A1 |
20040249762 | Garibay et al. | Dec 2004 | A1 |
20050022154 | Chung et al. | Jan 2005 | A1 |
20050060284 | Ruby et al. | Mar 2005 | A1 |
20050065942 | Diab | Mar 2005 | A1 |
20050097504 | Ballinger et al. | May 2005 | A1 |
20050102370 | Lin et al. | May 2005 | A1 |
20050108627 | Mireku | May 2005 | A1 |
20050144622 | Ballinger et al. | Jun 2005 | A1 |
20050240467 | Eckart et al. | Oct 2005 | A1 |
20050273709 | Lough et al. | Dec 2005 | A1 |
20060080289 | Brunswig et al. | Apr 2006 | A1 |
20060117061 | Weiss | Jun 2006 | A1 |
20060161912 | Barrs et al. | Jul 2006 | A1 |
20060168513 | Coulson et al. | Jul 2006 | A1 |
20060184918 | Rosaria et al. | Aug 2006 | A1 |
20060190814 | Collie et al. | Aug 2006 | A1 |
20060218160 | Bhatia | Sep 2006 | A1 |
20060230339 | Achanta et al. | Oct 2006 | A1 |
20060235862 | Heuer et al. | Oct 2006 | A1 |
20070005622 | Fernandes et al. | Jan 2007 | A1 |
20070083538 | Roy et al. | Apr 2007 | A1 |
20070112714 | Fairweather | May 2007 | A1 |
20070192679 | Foushee, Jr. et al. | Aug 2007 | A1 |
20070271305 | Chandrasekar et al. | Nov 2007 | A1 |
20070294684 | Kumashiro et al. | Dec 2007 | A1 |
20080065978 | Francker et al. | Mar 2008 | A1 |
20080098291 | Bradley et al. | Apr 2008 | A1 |
20080134019 | Wake et al. | Jun 2008 | A1 |
20090112902 | Sthanikam et al. | Apr 2009 | A1 |
Number | Date | Country |
---|---|---|
WO 0120504 | Mar 2001 | WO |
WO 0157613 | Aug 2001 | WO |
WO 2006032063 | Mar 2006 | WO |
Number | Date | Country | |
---|---|---|---|
20080133590 A1 | Jun 2008 | US |