Metadata-Version: 2.4
Name: poottu
Version: 1.0.1
Summary: Poottu Password Manager
Author-email: Manikandan D <manikandan@due.im>
License: MIT License
        
        Copyright (c) 2025 Manikandan D
        
        Permission is hereby granted, free of charge, to any person obtaining a copy
        of this software and associated documentation files (the "Software"), to deal
        in the Software without restriction, including without limitation the rights
        to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
        copies of the Software, and to permit persons to whom the Software is
        furnished to do so, subject to the following conditions:
        
        The above copyright notice and this permission notice shall be included in all
        copies or substantial portions of the Software.
        
        THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
        IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
        FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
        AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
        LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
        OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
        SOFTWARE.
Project-URL: Homepage, https://due.im/poottu/
Project-URL: Repository, https://github.com/manikandancode/poottu
Project-URL: BugTracker, https://github.com/manikandancode/poottu/issues
Keywords: password-manager,offline-password-manager,password,secure-password-generator,python-password-manager,password-manager-app
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: End Users/Desktop
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Operating System :: OS Independent
Classifier: Topic :: Utilities
Classifier: Topic :: Security
Classifier: Topic :: Security :: Cryptography
Requires-Python: <3.14,>=3.12
Description-Content-Type: text/markdown
License-File: LICENSE
License-File: LICENSE.txt
Requires-Dist: PySide6>=6.5.0
Requires-Dist: argon2-cffi>=21.3.0
Requires-Dist: pynacl>=1.5.0
Requires-Dist: zxcvbn>=4.5.0
Requires-Dist: cryptography>=41.0.0
Requires-Dist: platformdirs>=3.0.0
Dynamic: license-file

<p align="center">
  <img src="https://raw.githubusercontent.com/manikandancode/poottu/main/src/poottu/resources/icon.ico" 
       alt="Poottu App Icon" width="120"/>
</p>

# Poottu Password Manager

![Poottu](https://img.shields.io/badge/Poottu-Password%20Manager-4a86ff?style=for-the-badge&logo=qt&logoColor=white)
[![License: MIT](https://img.shields.io/badge/License-MIT-2ea44f?style=for-the-badge)](#license)
[![Website](https://img.shields.io/badge/Website-due.im%2Fpoottu-0aa77e?style=for-the-badge)](https://due.im/poottu/)
[![GitHub](https://img.shields.io/badge/GitHub-manikandancode%2Fpoottu-161b22?style=for-the-badge&logo=github)](https://github.com/manikandancode/poottu)
![Python](https://img.shields.io/badge/Python-3.12%2B-3776AB?style=for-the-badge&logo=python&logoColor=white)
![OS](https://img.shields.io/badge/OS-Windows%20%7C%20macOS%20%7C%20Linux-6c757d?style=for-the-badge)
![Offline](https://img.shields.io/badge/Offline-First-6f42c1?style=for-the-badge)
[![Release](https://img.shields.io/github/v/release/manikandancode/poottu?style=for-the-badge)](https://github.com/manikandancode/poottu/releases)
[![Downloads](https://img.shields.io/github/downloads/manikandancode/poottu/total?style=for-the-badge)](https://github.com/manikandancode/poottu/releases)
[![PyPI - Package](https://img.shields.io/pypi/v/poottu?style=for-the-badge)](https://pypi.org/project/poottu/)
![Status](https://img.shields.io/badge/Status-Stable-28a745?style=for-the-badge)

A fast, privacy-first, offline desktop password manager for Windows, macOS, and Linux. Poottu stores credentials locally with strong, authenticated encryption and offers a clean, modern UI with helpful workflows like live search, context-menu copy, timed clipboard clearing, and encrypted backup/restore.

![Poottu_main_window](https://github.com/user-attachments/assets/bef45d35-41e7-489c-9379-b6236fbd5419)


## Features

- Secure, offline-by-default local vault with modern, authenticated encryption.
- Create/Unlock dialogs with readable light/dark designs and show/hide toggles.
- Groups for organizing entries, with quick Edit Groups management.
- Live search across Title, Username, URL, and Notes.
- Entry preview panel with Show Password button.
- Context menu actions: Copy Username, Password, URL, Old Password, and Notes.
- Timed clipboard clear, plus an in-app HUD toast that confirms copy and clear timing.
- Encrypted Backup and Restore from the File menu.
- Build in Password Generator in add entry
- Keyboard shortcuts:
  - Ctrl+N: Add Entry
  - Ctrl+G: Edit Groups
  - Ctrl+B: Backup
  - Ctrl+R: Restore
  - F2: Edit selected entry
  - Delete: Delete selected entry

## Why the name “Poottu”?

Poottu (பூட்டு, pronounced Poo-ttu) means “lock” in Tamil, symbolizing security and protection. The name reflects the app’s purpose: a simple, safe, and trusted password manager.

## Screenshots

- Unlock dialog with modern card design and show/hide toggles.
- ![Poottu_master_password_unlock](https://github.com/user-attachments/assets/ae9b630d-dcae-4c55-9f11-464c3198df77)

- Manage Gruops Window.
- ![Poottu_manage_groups](https://github.com/user-attachments/assets/ed346e76-ed6f-4a02-a643-d8197bd5bea3)

- Add/Edit Entry
- ![Poottu_Add_entry](https://github.com/user-attachments/assets/36dd6ba2-df64-4859-af9a-0fd390d768e9)


## Getting Started

### Prerequisites

- Python 3.12+
- A virtual environment is recommended.

### Installation

1) Clone the repository and enter the project directory.

2) Create and activate a virtual environment:
- Windows:
  - python -m venv venv
  - venv\Scripts\activate
- macOS/Linux:
  - python3 -m venv venv
  - source venv/bin/activate

3) Install dependencies:
- pip install -r requirements.txt
  - or
- pip install "PySide6>=6.5.0" "argon2-cffi>=21.3.0" "pynacl>=1.5.0" "cryptography>=41.0.0" "platformdirs>=3.0.0" "zxcvbn>=4.5.0"


### Running

- From the project root:
  - python src/poottu/main.py

On first run without a vault, the Create window appears to set a master password. If a vault already exists, the Unlock window will prompt for the master password.

## Usage

### Create Master Password

- Enter and confirm a strong password.
- Requirements:
  - At least 12 characters.
  - Contains lowercase, uppercase, number, and special character.
- The strength checker will guide improvements if needed.
- Press Create to initialize the vault.

### Unlock Vault

- Enter master password and press Unlock or hit Enter.
- Use Show to verify the password if necessary.
- On error, an “Invalid master password” message appears.

### Main Window Overview

- Groups (left): pick a group to filter entries.
- Search (top): filters entries across Title, Username, URL, and Notes as text is typed.
- Entries (top-right): table with Title, Username, masked Password/Old Password, URL, Notes preview, and Expires.
- Preview (bottom-right): see details for the selected entry and reveal/hide password.

### File Menu

- Add Entry: create new credential records.
- Edit Groups: add, rename, and delete groups.
- Backup: export an encrypted backup file.
- Restore: import a previously exported encrypted backup.
- Clipboard → Configure Clear Timer…: choose the seconds before the clipboard is auto-cleared (0 disables).
- About: version, author, project URL, and full MIT license.
- Exit: close the app.

### Entries

- Add Entry: choose Group, then fill Title, Username, Password, Old Password, URL, Notes, optional Expires.
- Edit Entry: right-click rows or select a row and press F2.
- Delete Entry: right-click rows or press Delete, then confirm.

### Copying Safely

- Right-click an entry row to copy Username/Password/URL/Old Password/Notes.
- If the clipboard clear timer is enabled, copied data is automatically cleared after N seconds.
- A small HUD toast displays “Copied. Will clear in Ns” or “Copied.” when timer is disabled.

### Keyboard Shortcuts

- Ctrl+N: Add Entry
- Ctrl+G: Edit Groups
- Ctrl+B: Backup
- Ctrl+R: Restore
- F2: Edit selected entry
- Delete: Delete selected entry

## Backup and Restore

- Backup creates an encrypted backup file; keep it in a safe location.
- Restore replaces current contents with the backup’s data after validation.
- Recommended:
  - Maintain multiple backups.
  - Verify backups periodically by restoring in a separate environment.

## Security Notes

- Offline-first: no automatic syncing or telemetry; everything stays local unless a manual backup is performed.
- Modern, authenticated encryption protects sensitive fields.
- Strong key derivation and header checks ensure data integrity and tamper resistance.
- Clipboard timer reduces the time secrets remain accessible to other apps.

## Best Practices

- Use unique, strong passwords for each account.
- Rotate passwords periodically; use the Expires field to track changes.
- Keep multiple encrypted backups in different secure locations.
- Never share the master password; it cannot be recovered if lost.
- Lock the OS session or close the app when stepping away from the computer.
- Keep the OS and Python environment up to date for security patches.

## Troubleshooting

- Invalid master password:
  - Check keyboard layout, caps lock, and try again.
- Clipboard not clearing:
  - Ensure the timer isn’t set to 0 (disabled) in File → Clipboard → Configure Clear Timer….
- Text readability:
  - The app uses accessible styles for light/dark themes. If a custom OS theme overrides defaults, consider adjusting system appearance for contrast.

## Contributing

- Bug reports, feature requests, and pull requests are welcome.
- Please discuss large changes via an issue first.

## License

MIT License

Copyright (c) 2025 Manikandan D

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

## Acknowledgements

- Thanks to the open-source ecosystem for libraries and inspiration that make secure, user-friendly tools possible.

## Project

Website: https://due.im/poottu/
Version: 1.0.0
Author: Manikandan D
