Document Storage System

AssignedTuesday, April 10, 2012
Program DueMonday, April 23, 2012, 9:00am
Weight9%
Updates

Objectives

To gain experience

Project Description

In the information age, the storage and retrieval of documents has become a fundamental requirement of any company. The ability to query documents about their content is also essential to the company's smooth operation. In this project, you will build a small document storage system that contains documents of various types. You will also write a menu-driven user interface that allows users to create and store documents, archive documents, retrieve documents, and make inquiries about the documents.

Project Specification

In this project, you will design and implement a document storage system that will be used by the MitchBer software consulting firm. This system stores internal company reports and company correspondence, such as memos and emails. All relevant document information will be input by the user. Documents are initially stored in an “active” document list. Upon request, a document may be moved from the active list to the document “archive.” An archive is a place where documents that are no longer used, or “active,” are stored, as opposed to disposing of them. Sort of like a recycle bin. Your system should also allow a user to reactivate a document by moving it back from the document archive to the active list.

When a document is initially stored, the author and the date/time created are recorded. A unique document identification number is assigned to the document starting with 10001. The document number (its ID) is incremented for each subsequent document stored. Your document storage system must be able to store an unlimited number of documents.

In addition to author, date/time, and document ID, which are common to all documents, company reports include a title. Your system must also store memos, which are a kind of correspondence. Memos include the name of the person to whom the memo is being sent, a list of people who will receive a copy of the memo (the distribution list), and the subject of the memo. Email must be stored in your document storage system as well. Emails are electronic correspondence that include the email's subject, the name of the person to whom it is being sent, along with his/her email address.

Your document system must provide the following services for the user. Your user menu will display these options, in this order, and accept an integer menu selection from the user.

  1. Create and store an email message

    This service should accept all necessary email information followed by the contents of the email. This service will display the document ID assigned to the email.

  2. Create and store a memo

    This service should accept all necessary memo information followed by the body (contents) of the memo. Since there is no limit on the number of names on the distribution list, your program should continue to accept names (one per line) until the user types “END” (without the quotes, in upper-, lower-, or camel-case) at the begining of a separate line. This service will display the document ID assigned to the memo.

  3. Create and store a report

    This service accepts all necessary report information followed by the contents of the report. This service will display the document ID assigned to the report.

  4. Display a single document

    The user inputs a document ID and all relevant document information is displayed followed by the document body. The document may be either active or archived.

  5. List all active documents stored in the system

    For each document that HAS NOT been archived, this service displays the document's ID, author, and creation date/time, and any document-specific information, in order by document ID. The body of the documents are NOT displayed.

  6. List all archived documents stored in the system

    For each document that HAS been archived, this service displays the document's ID, author, and creation date/time, and any document-specific information, in order by document ID. The body of the documents are NOT displayed.

  7. Search all active documents for a specified word or phrase

    The user inputs a word or phrase on a single line. A listing of the IDs of the active documents that contain the word/phrase in their text body is displayed in document ID order. It is NOT necessary to find phrases that are split across lines. Additionally, the search should ignore case. For example, “BOB was HERE” will match “bob was here”.

  8. Archive a document

    The user inputs the document ID of the document to be archived. The system responds with an appropriate message indicating whether or not the document was archived.

  9. Retrieve a document from the archive

    The user inputs the document ID of the archived document that he/she wishes to return to the active list of documents. The system responds with an appropriate message indicating whether or not the document was returned to the active list.

  10. Empty the archive

    All archived documents are permanently removed from the document system.

  11. Quit the program

    Your program exits gracefully.

Requirements, Hints, and Tips

  1. (Reqirement) All classes in this project should be in a package named proj4.
  2. (Reqirement) Your design should consist of four basic elements which will be briefly discussed in class.
    1. main( ) which provides the user interface
    2. A single class (lets call it the DocumentStorageSystem, or DSS for short) that stores the documents and performs the services requested by the user.
    3. A hierarchy of document classes
  3. (Reqirement) main( ) and all its helper methods must be implemented in Project4.java.
  4. (Reqirement) You should make good use of method overriding, inherited methods, and polymorphism to show that you understand and can apply these techniques.
  5. (Reqirement) There is no guarantee that the user will input an integer for the menu selection. You will NEED to check types of input.
  6. (Reqirement) All static and instance variables must be private. No protected variables are permitted.
  7. (Reqirement) Use the Date class provided by the Java library (java.util) for storing and printing the creation date/time information.
  8. (Reqirement) Note that the body of text for any document may contain blank lines. These blank lines must be present whenever the text body is displayed.
  9. (Reqirement) Be sure to create only one Scanner object. Declare its reference as static with class scope so it can be used in main( ) and all of its helper methods.
  10. (Reqirement) Because the text of a document is of indeterminant length, your program should continue to accept text for a document's content until the user types “END” (without the quotes and in upper- , lower- or camel-case) at the beginning of a separate line.
  11. (Requirement) For some menu items, the user is asked to input a document ID. If an invalid ID is entered, the system should respond by redisplaying the menu. DO NOT reprompt the user for a new document ID.
  12. (Requirement) Your menu MUST ask for the information for an email in the following order: author, subject, recipient's name, recipient's email address, text body
  13. (Requirement) Your menu MUST ask for the information for a memo in the following order: author, subject, recipient's name, copies list, text body.
  14. (Requirement) Your menu MUST ask for the information for a report in the following order: author, title, text body.
  15. (Tip) When entering author's name, subject, etc., we promise that the user will not enter a blank line. Blank lines may (will) only occur within the document text.
  16. (Tip) It's not necessary to display the menu after each selection has been completed. It's OK to display the menu just once at the beginning of your program. Or, add another option (like 98) that allows the user to display the menu. Just don't choose a number that changes the main menu selections.
  17. (Hint) Good OO design dictates that main( ) will rely on the DSS to perform the user's request. Other than constructors, the code in main( ) will not call any methods of any class other than the DSS.
  18. (Hint) Proper use of inheritance and polymorphism means that no code in the DSS “knows” the type of the Document it is handling. This means that there can be no references to Emails, Memos, or Reports.
  19. (Hint) Don't forget to use good top-down design when implementing code in Project4.java.
  20. Sample program output is given HERE. NOTE: The order of the input prompts when a document is created must match the order found in the sample session so that the grading scripts will work properly.

Project Policy

This project is considered an CLOSED project. Please review the CLOSED project policy on the course website.

Grading

See the course website for a description of how your project will be graded.

Project Submission

  1. Since no files are provided for you, be sure to submit all .java files necessary to compile and run your project.
  2. Use submitls to verify they are in the remote directory

The order in which the files are listed doesn't matter. However, you must make sure that all files necessary to compile and run your project are submitted. You need not submit all files at the same time. You may resubmit your files as often as you like, but only the last submittal will be graded and will be used to determine if your project is late. For more information, see the projects page on the course website.

You can check to see what files you have submitted by typing:

submitls cs202 Proj4

See the Project Submission page for detailed instructions.

Remember — if you make any change to your program, no matter how insignificant it may seem, you should recompile and retest your program before submitting it. Even the smallest typo can cause compiler errors and a reduction in your grade.

Avoid unpleasant surprises!