Sen descrición

Pk-web6936 b75a1ef5e1 Code refactoring (#2877) hai 1 día
.github 878e0d02cd Xray Core v25.3.31 hai 6 días
config 2ffde55f8f v2.5.6 - Happy Nowruz hai 3 semanas
database 0bde51b91e Refactor: Use any instead of interface{} hai 4 semanas
logger 0bde51b91e Refactor: Use any instead of interface{} hai 4 semanas
media 518bc72f90 media - telebot hai 3 meses
sub d30cdbf49a feat: custom subscription title in panel (#2773) hai 3 semanas
util 0bde51b91e Refactor: Use any instead of interface{} hai 4 semanas
web d956f78347 feat: add Arabic language (#2880) hai 2 días
xray b68f0a206c xray log - minor change hai 4 semanas
.gitignore 3ded4ee658 minor changes hai 3 días
DockerEntrypoint.sh a4c38ec8ae fail2ban service in docker container (#2632) hai 2 meses
DockerInit.sh 878e0d02cd Xray Core v25.3.31 hai 6 días
Dockerfile e0e9e2681a docker: go 1.24 hai 1 mes
LICENSE b73e4173a3 3x-ui %!s(int64=2) %!d(string=hai) anos
README.ar_EG.md d956f78347 feat: add Arabic language (#2880) hai 2 días
README.es_ES.md d956f78347 feat: add Arabic language (#2880) hai 2 días
README.fa_IR.md d956f78347 feat: add Arabic language (#2880) hai 2 días
README.md d956f78347 feat: add Arabic language (#2880) hai 2 días
README.ru_RU.md d956f78347 feat: add Arabic language (#2880) hai 2 días
README.zh_CN.md d956f78347 feat: add Arabic language (#2880) hai 2 días
docker-compose.yml a4c38ec8ae fail2ban service in docker container (#2632) hai 2 meses
go.mod 878e0d02cd Xray Core v25.3.31 hai 6 días
go.sum 878e0d02cd Xray Core v25.3.31 hai 6 días
install.sh b75a1ef5e1 Code refactoring (#2877) hai 1 día
main.go c158e6ec73 getListen & getCert hai 5 meses
x-ui.service b73e4173a3 3x-ui %!s(int64=2) %!d(string=hai) anos
x-ui.sh b75a1ef5e1 Code refactoring (#2877) hai 1 día

README.ar_EG.md

English | فارسی | العربية | 中文 | Español | Русский

3x-ui

لوحة تحكم ويب متقدمة • مبنية على Xray Core

GO Version Downloads License

تنبيه: المشروع ده للتعلم الشخصي والتواصل فقط. رجاءً استخدمه بشكل قانوني.

لو المشروع عجبك وساعدك، ممكن تدعمنا بعمل :star2:

Image

  • USDT (TRC20): TXncxkvhkDWGts487Pjqq1qT9JmwRUz8CC
  • MATIC (polygon): 0x41C9548675D044c6Bfb425786C765bc37427256A
  • LTC (Litecoin): ltc1q2ach7x6d2zq0n4l0t4zl7d7xe2s6fs7a3vspwv

التثبيت والتحديث

لتثبيت المشروع أو تحديثه، نفذ الأمر ده:

bash <(curl -Ls https://raw.githubusercontent.com/mhsanaei/3x-ui/master/install.sh)

تثبيت النسخة القديمة (مش موصى بيها)

لو عايز تثبت نسخة معينة، استخدم الأمر ده، مثلاً نسخة v1.7.9:

VERSION=v1.7.9 && bash <(curl -Ls "https://raw.githubusercontent.com/mhsanaei/3x-ui/$VERSION/install.sh") $VERSION

شهادة SSL

اضغط لعرض تفاصيل شهادة SSL ### ACME عشان تدير شهادات SSL باستخدام ACME: 1. تأكد إن الدومين بتاعك متربط صح بالسيرفر. 2. شغّل أمر `x-ui` في الترمينال واختار خيار "إدارة شهادات SSL". 3. هتلاقي الخيارات دي: - **Get SSL:** الحصول على شهادة SSL. - **Revoke:** إلغاء شهادة SSL موجودة. - **Force Renew:** تجديد شهادة SSL بالقوة. - **Show Existing Domains:** عرض كل شهادات الدومين المتوفرة على السيرفر. - **Set Certificate Paths for the Panel:** تعيين مسارات الشهادة عشان البانل يستخدمها. ### Certbot لتثبيت واستخدام Certbot: ```sh apt-get install certbot -y certbot certonly --standalone --agree-tos --register-unsafely-without-email -d yourdomain.com certbot renew --dry-run ``` ### Cloudflare السكريبت بتاع الإدارة فيه آلية مدمجة للتقديم على شهادة SSL من خلال Cloudflare. عشان تستخدمها، هتحتاج: - بريد إلكتروني مسجل على Cloudflare. - الـ Global API Key بتاع Cloudflare. - الدومين لازم يكون مربوط للسيرفر الحالي عن طريق Cloudflare. **كيفية الحصول على Global API Key من Cloudflare:** 1. شغّل أمر `x-ui` في الترمينال واختار "Cloudflare SSL Certificate". 2. ادخل على [Cloudflare API Tokens](https://dash.cloudflare.com/profile/api-tokens). 3. دوس على "View Global API Key" (شوف الصورة التوضيحية): ![](media/APIKey1.PNG) 4. يمكن تحتاج تعيد تسجيل الدخول، وبعدها هتظهر الـ API Key (شوف الصورة التوضيحية): ![](media/APIKey2.png) عند الاستخدام، ادخل اسم الدومين، البريد الإلكتروني، وAPI Key. المخطط كالتالي: ![](media/DetailEnter.png)

التثبيت والتحديث يدويًا

اضغط لعرض تفاصيل التثبيت اليدوي #### الاستخدام 1. لتحميل أحدث نسخة من الباكدج المظغوطة مباشرة على السيرفر، نفذ الأمر التالي: ```sh ARCH=$(uname -m) case "${ARCH}" in x86_64 | x64 | amd64) XUI_ARCH="amd64" ;; i*86 | x86) XUI_ARCH="386" ;; armv8* | armv8 | arm64 | aarch64) XUI_ARCH="arm64" ;; armv7* | armv7) XUI_ARCH="armv7" ;; armv6* | armv6) XUI_ARCH="armv6" ;; armv5* | armv5) XUI_ARCH="armv5" ;; s390x) echo 's390x' ;; *) XUI_ARCH="amd64" ;; esac wget https://github.com/MHSanaei/3x-ui/releases/latest/download/x-ui-linux-${XUI_ARCH}.tar.gz ``` 2. بعد تحميل الباكدج، نفذ الأوامر دي للتثبيت أو التحديث: ```sh ARCH=$(uname -m) case "${ARCH}" in x86_64 | x64 | amd64) XUI_ARCH="amd64" ;; i*86 | x86) XUI_ARCH="386" ;; armv8* | armv8 | arm64 | aarch64) XUI_ARCH="arm64" ;; armv7* | armv7) XUI_ARCH="armv7" ;; armv6* | armv6) XUI_ARCH="armv6" ;; armv5* | armv5) XUI_ARCH="armv5" ;; s390x) echo 's390x' ;; *) XUI_ARCH="amd64" ;; esac cd /root/ rm -rf x-ui/ /usr/local/x-ui/ /usr/bin/x-ui tar zxvf x-ui-linux-${XUI_ARCH}.tar.gz chmod +x x-ui/x-ui x-ui/bin/xray-linux-* x-ui/x-ui.sh cp x-ui/x-ui.sh /usr/bin/x-ui cp -f x-ui/x-ui.service /etc/systemd/system/ mv x-ui/ /usr/local/ systemctl daemon-reload systemctl enable x-ui systemctl restart x-ui ```

التثبيت باستخدام Docker

اضغط لعرض تفاصيل Docker #### الاستخدام 1. **تثبيت Docker:** ```sh bash <(curl -sSL https://get.docker.com) ``` 2. **نسخ مستودع المشروع:** ```sh git clone https://github.com/MHSanaei/3x-ui.git cd 3x-ui ``` 3. **تشغيل الخدمة:** ```sh docker compose up -d ``` ممكن تضيف الخيار ```--pull always``` عشان Docker يسحب أحدث صورة لو موجودة. (راجع [مستندات Docker](https://docs.docker.com/reference/cli/docker/container/run/#pull) للمزيد من التفاصيل). **أو** ```sh docker run -itd \ -e XRAY_VMESS_AEAD_FORCED=false \ -v $PWD/db/:/etc/x-ui/ \ -v $PWD/cert/:/root/cert/ \ --network=host \ --restart=unless-stopped \ --name 3x-ui \ ghcr.io/mhsanaei/3x-ui:latest ``` 4. **التحديث إلى أحدث نسخة:** ```sh cd 3x-ui docker compose down docker compose pull 3x-ui docker compose up -d ``` 5. **إزالة 3x-ui من Docker:** ```sh docker stop 3x-ui docker rm 3x-ui cd -- rm -r 3x-ui ```

إعدادات Nginx

اضغط لعرض إعدادات البروكسي العكسي (Reverse Proxy) #### Reverse Proxy باستخدام Nginx ```nginx location / { proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header Range $http_range; proxy_set_header If-Range $http_if_range; proxy_redirect off; proxy_pass http://127.0.0.1:2053; } ``` #### استخدام Nginx مع sub-path - تأكد إن "URI Path" في إعدادات `/sub` للبانل متطابق. - لازم يكون رابط `url` في إعدادات البانل منتهي بـ `/`. ```nginx location /sub { proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header Range $http_range; proxy_set_header If-Range $http_if_range; proxy_redirect off; proxy_pass http://127.0.0.1:2053; } ```

نظام التشغيل الموصى به

  • Ubuntu 22.04+
  • Debian 12+
  • CentOS 8+
  • OpenEuler 22.03+
  • Fedora 36+
  • Arch Linux
  • Parch Linux
  • Manjaro
  • Armbian
  • AlmaLinux 9.5+
  • Rocky Linux 9.5+
  • Oracle Linux 8+
  • OpenSUSE Tubleweed
  • Amazon Linux 2023
  • Virtuozzo Linux 8+
  • Windows x64

المعماريات والأجهزة المدعومة

اضغط لعرض تفاصيل المعماريات والأجهزة المدعومة منصتنا بتدعم مجموعة متنوعة من المعماريات والأجهزة عشان تناسب بيئات مختلفة. أبرز المعماريات هي: - **amd64:** المعمارية القياسية للكمبيوترات الشخصية والسيرفرات. - **x86 / i386:** مستخدمة على نطاق واسع في أجهزة الديسكتوب واللاب توب. - **armv8 / arm64 / aarch64:** موجهة للأجهزة المحمولة والمضمنة زي Raspberry Pi 4, Raspberry Pi 3, Raspberry Pi Zero 2/Zero 2 W, Orange Pi 3 LTS، وغيرها. - **armv7 / arm / arm32:** للأجهزة المحمولة والأجهزة المضمنة القديمة، مثل Orange Pi Zero LTS, Orange Pi PC Plus, Raspberry Pi 2. - **armv6 / arm / arm32:** للأجهزة المضمنة القديمة جداً، زي Raspberry Pi 1, Raspberry Pi Zero/Zero W. - **armv5 / arm / arm32:** معمارية أقدم مرتبطة بالأنظمة المضمنة القديمة. - **s390x:** مستخدمة في الحواسيب الرئيسية من IBM وتوفر أداء عالي واعتمادية للمشاريع الكبيرة.

اللغات

  • English (إنجليزي)
  • Persian (فارسي)
  • Traditional Chinese (الصيني التقليدي)
  • Simplified Chinese (الصيني المبسط)
  • Japanese (ياباني)
  • Russian (روسي)
  • Vietnamese (فيتنامي)
  • Spanish (إسباني)
  • Indonesian (إندونيسي)
  • Ukrainian (أوكراني)
  • Turkish (تركي)
  • Português (Brazil) (برتغالي - البرازيل)

الميزات

  • مراقبة حالة النظام
  • البحث داخل كل الإدخالات والعملاء
  • ثيم داكن وفاتح
  • دعم تعدد المستخدمين والبروتوكولات
  • دعم بروتوكولات زي VMESS، VLESS، Trojan، Shadowsocks، Dokodemo-door، Socks، HTTP، wireguard
  • دعم بروتوكولات XTLS الأصلية مثل RPRX-Direct، Vision، REALITY
  • إحصائيات الترافيك، تحديد حد للترافيك، وتحديد فترة انتهاء الصلاحية
  • قوالب إعدادات Xray قابلة للتخصيص
  • دعم لوحة تحكم عبر HTTPS (بإستخدام الدومين الخاص وشهادة SSL)
  • دعم التقديم على شهادات SSL بلمسة واحدة والتجديد التلقائي
  • لمزيد من إعدادات التخصيص المتقدمة، راجع إعدادات البانل
  • إصلاح مسارات الـ API (سيتم إنشاء إعدادات للمستخدم مع الـ API)
  • دعم تغيير الإعدادات من خلال الخيارات المتوفرة في البانل
  • دعم تصدير/استيراد قاعدة البيانات من خلال البانل

إعدادات البانل الافتراضية

اضغط لعرض تفاصيل الإعدادات الافتراضية ### اسم المستخدم، الباسورد، البورت ومسار الويب الأساسي لو مش هتعدل الإعدادات دي، هتتولد تلقائياً (ده مش بينطبق على Docker). **الإعدادات الافتراضية لـ Docker:** - **اسم المستخدم:** admin - **الباسورد:** admin - **البورت:** 2053 ### إدارة قاعدة البيانات: ممكن تعمل نسخ احتياطية واسترجاع لقاعدة البيانات مباشرة من البانل. - **مسار قاعدة البيانات:** - `/etc/x-ui/x-ui.db` ### المسار الأساسي للويب 1. **إعادة تعيين المسار الأساسي:** - افتح الترمينال. - نفذ أمر `x-ui`. - اختار خيار "إعادة تعيين المسار الأساسي للويب". 2. **توليد أو تخصيص المسار:** - المسار هيتولد تلقائياً، أو ممكن تدخل مسار مخصص. 3. **عرض الإعدادات الحالية:** - لمشاهدة الإعدادات الحالية، نفذ أمر `x-ui settings` في الترمينال أو استخدم خيار "عرض الإعدادات الحالية" في البانل. ### توصية الأمان: - لتحسين الأمان، استخدم كلمة طويلة وعشوائية في مسار URL الخاص بالبانل. **مثال:** - `http://ip:port/*webbasepath*/panel` - `http://domain:port/*webbasepath*/panel`

إعداد WARP

اضغط لعرض تفاصيل إعداد WARP #### الاستخدام **لإصدارات `v2.1.0` وما بعدها:** WARP مدمج ومش محتاج تثبيت إضافي. فعل الإعدادات المطلوبة من خلال البانل.

تحديد IP

اضغط لعرض تفاصيل تحديد IP #### الاستخدام **ملحوظة:** تحديد IP ممكن مايشتغلش صح مع IP Tunnel. - **للإصدارات حتى `v1.6.1`:** - تحديد IP مدمج في البانل. **للإصدارات `v1.7.0` وما بعدها:** لتفعيل وظيفة تحديد IP، هتحتاج تثبيت `fail2ban` والملفات المطلوبة من خلال الخطوات دي: 1. شغل أمر `x-ui` في الترمينال واختار "إدارة تحديد IP". 2. هتلاقي الخيارات التالية: - **تغيير مدة الحظر:** لتعديل مدة الحظر. - **رفع الحظر عن الجميع:** لإلغاء كل الحظر الحالي. - **عرض السجلات:** لمراجعة السجلات. - **حالة Fail2ban:** لمراجعة حالة fail2ban. - **إعادة تشغيل Fail2ban:** لإعادة تشغيل خدمة fail2ban. - **إلغاء تثبيت Fail2ban:** لإلغاء تثبيت fail2ban مع إعداداته. 3. حدد مسار سجل الوصول على البانل من خلال ضبط `Xray Configs/log/Access log` على `./access.log` ثم احفظ وأعد تشغيل x-ui. - **للإصدارات قبل `v2.1.3`:** - هتحتاج تضبط مسار سجل الوصول يدويًا في إعدادات Xray: ```sh "log": { "access": "./access.log", "dnsLog": false, "loglevel": "warning" }, ``` - **للإصدارات `v2.1.3` وما بعدها:** - في خيار لضبط `access.log` مباشرة من البانل.

بوت Telegram

اضغط لعرض تفاصيل بوت Telegram #### الاستخدام تدعم لوحة التحكم إشعارات بترافيك يومي، تسجيل الدخول للبانل، نسخ احتياطية للقاعدة، حالة النظام، معلومات العملاء، وغيرها من الوظائف عن طريق بوت Telegram. عشان تستخدم البوت، لازم تضبط معلمات البوت في البانل، ومن ضمنهم: - توكن Telegram - ID شات الأدمن (يمكن إدخال أكثر من واحد بفواصل) - وقت الإشعار (باستخدام صيغة cron) - إشعار بتاريخ انتهاء الصلاحية - إشعار حد الترافيك - نسخ احتياطية للقاعدة - إشعار حمل المعالج **صيغة مرجعية:** - `30 * * * * *` - إشعار عند الـ 30 ثانية من كل دقيقة. - `0 */10 * * * *` - إشعار عند أول ثانية من كل 10 دقايق. - `@hourly` - إشعار كل ساعة. - `@daily` - إشعار يومي (في تمام منتصف الليل). - `@weekly` - إشعار أسبوعي. - `@every 8h` - إشعار كل 8 ساعات. ### ميزات بوت Telegram - تقارير دورية. - إشعارات عند تسجيل الدخول. - إشعار عند تجاوز حمل المعالج. - تنبيهات قبل انتهاء الصلاحية أو وصول حد الترافيك. - دعم قوائم تقارير العملاء لو تم إضافة اسم مستخدم Telegram للمستخدم في الإعدادات. - إمكانية البحث عن تقرير الترافيك باستخدام UUID (VMESS/VLESS) أو الباسورد (TROJAN) بشكل مجهول. - بوت يعتمد على القوائم. - البحث عن العملاء بالإيميل (للأدمن فقط). - استعراض كافة الإدخالات. - عرض حالة السيرفر. - استعراض العملاء المستنفدين. - استقبال النسخ الاحتياطية عند الطلب وفي التقارير الدورية. - بوت متعدد اللغات. ### إعداد بوت Telegram - ابدأ [Botfather](https://t.me/BotFather) في حساب Telegram بتاعك: ![Botfather](./media/botfather.png) - أنشئ بوت جديد باستخدام أمر /newbot: هيسألك سؤالين، اسم للبوت واسم مستخدم (لازم ينتهي بكلمة "bot"). ![Create new bot](./media/newbot.png) - شغل البوت اللي أنشأته. هتلاقي رابط البوت بعد كده. ![token](./media/token.png) - ادخل على البانل واضبط إعدادات بوت Telegram زي ما هو موضح: ![Panel Config](./media/panel-bot-config.png) ادخل توكن البوت في الحقل رقم 3. ادخل ID المستخدم في الحقل رقم 4. الحسابات اللي بالـ ID ده هيبقى ليها صلاحية الأدمن. (يمكن إدخال أكثر من واحد بفواصل) - كيفية الحصول على ID حساب Telegram؟ استخدم [هذا البوت](https://t.me/useridinfobot). شغله وهيدي الـ ID بتاعك. ![User ID](./media/user-id.png)

مسارات API

اضغط لعرض تفاصيل مسارات API #### الاستخدام - [توثيق الـ API](https://www.postman.com/hsanaei/3x-ui/collection/q1l5l0u/3x-ui) - `/login` مع بيانات المستخدم باستخدام `POST`: `{username: '', password: ''}` لتسجيل الدخول. - المسار الأساسي لـ `/panel/api/inbounds` للعمليات التالية: | الطريقة | المسار | الفعل | | :-----: | ------------------------------------ | ------------------------------------------ | | `GET` | `"/list"` | استرجاع كل الإدخالات | | `GET` | `"/get/:id"` | استرجاع إدخال بالـ id | | `GET` | `"/getClientTraffics/:email"` | استرجاع ترافيك عميل بالإيميل | | `GET` | `"/getClientTrafficsById/:id"` | استرجاع ترافيك عميل بالـ id | | `GET` | `"/createbackup"` | البوت بيرسل نسخة احتياطية للأدمن | | `POST` | `"/add"` | إضافة إدخال | | `POST` | `"/del/:id"` | حذف إدخال | | `POST` | `"/update/:id"` | تحديث إدخال | | `POST` | `"/clientIps/:email"` | استرجاع عنوان IP للعميل | | `POST` | `"/clearClientIps/:email"` | مسح عنوان IP للعميل | | `POST` | `"/addClient"` | إضافة عميل للإدخال | | `POST` | `"/:id/delClient/:clientId"` | حذف عميل باستخدام clientId\* | | `POST` | `"/updateClient/:clientId"` | تحديث بيانات عميل باستخدام clientId\* | | `POST` | `"/:id/resetClientTraffic/:email"` | إعادة ضبط ترافيك عميل | | `POST` | `"/resetAllTraffics"` | إعادة ضبط الترافيك لكل الإدخالات | | `POST` | `"/resetAllClientTraffics/:id"` | إعادة ضبط ترافيك كل العملاء في إدخال معين | | `POST` | `"/delDepletedClients/:id"` | حذف العملاء المستنفدين في الإدخال (-1: الكل) | | `POST` | `"/onlines"` | استرجاع قائمة العملاء الأونلاين (الإيميلات) | \*- بالنسبة لحقل `clientId`: - استخدم `client.id` لـ VMESS و VLESS. - استخدم `client.password` لـ TROJAN. - استخدم `client.email` لـ Shadowsocks. - [![Run In Postman](https://run.pstmn.io/button.svg)](https://app.getpostman.com/run-collection/5146551-dda3cab3-0e33-485f-96f9-d4262f437a?action=collection%2Ffork&source=rip_markdown&collection-url=entityId%3D5146551-dda3cab3-0e33-485f-96f9-d4262f437a%26entityType%3Dcollection%26workspaceId%3Dd64f609f-485a-4951-9b8f-876b3f9171)

المتغيرات البيئية

اضغط لعرض تفاصيل المتغيرات البيئية #### الاستخدام | المتغير | النوع | القيمة الافتراضية | | ---------------- | :--------------------------------------------: | ------------------: | | XUI_LOG_LEVEL | `"debug"` \| `"info"` \| `"warn"` \| `"error"` | `"info"` | | XUI_DEBUG | `boolean` | `false` | | XUI_BIN_FOLDER | `string` | `"bin"` | | XUI_DB_FOLDER | `string` | `"/etc/x-ui"` | | XUI_LOG_FOLDER | `string` | `"/var/log"` | مثال: ```sh XUI_BIN_FOLDER="bin" XUI_DB_FOLDER="/etc/x-ui" go build main.go ```

المعاينة

3x-ui 3x-ui 3x-ui 3x-ui 3x-ui 3x-ui 3x-ui

شكر خاص لـ

التحيات

  • Iran v2ray rules (الرخصة: GPL-3.0): قواعد محدثة لتوجيهات v2ray/xray مع تضمين دومينات إيرانية وتركيز على الأمان وحجب الإعلانات.
  • Russia v2ray rules (الرخصة: GPL-3.0): المستودع ده بيحتوي على قواعد توجيه v2ray/xray محدثة تلقائيًا بناءً على بيانات الدومينات والعناوين المحظورة في روسيا.

عدد النجوم مع مرور الوقت

Stargazers over time