👉 Beginner’s Guide – UI Deployment
![]() | ![]() |
|---|---|
![]() | ![]() |
![]() | ![]() |
![]() | ![]() |
💻 Responsive Design: Automatically adapts to both desktop and most mobile browsers.
📧 Email Sending: Integrated with Resend for bulk email sending, embedded images, attachments, and status tracking.
🛡️ Admin Features: Admins can manage users and emails, with RBAC permission control to limit access to features and resources.
🔀 Multiple Accounts: Users can add multiple email accounts.
📦 Attachment Support: Send and receive attachments, stored and downloaded via R2 object storage.
🔔 Email Push: Forward received emails to Telegram bots or other email providers.
📈 Data Visualization: Use Echarts to visualize system data, including user email growth.
⭐ Starred Emails: Mark important emails for quick access.
🎨 Personalization: Customize website title, login background, and transparency.
⚙️ Feature Settings: Toggle on or off features like registration, email sending, and more, with the option to make the site private.
🤖 CAPTCHA: Integrated with Turnstile CAPTCHA to prevent automated registration.
📜 More Features: Under development...
Framework: Vue3 + Element Plus
Web Framework: Hono
ORM: Drizzle
Platform: Cloudflare Workers
Email Service: Resend
Caching: Cloudflare KV
Database: Cloudflare D1
File Storage: Cloudflare R2
Nodejs v18.20 +
Cloudflare account (with a bound domain)
Clone the project to your local machine:
git clone https://github.com/eoao/cloud-mail cd cloud-mail/mail-worker
Install Dependencies:
npm i
Configure the Project
mail-worker/wrangler.toml
[[d1_databases]]
binding = "db" # Default binding name for D1 database, cannot be changed
database_name = "" # Database name
database_id = "" # Database ID
[[kv_namespaces]]
binding = "kv" # Default binding name for KV storage, cannot be changed
id = "" # KV namespace ID
[[r2_buckets]]
binding = "r2" # Default binding name for R2 storage, cannot be changed
bucket_name = "" # R2 bucket name
[assets]
binding = "assets" # Static asset binding name, cannot be changed
directory = "./dist" # Directory for frontend Vue project build, default: dist
[vars]
orm_log = false
domain = [] # Configure email domains, example: ["example1.com", "example2.com"]
admin = "" # Admin email, example: "admin@example.com"
jwt_secret = "" # JWT secret for login tokens, choose a random string
Deploy Remotely
Create KV, D1 database, and R2 object storage in Cloudflare Console.
In the project directory mail-worker/wrangler.toml, configure the environment variables and database IDs/names.
Run the deployment command:
npm run deploy
In Cloudflare → Account Home → Your Domain → Email → Email Routing → Route Rules → Catch-all Address, edit and route to the worker.
In your browser, visit https://your-project-domain/api/init/your-jwt-secret to initialize or update the D1 and KV databases.
After deployment, log in to the site with the admin account to configure R2 domains, Turnstile keys, and more.
Run Locally
Run locally. Databases and object storage will automatically be set up, no manual creation needed. Data is stored in the mail-worker/.wrangler folder.
npm run dev
In your browser, visit http://127.0.0.1:8787/api/init/your-jwt-secret to initialize D1 and KV databases.
For local testing, you can set the R2 domain to http://127.0.0.1:8787/api/file.
Email Sending
Register on Resend, then click on “Domains” to add and verify your domain. Wait for verification.
Go to "API Keys" to create an API key, then copy the token and paste it in the project website settings.
Go to "Webhooks" and add a callback URL https://your-project-domain/api/webhooks.
Select the following events: ✅ (email.bounced, email.complained, email.delivered, email.delivery_delayed).
Project Update
After the update, run https://your-project-domain/api/init/your-jwt-secret to synchronize the database schema.
Buy me a cup of milk tea
Special Sponsors
DartNode:Providing cloud computing service resource support
This project is licensed under the MIT license.