Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update server.go #105

Open
wants to merge 20 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ on:

jobs:
release:
permissions: write-all
runs-on: ubuntu-18.04
outputs:
upload_url: ${{ steps.create_release.outputs.upload_url }}
Expand Down
137 changes: 135 additions & 2 deletions README-fa.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,136 @@
پنل فارسی X-UI

به زودی توضیحات فارسی اضافه میشود.

یکی دیگر از نسخه های ترجمه شده به انگلیسی و فارسی X-UI. همراه با تعدادی ویژگی های پیشرفته تر پیاده سازی شده است.


# امکانات

- همه ی قسمت ها به صورت انگلیسی و فارسی (تنظیمات سمت سرور + رابط کاربری سمت سرور + رابط کاربری وب)
- نظارت بر وضعیت سیستم
- پشتیبانی از پروتکل چند کاربره، web page visualization operation
- چندین UUID را می توان به عنوان کاربر ها برای تنظیمات Vmess و Vless با QR codes مجزا اضافه کرد
- محدود کردن IP
- پروتکل های پشتیبانی شده: vmess, vless, trojan, shadowsocks, dokodemo-door, socks, http
- پشتیبانی برای تنظیم حالت های بیشتر انتقال
- آمار ترافیک، محدود کردن ترافیک، محدودیت با زمان انقضا
- قالب های پیکربندی xray قابل تنظیم
- پشتیبانی از پنل دسترسی https (نام دامنه + گواهی ssl خود را می توان استفاده کرد)
- ربات تلگرام برای توابع اولیه و اعلان ها
- پشتیبانی از برنامه گواهینامه SSL با یک کلیک و تمدید خودکار
- می توان به طور ایمن از v2-ui مهاجرت کرد
- می تواند به طور ایمن از نسخه قبلی X-UI (CH/EN) بدون از دست دادن خروجی به روزرسانی شود
- برای موارد پیکربندی پیشرفته تر، برای جزئیات به پنل مراجعه کنید

# پیش نمایش پنل
![](media/Web.png)
![](media/PostInstallation.png)
# پیش نمایش بات تلگرام (در حال حاظر، فقط برای نسخه V0.2)
![](media/TGBot1.PNG)![](media/TGBot2.PNG)

# نصب و ارتقاء تک دستوره

```
bash <(curl -Ls https://raw.githubusercontent.com/NidukaAkalanka/x-ui-english/master/install.sh)
````
## نصب و ارتقاء دستی

1. ابتدا سیستم خود را آپدیت کنید و دستورات زیر را اجرا کنید. (باید مجوزهای کاربر روت را داشته باشد)
````
sudo su
cd
````
2. سپس آخرین بسته فشرده را از https://github.com/NidukaAkalanka/x-ui-english/releases/latest دانلود کنید، به طور معمول معماری «amd64» را انتخاب کنید.

در پایان دستورات زیر را به ترتیب اجرا کنید:

> اگر معماری cpu سرور شما "amd64" نیست، "*" را در دستور با معماری دیگری جایگزین کنید درعیر اینصورت همان "amd64" را وارد کنید.
````
rm x-ui/ /usr/local/x-ui/ /usr/bin/x-ui -rf
tar zxvf x-ui-linux-amd64.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
1. ابتدا docker را نصب کنید
```shell
curl -fsSL https://get.docker.com | sh
````
2. سپس x-ui را نصب کنید
```shell
mkdir x-ui && cd x-ui
docker run -itd --network=host \
-v $PWD/db/:/etc/x-ui/ \
-v $PWD/cert/:/root/cert/ \
--name x-ui --restart=unless-stopped \
enwaiax/x-ui:latest
````

> ایمیج خود را بسازید
```shell
docker build -t x-ui .
````


## برنامه گواهی SSL
این اسکریپت دارای 3 عملکرد داخلی گواهینامه SSL است. استفاده از یک زیر دامنه توصیه می شود.
- ### روش اول (توصیه می شود. تقریباً برای هر TLD از جمله TLD های رایگان Freenom کار می کن)
برای استفاده از این روش برای درخواست گواهی، تنها نیاز است که آدرس های IP سرور شما به درستی به دامنه یا زیر دامنه ای که متعلق به شماست اشاره شود. (گزینه سوم اسکریپت Acme.sh)

- ### روش دوم و سوم (اگر روش بالا ناموفق بود استفاده کنید. برای TLD های رایگان Freenom کار نمی کند)
این به اندازه مورد اول برای مبتدیان نیست. برای استفاده از این روش، تمام پیش نیازهای زیر باید رعایت شود:
- دانستن آدرس ایمیل ثبت شده در Cloudflare
- دانستن کلید Cloudflare Global API
- داشتن یک نام دامنه که توسط Cloudflare به سرور فعلی شما حل می شود

نحوه دریافت Cloudflare Global API Key:

1- از پیوند https://dash.cloudflare.com/profile/api-tokens دیدن کنید
2- روی View Global API Key کلیک کنید (تصویر زیر را ببینید)
![](media/APIKey1.PNG)

3- ممکن است مجبور شوید حساب خود را مجدداً احراز هویت کنید. پس از آن، کلید API نشان داده می شود (تصویر زیر را ببینید)
![](media/APIKey2.png)

هنگام استفاده، فقط "نام دامنه"، "ایمیل"، "کلید API" را وارد کنید، نمودار به شرح زیر است:
![](media/DetailEnter.png)
> موارد احتیاط:
- اسکریپت از DNS API برای درخواست گواهی استفاده می کند
- به طور پیش فرض از Let'sEncrypt به عنوان طرف CA استفاده کنید. می توانید بین Zerossl.com یا Buypass.com یکی را انتخاب کنید
- دایرکتوری نصب گواهی root/ directory/ است
- گواهینامه های درخواست شده توسط این اسکریپت همه گواهینامه های نام دامنه عمومی هستند

## محدودیت IP و چند کاربر در همان پورت
تقریباً چیزی برای توضیح در مورد چند کاربر بودن وجود ندارد.شما QR codes جداگانه به همراه محاسبه ترافیک، تنظیم تاریخ انقضا و موارد دیگر خواهید داشت.

**محدودیت IP به شرح زیر عمل می کند:**

**مورد:**
- یک کلاینت وجود دارد که از پیکربندی v2ray با محدودیت IP = 1 استفاده می کند.
- او در حال حاضر از طریق رایانه شخصی خود با Wi-Fi (اینترنت ثابت) به سرور v2ray متصل است.
- سپس سعی می کند با استفاده از همان پیکربندی v2ray از تلفن همراه خود با اینترنت 4G **در همان زمان** به سرور متصل شود.

**نتیجه:**
- هیچ تاثیری روی اتصال رایانه شخصی او وجود نخواهد داشت
- در موبایلش حدود 10 ثانیه با موفقیت وصل می شود
- سپس اتصال اینترنت موبایل وی از طریق v2ray قطع می شود. بازگشت **ERR_CONNECTION_CLOSED**.


**مورد:**
- پس از مدتی، همان کلاینت که در بالا ذکر شد، کامپیوتر خود را از v2ray قطع می کند
- اما موبایل خود را در تلاش برای اتصال نگه می دارد

**نتیجه:**
- پس از گذشت حدود 10 ثانیه از قطع کردن رایانه شخصی، اتصال تلفن همراه خود را دوباره به دست می آورد.

**اگر یک نصب جدیدی باشد، این توابع، به خصوص محدود کردن IP، بی عیب و نقص کار خواهد کرد. اما اگر نسخه شما یک ارتقا باشد، ممکن است آن ها کار نکنند در حالی که وضعیت XRAY: اجرا نمی شود، باشد. در چنین مواردی لطفاً [اینجا](https://github.com/NidukaAkalanka/x-ui-english/discussions/27) مراجعه کنید.

## سیستم عامل های پیشنهادی
- CentOS 7+
- Ubuntu 16+
- Debian 8+
16 changes: 8 additions & 8 deletions go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -7,15 +7,16 @@ require (
github.com/Workiva/go-datastructures v1.0.53
github.com/gin-contrib/sessions v0.0.5
github.com/gin-gonic/gin v1.8.1
github.com/go-cmd/cmd v1.4.1
github.com/go-telegram-bot-api/telegram-bot-api/v5 v5.5.1
github.com/nicksnyder/go-i18n/v2 v2.2.0
github.com/op/go-logging v0.0.0-20160315200505-970db520ece7
github.com/robfig/cron/v3 v3.0.1
github.com/shirou/gopsutil v3.21.11+incompatible
github.com/xtls/xray-core v1.6.0
github.com/xtls/xray-core v1.7.2
go.uber.org/atomic v1.10.0
golang.org/x/text v0.3.7
google.golang.org/grpc v1.49.0
golang.org/x/text v0.6.0
google.golang.org/grpc v1.51.0
gorm.io/driver/sqlite v1.3.6
gorm.io/gorm v1.23.10
)
Expand Down Expand Up @@ -45,11 +46,10 @@ require (
github.com/tklauser/numcpus v0.5.0 // indirect
github.com/ugorji/go/codec v1.2.7 // indirect
github.com/yusufpapurcu/wmi v1.2.2 // indirect
golang.org/x/crypto v0.0.0-20220829220503-c86fa9a7ed90 // indirect
golang.org/x/net v0.0.0-20220909164309-bea034e7d591 // indirect
golang.org/x/sys v0.0.0-20220915200043-7b5979e65e41 // indirect
google.golang.org/genproto v0.0.0-20220916172020-2692e8806bfa // indirect
golang.org/x/crypto v0.5.0 // indirect
golang.org/x/net v0.5.0 // indirect
golang.org/x/sys v0.4.0 // indirect
google.golang.org/genproto v0.0.0-20230106154932-a12b697841d9 // indirect
google.golang.org/protobuf v1.28.1 // indirect
gopkg.in/yaml.v2 v2.4.0 // indirect
github.com/go-cmd/cmd v1.4.1 // indirect
)
Loading