A company involved in litigation may be obligated to locate and disclose all relevant “evidence” to opposing counsel. Such evidence may include a variety of electronic content, including email messages, documents and files, list and other contents maintained on websites, and the like, spread across disparate contents source systems including on premise (local) and cloud-based servers. Content in these content source systems related to the litigation is often placed “on hold” or preserved for later retrieval and analysis. The amount of data preserved may be vast, and locating and preserving the relevant electronic content across the disparate systems may need to be performed without disrupting end-users' access to the content or the content sources.
It is with respect to these considerations and others that the disclosure made herein is presented.
Technologies are described herein for providing efficient in-place preservation of content in multiple, disparate content sources without disrupting end-users' access to the content or content sources. Utilizing the technologies described herein, various content items in disparate content sources deemed relevant to a business issue or event may be preserved as of a particular date for later retrieval and analysis. The preservation may be performed in-place so that duplicate storage of content items is minimized or eliminated without limiting end-users' ability to access or modify the content items. Moreover, the in-place preservation may allow the preserved content items to be indexed and searched by appropriate personnel involved in the business issue or event utilizing the security and services provided by the content source system while the preserved versions of the content items remain hidden to the end-users.
According to embodiments, a content server receives a preservation request comprising a specification of a content source hosted on the content server and a filter specification. The content server may mark the specified content source as “on hold” by creating a hold specification related to the content source. If the content server detects that a content item has been modified or deleted in a content source that is on hold, the content server places a copy of the current version of the content item into a preservation storage area. The preservation storage area may be a hidden area in the content source, for example. The content server may then periodically run a trim job that removes content items from the preservation storage area that do not match the filter specification.
It will be appreciated that the above-described subject matter may be implemented as a computer-controlled apparatus, a computer process, a computing system, or as an article of manufacture such as a computer-readable medium. These and various other features will be apparent from a reading of the following Detailed Description and a review of the associated drawings.
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 that this Summary be used to limit the scope of the claimed subject matter. Furthermore, the claimed subject matter is not limited to implementations that solve any or all disadvantages noted in any part of this disclosure.
The following detailed description is directed to technologies for providing efficient in-place preservation of content in multiple, disparate content sources without disrupting end-users' access to the content or content sources. While the subject matter described herein is presented in the general context of program modules that execute in conjunction with the execution of an operating system and application programs on a computer system, those skilled in the art will recognize that other implementations may be performed in combination with other types of program modules. Generally, program modules include routines, programs, components, data structures, and other types of structures that perform particular tasks or implement particular abstract data types. Moreover, those skilled in the art will appreciate that the subject matter described herein may be practiced with other computer system configurations, including hand-held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, mainframe computers, and the like.
In the following detailed description, references are made to the accompanying drawings that form a part hereof and that show, by way of illustration, specific embodiments or examples. In the accompanying drawings, like numerals represent like elements through the several figures.
An e-discovery client 104 may execute on the computer system 102. In one embodiment, the e-discovery client 104 may be a component of a larger e-discovery application that may be utilized by a user to identify and preserve a set of content items relevant to a business issue or event, such as litigation or other legal matters, for example. The e-discovery client 104 may allow the user to utilize targeted search queries to locate relevant content items from a “virtual archive” comprising content items 108 stored in multiple content sources 110. Examples of a content source 110 may include an email mailbox, a document library, a fileshare, a discussion thread, a Web log (“blog”), a website, and the like. Examples of content items 108 may include email messages, documents or files, webpages, an entry in a discussion thread, a blog post, a wiki page entry, and the like.
According to embodiments, the content items 108 may be hosted by, stored on, and/or accessed through multiple, disparate content servers 112A-112N (also referred to herein generally as content servers 112 or content server 112). The e-discovery client 104 may access the content servers 112 over a network 114. The network 114 may be a local-area network (“LAN”), a wide-area network (“WAN”), the Internet, or any other networking topology known in the art that connects the computer system 102 to the content servers 112. The content servers 112 may include local servers located in the same location or on the same corporate LAN/WAN as the computer system 102, as well as cloud-based server resources accessed by the e-discovery client 104 over the Internet.
In one embodiment, the content servers 112 include one or more email servers, such as MICROSOFT® EXCHANGE SERVER email servers from Microsoft Corporation of Redmond, Washington. The content servers 112 may also include one or more content site servers, such as MICROSOFT® SHAREPOINT® servers, also from Microsoft Corporation. The content servers 112 may also include one or more file servers, NAS storage devices, or other file and document storage systems. In other embodiments, the content servers 112 may include document management servers, database servers, Web servers, and other data and content servers known in the art.
The e-discovery client 104 may access a case dataset 116 that defines the various content sources 110 containing the content items 108 comprising the virtual archive of items to be located and preserved. The case dataset 116 may represent an XML file, one or more database tables in a database, or any other structured storage mechanism known in the art stored on or accessible to the computer system 102. The case dataset 116 may contain one or more content collections 118, each content collection 118 comprising one or more source specifications 120A-120N (also referred to herein as source specifications 120 or source specification 120).
Each source specification 120 may identify a specific content source 110 containing content items 108 that collectively make up the virtual archive. For example, one source specification 120A may identify a specific email mailbox hosted on an email server. Another source specification 120B may identify a document library accessed through a content site server hosting a content site. In other embodiments, a source specification may specify the entire content site, which may include multiple sub-sites, one or more document libraries, web pages, wikis, blogs, publishing pages, and items lists, such as tasks, status, and microblogs. Organizing the source specifications 120 into content collection(s) 118 may allow configuration options for the virtual archive to be applied at a content collection level, such as whether content items 108 are to be preserved in place or in an external archive, how duplicate content items will be handled during export, whether multiple versions of the content items will be exported when available, and the like.
A content collection may further include a filter specification 122. The filter specification 122 may provide parameters for further limiting the content items 108 contained in the source specifications 120 that are deemed to be relevant content items. According to embodiments, the filter specification 122 may include a date-range for email messages sent or documents created or modified, one or more keywords or search expressions for filtering the content items, author/sender of documents or email messages, and/or the like. In further embodiments, filters specifications 122 may be specified at a content source level, i.e. per source specification 120, or for the entire virtual archive defined in the case dataset 116.
The e-discovery client 104 may request the preservation of the content items 108 as defined by the source specifications 120 and filter specifications 122 in the case dataset 116 through a preservation interface 124A-124N (also referred to herein as preservation interfaces 124 or preservation interface 124) exposed by each content server 112A-112N containing specified content items. For example a content server 112A comprising an email server may provide a preservation interface 124A allowing the e-discovery client to specify one or more source specifications 120 (email mailboxes) in which the content items 108 (email message) are to be preserved as of a particular date (referred to herein as the “preservation date”). The preservation interfaces 124 may comprise SOAP-based Web services, Java RMI calls, WINDOWS® communication foundation (“WFC”) services, or any combination of these and other interfaces known in the art.
The preservation interface 124 for the content server 112A may further allow the filter specification 122 to be specified to further limit the content items 108 in the specified sources specifications 120 to be preserved as of the preservation date. Each content server 112 may effect preservation of the corresponding content items 108 in a different fashion. According to embodiments, content servers 112, such as the MICROSOFT® EXCHANGE SERVER email server or the MICROSOFT® SHAREPOINT® server, may implement an in-place preservation mechanism that minimizes the storage space required for preservation without limiting end-users' ability to access or modify the content items 108, as will be described below.
The hold manager module 202 may mark the content sources 110 specified in the preservation request as “on-hold” by creating a hold specification 204 related to each content source 110. In some embodiments, the hold specification 204 comprises a flag or other attribute of the content source 110 indicating that the content source 110 has been placed on-hold. In further embodiments, the hold specification 204 may additionally store parameter values regarding the preservation request received at the content server 112. According to one embodiment the hold specification 204 may be created for each content source 110 and stored with the content source. For example, a hold specification 204 may be created for an individual email mailbox hosted by an email server and stored in the metadata for the email mailbox.
In another embodiment, the hold specification 204 may be created for a higher level storage container containing the content source 110. For example, for a specified content source 110 comprising a document library, the hold specification 204 may be created for the entire content site containing the document library and stored as metadata describing the content site. In further embodiments, the hold specification 204 may be created in a database, file, or other storage system implemented by or accessible to the content server 112 and related to the content source 110 hosted by the content server through a source specification 120. In addition, a single hold specification 204 may be related to multiple content sources 110 through multiple source specifications 120. For example, an email server may store a list of hold specifications 204, each of which specifies a list of email mailboxes to which the corresponding preservation request or “hold” applies.
The hold specification 204 may include a preservation date 208 indicating the date as of which content items 108 in the related content source 110 are to be preserved. According to some embodiments, the preservation date 208 may be specified in the parameters of the preservation request received from the e-discovery client 104. In other embodiments, the preservation date 208 may be defaulted to the date that the preservation request was received, for example. The hold specification 204 may also include an expiration date 210 indicating a date after which preserved versions of content items 108 that have been deleted or modified by end-users may be purged. As in the case of the preservation date 208, the expiration date 210 may be specified in the parameters of the preservation request received from the e-discovery client 104, or the expiration date 210 may be set to a value in order for the items to be preserved for some default period of time. In one embodiment, the expiration date 210 may default to a max date value, indicating that the content items 108 in the related content source 110 are to be preserved indefinitely.
The hold specification 204 may further include the filter specification 122 provided by the e-discovery client 104 in the preservation request. As described above in regard to
The hold manager module 202 may utilize the parameter values included in the hold specification 204 to effect preservation of the content items 108 contained in the related content source 110 as of the specified preservation date 208. For example, as will be described in more detail below in regard to
According to some embodiments, the preservation storage area 212 may represent an area of the content source 110 in which the preserved versions of the content items 108 may be stored in such a way that they are hidden to the end-user of the content source but remain accessible by appropriate personnel involved in the business issue or event. For example, for a content source 110 comprising an email mailbox on an email server, the preservation storage area 212 may comprise a hidden folder in the email mailbox. Email messages deleted from the email mailbox may instead be moved to the hidden folder. Messages stored in the hidden folder may be inaccessible to the mailbox user, but may be indexed by the email server and searchable and accessible by other personnel through appropriate security settings on the email server.
In other embodiments, the preservation storage area 212 may represent an area of the higher level storage container in which the content source 110 is contained. For example, for a content source 110 comprising a document library, the preservation storage area 212 may comprise a separate, hidden document library in the content site containing the document library. If a document in the document library is modified, the current version of the document may be stored in the hidden document library. As in the case of the email mailbox described above, documents stored in the hidden document library may be inaccessible to end-users of the content site, but may be indexed by the content site server and made searchable and accessible by other personnel through appropriate security settings on the content site server. It will be appreciated that by storing only those content items 108 that are deleted or modified in the preservation storage area 212, the amount of storage space required to effect preservation of the content items in the content source 110 is minimal in comparison to that required by a traditional snapshot archive of the content source taken on the preservation date.
In further embodiments, the content server 112 may execute a trim job module 214. As will be described in more detail below in regard to
Referring now to
The routine 300 proceeds from operation 302 to operation 304, where the hold manager module 202 determines if a hold is in effect for the content source 110 containing the content item 108. This may be accomplished by checking a particular flag or attribute of the content source 110 or by determining if a hold specification 204 related to the content source 110 exists in the metadata defining the content source or a higher level storage container, for example. If no hold is in effect for the content source 110 containing the content item 108, then the routine 300 ends, and the deletion or modification of the content item proceeds as normal.
However, if a hold is in effect for the content source, the routine 300 proceeds from operation 304 to operation 306, where the hold manager module 202 determines if the content item 108 is being deleted or modified. If the content item 108 is being deleted, then the routine 300 proceeds to operation 308, where the hold manager module 202 places the current version of the content item 108 in the preservation storage area 212. This may entail simply moving the content item 108 to the preservation storage area 212 in lieu of deleting the content item from content source 110, or a copy of the content item 108 may be placed in the preservation storage area before allowing the deletion of the content item to proceed as normal. In other embodiments, if the content item 108 being deleted is a document for which multiple versions exist in a document library, for example, all of the stored versions of the document may be moved to the preservation storage area. From operation 308, the routine 300 then ends.
If, at operation 306, it is determined that the content item 108 is being modified, then the routine 300 proceeds to operation 310, where the hold manager module 202 determines if the modified date of the current version of the content item 108 is less than the preservation date 208 specified in the hold specification 204 related to the content source 110. If the modified date of the current version of the content item 108 is less than or equal to the preservation date 208, then the routine 300 proceeds to operation 308, where the hold manager module 202 places the current version of the content item 108 in the preservation storage area 212 before the item is updated in the content source 110. From operation 308, the routine 300 then ends.
If, at operation 310, the modified date of the current version of the content item 108 is not less than or equal to the preservation date 208, then the routine 300 ends, and the content item 108 is updated without placing a copy of the item in the preservation storage area 212. Performing the check of the modified date in relation to the preservation date 208 allows for only one version of the content item 108—the version that existed as of the preservation date—to be stored in the preservation storage area 212, further reducing the amount of storage space required to effect preservation of the content items 108 in the content source.
It will be appreciated that if multiple holds are in effect for the content source 110, i.e. multiple hold specifications 204 related to the content source exist, then the hold manager module 202 may check the modified date of the current version of the content item 108 against the latest preservation date 208 from all of the related hold specifications in order to determine if a copy of the content item is to be placed in the preservation storage area 212. In another embodiment, the hold manager module 202 may always place the current version of the content item 108 in the preservation storage area 212 upon the content item being deleted or modified, regardless of the modified date of the current version. In some embodiments, the hold manager module 202 may further only place a copy of the content item 108 into the preservation area if the content item matches the filter specification 122.
According to some embodiments, when placing the current version of the content item 108 into the preservation storage area 212, the hold manager module 202 may ensure that metadata regarding that version of the content item is preserved as well. For example, for a content item 108 comprising a document in a document library, the current version of the document may be placed into the preservation storage area 212 along with metadata describing the creation date of the document, the last modified date, the author, the version number or name, and the like. The original location of the content item 108 in the content source 110, such as the particular document library or the folder containing the item in the email mailbox, may be preserved in the metadata as well, in order for any manifest created during the export of the preserved content items from the content sources to show the original location as the location for the exported content item instead of the hidden preservation storage area 212.
In further embodiments, if the content item 108 being modified or deleted is an individual item in a content source 110 comprising a list of items, such as a post in a discussion thread, an entry in a wiki page, or a post in a blog, for example, the hold manager module 202 may place the current version of the entire list in the preservation storage area 212 before the deletion or modification of the individual list item occurs. Similarly, the hold manager module 202 may place an entire container, such as a folder, containing the content item 108 in the preservation storage area 212 before the deletion or modification of the individual content item occurs. In other embodiments, the hold manager module 202 may employ a file or document naming scheme to handle situations where multiple copies or different versions of the same content item 108 are placed in the preservation storage area 212. For example, the hold manager module 202 may rename the content items 108 moved to the preservation storage area 212 using the following format:
The routine 400 begins at operation 402, where the trim job module 214 executes a query against the content items 108 stored in the preservation storage area 212 to locate the items to be removed, or “trimmed.” According to embodiments, the executed query is built from the filter specification 122 for any active hold specifications related to the content source 110. As described above, the filter specification 122 may include one or more keywords or a search expression for filtering the content items 108. The filter specification 122 may also include a date-range for filtering email messages by date sent or received, documents by created or modified date, and the like. The trim job module 214 may utilize the indexing and searching facilities provided by the content server 112 to execute the query against the content items 108 in the preservation storage area 212, for example.
According to one embodiment, the trim job module 214 executes a query comprising a negation of the filter specification 122. For example, if the filter specification 122 specifies the keywords “CAT” and “DOG” or the search expression “CAT OR DOG,” then the trim job module 214 may execute a query comprising “NOT CAT AND NOT DOG” against the content items 108 in the preservation storage area 212 in order to locate the items to remove. Utilizing the negative of the filter specification 122 to query the content items 108 has the advantage that items that cannot be indexed and searched, such as encrypted or compressed items or items stored in a proprietary format, will remain in the preservation storage area 212 for later retrieval and review by appropriate personnel.
In other embodiments, the trim job module may execute a query built directly from the filter specification 122, and then identify those content items 108 in the preservation storage area 212 not returned by the query as candidates for removal. It will be appreciated that if multiple holds are in effect for the content source 110, i.e. multiple hold specifications 204 related to the content source exist, then the trim job module 214 may combine the filter specifications 122 from the active hold specifications 204 using known methods to build the query to be executed against the content items 108 stored in the preservation storage area 212 in order to locate the items for removal.
The routine 400 proceeds from operation 402 to operation 404, where the trim job module 214 removes those content items 108 from the preservation storage area 212 that do not match the filter specification(s) 122 that were located in operation 402. As described above, content items 108 that cannot be indexed and searched, such as encrypted or compressed items or items stored in a proprietary format, may not be removed from the preservation storage area 212 by the trim job module 214 so that these content items may be retrieved and reviewed by appropriate personnel at a later time. From operation 404, the routine 400 ends.
According to further embodiments, the trim job module 214 may further clean up content items 108 that were placed in the preservation storage area 212 based on expired holds, i.e. hold specifications 204 that have an expiration date 210 that has passed. The trim job module 214 may also remove the preservation storage area 212 if it is determined that no active holds related to the content source 110 exist. In alternative embodiments, the hold manager module 202 may copy all content items 108 in the content source 110 or higher level storage container to the preservation storage area 212 at the time the preservation request is received, i.e. when a hold specification 204 is created for the content source. In one embodiment, the content items 108 copied to the preservation storage area 212 may be limited based on the preservation date 208. The trim job module 214 may then be executed to cleanup those items not matching any specified filter specification(s) 122 for the related hold specification(s) 204.
The computer 500 includes one or more central processing units (“CPUs”) 502. The CPUs 502 may be standard processors that perform the arithmetic and logical operations necessary for the operation of the computer 500. The CPUs 502 perform the necessary operations by transitioning from one discrete, physical state to the next through the manipulation of switching elements that differentiate between and change these states. Switching elements may generally include electronic circuits that maintain one of two binary states, such as flip-flops, and electronic circuits that provide an output state based on the logical combination of the states of one or more other switching elements, such as logic gates. These basic switching elements may be combined to create more complex logic circuits, including registers, adders-subtractors, arithmetic logic units, floating-point units, and other logic elements.
The computer architecture further includes a system memory 508, including a random access memory (“RAM”) 514 and a read-only memory (“ROM”) 516, and a system bus 504 that couples the memory to the CPUs 502. A basic input/output system containing the basic routines that help to transfer information between elements within the computer 500, such as during startup, is stored in the ROM 516. The computer 500 also includes a mass storage device 510 for storing an operating system 518, application programs, and other program modules, which are described in greater detail herein.
The mass storage device 510 is connected to the CPUs 502 through a mass storage controller (not shown) connected to the bus 504. The mass storage device 510 provides non-volatile storage for the computer 500. The computer 500 may store information on the mass storage device 510 by transforming the physical state of the device to reflect the information being stored. The specific transformation of physical state may depend on various factors, in different implementations of this description. Examples of such factors may include, but are not limited to, the technology used to implement the mass storage device, whether the mass storage device is characterized as primary or secondary storage, and the like.
For example, the computer 500 may store information to the mass storage device 510 by issuing instructions to the mass storage controller to alter the magnetic characteristics of a particular location within a magnetic disk drive, the reflective or refractive characteristics of a particular location in an optical storage device, or the electrical characteristics of a particular capacitor, transistor, or other discrete component in a solid-state storage device. Other transformations of physical media are possible without departing from the scope and spirit of the present description. The computer 500 may further read information from the mass storage device 510 by detecting the physical states or characteristics of one or more particular locations within the mass storage device.
As mentioned briefly above, a number of program modules and data files may be stored in the mass storage device 510 and RAM 514 of the computer 500, including an operating system 518 suitable for controlling the operation of a computer. The mass storage device 510 and RAM 514 may also store one or more program modules. In particular, the mass storage device 510 and the RAM 514 may store the e-discovery client 104, the hold manager module 202, and/or the trim job module 214, each of which was described in detail above in regard to
In addition to the mass storage device 510 described above, the computer 500 may have access to other computer-readable media to store and retrieve information, such as program modules, data structures, or other data. It will be appreciated by those skilled in the art that computer-readable media may be any available media that can be accessed by the computer 500, including computer-readable storage media and communications media. Communications media includes transitory signals. Computer-readable storage media includes volatile and non-volatile, removable and non-removable media implemented in any method or technology for the non-transitory storage of information, such as computer-readable instructions, data structures, program modules, or other data. For example, computer-readable storage media includes, but is not limited to, RAM, ROM, EPROM, EEPROM, flash memory or other solid state memory technology, CD-ROM, digital versatile disks (DVD), HD-DVD, BLU-RAY, or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to store the desired information and that can be accessed by the computer 500.
The computer-readable storage medium may be encoded with computer-executable instructions that, when loaded into the computer 500, may transform the computer system from a general-purpose computing system into a special-purpose computer capable of implementing the embodiments described herein. The computer-executable instructions may be encoded on the computer-readable storage medium by altering the electrical, optical, magnetic, or other physical characteristics of particular locations within the media. These computer-executable instructions transform the computer 500 by specifying how the CPUs 502 transition between states, as described above. According to one embodiment, the computer 500 may have access to computer-readable storage media storing computer-executable instructions that, when executed by the computer, perform the routines 300 and 400 for providing efficient in-place preservation of content in multiple, disparate content sources without disrupting end-users' access to the content or content sources, described above in regard to
According to various embodiments, the computer 500 may operate in a networked environment using logical connections to remote computing devices and computer systems through one or more networks, such as the network 114. The network 114 may include a LAN, a WAN, the Internet, or a combination of these and any networking topology known in the art. The computer 500 may connect to the network 114 through a network interface unit 506 connected to the bus 504. It should be appreciated that the network interface unit 506 may also be utilized to connect to other types of networks and remote computer systems.
The computer 500 may also include an input/output controller 512 for receiving and processing input from a number of input devices, including a touchscreen, a keyboard, a mouse, a touchpad, an electronic stylus, or other type of input device. Similarly, the input/output controller 512 may provide output to a display device, such as a computer monitor, a flat-panel display, a digital projector, a printer, a plotter, or other type of output device. It will be appreciated that the computer 500 may not include all of the components shown in
According to various implementations, the distributed computing environment 600 includes a computing environment 602 operating on, in communication with, or as part of a network 604. The network 604 also can include various access networks. One or more client devices 606A-606N (hereinafter referred to collectively and/or generically as “clients 606”) can communicate with the computing environment 602 via the network 604 and/or other connections (not illustrated in
In the illustrated embodiment, the computing environment 602 includes application servers 608, data storage 610, and one or more network interfaces 612. According to various implementations, the functionality of the application servers 608 can be provided by one or more server computers that are executing as part of, or in communication with, the network 604. The application servers 608 can host various services, virtual machines, portals, and/or other resources. In the illustrated embodiment, the application servers 608 host one or more virtual machines 614 for hosting applications or other functionality. According to various implementations, the virtual machines 614 host one or more applications and/or software modules for providing the functionality described herein. It should be understood that this embodiment is illustrative, and should not be construed as being limiting in any way. The application servers 608 also host or provide access to one or more Web portals, link pages, Web sites, and/or other information (“Web portals”) 616.
As shown in
The computing environment 602 can communicate with, or be accessed by, the network interfaces 612. The network interfaces 612 can include various types of network hardware and software for supporting communications between two or more computing devices including, but not limited to, the clients 606 and the application servers 608. It should be appreciated that the network interfaces 612 also may be utilized to connect to other types of networks and/or computer systems.
It should be understood that the distributed computing environment 600 described herein can provide any aspects of the software elements described herein with any number of virtual computing resources and/or other distributed computing functionality that can be configured to execute any aspects of the software components disclosed herein. According to various implementations of the concepts and technologies disclosed herein, the distributed computing environment 600 provides the software functionality described herein as a service to the clients 606. It should be understood that the clients 606 can include real or virtual machines including, but not limited to, server computers, web servers, personal computers, mobile computing devices, smart phones, and/or other devices. As such, various embodiments of the concepts and technologies disclosed herein enable any device configured to access the distributed computing environment 600 to utilize the functionality described herein for providing efficient in-place preservation of content in multiple, disparate content sources without disrupting end-users' access to the content or content sources.
Based on the foregoing, it should be appreciated that technologies for providing efficient in-place preservation of content in multiple, disparate content sources without disrupting end-users' access to the content or content sources are provided herein. Although the subject matter presented herein has been described in language specific to computer structural features, methodological acts, and computer-readable storage media, it is to be understood that the invention defined in the appended claims is not necessarily limited to the specific features, acts, or media described herein. Rather, the specific features, acts, and mediums are disclosed as example forms of implementing the claims.
The subject matter described above is provided by way of illustration only and should not be construed as limiting. Various modifications and changes may be made to the subject matter described herein without following the example embodiments and applications illustrated and described, and without departing from the true spirit and scope of the present invention, which is set forth in the following claims.