rustdesk-api-server/api/models_work.py

230 lines
9.3 KiB
Python

# cython:language_level=3
from django.db import models
from django.contrib import admin
from django.utils.translation import gettext as _
from django.db.models import Q
from django.db.models.query import QuerySet
class RustDeskToken(models.Model):
''' Token
'''
username = models.CharField(verbose_name=_('用户名'), max_length=20)
rid = models.CharField(verbose_name=_('RustDesk ID'), max_length=16)
uid = models.CharField(verbose_name=_('用户ID'), max_length=16)
uuid = models.CharField(verbose_name=_('uuid'), max_length=60)
access_token = models.CharField(verbose_name=_('access_token'), max_length=60, blank=True)
create_time = models.DateTimeField(verbose_name=_('登录时间'), auto_now_add=True)
# expire_time = models.DateTimeField(verbose_name='过期时间')
class Meta:
ordering = ('-username',)
verbose_name = "Token"
verbose_name_plural = _("Token列表")
class RustDeskTokenAdmin(admin.ModelAdmin):
list_display = ('username', 'uid')
search_fields = ('username', 'uid')
list_filter = ('create_time', ) # 过滤器
class RustDeskTag(models.Model):
''' Tags
'''
uid = models.CharField(verbose_name=_('所属用户ID'), max_length=16)
tag_name = models.CharField(verbose_name=_('标签名称'), max_length=60)
tag_color = models.CharField(verbose_name=_('标签颜色'), max_length=60, blank=True)
class Meta:
ordering = ('-uid',)
verbose_name = "Tags"
verbose_name_plural = _("Tags列表")
class RustDeskTagAdmin(admin.ModelAdmin):
list_display = ('tag_name', 'uid', 'tag_color')
search_fields = ('tag_name', 'uid')
list_filter = ('uid', )
class RustDeskPeer(models.Model):
''' Pees
'''
uid = models.CharField(verbose_name=_('用户ID'), max_length=16)
rid = models.CharField(verbose_name=_('客户端ID'), max_length=60)
username = models.CharField(verbose_name=_('系统用户名'), max_length=20)
hostname = models.CharField(verbose_name=_('操作系统名'), max_length=30)
alias = models.CharField(verbose_name=_('别名'), max_length=30)
platform = models.CharField(verbose_name=_('平台'), max_length=30)
tags = models.CharField(verbose_name=_('标签'), max_length=30)
rhash = models.CharField(verbose_name=_('设备链接密码'), max_length=60)
class Meta:
ordering = ('-username',)
verbose_name = "Peers"
verbose_name_plural = _("Peers列表")
@classmethod
def get_peers_by_uid(cls, uid: str) -> QuerySet:
'''
Get all peers owned by a user.
Args:
uid (required): str, uid
Returns:
QuerySet: A queryset of peers owned by the user.
'''
return cls.objects.filter(uid=uid)
class RustDeskPeerAdmin(admin.ModelAdmin):
list_display = ('rid', 'uid', 'username', 'hostname', 'platform', 'alias', 'tags')
search_fields = ('deviceid', 'alias')
list_filter = ('rid', 'uid', )
class RustDesDevice(models.Model):
rid = models.CharField(verbose_name=_('客户端ID'), max_length=60, blank=True)
cpu = models.CharField(verbose_name='CPU', max_length=100)
hostname = models.CharField(verbose_name=_('主机名'), max_length=100)
memory = models.CharField(verbose_name=_('内存'), max_length=100)
os = models.CharField(verbose_name=_('操作系统'), max_length=100)
uuid = models.CharField(verbose_name='uuid', max_length=100)
username = models.CharField(verbose_name=_('系统用户名'), max_length=100, blank=True)
version = models.CharField(verbose_name=_('客户端版本'), max_length=100)
create_time = models.DateTimeField(verbose_name=_('设备注册时间'), auto_now_add=True)
update_time = models.DateTimeField(verbose_name=('设备更新时间'), auto_now=True, blank=True)
owner = models.CharField(verbose_name=_('所属用户'), max_length=100, blank=True)
class Meta:
ordering = ('-rid',)
verbose_name = _("设备")
verbose_name_plural = _("设备列表")
@classmethod
def update_device(cls, rid: str, uuid: str, cpu: str = None,
hostname: str = None, memory: str = None, os: str = None,
username: str = None, version: str = None, owner: str = None
) -> 'RustDesDevice':
'''
Update or create a device and update its information if provided.
Args:
rid (required): str, rid
uuid (required): str, uuid
cpu (optional): str, default None
hostname (optional): str, default None
memory (optional): str, default None
os (optional): str, default None
username (optional): str, default None
version (optional): str, default None
owner (optional): str, default None
Returns:
RustDesDevice: The created or updated device object.
'''
# Use get_or_create to either get an existing device or create a new one
device, created = cls.objects.get_or_create(rid=rid, uuid=uuid)
# Collect all non-None fields that need to be updated
update_fields = {}
if cpu is not None:
update_fields['cpu'] = cpu
if hostname is not None:
update_fields['hostname'] = hostname
if memory is not None:
update_fields['memory'] = memory
if os is not None:
update_fields['os'] = os
if username is not None:
update_fields['username'] = username
if version is not None:
update_fields['version'] = version
if owner is not None: # assuming you want to update owner even when it is None
update_fields['owner'] = owner
# Update only the provided fields
if update_fields:
for field, value in update_fields.items():
setattr(device, field, value)
device.save(update_fields=update_fields.keys())
return device
@classmethod
def get_devices_by_owner(cls, owner: str) -> QuerySet:
'''
Get all devices owned by a user.
Args:
owner (required): str, owner
Returns:
QuerySet: A queryset of devices owned by the user.
'''
return cls.objects.filter(owner=owner)
class RustDesDeviceAdmin(admin.ModelAdmin):
list_display = ('rid', 'hostname', 'memory', 'uuid', 'version', 'create_time', 'update_time')
search_fields = ('hostname', 'memory')
list_filter = ('rid', )
class ConnLog(models.Model):
id = models.IntegerField(verbose_name='ID', primary_key=True)
action = models.CharField(verbose_name='Action', max_length=20, null=True)
conn_id = models.CharField(verbose_name='Connection ID', max_length=10, null=True)
from_ip = models.CharField(verbose_name='From IP', max_length=30, null=True)
from_id = models.CharField(verbose_name='From ID', max_length=20, null=True)
rid = models.CharField(verbose_name='To ID', max_length=20, null=True)
conn_start = models.DateTimeField(verbose_name='Connected', null=True)
conn_end = models.DateTimeField(verbose_name='Disconnected', null=True)
session_id = models.CharField(verbose_name='Session ID', max_length=60, null=True)
uuid = models.CharField(verbose_name='uuid', max_length=60, null=True)
class ConnLogAdmin(admin.ModelAdmin):
list_display = ('id', 'action', 'conn_id', 'from_ip', 'from_id', 'rid', 'conn_start', 'conn_end', 'session_id', 'uuid')
search_fields = ('from_ip', 'rid')
list_filter = ('id', 'from_ip', 'from_id', 'rid', 'conn_start', 'conn_end')
class FileLog(models.Model):
id = models.IntegerField(verbose_name='ID', primary_key=True)
file = models.CharField(verbose_name='Path', max_length=500)
remote_id = models.CharField(verbose_name='Remote ID', max_length=20, default='0')
user_id = models.CharField(verbose_name='User ID', max_length=20, default='0')
user_ip = models.CharField(verbose_name='User IP', max_length=20, default='0')
filesize = models.CharField(verbose_name='Filesize', max_length=500, default='')
direction = models.IntegerField(verbose_name='Direction', default=0)
logged_at = models.DateTimeField(verbose_name='Logged At', null=True)
class FileLogAdmin(admin.ModelAdmin):
list_display = ('id', 'file', 'remote_id', 'user_id', 'user_ip', 'filesize', 'direction', 'logged_at')
search_fields = ('file', 'remote_id', 'user_id', 'user_ip')
list_filter = ('id', 'file', 'remote_id', 'user_id', 'user_ip', 'filesize', 'direction', 'logged_at')
class ShareLink(models.Model):
''' 分享链接
'''
uid = models.CharField(verbose_name=_('用户ID'), max_length=16)
shash = models.CharField(verbose_name=_('链接Key'), max_length=60)
peers = models.CharField(verbose_name=_('机器ID列表'), max_length=20)
is_used = models.BooleanField(verbose_name=_('是否使用'), default=False)
is_expired = models.BooleanField(verbose_name=_('是否过期'), default=False)
create_time = models.DateTimeField(verbose_name=_('生成时间'), auto_now_add=True)
class Meta:
ordering = ('-create_time',)
verbose_name = _("分享链接")
verbose_name_plural = _("链接列表")
class ShareLinkAdmin(admin.ModelAdmin):
list_display = ('shash', 'uid', 'peers', 'is_used', 'is_expired', 'create_time')
search_fields = ('peers', )
list_filter = ('is_used', 'uid', 'is_expired')