276 lines
10 KiB
Markdown
276 lines
10 KiB
Markdown
# Security Policy
|
|
|
|
## Supported Versions
|
|
|
|
| Version | Supported | Notes |
|
|
| ------- | ------------------ | ----- |
|
|
| 4.1.x | Current Version | |
|
|
| 4.x.x | ⚠️ Security fixes only | EOL Soon |
|
|
| 3.x.x | ❌ End of life | Upgrade recommended |
|
|
| 2.x.x | ❌ End of life | |
|
|
| 1.x.x | ❌ End of life | |
|
|
|
|
## Reporting a Vulnerability
|
|
|
|
**Please do not report security vulnerabilities through public GitHub issues.**
|
|
|
|
Instead, please email: **security@example.com** (replace with your email)
|
|
|
|
Include:
|
|
- Description of the vulnerability
|
|
- Steps to reproduce
|
|
- Potential impact
|
|
- Any suggested fixes
|
|
|
|
You should receive a response within 48 hours. We'll work with you to understand and address the issue.
|
|
|
|
---
|
|
|
|
# Threat Model
|
|
|
|
## What Stegasoo Protects
|
|
|
|
Stegasoo is designed to hide the **existence** of a secret message within an ordinary-looking image, protected by multi-factor authentication.
|
|
|
|
### Protection Goals
|
|
|
|
| Goal | How It's Achieved |
|
|
|------|-------------------|
|
|
| **Confidentiality** | AES-256-GCM encryption with Argon2id key derivation |
|
|
| **Steganography** | LSB/DCT embedding with pseudo-random pixel/coefficient selection |
|
|
| **Authentication** | Multi-factor: reference photo + passphrase + PIN (or RSA key) |
|
|
| **Integrity** | GCM authentication tag detects tampering |
|
|
|
|
### Security Factors
|
|
|
|
Stegasoo combines multiple authentication factors:
|
|
|
|
```
|
|
┌─────────────────────────────────────────────────────────────────┐
|
|
│ Key Derivation │
|
|
│ │
|
|
│ Reference Photo ───────┐ │
|
|
│ (something you have) │ │
|
|
│ ├──► Argon2id ──► AES-256 Key │
|
|
│ Passphrase ────────────┤ (256MB RAM) │
|
|
│ (something you know) │ │
|
|
│ │ │
|
|
│ PIN or RSA Key ────────┘ │
|
|
│ (second factor) │
|
|
└─────────────────────────────────────────────────────────────────┘
|
|
```
|
|
|
|
## Changes in v4.0
|
|
|
|
### Removed: Date-Based Key Rotation
|
|
|
|
**Previous versions (v3.x and earlier):**
|
|
- Required a date parameter for encode/decode
|
|
- Keys rotated daily based on "day phrase"
|
|
- Users had to remember which date they used
|
|
|
|
**Version 4.0:**
|
|
- No date dependency
|
|
- Single passphrase (no rotation)
|
|
- Simpler but slightly reduced entropy per-message
|
|
|
|
**Security Impact:**
|
|
- Minimal - the date only added ~10 bits of entropy
|
|
- Passphrase default increased from 3 to 4 words to compensate (+11 bits)
|
|
- Overall entropy remains similar or higher with 4-word default
|
|
|
|
### Renamed: day_phrase → passphrase
|
|
|
|
Terminology change only. No security impact.
|
|
|
|
## What Stegasoo Does NOT Protect Against
|
|
|
|
### 1. Statistical Steganalysis
|
|
|
|
**Risk:** Advanced analysis can detect that an image contains hidden data.
|
|
|
|
**Reality:** LSB steganography is detectable by:
|
|
- Chi-square analysis
|
|
- RS analysis
|
|
- Machine learning classifiers
|
|
|
|
**DCT mode is more resilient** but not undetectable.
|
|
|
|
**Mitigation:** Stegasoo uses pseudo-random pixel/coefficient selection, which helps but doesn't eliminate detectability.
|
|
|
|
**Recommendation:** Don't rely on Stegasoo if your adversary has:
|
|
- Access to the original carrier image
|
|
- Sophisticated forensic tools
|
|
- Motivation to analyze your specific images
|
|
|
|
### 2. Compromised Endpoints
|
|
|
|
**Risk:** If your device is compromised, the attacker can capture credentials.
|
|
|
|
**Not protected:**
|
|
- Keyloggers capturing your PIN/passphrase
|
|
- Screen capture of decoded messages
|
|
- Memory scraping during encode/decode
|
|
- Malware on sender or receiver device
|
|
|
|
**Recommendation:** Use on trusted devices only.
|
|
|
|
### 3. Reference Photo Exposure
|
|
|
|
**Risk:** The reference photo is a critical secret.
|
|
|
|
**If leaked:** Attacker only needs to guess/brute-force the passphrase + PIN.
|
|
|
|
**Recommendation:**
|
|
- Never share the reference photo
|
|
- Use a unique photo (not posted online)
|
|
- Store securely (encrypted drive, password manager)
|
|
|
|
### 4. Weak Credentials
|
|
|
|
**Risk:** Short PINs or common passphrases can be brute-forced.
|
|
|
|
| PIN Length | Combinations | Time to Brute Force* |
|
|
|------------|--------------|----------------------|
|
|
| 4 digits | 10,000 | Seconds |
|
|
| 6 digits | 1,000,000 | Minutes |
|
|
| 8 digits | 100,000,000 | Hours |
|
|
| 9 digits | 1,000,000,000| Days |
|
|
|
|
*With Argon2 (256MB RAM, 4 iterations), each attempt takes ~1 second, making brute force slow but not impossible for short PINs.
|
|
|
|
**Recommendation:**
|
|
- Use 8+ digit PINs
|
|
- Use 4+ word passphrases (v4.0 default)
|
|
- Consider RSA keys for high-security use cases
|
|
|
|
### 5. Image Modification
|
|
|
|
**Risk:** Lossy compression destroys hidden data.
|
|
|
|
**LSB mode - data is destroyed by:**
|
|
- JPEG compression
|
|
- Resizing
|
|
- Filters/effects
|
|
- Screenshots
|
|
- Social media upload
|
|
|
|
**DCT mode - more resilient but not immune:**
|
|
- Survives moderate JPEG recompression
|
|
- May fail with aggressive compression (quality < 70)
|
|
- Still destroyed by resizing, filters, screenshots
|
|
|
|
**Recommendation:**
|
|
- LSB: Always use lossless formats (PNG, BMP), direct transfer
|
|
- DCT: Use for social media, but test with your specific platform
|
|
|
|
### 6. Metadata Leakage
|
|
|
|
**Risk:** The stego image itself may reveal information.
|
|
|
|
**Potential leaks:**
|
|
- File creation timestamp
|
|
- Camera EXIF data (if carrier has it)
|
|
- File size changes
|
|
|
|
**Mitigation:** Stegasoo strips EXIF on output, but timestamps remain.
|
|
|
|
### 7. Traffic Analysis
|
|
|
|
**Risk:** The act of sending an image may be suspicious.
|
|
|
|
**Not protected:**
|
|
- Network observers seeing you send image files
|
|
- Email metadata showing sender/receiver
|
|
- Frequency analysis of communications
|
|
|
|
**Recommendation:** Use alongside normal image-sharing behavior.
|
|
|
|
## Cryptographic Details
|
|
|
|
### Encryption
|
|
|
|
| Component | Algorithm | Parameters |
|
|
|-----------|-----------|------------|
|
|
| Key Derivation | Argon2id | 256MB RAM, 4 iterations, 4 parallelism |
|
|
| Fallback KDF | PBKDF2-SHA256 | 600,000 iterations |
|
|
| Encryption | AES-256-GCM | 12-byte IV, 16-byte tag |
|
|
| Photo Hash | SHA-256 | Full image bytes |
|
|
|
|
### Pixel/Coefficient Selection
|
|
|
|
Selection key is derived from:
|
|
```
|
|
selection_key = SHA256(photo_hash || passphrase || pin/rsa_signature)
|
|
```
|
|
|
|
This prevents:
|
|
- Sequential embedding patterns
|
|
- Statistical detection of modified regions
|
|
|
|
### Message Format (v4.0)
|
|
|
|
```
|
|
┌──────────────────────────────────────────────────────────────────┐
|
|
│ Magic (4B) │ Version (1B) │ Salt (32B) │ IV (12B) │
|
|
├──────────────────────────────────────────────────────────────────┤
|
|
│ Encrypted Payload (AES-256-GCM) │
|
|
│ ├── Type (1B): 0x01=text, 0x02=file │
|
|
│ ├── Length (4B) │
|
|
│ ├── Data (variable) │
|
|
│ └── [Filename if file] (variable) │
|
|
├──────────────────────────────────────────────────────────────────┤
|
|
│ GCM Auth Tag (16B) │
|
|
└──────────────────────────────────────────────────────────────────┘
|
|
```
|
|
|
|
**Note:** v4.0 removed the date field from the header, reducing overhead by 10 bytes.
|
|
|
|
## Best Practices
|
|
|
|
### For Maximum Security
|
|
|
|
1. **Use RSA keys** instead of PINs for authentication
|
|
2. **Use unique reference photos** not available online
|
|
3. **Use long passphrases** (4+ random words, recommend 6+)
|
|
4. **Transfer via secure channels** (Signal, encrypted email)
|
|
5. **Delete stego images** after message is read
|
|
6. **Keep software updated** for security fixes
|
|
7. **Use DCT mode** for social media sharing
|
|
|
|
### For Casual Privacy
|
|
|
|
1. **6-digit PIN** is sufficient for non-adversarial use
|
|
2. **4-word passphrase** provides reasonable security (v4.0 default)
|
|
3. **PNG format** for LSB mode output
|
|
4. **Direct file transfer** (email attachment, AirDrop)
|
|
|
|
## Known Limitations
|
|
|
|
| Limitation | Impact | Status |
|
|
|------------|--------|--------|
|
|
| LSB is detectable | Statistical analysis can detect hidden data | By design (tradeoff for capacity) |
|
|
| No forward secrecy | Compromised key decrypts all messages | Use different keys per message for high security |
|
|
| No deniability | Single password = single message | Future: plausible deniability layers |
|
|
| Python 3.13 incompatible | jpegio C extension crashes | Use Python 3.12 or earlier |
|
|
|
|
## Security Audit Status
|
|
|
|
This software has **not** been professionally audited. Use at your own risk for sensitive applications.
|
|
|
|
If you're a security researcher interested in auditing Stegasoo, please reach out.
|
|
|
|
---
|
|
|
|
## Version History (Security Relevant)
|
|
|
|
| Version | Security Changes |
|
|
|---------|------------------|
|
|
| 4.0.0 | Removed date dependency, increased default passphrase to 4 words, added JPEG normalization |
|
|
| 3.2.0 | DCT color mode added |
|
|
| 3.0.0 | Added DCT steganography mode |
|
|
| 2.2.0 | Added compression (no security impact) |
|
|
| 2.1.0 | Upgraded to Argon2id, increased iterations |
|
|
| 2.0.0 | Added RSA key support |
|
|
| 1.0.0 | Initial release |
|