## SMC + Trend Breakout (MTF) for Exness MT5 This repo contains: - `mt5/MQL5/Indicators/SMC_TrendBreakout_MTF.mq5`: visual indicator (BOS/CHoCH + Donchian breakout + lower-timeframe confirmation). - `mt5/MQL5/Experts/SMC_TrendBreakout_MTF_EA.mq5`: Expert Advisor (alerts + optional auto-trading). ### ☁️ Cloud Deployment **Deploy to cloud platforms:** - **Render.com**: Auto-deploy with `render.yaml` - **Railway.app**: Deploy with `railway.json` - **Fly.io**: Deploy with `fly.toml` - **Docker**: Build and deploy anywhere **Quick Deploy:** ```bash # Setup all platform configs python scripts/deploy_cloud.py all # Deploy to specific platform python scripts/deploy_cloud.py render python scripts/deploy_cloud.py railway python scripts/deploy_cloud.py flyio python scripts/deploy_cloud.py docker --build ``` **🐳 Docker Hub Deployment:** 1. **Publish Image** (Run locally): ```bash ./scripts/deploy_docker_hub.sh ``` 2. **Run on VPS/Laptop**: ```bash # Update and run ./scripts/update_vps.sh ``` πŸ“– **For detailed cloud deployment instructions, see [Cloud Deployment Guide](docs/Cloud_Deployment_Guide.md)** ### Render workspace My Blue watermelon Workspace tea-d1joqqi4d50c738aiujg ### Install into Exness MetaTrader 5 > **⚠️ Note:** Custom Indicators and EAs are **not supported** on the Exness Web Terminal. You must use the **Desktop** version of MT5. **πŸ“– For detailed deployment instructions, see [Exness Deployment Guide](docs/Exness_Deployment_Guide.md)** Quick start: 1. Open **Exness MT5**. 2. Go to **File β†’ Open Data Folder**. 3. Copy: - `SMC_TrendBreakout_MTF.mq5` to `MQL5/Indicators/` - `SMC_TrendBreakout_MTF_EA.mq5` to `MQL5/Experts/` 4. In MT5, open **MetaEditor** (or press **F4**) and compile the files. 5. Back in MT5: **Navigator β†’ Refresh**. ### πŸš€ Automated Startup (NEW!) **Quick Start:** - **Windows**: `powershell -ExecutionPolicy Bypass -File scripts\startup.ps1` - **Ubuntu/VPS**: ```bash # First time setup (installs Python, Wine, etc.) bash scripts/setup_ubuntu.sh # Start the system ./scripts/startup.sh ``` - **Linux/WSL**: `./scripts/startup.sh` **Auto-Start on Boot:** - **Windows**: `powershell -ExecutionPolicy Bypass -File scripts\startup.ps1 -CreateScheduledTask` - **Linux**: `./scripts/startup.sh --setup-systemd` πŸ“š **Documentation**: - [**Full Documentation Index**](docs/INDEX.md) - πŸ‘ˆ Start here for all guides - [**Setup & Deployment (Comprehensive)**](docs/SETUP_AND_DEPLOY.md) - πŸ› οΈ Start here for manual setup & GCP - [WSL & VPS Guide](docs/WSL_AND_VPS_DEPLOYMENT.md) - Windows/Linux setup guide - [Quick Reference Guide](QUICK_REFERENCE.md) - Command cheat sheet - [Verification Report](VERIFICATION.md) - System status and test results - [Startup Automation Guide](docs/Startup_Automation_Guide.md) - Complete guide - [Quick Start](docs/Quick_Start_Automation.md) - Quick start instructions The automation system handles: - MT5 Terminal startup - Python scripts execution - Scheduled tasks configuration - Process monitoring and logging - Windows Task Scheduler integration - Linux systemd/cron integration ### Optional: package / deploy helpers - Create a zip you can copy to your PC: - `bash scripts/package_mt5.sh` β†’ outputs `dist/Exness_MT5_MQL5.zip` - Copy directly into your MT5 Data Folder (run this on the machine that has MT5 installed): - `bash scripts/deploy_mt5.sh "/path/from/MT5/File->Open Data Folder"` ### GitHub automation (reviews, CI, auto-merge, OneDrive sync) This repo includes GitHub Actions workflows under `.github/workflows/`: - **CI (`CI`)**: runs on pull requests and pushes to `main/master` - Validates repo structure - Builds `dist/Exness_MT5_MQL5.zip` and uploads it as an artifact - **Auto-merge enablement (`Enable auto-merge (label-driven)`)**: if a PR has the label **`automerge`**, it will enable GitHub’s auto-merge (squash). Your branch protection rules still control *when* it can merge (required reviews, required CI, etc.). - **OneDrive sync (`Sync to OneDrive (rclone)`)**: on pushes to `main` (and manual runs), syncs `mt5/MQL5` to OneDrive via `rclone`. Recommended repo settings (GitHub β†’ **Settings**): - **Branch protection (main)**: - Require pull request reviews (at least 1) - Require status checks: `CI / validate-and-package` - (Optional) Require CODEOWNERS review - **Auto-merge**: enable β€œAllow auto-merge” in repo settings OneDrive sync setup (required secrets): - **`RCLONE_CONFIG_B64`**: base64 of your `rclone.conf` containing a OneDrive remote. Example (run locally, then paste into GitHub Secrets): ```bash rclone config base64 -w0 ~/.config/rclone/rclone.conf ``` Optional secrets: - **`ONEDRIVE_REMOTE`**: remote name in `rclone.conf` (default: `onedrive`) - **`ONEDRIVE_PATH`**: destination folder path (default: `Apps/MT5/MQL5`) Firefox Relay API key (optional secrets): - **`SCRSOR`** - **`COPILOT`** Set both to your Firefox Relay profile API key (`https://relay.firefox.com/accounts/profile/`). Store these as GitHub Secrets or in a local `.env` file (see `.env.example`). Do not commit secret values. Cloudflare Configuration (required for domain registration/management): - **`CLOUDFLARE_ZONE_ID`**: Your Cloudflare Zone ID. - **`CLOUDFLARE_ACCOUNT_ID`**: Your Cloudflare Account ID. - **`DOMAIN_NAME`**: Your domain name (e.g., `Lengkundee01.org`). Store these as GitHub Secrets or in a local `.env` file. See [Secrets Management Guide](docs/Secrets_Management.md) for more details. You can use the helper script to set these secrets if you have the GitHub CLI installed: ```bash # First, update config/vault.json with your credentials # Then run: bash scripts/set_github_secrets.sh vault ``` ### Use the indicator - Attach `SMC_TrendBreakout_MTF` to a chart (your main timeframe). - Set **LowerTF** to a smaller timeframe (ex: main = M15, lower = M5 or M1). - Signals require lower-TF confirmation by default (EMA fast/slow direction). ### Use the EA (push to terminal + optional auto trading) - Attach `SMC_TrendBreakout_MTF_EA` to a chart. - Enable **Algo Trading** in MT5 if you want auto entries. - If you want phone push alerts: - MT5 β†’ **Tools β†’ Options β†’ Notifications** - enable push notifications and set your MetaQuotes ID. - For web request integrations (ZOLO-A6-9V-NUNA- plugin): - Enable `EnableWebRequest` parameter - Add `http://203.147.134.90` to MT5's allowed URLs list: - MT5 β†’ **Tools β†’ Options β†’ Expert Advisors** - Check "Allow WebRequest for listed URL" - Add the URL: `http://203.147.134.90` ### πŸ€– AI Integration (Gemini & Jules) The EA supports **Google Gemini** and **Jules AI** to confirm trades before entry. **Setup:** 1. **Get an API Key**: * Gemini: [Google AI Studio](https://aistudio.google.com/) * Jules: Your Jules API Dashboard 2. **Configure MT5**: * Go to **Tools β†’ Options β†’ Expert Advisors**. * Check **"Allow WebRequest for listed URL"**. * Add the URLs: * `https://generativelanguage.googleapis.com` (for Gemini) * Your Jules API URL (e.g., `https://api.jules.ai` or similar) 3. **Configure the EA**: * Set `UseGeminiFilter` to `true` (Enable AI). * Select `AiProvider`: `PROVIDER_GEMINI` or `PROVIDER_JULES`. * Paste your API Key into `GeminiApiKey` or `JulesApiKey`. **Shared/Default Keys:** * **Gemini**: `[INSERT_GEMINI_API_KEY]` * **Jules**: `[INSERT_JULES_API_KEY]` ### 🧠 AI Market Research & Upgrade Automation (New!) Automate market analysis and code upgrades using Gemini and Jules. **Setup:** 1. Run the setup script: ```bash ./scripts/setup_research.sh ``` 2. Add your API keys to the `.env` file generated: ``` GEMINI_API_KEY=... JULES_API_KEY=... JULES_API_URL=... ``` **Features:** - **Market Research**: Fetches real market data (via `yfinance`) and generates a report (`docs/market_research_report.md`). - **Code Upgrades**: Suggests EA improvements based on the research (`docs/upgrade_suggestions.md`). - **Scheduling**: Runs automatically every 4 hours via `scripts/schedule_research.py`. ### Auto SL/TP + risk management (EA) In `SMC_TrendBreakout_MTF_EA`: - **SLMode** - `SL_ATR`: SL = ATR Γ— `ATR_SL_Mult` - `SL_SWING`: SL beyond last confirmed fractal swing (with `SwingSLBufferPoints`), fallback to ATR if swing is missing/invalid - `SL_FIXED_POINTS`: SL = `FixedSLPoints` - **TPMode** - `TP_RR`: TP = `RR` Γ— SL distance - `TP_FIXED_POINTS`: TP = `FixedTPPoints` - `TP_DONCHIAN_WIDTH`: TP = Donchian channel width Γ— `DonchianTP_Mult` (fallback to ATR width if needed) - **RiskPercent** - If `RiskPercent > 0`, lots are calculated from SL distance so the **money at risk β‰ˆ RiskPercent of Equity** (or Balance if you disable `RiskUseEquity`). - `RiskClampToFreeMargin` can reduce lots if required margin is too high. ### Notes / safety - This is a rules-based implementation of common β€œSMC” ideas (fractal swing BOS/CHoCH) and a Donchian breakout. - Test in Strategy Tester and/or demo before using real funds. ### Project links - [**User Notes & References**](docs/USER_NOTES.md) - πŸ“ Personal notes and external links - **OneDrive Vault Password**: `[ACCESS_CODE_REQUIRED]` (Access Code) - **NotebookLM Context**: [NotebookLM](https://notebooklm.google.com/notebook/0e4dfc9b-d57d-4cfc-812d-905d37d67402) - **Cursor Connect**: [Join Session](https://prod.liveshare.vsengsaas.visualstudio.com/join?9C5AED55D7D6624FE2E1B50AD9F14D1339A5) - Developer tip window project: https://chatgpt.com/g/g-p-691e9c0ace5c8191a1b409c09251cc2b-window-for-developer-tip/project - GenX Workspace (VSCode): [OneDrive Folder](https://1drv.ms/f/c/8F247B1B46E82304/IgCPaN4jwMKZTar1XBwn8W9zAYFz0tYoNz7alcAhiiI9oIQ) - Samurai All Branch Structure: [OneDrive Folder](https://1drv.ms/f/c/8F247B1B46E82304/IgDpUzdplXkDTpiyCkdNDZpXASUMJEccVuNGxAaY3MxB1sA) - Plugin Integration: [ZOLO-A6-9V-NUNA-](https://1drv.ms/f/c/8F247B1B46E82304/IgBYRTEjjPv-SKHi70WnmmU8AZb3Mr5X1o3a0QNU_mKgAZg) - GitHub Pages: https://github.com/Mouy-leng/-LengKundee-mql5.github.io.git - ZOLO Bridge Endpoint: http://203.147.134.90 ### Contact - Email: `Lengkundee01.org@domain.com` - WhatsApp: [Agent community](https://chat.whatsapp.com/DYemXrBnMD63K55bjUMKYF)