Skip to content

Latest commit

 

History

History
91 lines (53 loc) · 3.32 KB

README.md

File metadata and controls

91 lines (53 loc) · 3.32 KB

audit-tool

Simple inventory and auditing for files/directories stored on file system.

Install

  1. Clone this repo.

     git clone https://github.com/gwu-libraries/audit-tool.git
    
  2. Copy example.config.py to config.py.

     cd audit-tool
     cp example.config.py config.py
    
  3. Edit the values in config.py. This file contains explanations of the values.

  4. Optional: Create a virtualenv.

    Check which version of Python 3 is installed:

     python3 --version
    

    Install the associated python3.x-venv. You may need to do this as a different user who has sudo privileges. For example, for Python 3.8:

     sudo apt install python3.8-env
    

    (As the gwlai user:) Create the Python virtual environment:

     python3 -m venv ENV
     source ENV/bin/activate
    
  5. Install requirements.

     pip install -r requirements.txt
    
  6. Optional: Schedule audits with cron.

     0 12 * * Sat /opt/audit-tool/ENV/bin/python /opt/audit-tool/audit_tool.py detect_changes --notify all /storage/Drobo5Volume1
    

Note: If multiple users will be performing inventorying activities, be cognizant of file permissions. One useful approach is to have all users in a common group, set the python executable to that group, and set the guid & group's executable bit (chmod g+s) on the python executable.

Initial population of inventory

When adding a new file system to the inventory, the inventory for that file system must be populated.

    python audit_tool.py populate <file system base path>

Updating files

  1. Add, update, or delete files. If copying files from other storage, that copy should be verified (e.g., by using rsync or checking fixities before and after copy).
  2. Detect the added, updated, or deleted files.

To generate json and Excel reports:

    python audit_tool.py detect_changes <base path containing the changes>

To generate a json report only:

    python audit_tool.py detect_changes <base path containing the changes>
  1. Detecting the changes will produce an inventory report, describing all of the changes that were detected. Review the report to make sure that it is accurate. To keep track of your progress, you may want to add notes.

  2. Update the inventory.

     python audit_tool.py update <path to report>
    

Note: If an report has notes, you will be asked to confirm before proceeding.

Auditing files

  1. Detect changes either by a scheduled cron job or by manually invoking:

     python audit_tool.py detect_changes <file system base path>
    
  2. Review the report to determine if any discrepancies were detected.

  3. If a discrepancy was detected and the discrepancy was caused by a failure to update the inventory after updating files then update the inventory:

     python audit_tool.py update <path to report>
    
  4. If a discrepancy was detected and the discrepancy was caused by an error with the files, then fix the error and re-run detect changes to make sure the problem was resolved.

Additional functions

Adding notes

You can add notes with:

    python audit_tool.py note <path to report> "Your note."

Notes will be added to the report.

Excel version of report

To get an Excel version of a report:

    python audit_tool.py excel <path to report>

Unit tests

python -m unittest discover