mirror of
https://github.com/house-of-vanity/OutFleet.git
synced 2025-10-23 16:59:08 +00:00
Fixed UI graph
This commit is contained in:
@@ -276,7 +276,7 @@
|
||||
padding: 12px;
|
||||
border-radius: 12px;
|
||||
border: 1px solid rgba(255, 255, 255, 0.1);
|
||||
min-width: 120px;
|
||||
min-width: 170px;
|
||||
}
|
||||
|
||||
.chart-title {
|
||||
@@ -290,15 +290,15 @@
|
||||
.chart-bars {
|
||||
display: flex;
|
||||
align-items: end;
|
||||
gap: 2px;
|
||||
gap: 1px;
|
||||
height: 30px;
|
||||
width: 70px;
|
||||
width: 150px;
|
||||
}
|
||||
|
||||
.chart-bar {
|
||||
background: linear-gradient(to top, #4ade80, #22c55e);
|
||||
width: 8px;
|
||||
border-radius: 2px 2px 0 0;
|
||||
width: 4px;
|
||||
border-radius: 1px 1px 0 0;
|
||||
transition: all 0.3s ease;
|
||||
min-height: 2px;
|
||||
opacity: 0.7;
|
||||
@@ -400,17 +400,17 @@
|
||||
}
|
||||
|
||||
.usage-chart {
|
||||
min-width: 100px;
|
||||
min-width: 160px;
|
||||
padding: 8px;
|
||||
}
|
||||
|
||||
.chart-bars {
|
||||
width: 60px;
|
||||
width: 120px;
|
||||
height: 25px;
|
||||
}
|
||||
|
||||
.chart-bar {
|
||||
width: 6px;
|
||||
width: 3px;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -495,7 +495,7 @@
|
||||
</div>
|
||||
</div>
|
||||
<div class="usage-chart" data-usage="{{ link_data.daily_usage|join:',' }}" data-max="{{ link_data.max_daily }}">
|
||||
<div class="chart-title">7-day activity</div>
|
||||
<div class="chart-title">30-day activity</div>
|
||||
<div class="chart-bars">
|
||||
{% for day_usage in link_data.daily_usage %}
|
||||
<div class="chart-bar" data-height="{{ day_usage }}" data-max="{{ link_data.max_daily }}"></div>
|
||||
|
91
vpn/views.py
91
vpn/views.py
@@ -28,63 +28,24 @@ def userPortal(request, user_hash):
|
||||
total_connections = 0
|
||||
|
||||
# Get date ranges for analysis
|
||||
from datetime import datetime, timedelta
|
||||
now = datetime.now()
|
||||
from django.utils import timezone
|
||||
from datetime import timedelta
|
||||
now = timezone.now()
|
||||
recent_date = now - timedelta(days=30)
|
||||
|
||||
for acl_link in acl_links:
|
||||
# Count successful connections for this specific link by checking if the link appears in the access log data
|
||||
link_connections = AccessLog.objects.filter(
|
||||
user=user.username,
|
||||
server=acl_link.acl.server.name,
|
||||
action='Success'
|
||||
).extra(
|
||||
where=["data LIKE %s"],
|
||||
params=[f'%{acl_link.link}%']
|
||||
).count()
|
||||
# Since we can't reliably track individual link usage from AccessLog.data,
|
||||
# we'll count all successful connections to the server for this user
|
||||
# and distribute them among all links for this server
|
||||
|
||||
# Get recent connections (last 30 days)
|
||||
recent_connections = AccessLog.objects.filter(
|
||||
user=user.username,
|
||||
server=acl_link.acl.server.name,
|
||||
action='Success',
|
||||
timestamp__gte=recent_date
|
||||
).extra(
|
||||
where=["data LIKE %s"],
|
||||
params=[f'%{acl_link.link}%']
|
||||
).count()
|
||||
|
||||
# Calculate usage frequency (connections per week over last 30 days)
|
||||
# Get daily usage for the last 7 days for mini chart
|
||||
daily_usage = []
|
||||
for i in range(7):
|
||||
day_start = now - timedelta(days=i+1)
|
||||
day_end = now - timedelta(days=i)
|
||||
|
||||
day_connections = AccessLog.objects.filter(
|
||||
user=user.username,
|
||||
server=acl_link.acl.server.name,
|
||||
action='Success',
|
||||
timestamp__gte=day_start,
|
||||
timestamp__lt=day_end
|
||||
).extra(
|
||||
where=["data LIKE %s"],
|
||||
params=[f'%{acl_link.link}%']
|
||||
).count()
|
||||
|
||||
daily_usage.append(day_connections)
|
||||
|
||||
# Reverse to show oldest to newest
|
||||
daily_usage.reverse()
|
||||
|
||||
# If no specific link matches found, fall back to general server connection count for this user
|
||||
if link_connections == 0:
|
||||
# Get all successful connections for this user on this server
|
||||
server_connections = AccessLog.objects.filter(
|
||||
user=user.username,
|
||||
server=acl_link.acl.server.name,
|
||||
action='Success'
|
||||
).count()
|
||||
|
||||
# Get recent connections (last 30 days)
|
||||
server_recent_connections = AccessLog.objects.filter(
|
||||
user=user.username,
|
||||
server=acl_link.acl.server.name,
|
||||
@@ -98,16 +59,30 @@ def userPortal(request, user_hash):
|
||||
acl__server=acl_link.acl.server
|
||||
).count()
|
||||
|
||||
# Distribute connections evenly among links if we can't track specific usage
|
||||
if user_links_on_server > 0:
|
||||
link_connections = server_connections // user_links_on_server
|
||||
recent_connections = server_recent_connections // user_links_on_server
|
||||
# Distribute daily usage as well
|
||||
if sum(daily_usage) == 0: # If no activity, create empty chart
|
||||
daily_usage = [0] * 7
|
||||
else:
|
||||
avg_daily = max(1, sum(daily_usage) // (user_links_on_server * 7))
|
||||
daily_usage = [avg_daily if sum(daily_usage) > 0 else 0 for _ in range(7)]
|
||||
# Distribute connections evenly among links
|
||||
link_connections = server_connections // user_links_on_server if user_links_on_server > 0 else 0
|
||||
recent_connections = server_recent_connections // user_links_on_server if user_links_on_server > 0 else 0
|
||||
|
||||
# Calculate daily usage for the last 30 days
|
||||
daily_usage = []
|
||||
for i in range(30):
|
||||
day_start = now - timedelta(days=i+1)
|
||||
day_end = now - timedelta(days=i)
|
||||
|
||||
day_connections = AccessLog.objects.filter(
|
||||
user=user.username,
|
||||
server=acl_link.acl.server.name,
|
||||
action='Success',
|
||||
timestamp__gte=day_start,
|
||||
timestamp__lt=day_end
|
||||
).count()
|
||||
|
||||
# Distribute daily connections among links
|
||||
day_link_connections = day_connections // user_links_on_server if user_links_on_server > 0 else 0
|
||||
daily_usage.append(day_link_connections)
|
||||
|
||||
# Reverse to show oldest to newest
|
||||
daily_usage.reverse()
|
||||
|
||||
connection_stats[acl_link.link] = link_connections
|
||||
recent_connection_stats[acl_link.link] = recent_connections
|
||||
@@ -148,7 +123,7 @@ def userPortal(request, user_hash):
|
||||
link_url = f"{EXTERNAL_ADDRESS}/ss/{link.link}#{server_name}"
|
||||
connection_count = connection_stats.get(link.link, 0)
|
||||
recent_count = recent_connection_stats.get(link.link, 0)
|
||||
daily_usage = usage_frequency.get(link.link, [0] * 7)
|
||||
daily_usage = usage_frequency.get(link.link, [0] * 30)
|
||||
|
||||
servers_data[server_name]['links'].append({
|
||||
'link': link,
|
||||
|
Reference in New Issue
Block a user