WO2001052052A1 - Automatic documentation of configurable systems - Google Patents

Automatic documentation of configurable systems Download PDF

Info

Publication number
WO2001052052A1
WO2001052052A1 PCT/US2000/004510 US0004510W WO0152052A1 WO 2001052052 A1 WO2001052052 A1 WO 2001052052A1 US 0004510 W US0004510 W US 0004510W WO 0152052 A1 WO0152052 A1 WO 0152052A1
Authority
WO
WIPO (PCT)
Prior art keywords
configurable
configuration parameters
documentation
computer
document
Prior art date
Application number
PCT/US2000/004510
Other languages
French (fr)
Inventor
Alexander Bakman
Tudor Hulubei
Daniel Sabin
Shalom Wertsberger
Original Assignee
Ecora.Com
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Ecora.Com filed Critical Ecora.Com
Priority to EP00911907A priority Critical patent/EP1257899A1/en
Priority to AU2000233726A priority patent/AU2000233726A1/en
Priority to IL13592600A priority patent/IL135926A/en
Publication of WO2001052052A1 publication Critical patent/WO2001052052A1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/166Editing, e.g. inserting or deleting
    • G06F40/174Form filling; Merging
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/22Detection or location of defective computer hardware by testing during standby operation or during idle time, e.g. start-up testing
    • G06F11/2257Detection or location of defective computer hardware by testing during standby operation or during idle time, e.g. start-up testing using expert systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/32Monitoring with visual or acoustical indication of the functioning of the machine
    • G06F11/324Display of status information
    • G06F11/327Alarm or error message display
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2201/00Indexing scheme relating to error detection, to error correction, and to monitoring
    • G06F2201/875Monitoring of systems including the internet

Definitions

  • the present invention relates to computer systems in general, and more particularly to systems and methods generation and management of automatic documentation for configurable computerized systems.
  • Collaborative configurable systems are computer software systems, computer hardware systems or combinations thereof, wherein a system behavior is controlled and modifiable by a set of configuration data.
  • Examples of such systems include, (but are not limited to), database management systems, electronic messaging and mail software and servers, electronic commerce systems, computer operating systems, (especially multi user system such as Unix ® or Microsoft Windows NT ® ), database management systems, configurable network equipment such as routers switches, and the like.
  • Those systems may comprise a single computer or multiple, interconnected computers, known as multi-server systems.
  • Configuration data is a collection of configuration parameters and data objects that control and modify at least a portion of the configurable system behavior.
  • Complex configurable systems typically have a large number of such configuration parameters, often ranging in the hundreds and sometimes thousands of parameters. Often cross-dependencies are observed, where a change of one parameter will cause unforeseen and unintended system behavior requiring change to other parameters. Configuring such systems is difficult, and requires a high level of knowledge, skill and experience. The problem becomes exponentially more complex when several such systems are connected together, for example a number of cooperating computer servers, distributed e-mail servers, distributed database systems, and cooperating network switches and routers or any other distributed configurable system. In those cases, changing a parameter on one system may even disrupt the operation of another.
  • the configurable system becomes a system of its own merit, a special case separate from the general case of the generic non-configured system. While the configured system behavior may be constructed and understood using documentation for the generic system combined with configuration data, such construction is time consuming and often wasteful and expensive. Therefore it is highly desirable to document the specific case of every instance of the configured system separately, in order to ease maintenance and troubleshooting, as well as to facilitate knowledge transfer to new personnel, and generally increase operational efficiency.
  • Constraint programming (alternatively referred to as “constraints-based reasoning", or “constraint satisfaction”) is a technique, most appropriate for computer use, which is based on creating a model of a problem in terms of the requirements for a solution. By defining acceptable values to variables and constraints that define and optionally quantify the allowed relationships among the values assigned to variables, a formal representation of the problem is produced. Standard constraints programming methods can use this representation to find a solution to the problem. The technique also offers an efficient approach to problem solving by making inferences on possible solutions. The technology is well known in the art. By way of example, constraints programming was used as an aid to system configuration as described in US patent 5,708,798 to Lynch et al.
  • Raw configuration data often relates to a single system in a multi-system environment, and is mostly a cryptic list of variable names with their associated values, with little if any explanation of their meaning. Nn excellent example of raw configuration data may be found in Windows Registry, which is a common configuration space for the Microsoft Windows operating systems. Documentation on the other hand, is an organized collection of knowledge that, separately or in combination, represents the state or configuration of a system, teaches system operation, and aids in troubleshooting.
  • Documentation is characteristically constructed of complete sentences in a human readable language, with appropriate punctuation, paragraph and optionally section! separation.
  • documentation also includes access tools such as a table of contents (TOC) or an index to further ease access to specific sections of the data.
  • TOC table of contents
  • documentation also attempts to explain the meaning behind the configuration parameters, optionally including the relationships between multiple systems and the meaning of several key parameters and their effect on system operation.
  • Another optional feature of documentation is the ability to propose configurable parameter values for sample systems, or, in the case of the current invention, the system being documented.
  • drawings depicting the condition and interrelationship between the described system elements further enhance the documentation. It should also be noted that documentation is characterized primarily by its content and organization, and not by the medium on which it is presented.
  • documentation may be printed on paper, viewed or edited on a computer screen by the likes of a word processor or a World Wide Web browser, etc. Whether viewed on a computer screen or printed on paper, documentation helps preserve and manage the knowledge accumulated in an organization. It thus increases operational efficiency, helps educate new members, and aids in problem solving and design for future expansion.
  • the embodiments of the invention derive documentation from a combination of generic system knowledge and the configuration data of a specific system instance, such as one or more configured systems. They thus retrieve or gather, configuration parameters into a computer, and the computer selects predetermined explanatory text segments corresponding with relevant configuration parameters. (Retrieve, collect or gather are used interchangeably in this application and in this context of gathering configuration parameters from a configurable system).
  • the computer outputs the selected text segments together with the corresponding parameters, thus forming a document specific to the configurable system.
  • the output is divided into sections and paragraphs where the parameter or a group of parameters, associated with a specific segment or paragraph is outputted in proximity to each other.
  • the current invention preferably groups similar interrelated parameters and their associated text segments in proximity to each other.
  • Text selection is generally done by a template, implemented by any convenient method.
  • the template will generally include placeholders for the configuration variables and their values, and optionally drawings and other explanatory material.
  • the template may be implemented as a collection of text stored in a file, embedded within the program code, or in a database. Alternatively or in combination, the template may comprise text segments included as print statements that are selectively executed according to specific system configurations and other environmental conditions such as system location, ownership data and the like. ... 5 ...
  • the invention also automatically generates tools to ease the access to the information in such a document.
  • the invention also provides a table of contents (TOC) detailing the relative locations of certain sections of the document.
  • TOC table of contents
  • An index of selected parameters and sections in the document is also provided, detailing their relative locations.
  • Both the table of contents and the index may be adapted best to the document media, for example a printed TOC and index when the document is printed on paper, and alternatively hyperlinks or other computerized access methods may be used when the documentation is viewed on computer screen.
  • the invention is easily adaptable for various types of configurable systems having configurable parameters accessible by computer, especially for configurable software applications.
  • electronic messaging and mail delivery systems such as Microsoft Exchange ® (Microsoft Corp, Redmond, WA, USA), computer operating systems such as Microsoft Windows NT ® or Windows 2000 ® and different varieties of the Unix ® operating systems, groups of computers such as one or more Windows NT domains.
  • configurable systems that may benefit from the current invention include electronic commerce applications, enterprise management systems such as SAP ® (SAP AG, Waldorf, Germany), BAAN (BAAN Corp, Bameveld, Netherland) and Peoplesoft ® (Peoplesoft, Pleasanton, CA, USA) and enterprise storage systems such as EMC 2® (EMC Corp, Hopkinton, MA, USA) and Legato ® (Legato Corp, Palo Alto, CA, USA), and network nodes such as Cisco ® routers (Cisco Corp, San Jose, CA, USA).
  • SAP ® SAP AG, Waldorf, Germany
  • BAAN BAAN Corp, Bameveld, Netherland
  • Peoplesoft ® Peoplesoft, Pleasanton, CA, USA
  • enterprise storage systems such as EMC 2® (EMC Corp, Hopkinton, MA, USA) and Legato ® (Legato Corp, Palo Alto, CA, USA)
  • network nodes such as Cisco ® routers (Cisco Corp, San Jose, CA, USA).
  • the invention provides a computer readable set of rules describing knowledge about the system.
  • the rules has embedded in them a set of acceptable values associated with specific configuration parameter(s).
  • the invention compare the values of configuration parameters against the values expressed in the associated rules, and output an error or warning condition if a parameter violates those rules.
  • the acceptable values may be fixed in the rule, or alternatively, may be computably modified based on one or more configuration parameters.
  • the program may also include indications of desired values that may be outputted as needed.
  • a method for providing the set of rules and the knowledge functionality as described above may be provided by a computer readable generic data model of the configurable system.
  • the generic model corresponds to the interrelationship of the sub-components of the configurable system and thus reflects its underlying structure.
  • an instance model is constructed in accordance with the generic model.
  • the generic model incorporates the system knowledge described above, and includes sets of acceptable values and other interrelationships between the system sub-components.
  • the system knowledge is implemented utilizing constraints programming logic and techniques, which allows for fast and efficient checking of a complex set of requirements, and easy flagging of error conditions.
  • the generic model also facilitates the creation of a document that is organized in a manner most closely related to the structure of the configurable system, and further enhances the readability and reduces the time required to comprehend the system.
  • the raw data is parsed by a data parser program module, entered into a database, and merged into a unified or segmented text template.
  • Rules as described above may be coded into the program or embedded in a database, to specify values, method of computing values or locations of finding the appropriate values, against which the configuration parameters of the sampled system may be checked. The invention thus provides identification of configuration mismatches or potential problems in a configuration and flags those conditions to the user.
  • Using the raw data database described above allows the user to change the presentation of the document by embedding the results of queries against the database into the document in ways the user best believes will enhance system understanding or troubleshooting. Using such a database is also advantageous due to the simplicity and low cost of the implementation. ...7 ...
  • Another alternative object of the invention is to provide means of comparing current and previous configurations and to point out differences between them. Such comparisons are useful during the troubleshooting of a system, which malfunctions due to unknown reason. By comparing an old, "known good" configuration with the current configuration, differences become apparent and, due to the documentation generating nature of the current invention, such changes may easily be placed in context and thus aid in determining if any of the modified parameters may have caused the malfunction.
  • the invention applies to multi-server configurable systems as well as single server configurable systems.
  • This is a clear advantage since, as mentioned earlier, the system complexity grows exponentially with the number of servers.
  • Examples of such multi-server environments are a plurality of server computers operating under the Windows NT operating system within a single domain, or multiple communicating domains with or without trust relationships.
  • Another example is one or more Microsoft Exchange electronic mail servers in an organization. Similar in nature is a set of co-operating configurable network nodes such as routers, switches, concentrators, frame relay access devices, and other nodes comprising a data or voice network.
  • the invention may be integrated within the configurable system itself, either as an integral part of the system software or by having a separate program active on a computer that is a part of the configurable system.
  • a configurable software application may be made self documenting by including program code that retrieves configuration parameters and merges them into explanatory material (template), implemented in any convenient manner, thus creating a document describing the specific instance of the configurable system.
  • the program code required for performing the steps for creating the document may be integrated into the configurable system itself.
  • most of the configuration data is available to the document generation module from within the program, and additional data may be derived from data stores such as an active directory, or from other computers that are a part of the configurable system.
  • the document generation module comprises primarily of an external text template, text segments coded within the module, or any other convenient manner to store the explanatory text and optional drawings.
  • the module also contains program code to merge the configuration data within such template and output the template with the merged data as a document.
  • the program code may be integrated directly into the configurable system as an integral part of the configurable system code or may be implemented as an add-on module loaded and executed by the configurable system at run-time.
  • the invention operates generally by collecting configuration data from individual systems or from system sub-components that comprise the configurable system to be documented.
  • a collector program is deployed to collect the configuration data.
  • a collector program is a program constructed to collect configuration data from one or more configurable systems, and is constructed specifically for each platform or configurable system and collects the raw data for transmission into a Documentor.
  • the configuration data is then preferably encrypted (especially in the case of transmitting the data over the Internet) before being transmitted to the Documentor.
  • a Documentor (alternatively referred herein as a Documentation Server) is a computer program or a collection of computer programs, that receives configuration data as its input and generates documentation as its output, primarily when receiving the data from a configurable system and generating documentation pertaining to the system. It performs this function by outputting a template, or pre-determined text segments relating to configuration parameters or to a group of inter-related configuration parameters.
  • the text segments of which the document is comprised are primarily explanatory in nature and are composed to improve the understanding of meaning and effects of the configuration parameters to which they relate.
  • drawings and tables are also outputted as needed to increase the understanding and readability of the produced document.
  • drawings, tables, and text segments are outputted to paper, a computer screen, the Internet, or any other appropriate output device or method. Additionally the Documentor may output the document to a computer file. It should also be noted that methods for dynamic generation of drawings and diagrams (as described for example by the Ahern et al. patent supra or other methods generally known in the art) may be integrated with this invention to generate drawings depicting the configurable system in part or as a whole. ... 9 ...
  • a generic operational model embeds therein information and knowledge which is required for a proper generic system operation, and may be viewed as a set of generic implementations of operational configurations specific to the generic system.
  • the generic model therefore, details the underlying structure of the interrelationships between different sub-components of the generic case of the configurable system.
  • Each allowable configured system is a subset of the generic configurable system.
  • each model of a configured system constructed according to the generic model is a subset of the generic model that reflects the configured system underlying structure as configured.
  • Such specific models of configured systems are called "instance models”.
  • a documentation server comprising the collector program and the Documentor portion is coupled to a local area network or an Intranet that is in communication with the configurable system to be documented.
  • An Intranet is one or more interconnected computer networks that are characterized by being primarily within the electronic bounds of an organization. Typically electronic access to an Intranet is not open to the general public, and it thus affords a protected computing environment for storing and accessing organization confidential data.
  • Many Intranets utilize Internet like technologies, and some utilize communications provided by public communication means, for example, a dedicated line in a PSTN network. However data access to an Intranet is controlled from within the owning organization.
  • Coupling a documentation server directly to an Intranet overcomes a disadvantage of an Internet coupled server by maintaining the configuration data within the organization- controlled network.
  • An Internet coupled server the data, even if encoded and encrypted, may present a security risk for certain configurable systems.
  • An Intranet coupled documentation server especially when implemented as a dedicated computer, becomes a Documentation Appliance, operating within the confines of an organization.
  • the Documentation Appliance is readily available to company personnel, offers local system documentation and storage of previous configurations, all while avoiding the need to send sensitive data over public networks.
  • Such a Documentation Appliance is preferably a dedicated server that may be adapted for documenting one or more types of configurable systems. It is also preferable to have such a Documentation Appliance keep logs of document production and that such logs will be remotely accessible to ease debugging and service.
  • the Appliance may be coupled directly to the configurable system or may utilize an intermediary computer.
  • a Documentation Appliance server attached to an organization Intranet may also be configured to retrieve the configurable system configuration information according to a predetermined schedule, and activate updated documentation production automatically. Together with the capability to compare previous and current sets of configuration parameters, a Documentation Appliance may thus produce a list of changes that occurred between activations, in effect to create a log, tracking modifications and changes in the configurable system.
  • the invention also provides for a World Wide Web type server that is constructed to distribute the documents produced by the current invention to a web browser. Since the documentation in the preferred implementation is produced by a print engine capable of producing HTML, the integration of a web server within the appliance allows any person with access rights to browse, search and view the documentation as needed.
  • Fig. 1 depicts a general schematic component and data flow diagram of a preferred embodiment of the invention
  • Fig. 2 is a generalized flow diagram of the collector program portion of an embodiment of the invention.
  • Fig. 3 is a flow diagram for generating an instance model in accordance with the invention
  • Fig. 4 depicts a generic model object in accordance with an embodiment of the present invention.
  • Fig. 5 is a partial and simplified 'C++' -like code of several classes used in model creation in one preferred embodiment.
  • Fig. 6 depicts 'C++'-like code of two 'document' methods referred to in Fig. 5 classes.
  • Fig. 7 depicts an example of a simplified portion of text template for another preferred embodiment of the present invention.
  • Fig. 8 is partial pseudo code showing a method for generating warning messages to the user according to the present invention.
  • Fig. 9 is a screen depiction of web based screen from which the documentation operation begins.
  • Fig. 10 is a screen depiction of an HTML page prior to sending collected data to documentation browser.
  • Fig. 11 depicts a partial sample of a table of contents for a document generated in accordance with the present invention.
  • Fig. 12 depicts a partial sample of documentation generated in accordance with the present invention.
  • Fig. 13 depicts another partial sample of documentation generated in accordance with the present invention.
  • Fig. 14 depicts another schematic implementation of the invention utilizing a database and a text template in accordance with the present invention.
  • Fig. 15 depicts a simplified diagram showing connection method of a documentation appliance in accordance with the present invention.
  • Fig. 16 is a simplified flow diagram depicting a documentation generation process according to the present invention.
  • An Application Programming Interface or API exists for most configurable systems that is designed to provide access to the configuration parameters, ideally fitted in most cases for a collector program or module as described herein.
  • the invention involves a database containing a set of predetermined text sentences or paragraphs, associated with at least one specific variable.
  • a collector program is provided for reading configuration parameters from a configurable system, and the associated text paragraph is outputted together with the configuration parameters.
  • entries are made in a table of contents for text paragraphs, and the table of contents is outputted as well.
  • the output may be to a printer, a screen, or a file.
  • Output may also utilize the World Wide Web technology to offer organized access to the documentation, in which case the table of contents is best composed of hyperlinks to appropriate sections.
  • Another alternative output forms include audio and video output.
  • An audio output may be generated by a text to speech translation module.
  • Video output require a video template, similar to the text template described herein, but adapted for video signals and for embedding external values such as configuration parameter values, in a predetermined video stream.
  • the invention may also be practiced by integrating the steps described herein into the configurable system code.
  • a module may be integrated into a Microsoft Exchange server that will retrieve all configuration parameters directly from the Exchange system within which it operates.
  • a Documentor program may be operated on a computer that is a part of the configurable system.
  • a Documentor program may be operated on a computer utilized as a Windows NT domain controller, where much of the configuration data is locally available in a system adapted for documenting a Windows NT environment.
  • the document generation steps described herein are similar with the primary difference being the location where certain portions of the invention are executed.
  • the invention further benefits the user by grouping similar features and/or variables together, for example listing all domain controllers in an NT domain, or creating a list of all mail transfer agents (MTA) scheduled to run in an Exchange organization, including their prospective protocols or schedule.
  • the Documentor portion may collect similar information from multiple servers. So, for example, replication information between database servers may be listed together to ease understanding of the proper propagation order. Such information will preferably be grouped in close proximity with several paragraphs explaining the process of propagation and the meaning of each of the related variables. As further explained below, utilizing constraints or rules eases verification of proper configuration.
  • the preferred implementation will contain general data explaining the generic operation of the configurable system, together with system specific data as configured.
  • generic and specific advice relating to configuration will be placed in proximity to system information relating specifically to the system being documented.
  • the documentation server 100 in a preferred implementation is located remotely to the client Exchange organization 170.
  • the documentation server 100 is connected to Exchange organization 170 via an Intranet.
  • an intermediate workstation 150 connects between the documentation server 100 and the Exchange organization 170.
  • the exchange organization depicted in Fig.l is a generic organization having at least one Exchange Source Server 174, and any number of servers, only two of which are shown, designated as 180 and 185.
  • the Exchange directory 176 resides on the source server 174. Utilizing the process begins with a client creating a connection from client workstation 150 to the documentation server 100 via the web browser 160. The client than downloads 11 a copy 125 of the collector program 120 to the client workstation.
  • the collector program is constructed as an ActiveX ® program or a Java ® (Sun Microsystems, Palo Alto, CA) program, and the copy of the collector 125 begins operating automatically after it was downloaded.
  • Fig. 2 depicts the operation of a collector program constructed for an embodiment configured as depicted in Fig. 1.
  • the collector program 125 connects to the Exchange Source Server 174 as depicted in step 12 in Fig.l, and extracts 220 the Exchange Directory information 176.
  • the collector program proceeds to extract 240 registry data 178 from the Exchange Source Server 174 in step 13, and retrieves registry data 182 and 187 for all other Exchange servers in the organization, as shown in steps 13 a, b ...n in Fig. 1.
  • Fig.l shows only three servers, this depiction is for explanation purposes, and the number of servers may vary from one to any number supportable by the configurable platform. For increased efficiency, the steps of collecting the configuration data from the various servers in steps 13b through 13n are carried out simultaneously.
  • Collector program 125 then creates 250 an HTML page 255, compresses the data collected in steps 12 and 13 a...n, and encodes 260 the data for compatibility with transmission using the HTTP protocol.
  • the data is than embedded in HTML page 255, preferably as hidden text.
  • the collector program 125 than loads HTML page 255 into web browser 160, and points 270 client web browser 160 to the page 255.
  • steps 220 and 240 While the mechanism of collecting the configuration data shown in steps 220 and 240 is described uniquely as applicable to Exchange environment, those steps constitute the mechanics of collecting configuration information specific to the platform.
  • the function of automatic collection of the configuration data may be performed by any known means without departing from the invention.
  • Adaptation of the collector program described above for different platforms requires only regular programming skills and general knowledge of the platform.
  • the collector program may be constructed to operate through other ... 15 ... communication and collecting methods such as SNMP for network nodes, in which case no HTML communications is required and is often unavailable.
  • the collector program may be implemented as a collector program module operating on the Appliance, with the configuration data retrieved directly from the configurable system by the module.
  • Fig. 3 details the operation of instance model creator 134.
  • the model creation happens within the document generator 130.
  • the program retrieves 310 the information from the web page, decodes and decompresses 320 the data.
  • the data is then parsed into variable names and corresponding values in steps 330 and 350.
  • the raw data is stored in a database 132. Doing so allows easy approach to different data views as needed.
  • the parsed data is then presented, one variable at a time, to step 360 in which an instance model is created.
  • the instance model 145 is an object-oriented artifact assembled from instances of predefined object types described in a generic model 140 that is incorporated into the documentation server 100.
  • the generic model 140 for a specific application domain (e.g., Microsoft Exchange, SAP database, or a specific computer operating system) consists of a set of classes describing objects available in the configurable system universe.
  • generic models are specific to a particular configurable system domain: for example, at least one generic model is provided for Microsoft Exchange, while another one is provided for Windows NT, and so on.
  • Each type of object in the configurable system universe that is relevant to the task performed by the current invention is represented in the generic model in the form of a class.
  • the class describes its composition (in terms of lower level objects) and structure (in terms of relationships among its components, e.g. Part-Of, Is-A, etc.).
  • behavior can also be expressed as part of the model, in the form of additional relations among constituent parts and/or attributes, describing correct and/or faulty functioning.
  • a library object describing a server, and certain server characteristic parameters such as name, version information, and the like. Constraints may be attached to each of those variables, for example a constraint that the domain name has to be the same for the server as for the whole domain is needed to verify that the domain is consistent.
  • Constraints may be attached to each of those variables, for example a constraint that the domain name has to be the same for the server as for the whole domain is needed to verify that the domain is consistent.
  • Such structural demands comprise the structural generic model 145, together with a set of constraints that are applied to this underlying structure.
  • class 'Organization' 510 is the root of the model, and comprises internal attributes such as the organization name 511, and other subservient objects comprising the rest of the organization model.
  • the vector of subservient objects is of type 'Site' shown as 516.
  • the class Organization 510 also incorporates several methods. The posting step described below is carried out in the method 'post' 512. Rules or constraints applied to the object to check the validity of the object against the generic model are applied using the 'validate' method 513, and the method 'document' 515 is used to create the documentation that is specific to the configurable system instance.
  • Examining class Site 520 shows a close similarity to class Organization 510 above, with the major structural differences being the members included in the class. While the Organization class 510 included a vector 516 detailing a list of sites, each Site object details a list of Server objects 526 and a list of Protocols objects 524 with similar collection of methods. In class Server 530 we see a similar pattern yet again. Class Protocol 540 also incorporates similar methods, but being a leaf of the hierarchical model structure, it does not include any vector of inherent objects connected thereto. It will therefore be clear to any person familiar with the organization and operation of the Microsoft Exchange software, that the construction shown in Fig. 5 represents not only a collection of objects of the types described above, but also the underlying structure of a Microsoft Exchange installation. It will also be clear that similar constructs may be created for other configurable systems such as a Windows NT domain, a network organization, Lotus Notes software, database servers etc. ... 17 ...
  • each applicable configuration variable is examined against the generic model.
  • this step known as the 'post' or 'posting' step, an object instance is created for each relevant configuration variable.
  • Variables that conform to the generic model and pass the constraints imposed on the instance object are posted in the instance model. Posting occurs in an object-oriented manner that maintains a structural semblance to the underlying principles defined in the generic model for the platform as described above.
  • Constraints may be divided primarily into two categories: hard and soft constraints.
  • Hard constraints are such that a violation thereof may prevent the system from operating, while soft constraints are mainly related to performance issues, and a violation of such soft constraints will allow continued system operation, albeit in less than optimal manner.
  • Whether a constraint is a hard or soft is particular to each constraint and is responsive to the value of one or more variables.
  • constraints may be quantitative, and assign values corresponding to a level of conformance with the generic model. For example, such values are utilized for providing the user with suggestions and warnings related to optimizing the configurable system performance and/or to modifications required for maintaining optimal system operational status.
  • Fig. 4 presents a simplified view of the document construction carried out in the document generation module 138 portion of the documentation generator 130.
  • a documentation template 430 describing and explaining different aspects of the system is created and stored in the documentation server 100.
  • the template may be stored in separate files, as part of the model, or as data available to the documentation generator 138 in any convenient format. Internal attributes and sub-components are integrated into the template as needed.
  • Figs. 12 and 13 are sample documentation pages, while Fig. 11 is a sample of a table of contents; all generated by the current invention. As can be observed in Figs. 12 and 13 drawings may also be embedded in the template.
  • Fig. 6 is a partial listing of a computer program, written in a 'C++'-like language.
  • the numeral 610 designates a simplified sample of the 'document' method 525 code of an object of class 'Site' 520.
  • the method uses the 'C++' standard output stream 'cout'.
  • Portions of the documentation template 430 are embedded in the first output statement 613 in the form of text strings like "The site" 618.
  • the output statement 613 also includes internal attributes 420 such as the variable 'm name' 615 and sub-components 410 such as the method 'm_servers.size()' 617.
  • the method calls other documenting methods in all servers in its 'm_servers' lists seen in 614 and all protocols in its 'mjprotocols' list as seen in 616. While simple attributes such as 'm_name' are outputted directly from class members or global variables, other outputs occur from methods internal as well as external to the method. Since each 'document' method dictates the order in which the subservient objects print, a very orderly and well-organized document can easily be produced. Attention is also called for the 'endl' statement 619 at the end of the cout statement 613, which is an example of the formatting information imparted by the program. More complex formatting, merging information, tables and drawings may be incorporated from such predetermined data or taken from files external to the program to be merged in the output document.
  • Fig. 6 also shows a method of generating the table of contents or TOC.
  • Statement 611 supplies the current location in the output stream to a procedure named TOCJBntry, which stores the context and associated location for further generation of the table of contents.
  • the procedure "Index EntryO" provides the index context, in the example the site name and the location within the output document. If for example the standard output stream 'cout' statements is redirected to one computer file, both the TOC and index generating procedures simply output the indexing information into one or more separate index files. Generating an index and TOC from such files is a simple procedure, and the TOC and index may be created according to the viewing method, e.g. by hyperlinks that are dynamically generated when the document is read on screen, or by printing the information when the document is reproduced on paper.
  • Fig. 6 also shows another example of the document method common to most if not all nodes in the model.
  • output statement 660 generates documentation output without calling any external method.
  • the output produced by the Documentor is a set of printing instructions for a virtual printing machine.
  • the documentor is then able to produce documentation in different formats such as HTML, Postscript, PCL, Latex ® , Adobe Acrobat ® Microsoft Word ® document, or any other desired format.
  • the language for the ... 19 ... virtual printing machine contains, among other constructs, commands for describing the document layout, such as chapter, section, subsection, and similar constructs. Those commands automatically create the appropriate entry in the optional TOC and index.
  • Other commands for the virtual printing machine include commands for specifying document composition, such as structured elements such as tables and bulleted lists, and/or unstructured elements such as paragraph, note, warning, and hints.
  • Additional virtual printing machine commands include formatting instructions like vertical/horizontal space, indentation justification and the like, as well as font management functions such as color, bold, italic, etc.
  • the virtual printing machine is implemented using object oriented programming techniques, which provides a multiplexer class.
  • object oriented programming techniques which provides a multiplexer class.
  • the multiplexer class is used the same way as standard 'C++' streams.
  • the virtual printing machine also provides several driver classes, one for each type of format or formatting language. Each class implements the translation of the printing commands to the target formatting language.
  • the Documentor creates one multiplexer instance to which it attaches instances of drivers for all the required types of output. Every time the documentor uses the output ' «' operator, the desired information or printing construct is sent to the multiplexer which distributes it to all the drivers currently attached to it. Each driver than creates an output according to its specific formatting language.
  • the drivers also create the table of contents and index in a desired manner that fits the formatted output, such as HTML style hyperlinks for an HTML document or as formatted and printable TOC and index for paper output.
  • the invention may further use the raw data database 132 to allow user specified view of data specific to the configurable system in question.
  • the raw data database may best be managed by a database management system against which queries may be posted, and in which the data retrieved forms the basis for the view.
  • the creation of such a view will allow generating partial documentation, for example detailing the entire information specific to a single subnet in a network. This allows users to concentrate on limited areas of interest; for example, a network under direct supervision of a specific user.
  • This feature may be further enhanced by the addition of pointers from the database to related objects in the instance model, since only the relevant portion of the instance model can easily be created as separate documentation with grouping of similar parameters in stored separate subsections of the model.
  • Query results may also be embedded in the output document either according as predetermined by the template or according to user preferences, in a system that includes a user interface portion to accept user input for selecting document generation options.
  • the process of document generation does not include constraint-based model creation.
  • the raw data is placed in raw data database 132 and is associated with parts of the documentation, (or text segments) that form template 1450 that correspond to the variables relevant to the documentation of the configurable system.
  • template 1450 may be a predetermined document template, which includes placeholders for the results of specific queries such as the names of all servers, name of all domain controllers, etc.
  • a documentation generation module 1410 reads the template, and when a query is encountered, it is parsed, presented to the database 132 and the results outputted to the document by a documentation generation module 1410.
  • FIG. 7 presents a simple portion of a template to generate partial documentation for a Windows NT domain. Queries to the database 710, 720 and 730 are enclosed between character strings ' ⁇ «' and '»>'.
  • the documentation generation module 1410 encounters a query such as 710, it parses the query and the results are inserted into the output stream.
  • the documentation generation module 1410 can also parse constructs such as variable name resolution and substitution, and an if statement as shown in 720, and decide which of the two statements 730 or 740 to output.
  • the example depicted in Fig. 7 shows a simple but effective method to automatically generate elaborate documentation from the collected configuration data without the use of a complete object oriented model.
  • a simple error checking and reporting routine may also be incorporated, in which a collection of rules is stored in the program and relevant variables are checked against those rules.
  • Fig. 8 depicts a pseudo-code portion of such rule-checking program.
  • an example 810 of such rules is to warn the user 820 if the number of mailboxes on the server multiplied by the desired mailbox disk space allocation, (or 5 MB in this example) is smaller than the available disk space.
  • the rule may further be constructed to issue warning or error messages, or to propose more fitting values for a parameter based on the value of one or more parameters.
  • the rules or constraints may compute and output a suggestion to modify the size of a virtual memory disk swap file in response to actual RAM memory and available disk space in a server operating under Windows NT.
  • Such proposed values may be based on an arbitrarily complex set of computations emanating from the configuration parameters or based on general system knowledge and experience.
  • the examples given in Fig. 7 and Fig. 8 are but a sample of the many ways rules may be applied to check configuration data and warn users of various inconsistencies and optimization issues.
  • Another objective of the current invention was previously described as comparing current with previous configurations of the configurable system to aid in troubleshooting. This objective is easily achieved by storing an older model or raw configuration data of an operational system. When a problem is observed in the configurable system operation, & present model or raw data set is collected and the new and old sets of configuration data or model are compared to each other. Outputting variables with different values between the two configurations will allow consideration of only those variables that have been modified, and thus will ease troubleshooting of the system as presently configured. Only minor change are required to the records in the database, such as for example adding a counter or a date associated with the configuration parameter set.
  • Fig. 15 depicts another preferred embodiment for a Documentation Appliance 1500 described above. While the methods of document generation are similar to the methods already described, the Documentation Appliance 1500 utilizes a collector module 1520 to perform the configuration data retrieval directly from the configurable system.
  • the documentation appliance is connected to an Intranet 1510 that comprises one or more interconnected networks and that is coupled to the configurable system as depicted by the Exchange Organization 170. In this case, all of the needed computers in the configurable system are directly available to the Documentation Appliance 1500, and therefore this embodiment does not require the services of an intermediate workstation 150 as described in the embodiment depicted in Fig. 1.
  • the documentation appliance also incorporates a web server 1560 to distribute the documentation to other computers.
  • a scheduler 1550 is provided to activate the documentation generation according to a predetermined schedule.
  • Fig. 16 is a simplified flow diagram showing an overview of the documentation process in a preferred embodiment of the invention. Beginning with the retrieval of the documentation parameters 1605 and their storage 1610 in a raw data database 132. In step 1615 the main execution loop is initialized with a selection of a first parameter, preferably the root or most important data of the configurable system. This variable is assigned as the Current Parameter or CP. The main loop or some variant thereof will be executed for all relevant parameters.
  • Step 1620 checks if the CP is indeed relevant to the documentation process. If not, step 1622 is executed to continue to the next step. If CP is relevant, a check is done to see if the value of the parameters is within preset boundaries 1625. If the value is outside the boundaries, an error message is generated 1627. Step 1625 may be used for more complex error checking, computation of boundary values, and optimization
  • step 1637 is executed, in which the required parameters are recursively obtained, merged and outputted into the same output stream of step 1650. Once all parameters are merged into the relevant template segment 1640, the results are outputted in stage 1650. If more parameters 1660 are present the loop continues through 1622 and back into step 1620. Otherwise, the documenting process stops at 1699.
  • Database 132 may also be conveniently used to store the rules or boundaries as well as text segments and other data.Once a document is generated with a computer readable main body and a table of contents, additional capabilities, such as searching and editing, may be easily added to the features of the current invention as is well known in the art.

Abstract

The invention discloses a documentation appliance system (100), which is a dedicated documentation server for automatic documentation generation (138) and management of documentation for configurable systems (170) such as complex software applications and hardware systems. The documentation appliance (100) is coupled to the configurable system (170) via a communication network, preferably an Intranet. The invention shows a method for automatic generation of documentation for configurable systems (170), as well as how to practice the invention by integrating code for automatic documentation generation within the configurable system program.

Description

AUTOMATIC DOCUMENTATION OF CONFIGURABLE SYSTEMS
The present invention relates to computer systems in general, and more particularly to systems and methods generation and management of automatic documentation for configurable computerized systems. Background of the Invention
Collaborative configurable systems are computer software systems, computer hardware systems or combinations thereof, wherein a system behavior is controlled and modifiable by a set of configuration data. Examples of such systems include, (but are not limited to), database management systems, electronic messaging and mail software and servers, electronic commerce systems, computer operating systems, (especially multi user system such as Unix® or Microsoft Windows NT®), database management systems, configurable network equipment such as routers switches, and the like. Those systems may comprise a single computer or multiple, interconnected computers, known as multi-server systems.
Configuration data is a collection of configuration parameters and data objects that control and modify at least a portion of the configurable system behavior. Complex configurable systems typically have a large number of such configuration parameters, often ranging in the hundreds and sometimes thousands of parameters. Often cross-dependencies are observed, where a change of one parameter will cause unforeseen and unintended system behavior requiring change to other parameters. Configuring such systems is difficult, and requires a high level of knowledge, skill and experience. The problem becomes exponentially more complex when several such systems are connected together, for example a number of cooperating computer servers, distributed e-mail servers, distributed database systems, and cooperating network switches and routers or any other distributed configurable system. In those cases, changing a parameter on one system may even disrupt the operation of another. Due to the complexity involved in the configuration, once configured, the configurable system becomes a system of its own merit, a special case separate from the general case of the generic non-configured system. While the configured system behavior may be constructed and understood using documentation for the generic system combined with configuration data, such construction is time consuming and often wasteful and expensive. Therefore it is highly desirable to document the specific case of every instance of the configured system separately, in order to ease maintenance and troubleshooting, as well as to facilitate knowledge transfer to new personnel, and generally increase operational efficiency.
Generating such documentation is an extremely tedious job that often requires a highly trained professional to perform. Since the configuration of such systems changes with time, the task is a continual one, taxing information technology personnel. And thus automatic generation of such documentation as shown by the present invention is clearly advantageous. In these specifications, the word "automatic" and its derivative means an operation that is, or may be, created or coordinated primarily by a machine or a computer, especially as compared to chores and tasks that were formerly done primarily by human labor. In an automatic documentation generation step for example, little or no manual user intervention is necessary. Manual intervention implies steps such as manual data entry of configuration parameters, repeated text entries, etc.
Constraint programming (alternatively referred to as "constraints-based reasoning", or "constraint satisfaction") is a technique, most appropriate for computer use, which is based on creating a model of a problem in terms of the requirements for a solution. By defining acceptable values to variables and constraints that define and optionally quantify the allowed relationships among the values assigned to variables, a formal representation of the problem is produced. Standard constraints programming methods can use this representation to find a solution to the problem. The technique also offers an efficient approach to problem solving by making inferences on possible solutions. The technology is well known in the art. By way of example, constraints programming was used as an aid to system configuration as described in US patent 5,708,798 to Lynch et al. and in PCT/US97/21218 to Elfe et al. Constraint programming easily lends itself to diagnostics and also to the automatic documentation process described herewith. While most configurable systems provide means for reading and printing the system configuration data, a distinction should be drawn between raw configuration data and documentation. Raw configuration data often relates to a single system in a multi-system environment, and is mostly a cryptic list of variable names with their associated values, with little if any explanation of their meaning. Nn excellent example of raw configuration data may be found in Windows Registry, which is a common configuration space for the Microsoft Windows operating systems. Documentation on the other hand, is an organized collection of knowledge that, separately or in combination, represents the state or configuration of a system, teaches system operation, and aids in troubleshooting. Documentation is characteristically constructed of complete sentences in a human readable language, with appropriate punctuation, paragraph and optionally section! separation. Typically, documentation also includes access tools such as a table of contents (TOC) or an index to further ease access to specific sections of the data. Generally, documentation also attempts to explain the meaning behind the configuration parameters, optionally including the relationships between multiple systems and the meaning of several key parameters and their effect on system operation. Another optional feature of documentation is the ability to propose configurable parameter values for sample systems, or, in the case of the current invention, the system being documented. Optionally, drawings depicting the condition and interrelationship between the described system elements further enhance the documentation. It should also be noted that documentation is characterized primarily by its content and organization, and not by the medium on which it is presented. Thus documentation may be printed on paper, viewed or edited on a computer screen by the likes of a word processor or a World Wide Web browser, etc. Whether viewed on a computer screen or printed on paper, documentation helps preserve and manage the knowledge accumulated in an organization. It thus increases operational efficiency, helps educate new members, and aids in problem solving and design for future expansion.
There are currently several aids to grouping and displaying raw configuration data relating to computer systems. One such example is available from Message Wise® in Ottawa, Ontario, Canada. This system reads configuration data from several Microsoft Exchange servers, and places them in a database. Queries can then be placed against the data to find answers to specific question. However the Message Wise system does not provide a well-documented meaning of a textual and visual description, organized in an easily read document as described above.
Another configuration data collection tool named Emap and distributed by Microsoft® Corporation of Redmond WN, USA, provides a graphical representation of connections between exchange servers in an organization. Similarly, several products allow representing ...4 ... an organizational data or voice network by drawings representing the network structure. These types of products are exemplified in US patent 5,926,463 to Ahern et al.
None of the above solutions provide documentation as described earlier in these specifications. All lack the effects and efficiency of teachings that a well organized textual and visual document provides, and thus do not provide the dept of knowledge preservation and knowledge management provided by such documents. It is clear therefore that there is an unfulfilled need in the industry to provide automated documentation generation, re-generation, and management tools for highly configurable systems.
Summary of the Invention It is therefore a goal of the current invention to provide a method and a system for automatic generation of documentation for computerized configurable systems.
The embodiments of the invention derive documentation from a combination of generic system knowledge and the configuration data of a specific system instance, such as one or more configured systems. They thus retrieve or gather, configuration parameters into a computer, and the computer selects predetermined explanatory text segments corresponding with relevant configuration parameters. (Retrieve, collect or gather are used interchangeably in this application and in this context of gathering configuration parameters from a configurable system). The computer outputs the selected text segments together with the corresponding parameters, thus forming a document specific to the configurable system. Preferably, the output is divided into sections and paragraphs where the parameter or a group of parameters, associated with a specific segment or paragraph is outputted in proximity to each other. Furthermore, the current invention preferably groups similar interrelated parameters and their associated text segments in proximity to each other.
Text selection is generally done by a template, implemented by any convenient method. The template will generally include placeholders for the configuration variables and their values, and optionally drawings and other explanatory material. The template may be implemented as a collection of text stored in a file, embedded within the program code, or in a database. Alternatively or in combination, the template may comprise text segments included as print statements that are selectively executed according to specific system configurations and other environmental conditions such as system location, ownership data and the like. ... 5 ...
These specifications relate interchangeably to different methods of producing a document from predetermined text segments merged with configuration parameters, as utilizing a template. Specific embodiments may use different methods as a matter of technical choice.
Preferably, the invention also automatically generates tools to ease the access to the information in such a document. Optionally, the invention also provides a table of contents (TOC) detailing the relative locations of certain sections of the document. An index of selected parameters and sections in the document is also provided, detailing their relative locations. Both the table of contents and the index may be adapted best to the document media, for example a printed TOC and index when the document is printed on paper, and alternatively hyperlinks or other computerized access methods may be used when the documentation is viewed on computer screen.
The invention is easily adaptable for various types of configurable systems having configurable parameters accessible by computer, especially for configurable software applications. Listed below are but a small sample of the systems and system types for which the invention is especially adaptable and beneficial: electronic messaging and mail delivery systems such as Microsoft Exchange® (Microsoft Corp, Redmond, WA, USA), computer operating systems such as Microsoft Windows NT® or Windows 2000® and different varieties of the Unix® operating systems, groups of computers such as one or more Windows NT domains. Similarly, complex database management systems such as DB2® (IBM Corp, Armonk, NY, USA), Informix® (Informix, Menlo Park, CA, USA), or Microsoft SQL Server®, and groupware applications like Lotus Notes" (Lotus Corp, Cambridge, MA, USA) and Group Wise® (Novell Corp., Provo, Utah, USA) all lend themselves to being documented by the present invention. Additional examples of configurable systems that may benefit from the current invention include electronic commerce applications, enterprise management systems such as SAP® (SAP AG, Waldorf, Germany), BAAN (BAAN Corp, Bameveld, Netherland) and Peoplesoft® (Peoplesoft, Pleasanton, CA, USA) and enterprise storage systems such as EMC (EMC Corp, Hopkinton, MA, USA) and Legato® (Legato Corp, Palo Alto, CA, USA), and network nodes such as Cisco® routers (Cisco Corp, San Jose, CA, USA).
Preferably, the invention provides a computer readable set of rules describing knowledge about the system. The rules has embedded in them a set of acceptable values associated with specific configuration parameter(s). The invention then compare the values of configuration parameters against the values expressed in the associated rules, and output an error or warning condition if a parameter violates those rules. The acceptable values may be fixed in the rule, or alternatively, may be computably modified based on one or more configuration parameters. In addition to acceptable values, the program may also include indications of desired values that may be outputted as needed.
A method for providing the set of rules and the knowledge functionality as described above may be provided by a computer readable generic data model of the configurable system. The generic model corresponds to the interrelationship of the sub-components of the configurable system and thus reflects its underlying structure. After the configuration data is retrieved from the configured system, an instance model is constructed in accordance with the generic model. Optionally, the generic model incorporates the system knowledge described above, and includes sets of acceptable values and other interrelationships between the system sub-components. Preferably the system knowledge is implemented utilizing constraints programming logic and techniques, which allows for fast and efficient checking of a complex set of requirements, and easy flagging of error conditions. The generic model also facilitates the creation of a document that is organized in a manner most closely related to the structure of the configurable system, and further enhances the readability and reduces the time required to comprehend the system. In a preferred embodiment of the invention, the raw data is parsed by a data parser program module, entered into a database, and merged into a unified or segmented text template. Rules as described above may be coded into the program or embedded in a database, to specify values, method of computing values or locations of finding the appropriate values, against which the configuration parameters of the sampled system may be checked. The invention thus provides identification of configuration mismatches or potential problems in a configuration and flags those conditions to the user.
Using the raw data database described above allows the user to change the presentation of the document by embedding the results of queries against the database into the document in ways the user best believes will enhance system understanding or troubleshooting. Using such a database is also advantageous due to the simplicity and low cost of the implementation. ...7 ...
Another alternative object of the invention is to provide means of comparing current and previous configurations and to point out differences between them. Such comparisons are useful during the troubleshooting of a system, which malfunctions due to unknown reason. By comparing an old, "known good" configuration with the current configuration, differences become apparent and, due to the documentation generating nature of the current invention, such changes may easily be placed in context and thus aid in determining if any of the modified parameters may have caused the malfunction.
It should be pointed out specifically that the invention, with its several capabilities, applies to multi-server configurable systems as well as single server configurable systems. This is a clear advantage since, as mentioned earlier, the system complexity grows exponentially with the number of servers. Examples of such multi-server environments are a plurality of server computers operating under the Windows NT operating system within a single domain, or multiple communicating domains with or without trust relationships. Another example is one or more Microsoft Exchange electronic mail servers in an organization. Similar in nature is a set of co-operating configurable network nodes such as routers, switches, concentrators, frame relay access devices, and other nodes comprising a data or voice network.
It should also be noted that the invention may be integrated within the configurable system itself, either as an integral part of the system software or by having a separate program active on a computer that is a part of the configurable system. Thus for example a configurable software application may be made self documenting by including program code that retrieves configuration parameters and merges them into explanatory material (template), implemented in any convenient manner, thus creating a document describing the specific instance of the configurable system.
The program code required for performing the steps for creating the document may be integrated into the configurable system itself. In such an embodiment most of the configuration data is available to the document generation module from within the program, and additional data may be derived from data stores such as an active directory, or from other computers that are a part of the configurable system. The document generation module comprises primarily of an external text template, text segments coded within the module, or any other convenient manner to store the explanatory text and optional drawings. The module also contains program code to merge the configuration data within such template and output the template with the merged data as a document. The program code may be integrated directly into the configurable system as an integral part of the configurable system code or may be implemented as an add-on module loaded and executed by the configurable system at run-time.
The invention operates generally by collecting configuration data from individual systems or from system sub-components that comprise the configurable system to be documented. Preferably, a collector program is deployed to collect the configuration data. A collector program is a program constructed to collect configuration data from one or more configurable systems, and is constructed specifically for each platform or configurable system and collects the raw data for transmission into a Documentor. The configuration data is then preferably encrypted (especially in the case of transmitting the data over the Internet) before being transmitted to the Documentor.
A Documentor, (alternatively referred herein as a Documentation Server) is a computer program or a collection of computer programs, that receives configuration data as its input and generates documentation as its output, primarily when receiving the data from a configurable system and generating documentation pertaining to the system. It performs this function by outputting a template, or pre-determined text segments relating to configuration parameters or to a group of inter-related configuration parameters. The text segments of which the document is comprised are primarily explanatory in nature and are composed to improve the understanding of meaning and effects of the configuration parameters to which they relate. Optionally, drawings and tables are also outputted as needed to increase the understanding and readability of the produced document. The drawings, tables, and text segments are outputted to paper, a computer screen, the Internet, or any other appropriate output device or method. Additionally the Documentor may output the document to a computer file. It should also be noted that methods for dynamic generation of drawings and diagrams (as described for example by the Ahern et al. patent supra or other methods generally known in the art) may be integrated with this invention to generate drawings depicting the configurable system in part or as a whole. ... 9 ...
In one alternative embodiment for a Documentor, a generic operational model is provided. The operational model embeds therein information and knowledge which is required for a proper generic system operation, and may be viewed as a set of generic implementations of operational configurations specific to the generic system. The generic model therefore, details the underlying structure of the interrelationships between different sub-components of the generic case of the configurable system. Each allowable configured system is a subset of the generic configurable system. Similarly, each model of a configured system constructed according to the generic model is a subset of the generic model that reflects the configured system underlying structure as configured. Such specific models of configured systems are called "instance models".
In the preferred implementation, a documentation server comprising the collector program and the Documentor portion is coupled to a local area network or an Intranet that is in communication with the configurable system to be documented. An Intranet is one or more interconnected computer networks that are characterized by being primarily within the electronic bounds of an organization. Typically electronic access to an Intranet is not open to the general public, and it thus affords a protected computing environment for storing and accessing organization confidential data. Many Intranets utilize Internet like technologies, and some utilize communications provided by public communication means, for example, a dedicated line in a PSTN network. However data access to an Intranet is controlled from within the owning organization.
Coupling a documentation server directly to an Intranet overcomes a disadvantage of an Internet coupled server by maintaining the configuration data within the organization- controlled network. In an Internet coupled server the data, even if encoded and encrypted, may present a security risk for certain configurable systems. An Intranet coupled documentation server, especially when implemented as a dedicated computer, becomes a Documentation Appliance, operating within the confines of an organization. The Documentation Appliance is readily available to company personnel, offers local system documentation and storage of previous configurations, all while avoiding the need to send sensitive data over public networks. Such a Documentation Appliance is preferably a dedicated server that may be adapted for documenting one or more types of configurable systems. It is also preferable to have such a Documentation Appliance keep logs of document production and that such logs will be remotely accessible to ease debugging and service. The Appliance may be coupled directly to the configurable system or may utilize an intermediary computer.
A Documentation Appliance server attached to an organization Intranet may also be configured to retrieve the configurable system configuration information according to a predetermined schedule, and activate updated documentation production automatically. Together with the capability to compare previous and current sets of configuration parameters, a Documentation Appliance may thus produce a list of changes that occurred between activations, in effect to create a log, tracking modifications and changes in the configurable system.
There are clear advantages to accessing the documentation via a computer. To facilitate that, the invention also provides for a World Wide Web type server that is constructed to distribute the documents produced by the current invention to a web browser. Since the documentation in the preferred implementation is produced by a print engine capable of producing HTML, the integration of a web server within the appliance allows any person with access rights to browse, search and view the documentation as needed.
Brief description of the drawings
This invention may be better understood from the descriptions and claims which follow, and from the accompanying drawings in which:
Fig. 1 depicts a general schematic component and data flow diagram of a preferred embodiment of the invention
Fig. 2 is a generalized flow diagram of the collector program portion of an embodiment of the invention.
Fig. 3 is a flow diagram for generating an instance model in accordance with the invention Fig. 4 depicts a generic model object in accordance with an embodiment of the present invention.
Fig. 5 is a partial and simplified 'C++' -like code of several classes used in model creation in one preferred embodiment. Fig. 6 depicts 'C++'-like code of two 'document' methods referred to in Fig. 5 classes.
Fig. 7 depicts an example of a simplified portion of text template for another preferred embodiment of the present invention.
Fig. 8 is partial pseudo code showing a method for generating warning messages to the user according to the present invention. Fig. 9 is a screen depiction of web based screen from which the documentation operation begins.
Fig. 10 is a screen depiction of an HTML page prior to sending collected data to documentation browser.
Fig. 11 depicts a partial sample of a table of contents for a document generated in accordance with the present invention.
Fig. 12 depicts a partial sample of documentation generated in accordance with the present invention.
Fig. 13 depicts another partial sample of documentation generated in accordance with the present invention. Fig. 14 depicts another schematic implementation of the invention utilizing a database and a text template in accordance with the present invention.
Fig. 15 depicts a simplified diagram showing connection method of a documentation appliance in accordance with the present invention.
Fig. 16 is a simplified flow diagram depicting a documentation generation process according to the present invention.
Detailed description of the invention This invention will be explained with reference primarily to Microsoft Exchange® and Windows NT® platforms by way of example only. Microsoft Exchange is a popular electronic mail server (hereinafter "Exchange"), and Microsoft Windows NT is a popular operating system (hereinafter "NT" or "Windows NT" interchangeably). It will be clear however to those skilled in the art that primarily the platform specific data need to be modified in order to modify the documentor portion of the invention to handle other types of configurable systems. Such platform specific data includes appropriate text sections and appropriate constraints or rules to define the underlying structure and the acceptable variable values and relationships. Similarly, it will be clear that while the collector portion of the current invention is platform and application specific, adapting the collector program described in this application to operate in a specific platform is a matter of common skill. An Application Programming Interface or API exists for most configurable systems that is designed to provide access to the configuration parameters, ideally fitted in most cases for a collector program or module as described herein. In its most basic form, the invention involves a database containing a set of predetermined text sentences or paragraphs, associated with at least one specific variable. A collector program is provided for reading configuration parameters from a configurable system, and the associated text paragraph is outputted together with the configuration parameters. Optionally entries are made in a table of contents for text paragraphs, and the table of contents is outputted as well. The output may be to a printer, a screen, or a file. Output may also utilize the World Wide Web technology to offer organized access to the documentation, in which case the table of contents is best composed of hyperlinks to appropriate sections. Another alternative output forms include audio and video output. An audio output may be generated by a text to speech translation module. Video output require a video template, similar to the text template described herein, but adapted for video signals and for embedding external values such as configuration parameter values, in a predetermined video stream.
As noted above, the invention may also be practiced by integrating the steps described herein into the configurable system code. For example, a module may be integrated into a Microsoft Exchange server that will retrieve all configuration parameters directly from the Exchange system within which it operates. Alternatively, a Documentor program may be operated on a computer that is a part of the configurable system. For example, a Documentor program may be operated on a computer utilized as a Windows NT domain controller, where much of the configuration data is locally available in a system adapted for documenting a Windows NT environment. The document generation steps described herein are similar with the primary difference being the location where certain portions of the invention are executed. While novel and useful even at this basic level, the invention further benefits the user by grouping similar features and/or variables together, for example listing all domain controllers in an NT domain, or creating a list of all mail transfer agents (MTA) scheduled to run in an Exchange organization, including their prospective protocols or schedule. Optionally, the Documentor portion may collect similar information from multiple servers. So, for example, replication information between database servers may be listed together to ease understanding of the proper propagation order. Such information will preferably be grouped in close proximity with several paragraphs explaining the process of propagation and the meaning of each of the related variables. As further explained below, utilizing constraints or rules eases verification of proper configuration. The preferred implementation will contain general data explaining the generic operation of the configurable system, together with system specific data as configured. Preferably, generic and specific advice relating to configuration will be placed in proximity to system information relating specifically to the system being documented.
For an explanation of the operation of the invention, reference is now made to the drawings, depicting preferred embodiments of the invention, shown here for illustrative purposes only, primarily for operation on a Microsoft Exchange platform.
In Fig. 1 the documentation server 100 in a preferred implementation is located remotely to the client Exchange organization 170. The documentation server 100 is connected to Exchange organization 170 via an Intranet. Optionally, an intermediate workstation 150 connects between the documentation server 100 and the Exchange organization 170.
Workstation 150 is unnecessary if the documentation server 100 has sufficient access rights and immediate network access to the Exchange organization as depicted in Fig. 15. The exchange organization depicted in Fig.l is a generic organization having at least one Exchange Source Server 174, and any number of servers, only two of which are shown, designated as 180 and 185. The Exchange directory 176 resides on the source server 174. Utilizing the process begins with a client creating a connection from client workstation 150 to the documentation server 100 via the web browser 160. The client than downloads 11 a copy 125 of the collector program 120 to the client workstation. In this preferred embodiment the collector program is constructed as an ActiveX ® program or a Java® (Sun Microsystems, Palo Alto, CA) program, and the copy of the collector 125 begins operating automatically after it was downloaded.
Fig. 2 depicts the operation of a collector program constructed for an embodiment configured as depicted in Fig. 1. After program initialization 200, the collector program 125 connects to the Exchange Source Server 174 as depicted in step 12 in Fig.l, and extracts 220 the Exchange Directory information 176. Next, the collector program proceeds to extract 240 registry data 178 from the Exchange Source Server 174 in step 13, and retrieves registry data 182 and 187 for all other Exchange servers in the organization, as shown in steps 13 a, b ...n in Fig. 1. Clearly, while Fig.l shows only three servers, this depiction is for explanation purposes, and the number of servers may vary from one to any number supportable by the configurable platform. For increased efficiency, the steps of collecting the configuration data from the various servers in steps 13b through 13n are carried out simultaneously.
Collector program 125 then creates 250 an HTML page 255, compresses the data collected in steps 12 and 13 a...n, and encodes 260 the data for compatibility with transmission using the HTTP protocol. The data is than embedded in HTML page 255, preferably as hidden text. The collector program 125 than loads HTML page 255 into web browser 160, and points 270 client web browser 160 to the page 255. An example of the HTML page 255 when acted upon by the web browser as depicted in Fig. 10. The user is given the option, by activating button 1010, to send the data to documentation server 100.
While the mechanism of collecting the configuration data shown in steps 220 and 240 is described uniquely as applicable to Exchange environment, those steps constitute the mechanics of collecting configuration information specific to the platform. The function of automatic collection of the configuration data may be performed by any known means without departing from the invention. Adaptation of the collector program described above for different platforms requires only regular programming skills and general knowledge of the platform. Alternatively, the collector program may be constructed to operate through other ... 15 ... communication and collecting methods such as SNMP for network nodes, in which case no HTML communications is required and is often unavailable. In the case of the Documentation Appliance, the collector program may be implemented as a collector program module operating on the Appliance, with the configuration data retrieved directly from the configurable system by the module.
Fig. 3 details the operation of instance model creator 134. The model creation happens within the document generator 130. Once the user sends the data embedded in HTML page 255 to the documentation server 100, the program retrieves 310 the information from the web page, decodes and decompresses 320 the data. The data is then parsed into variable names and corresponding values in steps 330 and 350. The raw data is stored in a database 132. Doing so allows easy approach to different data views as needed. The parsed data is then presented, one variable at a time, to step 360 in which an instance model is created.
In a preferred embodiment the instance model 145 is an object-oriented artifact assembled from instances of predefined object types described in a generic model 140 that is incorporated into the documentation server 100.
The generic model 140 for a specific application domain (e.g., Microsoft Exchange, SAP database, or a specific computer operating system) consists of a set of classes describing objects available in the configurable system universe. Thus, generic models are specific to a particular configurable system domain: for example, at least one generic model is provided for Microsoft Exchange, while another one is provided for Windows NT, and so on.
Each type of object in the configurable system universe that is relevant to the task performed by the current invention is represented in the generic model in the form of a class. The class describes its composition (in terms of lower level objects) and structure (in terms of relationships among its components, e.g. Part-Of, Is-A, etc.). Optionally, behavior can also be expressed as part of the model, in the form of additional relations among constituent parts and/or attributes, describing correct and/or faulty functioning.
By way of example, in a Windows NT domain, there will be a library object describing a server, and certain server characteristic parameters such as name, version information, and the like. Constraints may be attached to each of those variables, for example a constraint that the domain name has to be the same for the server as for the whole domain is needed to verify that the domain is consistent. However more complex requirements, for example communications capability between servers, require that a whole class of objects dealing with network communications be enabled and consistent. Such structural demands comprise the structural generic model 145, together with a set of constraints that are applied to this underlying structure. By adopting the generic model and the object library to specific platforms, such as mail servers, operating systems, network equipment, etc., the documentation server 100 can be modified to operate on various platforms.
A partial example of several objects relating to a model for the Microsoft Exchange platform is shown in Fig. 5 in 'C++' -like notation. By way of example, class 'Organization' 510 is the root of the model, and comprises internal attributes such as the organization name 511, and other subservient objects comprising the rest of the organization model. In this example, the vector of subservient objects is of type 'Site' shown as 516. The class Organization 510 also incorporates several methods. The posting step described below is carried out in the method 'post' 512. Rules or constraints applied to the object to check the validity of the object against the generic model are applied using the 'validate' method 513, and the method 'document' 515 is used to create the documentation that is specific to the configurable system instance.
Examining class Site 520 shows a close similarity to class Organization 510 above, with the major structural differences being the members included in the class. While the Organization class 510 included a vector 516 detailing a list of sites, each Site object details a list of Server objects 526 and a list of Protocols objects 524 with similar collection of methods. In class Server 530 we see a similar pattern yet again. Class Protocol 540 also incorporates similar methods, but being a leaf of the hierarchical model structure, it does not include any vector of inherent objects connected thereto. It will therefore be clear to any person familiar with the organization and operation of the Microsoft Exchange software, that the construction shown in Fig. 5 represents not only a collection of objects of the types described above, but also the underlying structure of a Microsoft Exchange installation. It will also be clear that similar constructs may be created for other configurable systems such as a Windows NT domain, a network organization, Lotus Notes software, database servers etc. ... 17 ...
In the process of instance model creation 360, each applicable configuration variable is examined against the generic model. In this step, known as the 'post' or 'posting' step, an object instance is created for each relevant configuration variable. Variables that conform to the generic model and pass the constraints imposed on the instance object are posted in the instance model. Posting occurs in an object-oriented manner that maintains a structural semblance to the underlying principles defined in the generic model for the platform as described above.
Constraints may be divided primarily into two categories: hard and soft constraints. Hard constraints are such that a violation thereof may prevent the system from operating, while soft constraints are mainly related to performance issues, and a violation of such soft constraints will allow continued system operation, albeit in less than optimal manner. Whether a constraint is a hard or soft, is particular to each constraint and is responsive to the value of one or more variables. Additionally, as is well known in the art, constraints may be quantitative, and assign values corresponding to a level of conformance with the generic model. For example, such values are utilized for providing the user with suggestions and warnings related to optimizing the configurable system performance and/or to modifications required for maintaining optimal system operational status.
Fig. 4 presents a simplified view of the document construction carried out in the document generation module 138 portion of the documentation generator 130. A documentation template 430 describing and explaining different aspects of the system is created and stored in the documentation server 100. The template may be stored in separate files, as part of the model, or as data available to the documentation generator 138 in any convenient format. Internal attributes and sub-components are integrated into the template as needed. Figs. 12 and 13 are sample documentation pages, while Fig. 11 is a sample of a table of contents; all generated by the current invention. As can be observed in Figs. 12 and 13 drawings may also be embedded in the template.
Fig. 6 is a partial listing of a computer program, written in a 'C++'-like language. The numeral 610 designates a simplified sample of the 'document' method 525 code of an object of class 'Site' 520. The method uses the 'C++' standard output stream 'cout'. Portions of the documentation template 430 are embedded in the first output statement 613 in the form of text strings like "The site" 618. The output statement 613 also includes internal attributes 420 such as the variable 'm name' 615 and sub-components 410 such as the method 'm_servers.size()' 617. Additionally, the method calls other documenting methods in all servers in its 'm_servers' lists seen in 614 and all protocols in its 'mjprotocols' list as seen in 616. While simple attributes such as 'm_name' are outputted directly from class members or global variables, other outputs occur from methods internal as well as external to the method. Since each 'document' method dictates the order in which the subservient objects print, a very orderly and well-organized document can easily be produced. Attention is also called for the 'endl' statement 619 at the end of the cout statement 613, which is an example of the formatting information imparted by the program. More complex formatting, merging information, tables and drawings may be incorporated from such predetermined data or taken from files external to the program to be merged in the output document.
Fig. 6 also shows a method of generating the table of contents or TOC. Statement 611 supplies the current location in the output stream to a procedure named TOCJBntry, which stores the context and associated location for further generation of the table of contents. Similarly, the procedure "Index EntryO" provides the index context, in the example the site name and the location within the output document. If for example the standard output stream 'cout' statements is redirected to one computer file, both the TOC and index generating procedures simply output the indexing information into one or more separate index files. Generating an index and TOC from such files is a simple procedure, and the TOC and index may be created according to the viewing method, e.g. by hyperlinks that are dynamically generated when the document is read on screen, or by printing the information when the document is reproduced on paper.
Fig. 6 also shows another example of the document method common to most if not all nodes in the model. In the ' Server: :document' method 650 output statement 660 generates documentation output without calling any external method.
In a preferred implementation, the output produced by the Documentor is a set of printing instructions for a virtual printing machine. Using specific drivers, the documentor is then able to produce documentation in different formats such as HTML, Postscript, PCL, Latex®, Adobe Acrobat® Microsoft Word® document, or any other desired format. The language for the ... 19 ... virtual printing machine contains, among other constructs, commands for describing the document layout, such as chapter, section, subsection, and similar constructs. Those commands automatically create the appropriate entry in the optional TOC and index. Other commands for the virtual printing machine include commands for specifying document composition, such as structured elements such as tables and bulleted lists, and/or unstructured elements such as paragraph, note, warning, and hints. Additional virtual printing machine commands include formatting instructions like vertical/horizontal space, indentation justification and the like, as well as font management functions such as color, bold, italic, etc.
The virtual printing machine is implemented using object oriented programming techniques, which provides a multiplexer class. Implementing the commands described above in a manner similar to the standard 'C++' stream manipulators and overloading the '«' operator, from the point of view of the Documentor, the multiplexer class is used the same way as standard 'C++' streams. The virtual printing machine also provides several driver classes, one for each type of format or formatting language. Each class implements the translation of the printing commands to the target formatting language.
A simplified description of the output process is as follows: The Documentor creates one multiplexer instance to which it attaches instances of drivers for all the required types of output. Every time the documentor uses the output '«' operator, the desired information or printing construct is sent to the multiplexer which distributes it to all the drivers currently attached to it. Each driver than creates an output according to its specific formatting language. The drivers also create the table of contents and index in a desired manner that fits the formatted output, such as HTML style hyperlinks for an HTML document or as formatted and printable TOC and index for paper output.
Preferably, the invention may further use the raw data database 132 to allow user specified view of data specific to the configurable system in question. The raw data database may best be managed by a database management system against which queries may be posted, and in which the data retrieved forms the basis for the view. The creation of such a view will allow generating partial documentation, for example detailing the entire information specific to a single subnet in a network. This allows users to concentrate on limited areas of interest; for example, a network under direct supervision of a specific user. This feature may be further enhanced by the addition of pointers from the database to related objects in the instance model, since only the relevant portion of the instance model can easily be created as separate documentation with grouping of similar parameters in stored separate subsections of the model. Query results may also be embedded in the output document either according as predetermined by the template or according to user preferences, in a system that includes a user interface portion to accept user input for selecting document generation options.
In a simpler embodiment of the present invention depicted generally in Fig. 14, the process of document generation does not include constraint-based model creation. In such an embodiment the raw data is placed in raw data database 132 and is associated with parts of the documentation, (or text segments) that form template 1450 that correspond to the variables relevant to the documentation of the configurable system. Alternatively, template 1450 may be a predetermined document template, which includes placeholders for the results of specific queries such as the names of all servers, name of all domain controllers, etc. A documentation generation module 1410 reads the template, and when a query is encountered, it is parsed, presented to the database 132 and the results outputted to the document by a documentation generation module 1410. Fig. 7 presents a simple portion of a template to generate partial documentation for a Windows NT domain. Queries to the database 710, 720 and 730 are enclosed between character strings '<«' and '»>'. When the documentation generation module 1410 encounters a query such as 710, it parses the query and the results are inserted into the output stream. The documentation generation module 1410 can also parse constructs such as variable name resolution and substitution, and an if statement as shown in 720, and decide which of the two statements 730 or 740 to output. The example depicted in Fig. 7 shows a simple but effective method to automatically generate elaborate documentation from the collected configuration data without the use of a complete object oriented model. Optionally, a simple error checking and reporting routine may also be incorporated, in which a collection of rules is stored in the program and relevant variables are checked against those rules. Fig. 8 depicts a pseudo-code portion of such rule-checking program. In accordance with Fig. 8 an example 810 of such rules is to warn the user 820 if the number of mailboxes on the server multiplied by the desired mailbox disk space allocation, (or 5 MB in this example) is smaller than the available disk space. The rule may further be constructed to issue warning or error messages, or to propose more fitting values for a parameter based on the value of one or more parameters. For example, the rules or constraints may compute and output a suggestion to modify the size of a virtual memory disk swap file in response to actual RAM memory and available disk space in a server operating under Windows NT. Such proposed values may be based on an arbitrarily complex set of computations emanating from the configuration parameters or based on general system knowledge and experience. The examples given in Fig. 7 and Fig. 8 are but a sample of the many ways rules may be applied to check configuration data and warn users of various inconsistencies and optimization issues.
Another objective of the current invention was previously described as comparing current with previous configurations of the configurable system to aid in troubleshooting. This objective is easily achieved by storing an older model or raw configuration data of an operational system. When a problem is observed in the configurable system operation, & present model or raw data set is collected and the new and old sets of configuration data or model are compared to each other. Outputting variables with different values between the two configurations will allow consideration of only those variables that have been modified, and thus will ease troubleshooting of the system as presently configured. Only minor change are required to the records in the database, such as for example adding a counter or a date associated with the configuration parameter set.
Fig. 15 depicts another preferred embodiment for a Documentation Appliance 1500 described above. While the methods of document generation are similar to the methods already described, the Documentation Appliance 1500 utilizes a collector module 1520 to perform the configuration data retrieval directly from the configurable system. The documentation appliance is connected to an Intranet 1510 that comprises one or more interconnected networks and that is coupled to the configurable system as depicted by the Exchange Organization 170. In this case, all of the needed computers in the configurable system are directly available to the Documentation Appliance 1500, and therefore this embodiment does not require the services of an intermediate workstation 150 as described in the embodiment depicted in Fig. 1. Optionally, the documentation appliance also incorporates a web server 1560 to distribute the documentation to other computers. Optionally a scheduler 1550 is provided to activate the documentation generation according to a predetermined schedule. Fig. 16 is a simplified flow diagram showing an overview of the documentation process in a preferred embodiment of the invention. Beginning with the retrieval of the documentation parameters 1605 and their storage 1610 in a raw data database 132. In step 1615 the main execution loop is initialized with a selection of a first parameter, preferably the root or most important data of the configurable system. This variable is assigned as the Current Parameter or CP. The main loop or some variant thereof will be executed for all relevant parameters.
Step 1620 checks if the CP is indeed relevant to the documentation process. If not, step 1622 is executed to continue to the next step. If CP is relevant, a check is done to see if the value of the parameters is within preset boundaries 1625. If the value is outside the boundaries, an error message is generated 1627. Step 1625 may be used for more complex error checking, computation of boundary values, and optimization
One or more explanatory text segments, (as well as optional drawings and tables) is drawn from the template 1680 in stage 1630. If the template data relevant to the CP requires other parameters (as shown in fig. 7 for example) step 1637 is executed, in which the required parameters are recursively obtained, merged and outputted into the same output stream of step 1650. Once all parameters are merged into the relevant template segment 1640, the results are outputted in stage 1650. If more parameters 1660 are present the loop continues through 1622 and back into step 1620. Otherwise, the documenting process stops at 1699. Database 132 may also be conveniently used to store the rules or boundaries as well as text segments and other data.Once a document is generated with a computer readable main body and a table of contents, additional capabilities, such as searching and editing, may be easily added to the features of the current invention as is well known in the art.
While there have been described what are at present considered to be the preferred embodiments of this invention, it will be obvious to those skilled in the art that various other embodiments, changes, and modifications may be made therein without departing from the spirit or scope of this invention and that it is, therefore, aimed to cover all such changes and modifications as fall within the true spirit and scope of the invention, for which letters patent is applied.

Claims

Claims
1. A method for automatic production of documentation for configurable computerized systems, comprising the steps of: a) retrieving (1605) configuration parameters having values associated therewith, from a configurable system into a computer coupled to at least portion of said configurable system via an Intranet (1510); b) outputting (1650) explanatory text segments corresponding with at least one of said configuration parameters and the value associated therewith, to form a document or a portion thereof.
2. The method of claim 1 further comprising the step of automatically selecting said explanatory text segments by a computer, in accordance with said configuration parameters.
3. The method of claim 1 wherein said step of retrieving is performed using a collector computer program (1520, 120) coupled to said configurable system.
4. The method of claim 3 further comprising the step of constructing said collector program as an ActiveX1 program.
5. The method of claim 3 further comprising the step of constructing said collector program using the Java® programming language.
6. The method of claim 1 or 3 wherein said computer is coupled to said configurable system via one or more intermediary computers (150).
7. The method of claim 1 or 3 further comprising the step of automatically retrieving said configuration parameters in accordance with a predetermined schedule.
8. The method of claim 1 further comprising the step of constructing a table of contents for said document.
9. The method of claims 1 or 8 wherein at least two of said explanatory text segments are grouped in accordance with interrelationship of their corresponding parameters.
10. The method of claims 1 or 8 further comprising the step of generating an index of selected parameters and paragraphs detailing relative location of said parameters and paragraphs within said document.
11. The method of claim 1 or 8 further comprising the steps of: a) providing a computer readable set of rules, (1590) at least one of said rules having a range of acceptable values associated with one or more configuration parameters for said configurable system; and, b) comparing (1625) said retrieved configuration parameters against said set of rules.
12. The method of claim 11 further comprising the step of outputting an indication of error conditions (1627) if at least one of said configuration parameters violates one or more of said rules.
13. The method of claim 11 wherein at least one of said rules also comprise indications of desired values for said associated parameter, and further comprising the step of outputting information conveying said desired values.
14. The method of claim 13 wherein said desired values are computably modifiable.
15. The method of claim 1 wherein said explanatory text is arranged in a text template (1680) having placeholders embedded therein and further comprising the step of merging the values associated with said configuration variables with the template in accordance with said placeholders.
16. The method of claims 1, 3 or 8 wherein said step of outputting further comprises the step of embedding one or more drawings within said document.
17. The method of claims 1 or 8 further comprising the step of communicating said document to another computer by means of a World Wide Web server (1560).
18. The method of claims 1, 3 or 8 further comprising the step of activating said method from within a World Wide Web browser program (160).
19. The method for claim 1 further comprising the step of storing said retrieved configuration parameters in a database (132) adapted to store one or more sets of configuration variables, and retrieve portions of one or more said sets in response to queries.
20. The method of claim 19 further comprising the step of embedding results of queries within said document.
21. A system for automatic production of documentation for configurable computerized systems, comprising: a) a computer (1500) adapted to be coupled to a configurable system via an Intranet (1510); b) means (1520) for receiving configuration parameters from said configurable system; c) means (130) for generating explanatory documentation specific for said configurable system in accordance with said configuration parameters; and, d) means (139) for outputting said documentation.
22. A system for automatic production of documentation for configurable computerized systems, comprising: a) a computer (100) coupled to said configurable system via an Intranet (1510); b) a collector program (1520) operated on said computer and adapted to retrieve configuration parameters from at least one configurable system; c) a documentation generator program (130), comprising : i. a text template (1450) having place holders indicating placement of one or more configuration parameters; ii. a data parser in communication with said collector program, said parser adapted to parse said configuration parameters into associated values and merge said values into said template; and, iii. an output module (139) adapted to output said text template with said merged values to form a document or a portion thereof.
23. The system of claim 22 further comprising a set of acceptable values for at least one of said configuration parameters and wherein an error condition indication is outputted if the value of a configuration parameter violates said acceptable values.
24. A method for automated production of documentation for configurable computerized system, comprising the steps of: a) receiving (1605) configuration parameters from a configurable system, into a computer that is in communication with said configurable system via an Intranet; b) selecting (1630) explanatory text segments in accordance with said configuration parameters; c) outputting (1650) a document having said text segments and values associated with said configuration parameters embedded therein, wherein said document is characterized by having said explanatory text being proximal to correlated configuration parameters, and by having a table of contents detailing relative location of certain segments of said explanatory text.
25. The method of claim 24 further comprising the steps of storing a first and a second set of configuration parameters; and, comparing said first set and second set and outputting differences therebetween.
26. The method of claims 1, 8 or 24 wherein said computer is coupled via an Intranet to at least one configurable system selected from a group consisting of a configurable software application, a computer operating system, an electronic messaging system, a database management system, an enterprise resource planing system, a mass storage platform, file server system, a network router, and a network switching device.
27. The method of claims 1, 8, or 24 wherein said configurable system is at least one selected from a group consisting of Lotus Notes system, Novel Group Wise system, Microsoft Windows NT server, Microsoft Windows NT domain, Microsoft Windows
2000 system, Microsoft Windows 2000 domain, Unix operating system, Linux operating system, Sun Solaris operating system, EMC mass storage system, a Baan enterprise management system, a Peoplesoft enterprise management system, an Oracle database management system, and a Microsoft SQL Server database management system.
28. The method of claims 1, 8 or 24 further comprising the step of outputting said documentation in at least one format compatible with a format selected from the group consisting of HTML, Postscript, Latex, audio, PCL, Microsoft Word, and Adobe
Acrobat.
29. The method of claims 1, 8 or 24 wherein said computer is adapted to produce documentation for a plurality of configurable systems.
30. The method of claims 1, 8 or 24 further comprising the step of maintaining an activity log detailing operations of said steps of retrieving and outputting.
31. The method of claims 1, 8 or 24 wherein said configurable system is a SAP enterprise management system.
32. The method of claims 1, 8 or 24 wherein said configurable system is a Microsoft Exchange messaging system.
33. The method of claims 1, 8, or 24 wherein said computer comprises a part of said configurable system.
34. The method of claims 1, 8, or 24 wherein said step of outputting is being performed by a software module integrated into said configurable system.
35. The method of claims 1, 8, or 24 wherein said step of retrieving is being performed by a software module integrated into said configurable system.
36. A self documenting configurable software system, comprising: a) a plurality of text segments comprising explanatory text relating to said configurable system; b) at least one software module constructed to merge a plurality of configuration parameter of said configurable system with related text segments, and output said text segment and configuration parameters to form a document specific to the instance of said configurable system.
37. The self documenting configurable software system of claim 36 wherein said software module is embedded within said configurable system.
38. The self documenting configurable software system of claim 36 wherein said software module is constructed to be integrated into said configurable system while said configurable system or portions thereof are being executed by at least one computer.
39. A method for automated production of documentation for configurable software system, having at least a portion of its behavior modifiable by configuration parameters stored in a computer accessible store, comprising the steps of: a) embedding into said configurable system a software module constructed to merge configuration parameters and explanatory text segments thereof; b) retrieving configuration parameters having values associated therewith, from a configurable system into a computer; and, c) outputting explanatory text segments corresponding with at least one of said configuration parameters and the value associated with said parameter, to form a document describing specifically said configurable software system as configured.
40. A self documenting configurable software system having configuration parameters stored in at least one computer data store, comprising: a) a software module constructed to retrieve configuration parameters from said computer data store; and, b) a software module constructed to merge text segments and said configuration parameters to produce a document containing information specific to said configurable system, and outputting said document.
PCT/US2000/004510 2000-01-11 2000-02-23 Automatic documentation of configurable systems WO2001052052A1 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
EP00911907A EP1257899A1 (en) 2000-01-11 2000-02-23 Automatic documentation of configurable systems
AU2000233726A AU2000233726A1 (en) 2000-01-11 2000-02-23 Automatic documentation of configurable systems
IL13592600A IL135926A (en) 2000-01-11 2000-05-02 Method and system for automatic documentation of configurable systems

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US09/481,069 2000-01-11
US09/481,069 US6981207B1 (en) 2000-01-11 2000-01-11 Automatic documentation of configurable systems by outputting explanatory information of configuration parameters in a narrative format and configuration parameters differences

Publications (1)

Publication Number Publication Date
WO2001052052A1 true WO2001052052A1 (en) 2001-07-19

Family

ID=23910453

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2000/004510 WO2001052052A1 (en) 2000-01-11 2000-02-23 Automatic documentation of configurable systems

Country Status (7)

Country Link
US (1) US6981207B1 (en)
EP (1) EP1257899A1 (en)
AU (1) AU2000233726A1 (en)
CA (1) CA2300582A1 (en)
GB (1) GB2359389B (en)
IL (1) IL135926A (en)
WO (1) WO2001052052A1 (en)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1536319A1 (en) * 2003-11-27 2005-06-01 Canon Kabushiki Kaisha Client terminal for creating environment information thereof for receiving service from web server, method for controlling the same and program for making a computer perform the controlling method
US9369664B1 (en) 2015-08-05 2016-06-14 International Business Machines Corporation Automated creation and maintenance of video-based documentation

Families Citing this family (47)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7155664B1 (en) * 2000-11-14 2006-12-26 Cypress Semiconductor, Corp. Extracting comment keywords from distinct design files to produce documentation
US20050149847A1 (en) * 2002-05-03 2005-07-07 Chandler Richard M. Monitoring system for general-purpose computers
US7779039B2 (en) 2004-04-02 2010-08-17 Salesforce.Com, Inc. Custom entities and fields in a multi-tenant database system
US20050091224A1 (en) * 2003-10-22 2005-04-28 Fisher James A. Collaborative web based development interface
US7617447B1 (en) 2003-12-09 2009-11-10 Microsoft Corporation Context free document portions
US7464330B2 (en) 2003-12-09 2008-12-09 Microsoft Corporation Context-free document portions with alternate formats
US7418652B2 (en) 2004-04-30 2008-08-26 Microsoft Corporation Method and apparatus for interleaving parts of a document
US7512878B2 (en) 2004-04-30 2009-03-31 Microsoft Corporation Modular document format
US7549118B2 (en) 2004-04-30 2009-06-16 Microsoft Corporation Methods and systems for defining documents with selectable and/or sequenceable parts
US7383500B2 (en) 2004-04-30 2008-06-03 Microsoft Corporation Methods and systems for building packages that contain pre-paginated documents
US7487448B2 (en) 2004-04-30 2009-02-03 Microsoft Corporation Document mark up methods and systems
US8661332B2 (en) 2004-04-30 2014-02-25 Microsoft Corporation Method and apparatus for document processing
US20060026503A1 (en) * 2004-07-30 2006-02-02 Wireless Services Corporation Markup document appearance manager
US20060059459A1 (en) * 2004-09-13 2006-03-16 Microsoft Corporation Generating solution-based software documentation
JP4667386B2 (en) * 2004-09-24 2011-04-13 富士通株式会社 Business model diagram creation support program, business model diagram creation support method, and business model diagram creation support device
US7617450B2 (en) * 2004-09-30 2009-11-10 Microsoft Corporation Method, system, and computer-readable medium for creating, inserting, and reusing document parts in an electronic document
US20060101335A1 (en) * 2004-11-08 2006-05-11 Pisciottano Maurice A Method and apparatus for generating and storing data and for generating a narrative report
US7617451B2 (en) 2004-12-20 2009-11-10 Microsoft Corporation Structuring data for word processing documents
US7617444B2 (en) 2004-12-20 2009-11-10 Microsoft Corporation File formats, methods, and computer program products for representing workbooks
US7617229B2 (en) 2004-12-20 2009-11-10 Microsoft Corporation Management and use of data in a computer-generated document
US7620889B2 (en) 2004-12-20 2009-11-17 Microsoft Corporation Method and system for linking data ranges of a computer-generated document with associated extensible markup language elements
US7614000B2 (en) 2004-12-20 2009-11-03 Microsoft Corporation File formats, methods, and computer program products for representing presentations
US7752632B2 (en) 2004-12-21 2010-07-06 Microsoft Corporation Method and system for exposing nested data in a computer-generated document in a transparent manner
US7770180B2 (en) 2004-12-21 2010-08-03 Microsoft Corporation Exposing embedded data in a computer-generated document
CN1869973A (en) * 2005-05-27 2006-11-29 国际商业机器公司 Method and system for generating file
JP5395434B2 (en) 2005-09-09 2014-01-22 セールスフォース ドット コム インコーポレイティッド System and method for exporting, publishing, browsing and installing on-demand applications in a multi-tenant database environment
US20070073850A1 (en) * 2005-09-29 2007-03-29 Rockwell Automation Technologies, Inc. Industrial control device configuration and discovery
US8019057B2 (en) * 2005-12-21 2011-09-13 Verizon Business Global Llc Systems and methods for generating and testing interactive voice response applications
US8219923B2 (en) * 2006-03-10 2012-07-10 National Instruments Corporation Automatic generation of documentation for specified systems
US7650316B2 (en) * 2006-03-10 2010-01-19 National Instruments Corporation Automatic generation of help information for specified systems
US20070244671A1 (en) * 2006-04-13 2007-10-18 Drone Iyangar Systems and methods for storing, retrieving, and sharing design and construction data
US8019720B2 (en) * 2006-10-02 2011-09-13 Salesforce.Com, Inc. Asynchronous method and system for performing an operation on metadata
US8572057B2 (en) * 2006-10-02 2013-10-29 Salesforce.Com, Inc. Method and system for applying a group of instructions to metadata
US9047168B2 (en) * 2009-05-14 2015-06-02 National Instruments Corporation Automatically generating documentation for a diagram including a plurality of states and transitions
US8479151B2 (en) 2010-05-12 2013-07-02 National Instruments Corporation Converting a statechart from a first statechart format to a second statechart format
US8560827B1 (en) * 2010-12-28 2013-10-15 Emc International Company Automatically determining configuration parameters for a system based on business objectives
WO2011100915A2 (en) * 2011-04-13 2011-08-25 华为技术有限公司 Method and device for assistance in information configuration process
US20150095378A1 (en) * 2012-04-16 2015-04-02 Genesisone, Inc. Method for automated documentation of structured query language including workflow and data dependencies
US9836509B2 (en) * 2012-09-20 2017-12-05 Sap Se Generic query templates for complex event processing and data stream systems
US10057331B2 (en) 2014-12-11 2018-08-21 International Business Machines Corporation Automatic abstraction of flow of control in a distributed virtualization platform
EP3043259A1 (en) 2015-01-09 2016-07-13 Tata Consultancy Services Limited Computer programs components dependencies analysis
US20180067729A1 (en) 2016-09-06 2018-03-08 Jacob Harris Apkon Techniques for modifying execution of a computer program based on user input received through a graphical user interface
US10127204B2 (en) * 2016-11-04 2018-11-13 Ca, Inc. Customized system documentation
US10225621B1 (en) 2017-12-20 2019-03-05 Dish Network L.L.C. Eyes free entertainment
EP3745789A4 (en) * 2018-02-12 2021-01-27 Huawei Technologies Co., Ltd. Communication method, communication device, and computer program storage medium
US10877737B2 (en) * 2018-12-26 2020-12-29 Paypal, Inc. Automatic translation of computer code
US20220004704A1 (en) * 2020-03-13 2022-01-06 DataRobot, Inc. Methods for documenting models, and related systems and apparatus

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5901286A (en) * 1996-11-15 1999-05-04 Canon Information Systems, Inc. Method and apparatus for communicating with a network peripheral
US6003078A (en) * 1996-11-15 1999-12-14 Canon Information Systems, Inc. Automatic service requests over the world wide web
US6044399A (en) * 1998-02-27 2000-03-28 Micron Electronics, Inc. Inferring the identity of a preferred server from configuration information
US6061692A (en) * 1997-11-04 2000-05-09 Microsoft Corporation System and method for administering a meta database as an integral component of an information server
US6065116A (en) * 1997-05-07 2000-05-16 Unisys Corporation Method and apparatus for configuring a distributed application program

Family Cites Families (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5732221A (en) 1992-03-27 1998-03-24 Documation, Inc. Electronic documentation system for generating written reports
US5515524A (en) 1993-03-29 1996-05-07 Trilogy Development Group Method and apparatus for configuring systems
US5638509A (en) * 1994-06-10 1997-06-10 Exabyte Corporation Data storage and protection system
US5799268A (en) * 1994-09-28 1998-08-25 Apple Computer, Inc. Method for extracting knowledge from online documentation and creating a glossary, index, help database or the like
US5815717A (en) 1995-10-27 1998-09-29 Authorgenics, Inc. Application program and documentation generator system and method
GB2308781A (en) * 1995-12-29 1997-07-02 Ibm Client-Server system
US5774667A (en) 1996-03-27 1998-06-30 Bay Networks, Inc. Method and apparatus for managing parameter settings for multiple network devices
US5918233A (en) 1996-05-30 1999-06-29 The Foxboro Company Methods and systems for providing electronic documentation to users of industrial process control systems
FR2751448B1 (en) 1996-07-17 1999-01-15 Bull Sa METHOD FOR REAL-TIME MONITORING OF A COMPUTER SYSTEM FOR ITS ADMINISTRATION AND ASSISTANCE IN MAINTAINING IT IN OPERATION
US6021429A (en) * 1996-11-18 2000-02-01 Canon Information Systems, Inc. Network device which maintains a list of device addresses
DE69732132T2 (en) 1996-11-19 2005-12-15 British Telecommunications Public Ltd. Co. SERVICE MANAGEMENT SYSTEM FOR APPLICATION IN COMMUNICATION SYSTEMS
US5978842A (en) * 1997-01-14 1999-11-02 Netmind Technologies, Inc. Distributed-client change-detection tool with change-detection augmented by multiple clients
US5924109A (en) 1997-03-03 1999-07-13 The United States Of America As Represented By The Secretary Of The Navy Method and apparatus for automatic generation of external interface specifications
KR100234204B1 (en) * 1997-05-15 1999-12-15 윤종용 After service system using internet
US6282454B1 (en) * 1997-09-10 2001-08-28 Schneider Automation Inc. Web interface to a programmable controller
US6094644A (en) * 1997-09-12 2000-07-25 Nortel Networks Corporation Method and apparatus for recording actual time used by a service which makes requests for data
US6308206B1 (en) 1997-09-17 2001-10-23 Hewlett-Packard Company Internet enabled computer system management
US5926463A (en) 1997-10-06 1999-07-20 3Com Corporation Method and apparatus for viewing and managing a configuration of a computer network
US5953526A (en) 1997-11-10 1999-09-14 Internatinal Business Machines Corp. Object oriented programming system with displayable natural language documentation through dual translation of program source code
US6038567A (en) * 1998-02-19 2000-03-14 Microsoft Corporation Method and system for propagating object properties in a desktop publishing program
US6507855B1 (en) * 1998-06-25 2003-01-14 Cisco Technology, Inc. Method and apparatus for extracting data from files
US6272508B1 (en) * 1998-10-13 2001-08-07 Avaya Technology Corp. Guide builder for documentation management in computer applications
US6629134B2 (en) * 1999-09-16 2003-09-30 Xerox Corporation Context sensitive web-based user support

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5901286A (en) * 1996-11-15 1999-05-04 Canon Information Systems, Inc. Method and apparatus for communicating with a network peripheral
US6003078A (en) * 1996-11-15 1999-12-14 Canon Information Systems, Inc. Automatic service requests over the world wide web
US6065116A (en) * 1997-05-07 2000-05-16 Unisys Corporation Method and apparatus for configuring a distributed application program
US6061692A (en) * 1997-11-04 2000-05-09 Microsoft Corporation System and method for administering a meta database as an integral component of an information server
US6044399A (en) * 1998-02-27 2000-03-28 Micron Electronics, Inc. Inferring the identity of a preferred server from configuration information

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1536319A1 (en) * 2003-11-27 2005-06-01 Canon Kabushiki Kaisha Client terminal for creating environment information thereof for receiving service from web server, method for controlling the same and program for making a computer perform the controlling method
US9369664B1 (en) 2015-08-05 2016-06-14 International Business Machines Corporation Automated creation and maintenance of video-based documentation
US9564063B1 (en) 2015-08-05 2017-02-07 International Business Machines Corporation Automated creation and maintenance of video-based documentation
US9666089B2 (en) 2015-08-05 2017-05-30 International Business Machines Corporation Automated creation and maintenance of video-based documentation
US9672867B2 (en) 2015-08-05 2017-06-06 International Business Machines Corporation Automated creation and maintenance of video-based documentation

Also Published As

Publication number Publication date
CA2300582A1 (en) 2001-07-11
IL135926A (en) 2004-03-28
GB2359389B (en) 2002-04-03
GB2359389A (en) 2001-08-22
US6981207B1 (en) 2005-12-27
AU2000233726A1 (en) 2001-07-24
EP1257899A1 (en) 2002-11-20
GB0012566D0 (en) 2000-07-12
IL135926A0 (en) 2001-05-20

Similar Documents

Publication Publication Date Title
US6981207B1 (en) Automatic documentation of configurable systems by outputting explanatory information of configuration parameters in a narrative format and configuration parameters differences
US20180260216A1 (en) Method and System for Automatic Documentation of Configurable Systems
US7035853B2 (en) Document management method and document management device
US5983170A (en) System and method for generating semantic analysis of textual information
US7430711B2 (en) Systems and methods for editing XML documents
US7287229B2 (en) Template-driven process system
US20040189716A1 (en) System and method for designing electronic forms and hierarchical schemas
US7152054B2 (en) Context-based help engine, dynamic help, and help architecture
US20040243613A1 (en) System and method for creating a custom view from information in a managed data store
US20100217777A1 (en) System for Automatic Arrangement of Portlets on Portal Pages According to Semantical and Functional Relationship
KR20040073386A (en) Linking elements of a document to corresponding fields, queries and/or procedures in a database
WO2005089525A2 (en) Facility reference system and method
US20040143795A1 (en) Display data creating technique for automatically Providing efficient representation of portal pages with improved visual recognition
JP2006259811A (en) Log creating device, and program
US6957429B1 (en) Service processing apparatus and service execution control method
CN102571420A (en) Method and system for network element data management
GB2354862A (en) Automatic documentation of configurable systems
JPWO2005098663A1 (en) Information management device
US6745195B1 (en) System, method and computer program product for generating software cards that summarize and index information
US20060212461A1 (en) System for organizing a plurality of data sources into a plurality of taxonomies
WO2007055900A2 (en) Automated interactive statistical call visualization using abstractions stack model framework
US6898586B1 (en) System and method for database design and maintenance
US20020077844A1 (en) Component-description-manual creation support method, component-description-manual creation support system, and computer-readable recording medium
JP3767763B2 (en) Information retrieval device and computer-readable recording medium recording a program for causing a computer to function as the device
WO2005114463A2 (en) Method and system for web-based enterprise change and configuration management reports

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AE AL AM AT AT AU AZ BA BB BG BR BY CA CH CN CR CU CZ CZ DE DE DK DK DM EE EE ES FI FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SK SL TJ TM TR TT TZ UA UG US UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): GH GM KE LS MW SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
REEP Request for entry into the european phase

Ref document number: 2000911907

Country of ref document: EP

WWE Wipo information: entry into national phase

Ref document number: 2000911907

Country of ref document: EP

WWP Wipo information: published in national office

Ref document number: 2000911907

Country of ref document: EP

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642