mirror of
https://github.com/house-of-vanity/OutFleet.git
synced 2025-10-24 01:09:08 +00:00
Fixed xray grps user update .
This commit is contained in:
@@ -423,43 +423,63 @@ class XrayServerV2(Server):
|
|||||||
return False
|
return False
|
||||||
|
|
||||||
try:
|
try:
|
||||||
# First, get existing inbound to check for other users
|
# Get all users who should have access to this inbound from database
|
||||||
existing_result = client.execute_command('lsi')
|
from vpn.models_xray import UserSubscription
|
||||||
existing_inbound = None
|
|
||||||
|
|
||||||
if existing_result and 'inbounds' in existing_result:
|
# Find all users who have subscriptions that include this inbound
|
||||||
for ib in existing_result['inbounds']:
|
users_with_access = set()
|
||||||
if ib.get('tag') == inbound.name:
|
subscriptions = UserSubscription.objects.filter(
|
||||||
existing_inbound = ib
|
active=True,
|
||||||
break
|
subscription_group__inbounds=inbound,
|
||||||
|
subscription_group__is_active=True
|
||||||
|
).select_related('user')
|
||||||
|
|
||||||
if not existing_inbound:
|
for subscription in subscriptions:
|
||||||
logger.warning(f"Inbound {inbound.name} not found on server, deploying it first")
|
users_with_access.add(subscription.user)
|
||||||
# Get or create ServerInbound for certificate access
|
|
||||||
from vpn.models_xray import ServerInbound
|
|
||||||
server_inbound_obj, created = ServerInbound.objects.get_or_create(
|
|
||||||
server=self, inbound=inbound, defaults={'active': True}
|
|
||||||
)
|
|
||||||
# Deploy the inbound if it doesn't exist
|
|
||||||
if not self.deploy_inbound(inbound, server_inbound=server_inbound_obj):
|
|
||||||
logger.error(f"Failed to deploy inbound {inbound.name}")
|
|
||||||
return False
|
|
||||||
# Get the inbound config we just created
|
|
||||||
existing_inbound = {"settings": {"clients": []}}
|
|
||||||
|
|
||||||
# Get existing users from the inbound
|
logger.info(f"Found {len(users_with_access)} users with database access to inbound {inbound.name}")
|
||||||
existing_users = existing_inbound.get('settings', {}).get('clients', [])
|
|
||||||
logger.info(f"Found {len(existing_users)} existing users in inbound {inbound.name}")
|
|
||||||
|
|
||||||
# Check if user already exists
|
# Build user configs for all users who should have access
|
||||||
for existing_user in existing_users:
|
existing_users = []
|
||||||
if existing_user.get('email') == f"{user.username}@{self.name}":
|
user_already_exists = False
|
||||||
logger.info(f"User {user.username} already exists in inbound {inbound.name}")
|
|
||||||
return True
|
|
||||||
|
|
||||||
# Add new user to existing users list
|
for db_user in users_with_access:
|
||||||
existing_users.append(user_config)
|
# Generate user UUID and config
|
||||||
logger.info(f"Creating new inbound with {len(existing_users)} users including {user.username}")
|
import uuid
|
||||||
|
db_user_uuid = str(uuid.uuid5(uuid.NAMESPACE_DNS, f"{db_user.username}-{inbound.name}"))
|
||||||
|
|
||||||
|
if db_user.username == user.username:
|
||||||
|
user_already_exists = True
|
||||||
|
|
||||||
|
if inbound.protocol == 'vless':
|
||||||
|
db_user_config = {
|
||||||
|
"email": f"{db_user.username}@{self.name}",
|
||||||
|
"id": db_user_uuid,
|
||||||
|
"level": 0
|
||||||
|
}
|
||||||
|
elif inbound.protocol == 'vmess':
|
||||||
|
db_user_config = {
|
||||||
|
"email": f"{db_user.username}@{self.name}",
|
||||||
|
"id": db_user_uuid,
|
||||||
|
"level": 0,
|
||||||
|
"alterId": 0
|
||||||
|
}
|
||||||
|
elif inbound.protocol == 'trojan':
|
||||||
|
db_user_config = {
|
||||||
|
"email": f"{db_user.username}@{self.name}",
|
||||||
|
"password": db_user_uuid,
|
||||||
|
"level": 0
|
||||||
|
}
|
||||||
|
else:
|
||||||
|
continue
|
||||||
|
|
||||||
|
existing_users.append(db_user_config)
|
||||||
|
|
||||||
|
if user_already_exists:
|
||||||
|
logger.info(f"User {user.username} already has database access to inbound {inbound.name}")
|
||||||
|
# Still proceed to ensure inbound is deployed with all users
|
||||||
|
|
||||||
|
logger.info(f"Creating inbound with {len(existing_users)} users from database including {user.username}")
|
||||||
|
|
||||||
# Remove the old inbound
|
# Remove the old inbound
|
||||||
logger.info(f"Removing old inbound {inbound.name}")
|
logger.info(f"Removing old inbound {inbound.name}")
|
||||||
@@ -511,14 +531,17 @@ class XrayServerV2(Server):
|
|||||||
elif inbound.protocol == 'trojan':
|
elif inbound.protocol == 'trojan':
|
||||||
inbound_config["settings"]["clients"] = existing_users
|
inbound_config["settings"]["clients"] = existing_users
|
||||||
|
|
||||||
logger.info(f"Deploying updated inbound with users: {[u.get('email') for u in existing_users]}")
|
logger.info(f"Deploying inbound with users: {[u.get('email') for u in existing_users]}")
|
||||||
result = client.add_inbound(inbound_config)
|
result = client.add_inbound(inbound_config)
|
||||||
|
|
||||||
if result is not None and not (isinstance(result, dict) and 'error' in result):
|
if result is not None and not (isinstance(result, dict) and 'error' in result):
|
||||||
|
if user_already_exists:
|
||||||
|
logger.info(f"Successfully ensured user {user.username} exists in inbound {inbound.name}")
|
||||||
|
else:
|
||||||
logger.info(f"Successfully added user {user.username} to inbound {inbound.name} via inbound recreation")
|
logger.info(f"Successfully added user {user.username} to inbound {inbound.name} via inbound recreation")
|
||||||
return True
|
return True
|
||||||
else:
|
else:
|
||||||
logger.error(f"Failed to recreate inbound {inbound.name} with user. Result: {result}")
|
logger.error(f"Failed to recreate inbound {inbound.name} with users. Result: {result}")
|
||||||
return False
|
return False
|
||||||
|
|
||||||
except Exception as cmd_error:
|
except Exception as cmd_error:
|
||||||
@@ -655,19 +678,34 @@ class XrayServerV2(Server):
|
|||||||
|
|
||||||
# Check if inbound exists on server
|
# Check if inbound exists on server
|
||||||
if inbound.name not in existing_inbound_tags:
|
if inbound.name not in existing_inbound_tags:
|
||||||
logger.info(f"Inbound {inbound.name} doesn't exist on server, creating with user")
|
logger.info(f"Inbound {inbound.name} doesn't exist on server, creating with all authorized users")
|
||||||
# Get or create ServerInbound for certificate access
|
|
||||||
from vpn.models_xray import ServerInbound
|
# Get all users who should have access to this inbound from database
|
||||||
|
from vpn.models_xray import ServerInbound, UserSubscription
|
||||||
server_inbound_obj, created = ServerInbound.objects.get_or_create(
|
server_inbound_obj, created = ServerInbound.objects.get_or_create(
|
||||||
server=self, inbound=inbound, defaults={'active': True}
|
server=self, inbound=inbound, defaults={'active': True}
|
||||||
)
|
)
|
||||||
# Create the inbound with the user directly
|
|
||||||
if self.deploy_inbound(inbound, users=[user], server_inbound=server_inbound_obj):
|
# Find all users who have subscriptions that include this inbound
|
||||||
logger.info(f"Successfully created inbound {inbound.name} with user {user.username}")
|
users_with_access = set()
|
||||||
|
subscriptions_for_inbound = UserSubscription.objects.filter(
|
||||||
|
active=True,
|
||||||
|
subscription_group__inbounds=inbound,
|
||||||
|
subscription_group__is_active=True
|
||||||
|
).select_related('user')
|
||||||
|
|
||||||
|
for subscription in subscriptions_for_inbound:
|
||||||
|
users_with_access.add(subscription.user)
|
||||||
|
|
||||||
|
logger.info(f"Creating inbound {inbound.name} with {len(users_with_access)} authorized users")
|
||||||
|
|
||||||
|
# Create the inbound with all authorized users
|
||||||
|
if self.deploy_inbound(inbound, users=list(users_with_access), server_inbound=server_inbound_obj):
|
||||||
|
logger.info(f"Successfully created inbound {inbound.name} with {len(users_with_access)} users")
|
||||||
added_count += 1
|
added_count += 1
|
||||||
existing_inbound_tags.add(inbound.name)
|
existing_inbound_tags.add(inbound.name)
|
||||||
else:
|
else:
|
||||||
logger.error(f"Failed to create inbound {inbound.name} with user")
|
logger.error(f"Failed to create inbound {inbound.name} with users")
|
||||||
continue
|
continue
|
||||||
else:
|
else:
|
||||||
# Inbound exists, add user using recreation approach
|
# Inbound exists, add user using recreation approach
|
||||||
|
Reference in New Issue
Block a user