jumpserver/apps/assets/const.py

318 lines
10 KiB
Python
Raw Normal View History

2022-04-07 10:51:35 +00:00
from django.db import models
from django.utils.translation import gettext_lazy as _
2022-09-07 09:12:53 +00:00
2022-08-22 03:47:45 +00:00
from common.db.models import IncludesTextChoicesMeta, ChoicesMixin
2022-08-08 02:41:37 +00:00
from common.tree import TreeNode
2022-04-07 10:51:35 +00:00
__all__ = [
2022-09-15 13:20:56 +00:00
'Category', 'HostTypes', 'DeviceTypes', 'DatabaseTypes',
2022-08-05 11:11:17 +00:00
'WebTypes', 'CloudTypes', 'Protocol', 'AllTypes',
2022-04-07 10:51:35 +00:00
]
2022-04-30 15:19:43 +00:00
class PlatformMixin:
@classmethod
2022-08-10 11:27:08 +00:00
def platform_constraints(cls):
return {
2022-09-01 09:42:48 +00:00
'domain_enabled': False,
'su_enabled': False,
2022-09-15 13:20:56 +00:00
'brand_enabled': False,
2022-09-15 08:22:01 +00:00
'ping_enabled': False,
'gather_facts_enabled': False,
2022-09-01 09:42:48 +00:00
'change_password_enabled': False,
'verify_account_enabled': False,
'create_account_enabled': False,
'gather_accounts_enabled': False,
2022-08-10 11:27:08 +00:00
'_protocols': []
}
2022-04-30 15:19:43 +00:00
2022-08-22 03:47:45 +00:00
class Category(PlatformMixin, ChoicesMixin, models.TextChoices):
2022-04-07 10:51:35 +00:00
HOST = 'host', _('Host')
2022-09-15 13:20:56 +00:00
DEVICE = 'device', _("Device")
2022-04-07 10:51:35 +00:00
DATABASE = 'database', _("Database")
2022-09-15 13:20:56 +00:00
CLOUD = 'cloud', _("Cloud service")
2022-08-05 11:11:17 +00:00
WEB = 'web', _("Web")
2022-04-07 10:51:35 +00:00
2022-04-30 15:19:43 +00:00
@classmethod
2022-08-10 11:27:08 +00:00
def platform_constraints(cls) -> dict:
2022-04-30 15:19:43 +00:00
return {
cls.HOST: {
2022-09-01 09:42:48 +00:00
'domain_enabled': True,
2022-09-14 12:55:14 +00:00
'su_enabled': True, 'su_method': 'sudo',
'ping_enabled': True, 'ping_method': 'ping',
'gather_facts_enabled': True, 'gather_facts_method': 'gather_facts_posix',
'verify_account_enabled': True, 'verify_account_method': 'verify_account_posix',
'change_password_enabled': True, 'change_password_method': 'change_password_posix',
'create_account_enabled': True, 'create_account_method': 'create_account_posix',
'gather_accounts_enabled': True, 'gather_accounts_method': 'gather_accounts_posix',
'_protocols': ['ssh', 'telnet'],
2022-04-30 15:19:43 +00:00
},
2022-09-15 13:20:56 +00:00
cls.DEVICE: {
2022-09-01 09:42:48 +00:00
'domain_enabled': True,
2022-09-15 08:22:01 +00:00
'brand_enabled': True,
'brands': [
('huawei', 'Huawei'),
('cisco', 'Cisco'),
('juniper', 'Juniper'),
('h3c', 'H3C'),
('dell', 'Dell'),
('other', 'Other'),
],
2022-09-07 09:12:53 +00:00
'su_enabled': False,
2022-09-14 12:55:14 +00:00
'ping_enabled': True, 'ping_method': 'ping',
2022-09-07 09:12:53 +00:00
'gather_facts_enabled': False,
'verify_account_enabled': False,
'change_password_enabled': False,
'create_account_enabled': False,
'gather_accounts_enabled': False,
2022-08-10 11:27:08 +00:00
'_protocols': ['ssh', 'telnet']
2022-04-30 15:19:43 +00:00
},
cls.DATABASE: {
2022-09-01 09:42:48 +00:00
'domain_enabled': True,
2022-09-07 09:12:53 +00:00
'su_enabled': False,
'gather_facts_enabled': True,
'verify_account_enabled': True,
'change_password_enabled': True,
'create_account_enabled': True,
'gather_accounts_enabled': True,
2022-09-14 12:55:14 +00:00
'_protocols': []
2022-04-30 15:19:43 +00:00
},
2022-08-05 11:11:17 +00:00
cls.WEB: {
2022-09-01 09:42:48 +00:00
'domain_enabled': False,
2022-09-07 09:12:53 +00:00
'su_enabled': False,
2022-09-14 12:55:14 +00:00
'ping_enabled': False,
'gather_facts_enabled': False,
'verify_account_enabled': False,
'change_password_enabled': False,
'create_account_enabled': False,
'gather_accounts_enabled': False,
2022-09-07 09:12:53 +00:00
'_protocols': ['http', 'https']
2022-04-30 15:19:43 +00:00
},
cls.CLOUD: {
2022-09-01 09:42:48 +00:00
'domain_enabled': False,
2022-09-07 09:12:53 +00:00
'su_enabled': False,
2022-09-14 12:55:14 +00:00
'ping_enabled': False,
'gather_facts_enabled': False,
'verify_account_enabled': False,
'change_password_enabled': False,
'create_account_enabled': False,
'gather_accounts_enabled': False,
2022-08-10 11:27:08 +00:00
'_protocols': []
2022-04-30 15:19:43 +00:00
}
}
2022-08-22 03:47:45 +00:00
class HostTypes(PlatformMixin, ChoicesMixin, models.TextChoices):
2022-04-07 10:51:35 +00:00
LINUX = 'linux', 'Linux'
WINDOWS = 'windows', 'Windows'
UNIX = 'unix', 'Unix'
2022-09-15 13:20:56 +00:00
OTHER_HOST = 'other', _("Other")
2022-04-07 10:51:35 +00:00
2022-04-30 15:19:43 +00:00
@classmethod
2022-08-10 11:27:08 +00:00
def platform_constraints(cls):
return {
cls.LINUX: {
2022-09-08 12:31:04 +00:00
'_protocols': ['ssh', 'rdp', 'vnc', 'telnet']
2022-08-10 11:27:08 +00:00
},
cls.WINDOWS: {
2022-09-14 12:55:14 +00:00
'gather_facts_method': 'gather_facts_windows',
'verify_account_method': 'verify_account_windows',
'change_password_method': 'change_password_windows',
'create_account_method': 'create_account_windows',
'gather_accounts_method': 'gather_accounts_windows',
'_protocols': ['rdp', 'ssh', 'vnc'],
2022-09-01 09:42:48 +00:00
'su_enabled': False
2022-08-10 11:27:08 +00:00
},
2022-09-14 12:55:14 +00:00
cls.UNIX: {
2022-08-10 11:27:08 +00:00
'_protocols': ['ssh', 'vnc']
}
2022-04-30 15:19:43 +00:00
}
2022-09-15 13:20:56 +00:00
class DeviceTypes(PlatformMixin, ChoicesMixin, models.TextChoices):
2022-09-14 12:55:14 +00:00
GENERAL = 'general', _("General device")
2022-04-07 10:51:35 +00:00
SWITCH = 'switch', _("Switch")
ROUTER = 'router', _("Router")
FIREWALL = 'firewall', _("Firewall")
2022-08-22 03:47:45 +00:00
class DatabaseTypes(PlatformMixin, ChoicesMixin, models.TextChoices):
2022-04-07 10:51:35 +00:00
MYSQL = 'mysql', 'MySQL'
MARIADB = 'mariadb', 'MariaDB'
POSTGRESQL = 'postgresql', 'PostgreSQL'
ORACLE = 'oracle', 'Oracle'
SQLSERVER = 'sqlserver', 'SQLServer'
MONGODB = 'mongodb', 'MongoDB'
REDIS = 'redis', 'Redis'
2022-04-30 15:19:43 +00:00
@classmethod
2022-08-10 11:27:08 +00:00
def platform_constraints(cls):
2022-04-30 15:19:43 +00:00
meta = {}
2022-05-05 08:18:05 +00:00
for name, label in cls.choices:
2022-04-30 15:19:43 +00:00
meta[name] = {
2022-09-14 12:55:14 +00:00
'_protocols': [name],
'gather_facts_method': f'gather_facts_{name}',
'verify_account_method': f'verify_account_{name}',
'change_password_method': f'change_password_{name}',
'create_account_method': f'create_account_{name}',
'gather_accounts_method': f'gather_accounts_{name}',
2022-04-30 15:19:43 +00:00
}
2022-05-02 13:37:42 +00:00
return meta
2022-04-07 10:51:35 +00:00
2022-04-30 15:19:43 +00:00
2022-08-22 03:47:45 +00:00
class WebTypes(PlatformMixin, ChoicesMixin, models.TextChoices):
2022-09-15 13:20:56 +00:00
WEBSITE = 'website', _('General website')
2022-04-07 10:51:35 +00:00
2022-08-22 03:47:45 +00:00
class CloudTypes(PlatformMixin, ChoicesMixin, models.TextChoices):
2022-04-07 10:51:35 +00:00
K8S = 'k8s', 'Kubernetes'
2022-09-07 09:12:53 +00:00
@classmethod
def platform_constraints(cls):
return {
cls.K8S: {
'_protocols': ['k8s']
}
}
2022-04-07 10:51:35 +00:00
2022-08-22 03:47:45 +00:00
class AllTypes(ChoicesMixin, metaclass=IncludesTextChoicesMeta):
2022-04-07 10:51:35 +00:00
choices: list
includes = [
2022-09-15 13:20:56 +00:00
HostTypes, DeviceTypes, DatabaseTypes,
2022-08-05 11:11:17 +00:00
WebTypes, CloudTypes
2022-04-07 10:51:35 +00:00
]
2022-05-05 08:18:05 +00:00
@classmethod
2022-08-10 11:27:08 +00:00
def get_constraints(cls, category, tp):
constraints = PlatformMixin.platform_constraints()
category_constraints = Category.platform_constraints().get(category) or {}
constraints.update(category_constraints)
2022-05-05 08:18:05 +00:00
types_cls = dict(cls.category_types()).get(category)
if not types_cls:
2022-08-10 11:27:08 +00:00
return constraints
type_constraints = types_cls.platform_constraints().get(tp) or {}
constraints.update(type_constraints)
2022-05-05 08:18:05 +00:00
2022-08-10 11:27:08 +00:00
_protocols = constraints.pop('_protocols', [])
2022-05-05 08:18:05 +00:00
default_ports = Protocol.default_ports()
2022-08-10 11:27:08 +00:00
protocols = []
for p in _protocols:
2022-05-05 08:18:05 +00:00
port = default_ports.get(p, 0)
2022-08-10 11:27:08 +00:00
protocols.append({'name': p, 'port': port})
constraints['protocols'] = protocols
return constraints
2022-05-05 08:18:05 +00:00
2022-04-30 15:19:43 +00:00
@classmethod
def category_types(cls):
return (
(Category.HOST, HostTypes),
2022-09-15 13:20:56 +00:00
(Category.DEVICE, DeviceTypes),
2022-04-30 15:19:43 +00:00
(Category.DATABASE, DatabaseTypes),
2022-08-05 11:11:17 +00:00
(Category.WEB, WebTypes),
2022-04-30 15:19:43 +00:00
(Category.CLOUD, CloudTypes)
)
2022-04-28 14:54:18 +00:00
@classmethod
def grouped_choices(cls):
2022-04-30 15:19:43 +00:00
grouped_types = [(str(ca), tp.choices) for ca, tp in cls.category_types()]
2022-04-28 14:54:18 +00:00
return grouped_types
@classmethod
def grouped_choices_to_objs(cls):
choices = cls.serialize_to_objs(Category.choices)
mapper = dict(cls.grouped_choices())
for choice in choices:
children = cls.serialize_to_objs(mapper[choice['value']])
choice['children'] = children
return choices
@staticmethod
def serialize_to_objs(choices):
title = ['value', 'display_name']
return [dict(zip(title, choice)) for choice in choices]
2022-08-08 02:41:37 +00:00
@staticmethod
def choice_to_node(choice, pid, opened=True, is_parent=True, meta=None):
node = TreeNode(**{
'id': choice.name,
'name': choice.label,
'title': choice.label,
'pId': pid,
'open': opened,
'isParent': is_parent,
})
if meta:
node.meta = meta
return node
@classmethod
def to_tree_nodes(cls):
root = TreeNode(id='ROOT', name='类型节点', title='类型节点')
nodes = [root]
for category, types in cls.category_types():
category_node = cls.choice_to_node(category, 'ROOT', meta={'type': 'category'})
nodes.append(category_node)
for tp in types:
tp_node = cls.choice_to_node(tp, category_node.id, meta={'type': 'type'})
nodes.append(tp_node)
return nodes
2022-04-28 14:54:18 +00:00
2022-08-22 03:47:45 +00:00
class Protocol(ChoicesMixin, models.TextChoices):
2022-04-07 10:51:35 +00:00
ssh = 'ssh', 'SSH'
2022-09-07 09:12:53 +00:00
sftp = 'sftp', 'SFTP'
2022-04-07 10:51:35 +00:00
rdp = 'rdp', 'RDP'
telnet = 'telnet', 'Telnet'
vnc = 'vnc', 'VNC'
mysql = 'mysql', 'MySQL'
mariadb = 'mariadb', 'MariaDB'
oracle = 'oracle', 'Oracle'
postgresql = 'postgresql', 'PostgreSQL'
sqlserver = 'sqlserver', 'SQLServer'
redis = 'redis', 'Redis'
mongodb = 'mongodb', 'MongoDB'
k8s = 'k8s', 'K8S'
2022-08-24 08:14:32 +00:00
http = 'http', 'HTTP'
https = 'https', 'HTTPS'
2022-04-07 10:51:35 +00:00
@classmethod
def host_protocols(cls):
return [cls.ssh, cls.rdp, cls.telnet, cls.vnc]
@classmethod
def db_protocols(cls):
return [
cls.mysql, cls.mariadb, cls.postgresql, cls.oracle,
cls.sqlserver, cls.redis, cls.mongodb,
]
2022-04-30 15:19:43 +00:00
@classmethod
def default_ports(cls):
return {
cls.ssh: 22,
2022-09-07 09:12:53 +00:00
cls.sftp: 22,
2022-04-30 15:19:43 +00:00
cls.rdp: 3389,
cls.vnc: 5900,
cls.telnet: 21,
cls.mysql: 3306,
cls.mariadb: 3306,
cls.postgresql: 5432,
cls.oracle: 1521,
cls.sqlserver: 1433,
cls.mongodb: 27017,
cls.redis: 6379,
2022-08-24 08:14:32 +00:00
cls.k8s: 0,
cls.http: 80,
cls.https: 443
2022-04-30 15:19:43 +00:00
}