mirror of
https://github.com/DeNNiiInc/Advanced-Smtp-Tester.git
synced 2026-04-18 01:45:58 +00:00
docs: Add comprehensive README with screenshots and documentation
This commit is contained in:
423
README.md
423
README.md
@@ -1,2 +1,421 @@
|
|||||||
# Advanced-Smtp-Tester
|
# Advanced SMTP Tester
|
||||||
Advanced Smtp Tester
|
|
||||||
|

|
||||||
|
|
||||||
|
[](https://www.gnu.org/licenses/gpl-3.0)
|
||||||
|
[](https://nodejs.org/)
|
||||||
|
[](https://github.com/DeNNiiInc/Advanced-Smtp-Tester)
|
||||||
|
|
||||||
|
A professional, feature-rich SMTP testing utility with a modern web interface. Test your email server configurations, troubleshoot delivery issues, and discover optimal SMTP settings automatically.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 📋 Table of Contents
|
||||||
|
|
||||||
|
- [Features](#-features)
|
||||||
|
- [Screenshots](#-screenshots)
|
||||||
|
- [Installation](#-installation)
|
||||||
|
- [Usage](#-usage)
|
||||||
|
- [Configuration Examples](#-configuration-examples)
|
||||||
|
- [API Endpoints](#-api-endpoints)
|
||||||
|
- [Security Notes](#-security-notes)
|
||||||
|
- [Troubleshooting](#-troubleshooting)
|
||||||
|
- [Contributing](#-contributing)
|
||||||
|
- [License](#-license)
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## ✨ Features
|
||||||
|
|
||||||
|
### 🔐 Comprehensive SMTP Support
|
||||||
|
- **Multiple Encryption Methods**: STARTTLS, SSL/TLS, and unencrypted connections
|
||||||
|
- **Common Ports**: Pre-configured support for ports 587, 465, 25, and 2525
|
||||||
|
- **Custom Configurations**: Flexible settings for any SMTP server
|
||||||
|
|
||||||
|
### 🔍 Auto-Discovery Testing
|
||||||
|
- Automatically tests multiple SMTP configurations
|
||||||
|
- Intelligently tries common port and encryption combinations
|
||||||
|
- Reports all successful configurations
|
||||||
|
- Sends test emails for each working setup
|
||||||
|
|
||||||
|
### 📧 Email Testing
|
||||||
|
- Sends styled HTML test emails
|
||||||
|
- Includes configuration details in email body
|
||||||
|
- Password included for verification (configurable)
|
||||||
|
- From/To address customization
|
||||||
|
|
||||||
|
### 🎨 Modern User Interface
|
||||||
|
- Clean, intuitive design
|
||||||
|
- Responsive layout for all devices
|
||||||
|
- Real-time status updates
|
||||||
|
- Animated background effects
|
||||||
|
- Dark theme optimized for extended use
|
||||||
|
|
||||||
|
### 🛡️ Security Features
|
||||||
|
- Password visibility toggle
|
||||||
|
- Secure encryption options
|
||||||
|
- Warning notifications for sensitive data
|
||||||
|
- No credential storage
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## <20> How It Works
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
The SMTP testing process is simple and straightforward:
|
||||||
|
|
||||||
|
1. **Enter Credentials** - Provide your SMTP server details and authentication
|
||||||
|
2. **Connect to Server** - Application establishes secure connection to SMTP server
|
||||||
|
3. **Send Test Email** - Formatted test email is sent through the configured server
|
||||||
|
4. **View Results** - Detailed success/failure information displayed in real-time
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## <20>📸 Screenshots
|
||||||
|
|
||||||
|
### Main Interface
|
||||||
|

|
||||||
|
*Clean, modern interface for SMTP configuration*
|
||||||
|
|
||||||
|
### Form Example
|
||||||
|

|
||||||
|
*Example configuration with Gmail SMTP settings*
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 🚀 Installation
|
||||||
|
|
||||||
|
### Prerequisites
|
||||||
|
- **Node.js** (v14.0.0 or higher)
|
||||||
|
- **npm** (comes with Node.js)
|
||||||
|
|
||||||
|
### Quick Start
|
||||||
|
|
||||||
|
1. **Clone the repository**
|
||||||
|
```bash
|
||||||
|
git clone https://github.com/DeNNiiInc/Advanced-Smtp-Tester.git
|
||||||
|
cd Advanced-Smtp-Tester
|
||||||
|
```
|
||||||
|
|
||||||
|
2. **Install dependencies**
|
||||||
|
```bash
|
||||||
|
npm install
|
||||||
|
```
|
||||||
|
|
||||||
|
3. **Start the server**
|
||||||
|
```bash
|
||||||
|
npm start
|
||||||
|
```
|
||||||
|
|
||||||
|
4. **Open in browser**
|
||||||
|
```
|
||||||
|
http://localhost:3000
|
||||||
|
```
|
||||||
|
|
||||||
|
The application will be running on port 3000 by default.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 📖 Usage
|
||||||
|
|
||||||
|
### Manual Configuration Test
|
||||||
|
|
||||||
|
1. **Enter SMTP Server Details**
|
||||||
|
- **Host**: Your SMTP server address (e.g., `smtp.gmail.com`)
|
||||||
|
- **Port**: SMTP port number (e.g., `587` for STARTTLS)
|
||||||
|
- **Encryption**: Choose appropriate encryption method
|
||||||
|
- STARTTLS (587/25) - Most common for modern servers
|
||||||
|
- SSL/TLS (465) - Legacy secure connection
|
||||||
|
- Unencrypted - Not recommended for production
|
||||||
|
|
||||||
|
2. **Provide Authentication**
|
||||||
|
- **Username/Email**: Your email address or username
|
||||||
|
- **Password**: Account password or app-specific password
|
||||||
|
|
||||||
|
3. **Configure Email Details**
|
||||||
|
- **From Address** (Optional): Defaults to username if not specified
|
||||||
|
- **To Address**: Recipient email for the test
|
||||||
|
|
||||||
|
4. **Run Test**
|
||||||
|
- Click **"Test Configuration & Send Email"**
|
||||||
|
- Wait for results (typically 5-15 seconds)
|
||||||
|
- Check the results panel for success or error messages
|
||||||
|
|
||||||
|
### Auto-Discovery Test
|
||||||
|
|
||||||
|
For when you're not sure which configuration to use:
|
||||||
|
|
||||||
|
1. **Enter Basic Details**
|
||||||
|
- SMTP Host
|
||||||
|
- Username/Password
|
||||||
|
- To Address
|
||||||
|
|
||||||
|
2. **Click "🔍 Auto Discovery Test"**
|
||||||
|
|
||||||
|
3. **Review Results**
|
||||||
|
- The tool will test multiple port/encryption combinations
|
||||||
|
- Successful configurations will send test emails
|
||||||
|
- All working setups will be reported
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 🔧 Configuration Examples
|
||||||
|
|
||||||
|

|
||||||
|
*Quick reference for popular email providers*
|
||||||
|
|
||||||
|
### Gmail
|
||||||
|
|
||||||
|
```
|
||||||
|
Host: smtp.gmail.com
|
||||||
|
Port: 587
|
||||||
|
Encryption: STARTTLS (587/25)
|
||||||
|
Username: your-email@gmail.com
|
||||||
|
Password: your-app-password
|
||||||
|
```
|
||||||
|
|
||||||
|
> **Note**: Gmail requires [App Passwords](https://support.google.com/accounts/answer/185833) when 2FA is enabled.
|
||||||
|
|
||||||
|
### Outlook/Office 365
|
||||||
|
|
||||||
|
```
|
||||||
|
Host: smtp.office365.com
|
||||||
|
Port: 587
|
||||||
|
Encryption: STARTTLS (587/25)
|
||||||
|
Username: your-email@outlook.com
|
||||||
|
Password: your-password
|
||||||
|
```
|
||||||
|
|
||||||
|
### Yahoo Mail
|
||||||
|
|
||||||
|
```
|
||||||
|
Host: smtp.mail.yahoo.com
|
||||||
|
Port: 587
|
||||||
|
Encryption: STARTTLS (587/25)
|
||||||
|
Username: your-email@yahoo.com
|
||||||
|
Password: your-app-password
|
||||||
|
```
|
||||||
|
|
||||||
|
### Custom SMTP Server
|
||||||
|
|
||||||
|
```
|
||||||
|
Host: mail.yourdomain.com
|
||||||
|
Port: 587 (or 465, 25, 2525)
|
||||||
|
Encryption: Based on your server config
|
||||||
|
Username: user@yourdomain.com
|
||||||
|
Password: your-password
|
||||||
|
```
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 🔌 API Endpoints
|
||||||
|
|
||||||
|
### POST `/api/test-smtp`
|
||||||
|
|
||||||
|
Test a specific SMTP configuration and send an email.
|
||||||
|
|
||||||
|
**Request Body:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"host": "smtp.gmail.com",
|
||||||
|
"port": 587,
|
||||||
|
"secure": "false",
|
||||||
|
"user": "your-email@gmail.com",
|
||||||
|
"pass": "your-password",
|
||||||
|
"from": "sender@example.com",
|
||||||
|
"to": "recipient@example.com"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**Response:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"success": true,
|
||||||
|
"message": "Email sent successfully!",
|
||||||
|
"info": {
|
||||||
|
"accepted": ["recipient@example.com"],
|
||||||
|
"messageId": "<message-id>"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### POST `/api/auto-test-smtp`
|
||||||
|
|
||||||
|
Automatically test multiple SMTP configurations.
|
||||||
|
|
||||||
|
**Request Body:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"host": "smtp.gmail.com",
|
||||||
|
"user": "your-email@gmail.com",
|
||||||
|
"pass": "your-password",
|
||||||
|
"to": "recipient@example.com"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**Response:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"success": true,
|
||||||
|
"results": [
|
||||||
|
{
|
||||||
|
"port": 587,
|
||||||
|
"secure": "false",
|
||||||
|
"status": "success",
|
||||||
|
"message": "Email sent successfully!"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 🔒 Security Notes
|
||||||
|
|
||||||
|
> [!WARNING]
|
||||||
|
> **Password Transmission**
|
||||||
|
> By default, the test email includes the password used for testing in the email body. This is intentional for verification purposes but should be used carefully.
|
||||||
|
|
||||||
|
### Best Practices
|
||||||
|
|
||||||
|
1. **Use App-Specific Passwords**
|
||||||
|
- Don't use your main account password
|
||||||
|
- Create dedicated app passwords for testing
|
||||||
|
|
||||||
|
2. **Avoid Public Networks**
|
||||||
|
- Don't test on public WiFi
|
||||||
|
- Use VPN when possible
|
||||||
|
|
||||||
|
3. **Delete Test Emails**
|
||||||
|
- Remove test emails containing passwords
|
||||||
|
- Clear sent items after testing
|
||||||
|
|
||||||
|
4. **Local Hosting Only**
|
||||||
|
- By default, runs on localhost only
|
||||||
|
- Do not expose to the internet without proper security
|
||||||
|
|
||||||
|
5. **HTTPS in Production**
|
||||||
|
- Use reverse proxy (nginx, Apache) for HTTPS
|
||||||
|
- Never send credentials over unencrypted connections
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 🐛 Troubleshooting
|
||||||
|
|
||||||
|
### Common Issues
|
||||||
|
|
||||||
|
#### "Connection timeout" or "ETIMEDOUT"
|
||||||
|
- **Cause**: Firewall blocking SMTP ports
|
||||||
|
- **Solution**:
|
||||||
|
- Check firewall settings
|
||||||
|
- Try different ports (587, 465, 25)
|
||||||
|
- Contact your hosting provider
|
||||||
|
|
||||||
|
#### "Invalid login" or "Authentication failed"
|
||||||
|
- **Cause**: Incorrect credentials or security settings
|
||||||
|
- **Solution**:
|
||||||
|
- Verify username and password
|
||||||
|
- Use app-specific passwords
|
||||||
|
- Enable "Less secure apps" (not recommended)
|
||||||
|
- Check for 2FA requirements
|
||||||
|
|
||||||
|
#### "Self-signed certificate" errors
|
||||||
|
- **Cause**: Server using self-signed SSL certificate
|
||||||
|
- **Solution**:
|
||||||
|
- Try unencrypted connection for testing
|
||||||
|
- Update to use proper SSL certificates
|
||||||
|
|
||||||
|
#### Gmail "Username and Password not accepted"
|
||||||
|
- **Cause**: Gmail security blocks
|
||||||
|
- **Solution**:
|
||||||
|
- Enable 2-Step Verification
|
||||||
|
- Create App Password
|
||||||
|
- Use the App Password instead of account password
|
||||||
|
|
||||||
|
### Debug Mode
|
||||||
|
|
||||||
|
Check the browser console (F12) for detailed error messages. Server logs will show in the terminal where you ran `npm start`.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 🤝 Contributing
|
||||||
|
|
||||||
|
Contributions are welcome! Please follow these guidelines:
|
||||||
|
|
||||||
|
1. **Fork the repository**
|
||||||
|
2. **Create a feature branch**
|
||||||
|
```bash
|
||||||
|
git checkout -b feature/your-feature-name
|
||||||
|
```
|
||||||
|
3. **Commit your changes**
|
||||||
|
```bash
|
||||||
|
git commit -m "Add your feature description"
|
||||||
|
```
|
||||||
|
4. **Push to your branch**
|
||||||
|
```bash
|
||||||
|
git push origin feature/your-feature-name
|
||||||
|
```
|
||||||
|
5. **Open a Pull Request**
|
||||||
|
|
||||||
|
### Development Setup
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# Install dependencies
|
||||||
|
npm install
|
||||||
|
|
||||||
|
# Start development server
|
||||||
|
npm start
|
||||||
|
|
||||||
|
# The server runs with auto-reload enabled
|
||||||
|
```
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 📄 License
|
||||||
|
|
||||||
|
This project is licensed under the **GNU General Public License v3.0**.
|
||||||
|
|
||||||
|
```
|
||||||
|
Advanced SMTP Tester - Professional Email Configuration Testing
|
||||||
|
Copyright (C) 2025 Beyond Cloud Technology
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
```
|
||||||
|
|
||||||
|
See the [LICENSE](LICENSE) file for full details.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 🙏 Acknowledgments
|
||||||
|
|
||||||
|
- Built with [Node.js](https://nodejs.org/)
|
||||||
|
- Email functionality powered by [Nodemailer](https://nodemailer.com/)
|
||||||
|
- UI inspired by modern web design principles
|
||||||
|
- Developed by [Beyond Cloud Technology](https://github.com/DeNNiiInc)
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 📞 Support
|
||||||
|
|
||||||
|
- **Issues**: [GitHub Issues](https://github.com/DeNNiiInc/Advanced-Smtp-Tester/issues)
|
||||||
|
- **YouTube**: [@beyondcloudtechnology](https://www.youtube.com/@beyondcloudtechnology)
|
||||||
|
- **GitHub**: [@DeNNiiInc](https://github.com/DeNNiiInc)
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
<div align="center">
|
||||||
|
|
||||||
|
**Made with ❤️ by Beyond Cloud Technology**
|
||||||
|
|
||||||
|
[⭐ Star this repo](https://github.com/DeNNiiInc/Advanced-Smtp-Tester) | [🐛 Report Bug](https://github.com/DeNNiiInc/Advanced-Smtp-Tester/issues) | [✨ Request Feature](https://github.com/DeNNiiInc/Advanced-Smtp-Tester/issues)
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|||||||
BIN
docs/filled_form_example.png
Normal file
BIN
docs/filled_form_example.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 327 KiB |
BIN
docs/quick_reference.png
Normal file
BIN
docs/quick_reference.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 482 KiB |
BIN
docs/readme_banner.png
Normal file
BIN
docs/readme_banner.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 532 KiB |
BIN
docs/smtp_tester_interface.png
Normal file
BIN
docs/smtp_tester_interface.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 28 KiB |
BIN
docs/workflow_diagram.png
Normal file
BIN
docs/workflow_diagram.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 550 KiB |
Reference in New Issue
Block a user