2023-06-07 13:18:56 -04:00
|
|
|
package xray
|
2022-07-28 11:00:05 -04:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
2023-05-22 09:01:31 -04:00
|
|
|
"github.com/Yuzuki616/V2bX/common/builder"
|
2023-06-07 13:18:56 -04:00
|
|
|
vCore "github.com/Yuzuki616/V2bX/core"
|
2022-07-28 11:00:05 -04:00
|
|
|
"github.com/xtls/xray-core/common/protocol"
|
|
|
|
"github.com/xtls/xray-core/proxy"
|
|
|
|
)
|
|
|
|
|
2023-05-22 09:01:31 -04:00
|
|
|
func (c *Core) GetUserManager(tag string) (proxy.UserManager, error) {
|
|
|
|
handler, err := c.ihm.GetHandler(context.Background(), tag)
|
2022-07-28 11:00:05 -04:00
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("no such inbound tag: %s", err)
|
|
|
|
}
|
|
|
|
inboundInstance, ok := handler.(proxy.GetInbound)
|
|
|
|
if !ok {
|
|
|
|
return nil, fmt.Errorf("handler %s is not implement proxy.GetInbound", tag)
|
|
|
|
}
|
|
|
|
userManager, ok := inboundInstance.GetInbound().(proxy.UserManager)
|
|
|
|
if !ok {
|
|
|
|
return nil, fmt.Errorf("handler %s is not implement proxy.UserManager", tag)
|
|
|
|
}
|
|
|
|
return userManager, nil
|
|
|
|
}
|
|
|
|
|
2023-06-07 13:18:56 -04:00
|
|
|
func (c *Core) DelUsers(users []string, tag string) error {
|
2023-05-22 09:01:31 -04:00
|
|
|
userManager, err := c.GetUserManager(tag)
|
2022-07-28 11:00:05 -04:00
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("get user manager error: %s", err)
|
|
|
|
}
|
|
|
|
for _, email := range users {
|
|
|
|
err = userManager.RemoveUser(context.Background(), email)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2023-06-08 10:46:33 -04:00
|
|
|
func (c *Core) GetUserTraffic(tag, uuid string, reset bool) (up int64, down int64) {
|
|
|
|
upName := "user>>>" + builder.BuildUserTag(tag, uuid) + ">>>traffic>>>uplink"
|
|
|
|
downName := "user>>>" + builder.BuildUserTag(tag, uuid) + ">>>traffic>>>downlink"
|
2023-05-22 09:01:31 -04:00
|
|
|
upCounter := c.shm.GetCounter(upName)
|
|
|
|
downCounter := c.shm.GetCounter(downName)
|
2022-09-07 05:26:12 -04:00
|
|
|
if reset {
|
|
|
|
if upCounter != nil {
|
|
|
|
up = upCounter.Set(0)
|
|
|
|
}
|
|
|
|
if downCounter != nil {
|
|
|
|
down = downCounter.Set(0)
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if upCounter != nil {
|
|
|
|
up = upCounter.Value()
|
|
|
|
}
|
|
|
|
if downCounter != nil {
|
|
|
|
down = downCounter.Value()
|
|
|
|
}
|
2022-07-28 11:00:05 -04:00
|
|
|
}
|
|
|
|
return up, down
|
|
|
|
}
|
2023-05-22 09:01:31 -04:00
|
|
|
|
2023-06-07 13:18:56 -04:00
|
|
|
func (c *Core) AddUsers(p *vCore.AddUsersParams) (added int, err error) {
|
2023-05-22 09:01:31 -04:00
|
|
|
users := make([]*protocol.User, 0, len(p.UserInfo))
|
2023-06-08 10:46:33 -04:00
|
|
|
switch p.NodeInfo.Type {
|
2023-05-22 09:01:31 -04:00
|
|
|
case "v2ray":
|
2023-06-08 10:46:33 -04:00
|
|
|
if p.Config.XrayOptions.EnableXtls {
|
|
|
|
users = builder.BuildVlessUsers(p.Tag, p.UserInfo, true)
|
2023-05-22 09:01:31 -04:00
|
|
|
} else {
|
|
|
|
users = builder.BuildVmessUsers(p.Tag, p.UserInfo)
|
|
|
|
}
|
|
|
|
case "trojan":
|
|
|
|
users = builder.BuildTrojanUsers(p.Tag, p.UserInfo)
|
|
|
|
case "shadowsocks":
|
|
|
|
users = builder.BuildSSUsers(p.Tag,
|
|
|
|
p.UserInfo,
|
2023-05-30 04:08:21 -04:00
|
|
|
p.NodeInfo.Cipher,
|
2023-05-22 09:01:31 -04:00
|
|
|
p.NodeInfo.ServerKey)
|
|
|
|
default:
|
2023-06-08 10:46:33 -04:00
|
|
|
return 0, fmt.Errorf("unsupported node type: %s", p.NodeInfo.Type)
|
2023-05-22 09:01:31 -04:00
|
|
|
}
|
|
|
|
man, err := c.GetUserManager(p.Tag)
|
|
|
|
if err != nil {
|
|
|
|
return 0, fmt.Errorf("get user manager error: %s", err)
|
|
|
|
}
|
|
|
|
for _, u := range users {
|
|
|
|
mUser, err := u.ToMemoryUser()
|
|
|
|
if err != nil {
|
|
|
|
return 0, err
|
|
|
|
}
|
|
|
|
err = man.AddUser(context.Background(), mUser)
|
|
|
|
if err != nil {
|
|
|
|
return 0, err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return len(users), nil
|
|
|
|
}
|