SYSTEM, COMPUTER PROGRAM PRODUCT AND METHOD FOR MANAGING DOCUMENTS
A system, method and computer program product for managing documents. The system includes a document manager that is configured to search for application services providers (ASPs) over a network and based on a user input. The document manager can search documents within the ASPs, retrieve documents and URLs, store documents and data, format documents, generate and issue unified bills from a plurality of bills from a plurality of ASPs. The document manager can provide consulting advice to the user regarding document managing, and can manage the documents stored on a user storage device, for example by transferring these documents to a ASP storage device after storage time periods associated with the documents.
The present application is a divisional application of Ser. No. 09/684,965 filed Oct. 10, 2000, the entire contents of which are incorporated herein by reference.
BACKGROUND OF THE INVENTION1. Field of the Invention
The present invention is directed to methods, computer-based systems and computer program products for managing documents, in particular document retrieved from, or stored to, application service providers.
1. Discussion of the Background
An application service provider (ASP) is an entity, typically a company, that offers users (individual customers, companies, enterprises, etc.) access over a network, such as the Internet, to applications and related services that would otherwise have to be located on the customer's local computer. For example, ASPs can provide searchable databases of legal, medical, financial, educational, scientific, or marketing documents. Alternatively, some companies provide in-house type ASPs wherein applications are not on the company's employee's personal computers, but instead on a company computer accessible by the employees via a company network. For the purpose of this document, the term “ASP” is thus intended to be broadly interpreted and to include a provider that allows a user to use an application not loaded on the user's computer.
An example of a conventional network of ASPs connected via the Internet is shown in
Today, there are a great number of ASPs providing various kinds of services and documents. For example, an ASP may provide legal documents, while another may provide marketing documents, yet another may provide educational, scientific, financial, or medical documents, etc. Furthermore, different ASPs may provide these documents in different formats, for example, using different graphical user interfaces (GUIs). When a user needs different kinds of documents, for example, a legal document, a financial document, a scientific document, and each of which is stored in different ASPs, the user must search, find and access an ASP that provides the desired documents. When a number of different kinds of documents are desired, the user may have to search, find and access several ASPs. This multiple searching requirement is time consuming for the user. In addition, because various ASPs may provide documents using different formats, the user may have to re-format the documents so as to obtain documents of a single format. This re-formatting is also burdensome on the user. Because most ASP charge their customers for their services rendered, typically on a pay-per-use basis or a contract basis, the customers, or users, may have to pay several bills, one for each ASP used. This multiple billing system thus imposes an extra burden on the user.
In additions, while users of ASPs may be legal experts such as attorneys, medical experts such as doctors, or financial experts, users may not have any expertise in searching, formatting, organizing, updating, protecting, or in general managing documents retrieved from ASPs. Users therefore waste time attempting to learn about document managing on their own, often by a costly trial and error process.
SUMMARY OF THE INVENTIONAccordingly, one object of the present invention is to solve the above-noted problems and improve upon the noted inefficiencies.
Another object of the present invention is to provide a system for managing documents, which assists users in managing documents. For instance, the system for managing documents according to the present invention may include a consulting device configured to provide consulting advices to users on searching, accessing, formatting, organizing, updating, protecting documents based on the users'specific needs, or based on the users'specific business activities and/or goals.
Another object of the present invention is to provide a system for managing documents, which includes a user interaction device configured to exchange data with the users, for example names, passwords, search words, document type and format, or documents. The user interaction device thus permits the users of the system to input data to, and to retrieve data from, the system.
Another object of the present invention is to provide a system for managing documents, which includes a search engine configured to search for an ASP providing a specific service requested by a user. Optionally, the search engine may be configured to search for documents in individual ASPs, for example when an ASP does not have a search engine of its own.
Another object of the present invention is to provide a system for managing documents, which includes a formatting mechanism configured to format a document retrieved from an ASP in a format requested by the user.
Another object of the present invention is to provide a system for managing documents, which permits users to store documents from the user at the ASPs.
Another object of the present invention is to provide a system for managing documents from ASPs, which includes a bill generator configured to generate a unified bill from different bills received from different ASPs.
Another object of the present invention is to provide a method for managing documents, which assists users in managing documents. For instance, the method for managing documents according to the present invention may include a step of providing consulting advices to users on searching, accessing, formatting, organizing, updating, protecting documents based on the users'specific needs, or based on the users'specific business activities and/or goals.
Another object of the present invention is to provide a method for managing documents, which includes a step of exchanging data with the users, for example names, passwords, search words, document type and format, or documents.
Another object of the present invention is to provide a method for managing documents, which includes a step of searching for an ASP providing a specific service requested by a user. Optionally, the method may include a step of searching for documents in individual ASPs, for example when an ASP does not have a search engine of its own.
Another object of the present invention is to provide a method for managing documents, which includes a step of formatting a document retrieved from a ASP in a format requested by a user.
Another object of the present invention is to provide a method for managing documents, which includes a step of storing documents from a user at an ASP.
Another object of the present invention is to provide a method for managing documents, which includes a step of generating a unified bill from different bills received from different ASPs.
Yet another object of the present invention is to provide a computer program product, which assists users in managing documents. For instance, the computer program product according to the present invention may provide consulting advice to users on searching, accessing, formatting, organizing, updating, protecting documents based on the users'specific needs, or based on the users'specific business activities and/or goals.
Another object of the present invention is to provide a computer program product, which exchanges data with the users, for example names, passwords, search words, document type and format, or documents.
Yet another object of the present invention is to provide a computer program product, which searches for an ASP providing a specific service requested by a user. Optionally, the computer program product may search for documents in individual ASPs.
Another object of the present invention is to provide a computer program product, which formats a document retrieved from an ASP in a format requested by a user.
Another object of the present invention is to provide a computer program product, which stores a document from a user at an ASP.
Another object of the present invention is to provide a computer program product, which generates a unified bill from different bills received from different ASPs.
To achieve these and other objects, the present invention provides a computer based system managing documents from ASPs. The system according to the present invention typically includes a computer program, which receives data input from a user, data output from an ASP based on the user input, transforms the received data in some desired way, and then outputs the transformed data stream to the user. For example, the computer program receives a search request or a request for a specific document from a remote user; selects an ASP based on the request; forwards the request to the ASP; and receives information from the ASP indicating information, such as billing information, the document itself, or the document's URL, of a document provided from the ASP to the user.
Alternatively, a computer program receives data from the user and transmits the to the ASPs. For example, the computer program receives a request to transfer a document from a user. The computer program further receives the document and storage information from the user, then select an ASP based on the storage information; and transmits the document and at least part of the storage information to a storage device of the ASP.
BRIEF DESCRIPTION OF THE DRAWINGS
FIGS. 5A1, 5A2, and B-E show flowcharts of a method of managing documents implemented by a document manager according to one embodiment of the present invention.
Referring now to the drawings, wherein like reference numerals designate identical or corresponding parts throughout the several views,
In the embodiment shown in
As noted above, the document manager 60 includes a user interaction device 65 with which the user 70 can interact via network 55. In one embodiment, the user 70 may access document manager 60 by signing on, for example using a user-name and a password, which can be verified by user interaction device 65. If the user is not a registered user, the user interaction device 65 can request information from the user so as to generate a membership. The user interaction device 65 also receives the input data from the user regarding the type of documents the user is requesting. The user may also input a requested document format, or user information such as e-mail addresses, postal addresses, telephone numbers, or information about the type of document management needed by the user 70. The user interaction device 65 can either request more information from the user and/or provide the user 70 with document managing advice, strategies, and information, for example via the consulting device 67. The user interaction device 65 may also provide the user with the ASP addresses from which requested documents are available, or may transmit to the user 70 the requested documents, and the unified bill.
The document management 60 also includes a search engine 62 configured to search and access ASPs based on data input from the user 70, for example via user interaction device 65. The search engine 62 is also configured to retrieved documents. Advantageously, the user need only input information related to the document required and not related to the ASP from which the desired document is to be retrieved. The search engine 62 can also be configured to search the individual ASPs for documents when the ASPs do not have a search engine available. Search engines are well-known in the art and are explained for example, in part 32 of “How The Internet Works”, by Preston Gralla, Que Corporation, pps. 185-189, August 1999, ISBN: 0-7897-2132-5, the entire content of this book being incorporated by reference.
The document manager 60 also includes a storage device 64, which may store all the documents requested by the user 70, in their original formats and/or in their standardized format. The storage device 64 may also include the URL's of the ASPs from which a document was retrieved, and/or the billing information from each ASP from which the searching engines retrieved documents. The storage device 64 may also store user information, such as user-names, user passwords, e-mail addresses, postal addresses, telephone numbers, current and prior type of documents requested, current and prior document management strategies for specific users, current and prior user-requested searches, and/or searching parameters. In one embodiment, the storage device 64 is accessible by the user, for example via the user interaction device 65.
The storage device 64 can include, but is not limited to, any type of disk including floppy disks, optical disks, CD-ROM, magneto-optical disks, ROMs, RAMs, EPROMs, EEPROMs, Flash Memory, Magnetic or Optical Cards, or any type of media suitable for storing electronic instructions and/or data. Moreover, the storage device 64 may include a database, i.e., a digital repository, that may be implemented, for example, through a commercially available relational database management system (RDBMS) based on the structured query language (SQL) such as ORACLE, SYBASE, INFORMIX, or MICROSOFT ACCESS, through an object-oriented database management system (ODBMS), or through custom database management software.
The document manager 60 may also includes a format standardizing device 66 configured to standardize the formats of the documents retrieved from various ASPs. For example, the format standardizing device 66 can re-format the documents so that they may be accessed using a single GUI. Such re-formatting devices are well-known in the art. In one embodiment, the format standardizing device 66 receives the standard format from the user interaction device 65 and stores the standardized documents in the storage device 64. The documents to be formatted by the format standardizing device 66 can be received from the ASPs via network 50, from the user 70 via the network 55, from the storage device 64, or from the user interaction device 65.
The document manager 60 may also include a charge engine 68 configured to charge the user 70 with a unified bill. For example, the unified bill can correspond to the sum of the bills received from the ASPs. The bills from the ASPs can be received from the ASPs or the user interaction device 65, and can be forwarded to the user interaction device 65, or to the storage device 64 for storing, or to the user 70 via network 55.
The document manager 60 described above can provide consulting advice to the user, generate document managing strategies for the user based on the user's specific needs, retrieve and organize the addresses of, and links to, ASPs 10-40, retrieves documents from the ASPs 10-40, stores the documents, formats the documents, bills the user a unified bill, and/or transmits the documents to the user to be viewed on the screen of the PC 80, printed with printer 90, or stored in the local storage device 100 and/or medium drive 110. The document manager 60 thus provides the user with access-to-ASP services, the ability to retrieve-from-ASPs, a consistent user interface, a single sign-on service, the ability to request a single search for different documents and different document types, a single billing service, and a flexible storage service. The document manager 60 may also suggest to the user and provide the user with online print and delivery services, for example by ordering documents from the ASPs and securing their delivery to the user via a courier. In this embodiment, the document manager 60 can contract with the ASPs and the courier service to ensure proper delivery, to be the user's agent that keeps track of the delivery, and to inform the user of the status of the delivery. The document manager 60 can also generate a single bill for its services and those of the ASP and courier used.
The document manager 60 may also provides the user 70 with the links to the ASP documents so that the user may access the documents via the document manager 60 without having to store any document at the computer of the user, nor at the document manager 60, if desired. In this respect, the user 70 benefits from the searching, retrieving and storing known-how of the ASPs. In this embodiment, the ASP can charge a fee for access to their documents. In one embodiment, the fee may be incorporated into a unified bill generated by the document manager 60 and provided to the user 70 for its benefit. The term “unified bill”herein means a bill that includes the charges of at least two bills.
Furthermore, the document manager 60 permits the user to retrieve documents and to store the documents on a local storage device, either permanently or temporarily. Alternatively, the document manager allows the user 70 to store a document at the ASP. For example, the document manager 60 may be in a partnership with the ASPs to provide storage at the ASPs for documents of users, i.e. customers, of the document manager 60. For instance, a user may decide to store sensitive legal documents, insurance contracts, or digital certificates on a local storage device for a predetermined period of time, and have the documents protected from loss, theft, fire, disaster, etc. by storing them at an ASP, which may provide better protection for the secured documents. In this case, the user benefits from the ASP's know-how for handling and protecting secured documents. In this embodiment, the ASP can charge a fee for the storage. In one embodiment, such a fee would be included in a unified bill computed by the document manager for the benefit of the user.
Advantageously, the user does not have to be aware of the different ASPs used by the documents manager 60 to create the collection of documents retrieved and transmitted to the user, and used to store documents at the ASPs. Therefore, the user may deal with a single user interface when receiving the requested documents and when transmitting the user documents to be stored at the ASPs. In addition, the unified billed, generated by the ASPs for either searching, delivering, or storing documents, provided by the document manager 60 also alleviates the burden on the user 70 to pay several different bills.
The document manager 60 thus provides a single stop for consulting, billing, formatting, obtaining, reviewing, storing, and managing a variety of types of documents, such as legal, financial, insurance, engineering, accounting, or general office, educational, medical, governmental agencies documents.
For the direct search service, the user 60 can input the search requested at step 4070. At step 4080 the user signs on the document manager and the user request is inputted at step 4090. The document manager 60 then selects the ASPs appropriate for the requested service at step 4100 and requests the service from the ASPs at step 4060.
For both services, the document manager signs on to the ASP to request the service at step 4110. In other words, if the user signs on the document manager 60, the user can access several ASPs without signing on each ASP. Once the ASPs receive the requested service, the ASPs perform (execute) the service at step 4120, for example, search for a specific document, provide the document to the user at step 4130 and bills the document manager 60 at step 4140. The document manager 60 then provides the document(s) to the user 70 at step 4150 and issue a single bill to the user for all services performed at step 4160.
For both services, the user 70 has the option of signing-on the document manager 60 at step 4010 and 4080 and the ASPs 10-40 at step 4110 and placing the request. This may be beneficial when the user knows which ASP can provide the desired service. In this case, the document manager 60 can still perform the services of issuing a single bill, or reformatting the documents in accordance to the user's requested format, and/or securing the proper delivery of the document to the user, etc.
FIGS. 5A-E show flowcharts illustrating a method of managing documents according to one embodiment of the present invention, which can be implemented by the system shown in
The access level used by the method of the present invention is described next. As noted above, the document manager 60 permits storing of documents at the ASPs 10-40. In other words, the user 70 may transmit documents to the ASPs 10-40 for storage via the document manager 60. These documents may be downloaded from the user's local storage device 100 or medium drive 110, or generated by the user's PC 80, scanner, digital copier, facsimile machine, printer, or multi-function printer connected to the network 55. In a preferred embodiment, the documents stored at the ASPs 10-40 are stored with an access level associated with them. The access level identifies the documents which a specific user can access at the ASPs via the document manager 60. The user 70 may assign an access level to each document stored at the ASP. During a retrieval operation, the user's ID is transmitted to the document manager 60 so that the user's ID can be registered at step 340 and an access level set based on the user's ID at step 350. Because the access level is assigned to each user, the document manager 60 retrieves documents that match the user's access level. As a result, security management can be accomplished and the search time can be reduced. The access level for each user can be stored in the document manager 60, for example in storage device 64. When documents are stored in the ASPs, the access level can be set with each document. The access level for each stored document can be stored at the ASPs. When the document manager 60 executes a document retrieval operation, the document manager's search engine 62 and/or the ASPs'search engine execute the retrieval operation only for documents having an access level matching the user's access level. Consequently, the retrieval time is shortened and high security documents can be accessed by only appropriate users.
An example of an access level scheme applicable to the present invention is an access level that includes three sections:
(1) a first section to identify the business entity to which the document pertains, for example a group of companies (A), an individual company (B), or an individual subsidiary (C), etc . . . ;
(2) a second section to identify the department to which the document pertains, for example the legal (1), finance (2), marketing (3), or R&D department (4), etc . . . ; and
(3) a third section to identify the individual (Laura, Jim, Caroline, Phil . . . ) who created the document.
For example, a user with the access level B-2-% would have access to all (%) marketing documents (2) related to company B. Alternatively, a user having the access level A-%-Jim would have access to only the documents created by Jim, in any department (%) of the group of companies (A). Under this exemplary scheme, a legal document created by Phil for the subsidiary C would have an access level of C-1-Phil.
Returning now to
The document manager 60 then can go through a billing routine, for example as shown in
Returning to step 360 of
Turning to
At step 730, the document manager 60 inquires whether a medium storage request is received. If no such request is received, the document manager 60 transmits at step 740 a display command to inform the user of the retrieval results. For example, the display command can include the URL of the searched document, the titles of the documents, the document itself, the expected date of delivery (if applicable), or any other information relating the search results. The display command may be displayed on the screen of the user's PC 80, or can be displayed as an e-mail to the user, or a facsimile to the user. Once the display command is transmitted, the document manager 60 can run the billing routine shown in
If a medium storage request is received at step 730, the document manager 60 inquires at step 750 whether the delivery information is received. In this case, the delivery information can be the user's local storage device 100 address, or the user's medium drive address, or the address of any other storage device accessible by the user. If no delivery information is received, the document manager 60 sends a message to the user at step 760 and requests the delivery information. The document manager then inquires at step 770 whether the requested delivery information is received. Once delivering information is received, the document manager 60 transmits the requested documents at step 780 to the user's storage device based on the delivery information As an alternative to transmitting the document from the ASP, through the document manager 60, to the user, the document may be transmitted from the ASP to the user without going through the document manager. Once the document transmittal is performed, the document manager 60 assigns a value to a medium storage flag at step 790, for example the value 1. The document manager 60 transmits at step 800 a display command to inform the user of the retrieval results. For example, the display command can include the memory addresses of the stored document, the memory size of the stored document, the URL of the document, the document itself, the expected date of delivery (if applicable), or any other information relating the search results. The display command may be displayed on the screen of the user's PC 80, or can be displayed as an e-mail to the user, or a facsimile to the user. Once the display command is transmitted, the document manager 60 can run the billing routine shown in
The document manager 60 can help the user manage documents stored at the user, for example in the user's local storage device 100. An example of a method of managing documents stored at the user according to the present invention is shown in
Returning to step 900, if the received request is a document retrieve request, the ASP inquires at step 955 whether the ASP has a document search engine. If the ASP does not have a search engine, the ASP sends a message to the document manager at step 960, and permits the search to be executed by the document manager's search engine 62. If the ASP has a search engine, the ASP inquires at step 970 whether the key word(s) and access level of the user are received. If not, the ASP loops until the key word(s) and access level are received form the document manager 60. The ASP's search engine executes the search at step 975 based on the access level of the user and the key word(s). The ASP inquires at step 980 whether the document was found. If no document was found, the ASP sends a message at step 985 to the document manager to inform the document manager of the search results. Alternatively, the ASP can send a message directly to the user. If a document was found at step 980, the ASP transmits the document and the URL of the document to the document manager at step 990. The ASP then runs the billing routine of steps 930-950 as described above.
The above methods (
A conventional personal computer or computer workstation with sufficient memory and processing capability may also be configured to operate as device 190. In one embodiment, device 190 operates as the document manager 60, both receiving and transmitting information by users and ASPs. Central processing unit 200 is configured for high volume data transmission and performing a significant number of mathematical calculations in processing communications and database searches. A Pentium III microprocessor such as the 1 GHz Pentium III manufactured by Intel Inc. may be used for CPU 100. This processor employs a 32bit architecture. Other suitable processors include the Motorola 500 MHZ PowerPC G4 processor and the Advanced Micro Devices 1 GHz AMD Athlon processor. Multiple processors or workstations may be used as well.
The ROM 280 is preferably included in a semiconductor form although other read-only memory forms including optical media may be used to host application software and temporary results. The ROM 280 connects to the system bus 250 for use by the CPU 200. The ROM 280 includes computer readable instructions that, when executed by the CPU 200, perform the different functions discussed above associated with managing documents from ASPs. An input controller 260 connects to the system bus 250 and provides an interface with various peripheral equipment including a keyboard 261 and a pointing device such as a mouse 262. The input controller 260 may include different ports such as a mouse port in the form of a PS2 port or, for example, a universal serial bus (USB) port. The keyboard port for the input controller 260 is in the form of a mini-DIN port although other connectors may be used as well. The input controller 260 provides sound card connections so that external jacks on the sound card allow users to attach microphone speakers or an external sound source. The input controller 260 also may include serial ports or parallel ports as well.
A disk controller 240 is in the form of an IDE controller and connects via ribbon cables to a floppy disk drive 241 as well as a hard disk drive 242, a CD-ROM drive 251 and a compact disk 252 (
An input/output controller 220 also provides connections to external components such as an external hard disk 221, printer 222, for example, by way of an RS 232 port and a SCSI bus. For more information on how the input/output devices operate according to the present invention, such devices are described in part 5 of “How Computers Work”, by Ron White, Que Corporation, pps. 184-276, September, 1999, ISBN: 0-7897-2112-0, the entire content of which is hereby incorporated by reference.
A display controller 210 interconnects the system bus 250 to a display device, such as a cathode ray tube (CRT) 211. While a CRT is shown, a variety of other display devices may be used such as an LCD (liquid crystal display), or plasma display device. As noted above, the components shown in
The mechanisms and processes set forth in the present description may be implemented using a conventional general purpose microprocessor(s) programmed according to the teachings of the present specification, as will be appreciated to those skilled in the relevant arts. Appropriate software coding can readily be prepared by skilled programmers based on the teachings of the present disclosure, as will also be apparent to those skilled in the relevant arts.
The present invention thus also includes a computer-based product that may be hosted on a storage medium and include instructions that can be used to program a computer to perform a process in accordance with the present invention. This storage medium can include, but is not limited to, any type of disk including floppy disks, optical disks, CD-ROM, magneto-optical disks, ROMs, RAMs, EPROMs, EEPROMs, Flash Memory, Magnetic or Optical Cards, or any type of media suitable for storing electronic instructions.
This invention may also be conveniently implemented using a conventional general purpose digital computer programmed according to the teachings of the present specification, as will be apparent to those skilled in the computer art. Appropriate software coding can readily be prepared by skilled programmers based on the teachings of the present disclosure as will be apparent to those skilled in the software art. In particular, the computer program product for managing ASP documents according to the present invention can be written in a number of computer languages including but not limited to C, C++, Fortran, and Basic, as would be recognized by those of ordinary skill in the art. The invention may also be implemented by the preparation of applications specific integrated circuits or by interconnecting an appropriate network of conventional component circuits, as will be readily apparent to those skilled in the art.
Obviously, numerous additional modifications and variations of the present invention are possible in light of the above teachings. It is therefore to be understood that within the scope of the appended claims the present invention may be practiced otherwise than as specifically described herein.
Claims
1. A method for managing documents, comprising the steps of:
- receiving a request from a remote user;
- selecting an application service provider based on said request;
- forwarding said request to said application service provider; and
- receiving information from said application service provider indicating information of a document provided from said application service provider to said user.
Type: Application
Filed: Feb 15, 2007
Publication Date: Jun 14, 2007
Inventors: Yuki UCHIDA (Wayne, NJ), Shogo Hyakutake (Boonton Township, NJ), Minoru Aoshima (Edgewater, NJ)
Application Number: 11/675,125
International Classification: G06F 17/30 (20060101);