mirror of https://github.com/jumpserver/jumpserver
feat: 支持纳管 clickhouse[Web Terminal]
parent
4ceaba60ed
commit
262d070f3c
|
@ -27,6 +27,7 @@ class AppType(models.TextChoices):
|
||||||
sqlserver = 'sqlserver', 'SQLServer'
|
sqlserver = 'sqlserver', 'SQLServer'
|
||||||
redis = 'redis', 'Redis'
|
redis = 'redis', 'Redis'
|
||||||
mongodb = 'mongodb', 'MongoDB'
|
mongodb = 'mongodb', 'MongoDB'
|
||||||
|
clickhouse = 'clickhouse', 'ClickHouse'
|
||||||
|
|
||||||
# remote-app category
|
# remote-app category
|
||||||
chrome = 'chrome', 'Chrome'
|
chrome = 'chrome', 'Chrome'
|
||||||
|
@ -42,7 +43,7 @@ class AppType(models.TextChoices):
|
||||||
return {
|
return {
|
||||||
AppCategory.db: [
|
AppCategory.db: [
|
||||||
cls.mysql, cls.mariadb, cls.oracle, cls.pgsql,
|
cls.mysql, cls.mariadb, cls.oracle, cls.pgsql,
|
||||||
cls.sqlserver, cls.redis, cls.mongodb
|
cls.sqlserver, cls.redis, cls.mongodb, cls.clickhouse
|
||||||
],
|
],
|
||||||
AppCategory.remote_app: [
|
AppCategory.remote_app: [
|
||||||
cls.chrome, cls.mysql_workbench,
|
cls.chrome, cls.mysql_workbench,
|
||||||
|
@ -82,4 +83,4 @@ class AppType(models.TextChoices):
|
||||||
|
|
||||||
if AppCategory.is_xpack(category):
|
if AppCategory.is_xpack(category):
|
||||||
return True
|
return True
|
||||||
return tp in ['oracle', 'postgresql', 'sqlserver']
|
return tp in ['oracle', 'postgresql', 'sqlserver', 'clickhouse']
|
||||||
|
|
|
@ -6,6 +6,7 @@ from .pgsql import *
|
||||||
from .sqlserver import *
|
from .sqlserver import *
|
||||||
from .redis import *
|
from .redis import *
|
||||||
from .mongodb import *
|
from .mongodb import *
|
||||||
|
from .clickhouse import *
|
||||||
|
|
||||||
from .chrome import *
|
from .chrome import *
|
||||||
from .mysql_workbench import *
|
from .mysql_workbench import *
|
||||||
|
|
|
@ -0,0 +1,10 @@
|
||||||
|
from rest_framework import serializers
|
||||||
|
from django.utils.translation import ugettext_lazy as _
|
||||||
|
|
||||||
|
from ..application_category import DBSerializer
|
||||||
|
|
||||||
|
__all__ = ['ClickHouseSerializer']
|
||||||
|
|
||||||
|
|
||||||
|
class ClickHouseSerializer(DBSerializer):
|
||||||
|
port = serializers.IntegerField(default=9000, label=_('Port'), allow_null=True)
|
|
@ -31,6 +31,7 @@ type_serializer_classes_mapping = {
|
||||||
const.AppType.sqlserver.value: application_type.SQLServerSerializer,
|
const.AppType.sqlserver.value: application_type.SQLServerSerializer,
|
||||||
const.AppType.redis.value: application_type.RedisSerializer,
|
const.AppType.redis.value: application_type.RedisSerializer,
|
||||||
const.AppType.mongodb.value: application_type.MongoDBSerializer,
|
const.AppType.mongodb.value: application_type.MongoDBSerializer,
|
||||||
|
const.AppType.clickhouse.value: application_type.ClickHouseSerializer,
|
||||||
# cloud
|
# cloud
|
||||||
const.AppType.k8s.value: application_type.K8SSerializer
|
const.AppType.k8s.value: application_type.K8SSerializer
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,6 +34,7 @@ class ProtocolMixin:
|
||||||
sqlserver = 'sqlserver', 'SQLServer'
|
sqlserver = 'sqlserver', 'SQLServer'
|
||||||
redis = 'redis', 'Redis'
|
redis = 'redis', 'Redis'
|
||||||
mongodb = 'mongodb', 'MongoDB'
|
mongodb = 'mongodb', 'MongoDB'
|
||||||
|
clickhouse = 'clickhouse', 'ClickHouse'
|
||||||
k8s = 'k8s', 'K8S'
|
k8s = 'k8s', 'K8S'
|
||||||
|
|
||||||
SUPPORT_PUSH_PROTOCOLS = [Protocol.ssh, Protocol.rdp]
|
SUPPORT_PUSH_PROTOCOLS = [Protocol.ssh, Protocol.rdp]
|
||||||
|
@ -46,7 +47,7 @@ class ProtocolMixin:
|
||||||
]
|
]
|
||||||
APPLICATION_CATEGORY_DB_PROTOCOLS = [
|
APPLICATION_CATEGORY_DB_PROTOCOLS = [
|
||||||
Protocol.mysql, Protocol.mariadb, Protocol.oracle,
|
Protocol.mysql, Protocol.mariadb, Protocol.oracle,
|
||||||
Protocol.postgresql, Protocol.sqlserver,
|
Protocol.postgresql, Protocol.sqlserver, Protocol.clickhouse,
|
||||||
Protocol.redis, Protocol.mongodb
|
Protocol.redis, Protocol.mongodb
|
||||||
]
|
]
|
||||||
APPLICATION_CATEGORY_CLOUD_PROTOCOLS = [
|
APPLICATION_CATEGORY_CLOUD_PROTOCOLS = [
|
||||||
|
|
|
@ -38,6 +38,7 @@ class Session(OrgModelMixin):
|
||||||
POSTGRESQL = 'postgresql', 'postgresql'
|
POSTGRESQL = 'postgresql', 'postgresql'
|
||||||
REDIS = 'redis', 'redis'
|
REDIS = 'redis', 'redis'
|
||||||
MONGODB = 'mongodb', 'MongoDB'
|
MONGODB = 'mongodb', 'MongoDB'
|
||||||
|
CLICKHOUSE = 'clickhouse', 'ClickHouse'
|
||||||
K8S = 'k8s', 'kubernetes'
|
K8S = 'k8s', 'kubernetes'
|
||||||
|
|
||||||
id = models.UUIDField(default=uuid.uuid4, primary_key=True)
|
id = models.UUIDField(default=uuid.uuid4, primary_key=True)
|
||||||
|
@ -150,7 +151,7 @@ class Session(OrgModelMixin):
|
||||||
def db_protocols(self):
|
def db_protocols(self):
|
||||||
_PROTOCOL = self.PROTOCOL
|
_PROTOCOL = self.PROTOCOL
|
||||||
return [_PROTOCOL.MYSQL, _PROTOCOL.MARIADB, _PROTOCOL.ORACLE,
|
return [_PROTOCOL.MYSQL, _PROTOCOL.MARIADB, _PROTOCOL.ORACLE,
|
||||||
_PROTOCOL.POSTGRESQL, _PROTOCOL.SQLSERVER,
|
_PROTOCOL.POSTGRESQL, _PROTOCOL.SQLSERVER, _PROTOCOL.CLICKHOUSE,
|
||||||
_PROTOCOL.REDIS, _PROTOCOL.MONGODB]
|
_PROTOCOL.REDIS, _PROTOCOL.MONGODB]
|
||||||
|
|
||||||
@property
|
@property
|
||||||
|
|
Loading…
Reference in New Issue