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

[FR] Advance Inbounds #1264

Open
X-Oracle opened this issue May 20, 2024 · 7 comments
Open

[FR] Advance Inbounds #1264

X-Oracle opened this issue May 20, 2024 · 7 comments
Labels
enhancement New feature or request to deploy To be deployed during the time

Comments

@X-Oracle
Copy link

X-Oracle commented May 20, 2024

Hi @alireza0,

As you know Xray-core has a lot of options and a lot of them are not too handy for normal users, but for power users who want to use Custom configs it is a challenge to add new custom configurations, right now we can already add custom inbound in Xray advanced settings, but we will sacrifice X-UI user management,

I have been thinking of what ways we can configure this ...

  1. we can add custom configs in Xray Advanced settings and in X-UI inbound settings we can have an option to add and manage users of selected inbound tag.

  2. I recently got an idea from adding some outbounds through the panel new outbound manager. we can have both form and json system in inbounds too.

Anyway, I hope you got the point.

Good Luck.

@X-Oracle X-Oracle added the enhancement New feature or request label May 20, 2024
@pulsarice
Copy link

I think you want something like this #1206

@X-Oracle
Copy link
Author

I think you want something like this #1206

This is not a big deal as we can set x-ui to overwrite those specific parameters like inbound tags.

I already made a python script to do that.
It is possible at api level.

We can make a new api which only gets outbound configs.

OR

We can make controls at front-end.
I made a python script and it already overwrote x-ui parameters before sending.

It works great but any new inbound settings under x-ui front will undo the changes.

@X-Oracle
Copy link
Author

We are talking about outbound obj not api payload .

X-ui front will make payload so it can already change x-ui parameters before sending.

It is different from json section in Outbound manager. Outbound manager sends the exact json we put.

@alireza0
Copy link
Owner

Hello @X-Oracle ,

As you mentioned, in outbounds we have no databse related records per outbound and they are stored in a static json text in one database record ( as a part of xray's config template ).
For each inbound, we have a record in inbounds table and will be used in many processes.
Plus: they will be changed by xray-core's api by x-ui backend.
Each failure or miss-configuration could be harmful and may cause several problems.

@X-Oracle
Copy link
Author

X-Oracle commented May 22, 2024

HI, @alireza0,

Thanks for the reply.

As you mentioned, in outbounds we have no database related records per outbound and they are stored in a static Json text in one database record (as a part of xray's config template).

I already know. what I meant is not related to database at all cause all of the important parameters are already in database table.

the part which is important is streamSettings, settings and sniffing which has a lot of options and putting it to gui is going to be overwhelming, that's why I suggested Json tab is great. we can put the important parts in form tab for easy setup but if an option is not available, we can go to Json tab and add it manually.

Xray inbound is like bellow:

{
  "inbounds": [
    {
      "listen": "127.0.0.1",
      "port": 1080,
      "protocol": "协议名称",
      "settings": {},
      "streamSettings": {},
      "tag": "标识",
      "sniffing": {
        "enabled": true,
        "destOverride": ["http", "tls"]
      },
      "allocate": {
        "strategy": "always",
        "refresh": 5,
        "concurrency": 3
      }
    }
  ]
}

X-UI already covers most of inbound keys except allocate which is not an important key for penetrating wall.

1- we get xray part through "/get/:id" Api.
2- then we parse it to be like x-ui outbound and put it in Json tab.
3- the after editing and hitting save button we get the main key parameters and send them to api with "/update/:id".

Plus: they will be changed by xray-core's Api by x-ui backend.

this is not a problem as all of above changes is related to front and backend doesn't need to be changed so

Each failure or miss-configuration could be harmful and may cause several problems.

As I didn't see other x-ui backend code. I don't know what configs are being used by X-ui. but we can configure x-ui to post fill the keys which are important and may cause x-ui to fail to run (not the core).

For example, you told me before that inbound tag cannot be custom because some x-ui functions is based on that, so after user hit the save button, we can overwrite it before sending; in that case no matter what user fill or even not fill.

As for misconfiguration in x-ray part. it is users' responsibility to use Json tab (we are not enforcing Json tab just like outbound manager).

Think about it in your free time

I look forward for your reply about this,

Good Luck,

@alireza0
Copy link
Owner

Please take a look at outbound's modal. When you change sth which is not supported by modal, after pushing save button it will be converted by javascript to only supported paramethers.
As a solution for this problem, I thought about covering all the paramethers in JS code and implement only a part of them in GUI. It is the only way.
I have to work on feasibility of this implementation. According to lack of documentation for new paramethers in xray-core, it wouldn't be easy.

@X-Oracle
Copy link
Author

X-Oracle commented May 25, 2024

As a solution for this problem, I thought about covering all the paramethers in JS code and implement only a part of them in GUI. It is the only way.

In my opinion this mechanism is better and that's just what I did in my python script.

According to lack of documentation for new paramethers in xray-core, it wouldn't be easy.

The problem with official documentation is that only a few x-ray contributors and not the ones implanting the futures are writing it (seriously, why they would take their time to implant a feature and not going to write any guide on how to use it.) so it is not fully covered.

@alireza0 alireza0 added the to deploy To be deployed during the time label May 25, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request to deploy To be deployed during the time
Projects
None yet
Development

No branches or pull requests

3 participants