mirror of
https://github.com/jumpserver/jumpserver.git
synced 2025-09-18 16:39:28 +00:00
Config (#3502)
* [Update] 修改config * [Update] 移动存储设置到到terminal中 * [Update] 修改permission 查看 * [Update] pre merge * [Update] 录像存储 * [Update] 命令存储 * [Update] 添加存储测试可连接性 * [Update] 修改 meta 值的 key 为大写 * [Update] 修改 Terminal 相关 Storage 配置 * [Update] 删除之前获取录像/命令存储的代码 * [Update] 修改导入失败 * [Update] 迁移文件添加default存储 * [Update] 删除之前代码,添加help_text信息 * [Update] 删除之前代码 * [Update] 删除之前代码 * [Update] 抽象命令/录像存储 APIView * [Update] 抽象命令/录像存储 APIView 1 * [Update] 抽象命令/录像存储 DictField * [Update] 抽象命令/录像存储列表页面 * [Update] 修复CustomDictField的bug * [Update] RemoteApp 页面添加 hidden * [Update] 用户页面添加用户关联授权 * [Update] 修改存储测试可连接性 target * [Update] 修改配置 * [Update] 修改存储前端 Form 渲染逻辑 * [Update] 修改存储细节 * [Update] 统一存储类型到 const 文件 * [Update] 修改迁移文件及Model,创建默认存储 * [Update] 修改迁移文件及Model初始化默认数据 * [Update] 修改迁移文件 * [Update] 修改迁移文件 * [Update] 修改迁移文件 * [Update] 修改迁移文件 * [Update] 修改迁移文件 * [Update] 修改迁移文件 * [Update] 修改迁移文件 * [Update] 限制删除默认存储配置,只允许创建扩展的存储类型 * [Update] 修改ip字段长度 * [Update] 修改ip字段长度 * [Update] 修改一些css * [Update] 修改关联 * [Update] 添加操作日志定时清理 * [Update] 修改记录syslog的instance encoder * [Update] 忽略登录产生的操作日志 * [Update] 限制更新存储时不覆盖原有AK SK 等字段 * [Update] 修改迁移文件添加comment字段 * [Update] 修改迁移文件 * [Update] 添加 comment 字段 * [Update] 修改默认存储no -> null * [Update] 修改细节 * [Update] 更新翻译(存储配置 * [Update] 修改定时任务注册,修改系统用户资产、节点关系api * [Update] 添加监控磁盘任务 * [Update] 修改session * [Update] 拆分serializer * [Update] 还原setting原来的manager
This commit is contained in:
@@ -0,0 +1,47 @@
|
||||
# Generated by Django 2.2.5 on 2019-11-22 10:07
|
||||
|
||||
import common.fields.model
|
||||
from django.db import migrations, models
|
||||
import uuid
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('terminal', '0015_auto_20190923_1529'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name='CommandStorage',
|
||||
fields=[
|
||||
('id', models.UUIDField(default=uuid.uuid4, primary_key=True, serialize=False)),
|
||||
('created_by', models.CharField(blank=True, max_length=32, null=True, verbose_name='Created by')),
|
||||
('date_created', models.DateTimeField(auto_now_add=True, null=True, verbose_name='Date created')),
|
||||
('date_updated', models.DateTimeField(auto_now=True, verbose_name='Date updated')),
|
||||
('name', models.CharField(max_length=32, unique=True, verbose_name='Name')),
|
||||
('type', models.CharField(choices=[('null', 'Null'), ('server', 'Server'), ('es', 'Elasticsearch')], default='server', max_length=16, verbose_name='Type')),
|
||||
('meta', common.fields.model.EncryptJsonDictTextField(default={})),
|
||||
('comment', models.TextField(blank=True, default='', max_length=128, verbose_name='Comment')),
|
||||
],
|
||||
options={
|
||||
'abstract': False,
|
||||
},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name='ReplayStorage',
|
||||
fields=[
|
||||
('id', models.UUIDField(default=uuid.uuid4, primary_key=True, serialize=False)),
|
||||
('created_by', models.CharField(blank=True, max_length=32, null=True, verbose_name='Created by')),
|
||||
('date_created', models.DateTimeField(auto_now_add=True, null=True, verbose_name='Date created')),
|
||||
('date_updated', models.DateTimeField(auto_now=True, verbose_name='Date updated')),
|
||||
('name', models.CharField(max_length=32, unique=True, verbose_name='Name')),
|
||||
('type', models.CharField(choices=[('null', 'Null'), ('server', 'Server'), ('s3', 'S3'), ('oss', 'OSS'), ('azure', 'Azure')], default='server', max_length=16, verbose_name='Type')),
|
||||
('meta', common.fields.model.EncryptJsonDictTextField(default={})),
|
||||
('comment', models.TextField(blank=True, default='', max_length=128, verbose_name='Comment')),
|
||||
],
|
||||
options={
|
||||
'abstract': False,
|
||||
},
|
||||
),
|
||||
]
|
86
apps/terminal/migrations/0017_auto_20191125_0931.py
Normal file
86
apps/terminal/migrations/0017_auto_20191125_0931.py
Normal file
@@ -0,0 +1,86 @@
|
||||
# Generated by Django 2.2.5 on 2019-11-25 01:31
|
||||
|
||||
from django.db import migrations
|
||||
|
||||
|
||||
def get_storage_data(s):
|
||||
from common.utils import get_signer
|
||||
import json
|
||||
signer = get_signer()
|
||||
value = s.value
|
||||
encrypted = s.encrypted
|
||||
if encrypted:
|
||||
value = signer.unsign(value)
|
||||
try:
|
||||
value = json.loads(value)
|
||||
except:
|
||||
value = {}
|
||||
return value
|
||||
|
||||
|
||||
def get_setting(apps, schema_editor, key):
|
||||
model = apps.get_model('settings', 'Setting')
|
||||
db_alias = schema_editor.connection.alias
|
||||
setting = model.objects.using(db_alias).filter(name=key)
|
||||
if not setting:
|
||||
return
|
||||
return setting[0]
|
||||
|
||||
|
||||
def init_storage_data(model):
|
||||
model.objects.update_or_create(
|
||||
name='null', type='null',
|
||||
defaults={
|
||||
'name': 'null', 'type': 'null',
|
||||
'comment': "Do not save"
|
||||
}
|
||||
)
|
||||
model.objects.update_or_create(
|
||||
name='default', type='server',
|
||||
defaults={
|
||||
'name': 'default', 'type': 'server',
|
||||
'comment': "Store locally"
|
||||
}
|
||||
)
|
||||
|
||||
|
||||
def migrate_command_storage(apps, schema_editor):
|
||||
model = apps.get_model("terminal", "CommandStorage")
|
||||
init_storage_data(model)
|
||||
|
||||
setting = get_setting(apps, schema_editor, "TERMINAL_COMMAND_STORAGE")
|
||||
if not setting:
|
||||
return
|
||||
values = get_storage_data(setting)
|
||||
for name, meta in values.items():
|
||||
tp = meta.pop("TYPE")
|
||||
if not tp or name in ['default', 'null']:
|
||||
continue
|
||||
model.objects.create(name=name, type=tp, meta=meta)
|
||||
|
||||
|
||||
def migrate_replay_storage(apps, schema_editor):
|
||||
model = apps.get_model("terminal", "ReplayStorage")
|
||||
init_storage_data(model)
|
||||
|
||||
setting = get_setting(apps, schema_editor, "TERMINAL_REPLAY_STORAGE")
|
||||
if not setting:
|
||||
return
|
||||
values = get_storage_data(setting)
|
||||
for name, meta in values.items():
|
||||
tp = meta.pop("TYPE", None)
|
||||
if not tp or name in ['default', 'null']:
|
||||
continue
|
||||
model.objects.create(name=name, type=tp, meta=meta)
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('terminal', '0016_commandstorage_replaystorage'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.RunPython(migrate_command_storage),
|
||||
migrations.RunPython(migrate_replay_storage),
|
||||
]
|
67
apps/terminal/migrations/0018_auto_20191202_1010.py
Normal file
67
apps/terminal/migrations/0018_auto_20191202_1010.py
Normal file
@@ -0,0 +1,67 @@
|
||||
# Generated by Django 2.2.7 on 2019-12-02 02:10
|
||||
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('terminal', '0017_auto_20191125_0931'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.RemoveField(
|
||||
model_name='session',
|
||||
name='date_last_active',
|
||||
),
|
||||
migrations.AlterField(
|
||||
model_name='session',
|
||||
name='remote_addr',
|
||||
field=models.CharField(blank=True, max_length=128, null=True,
|
||||
verbose_name='Remote addr'),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='session',
|
||||
name='asset_id',
|
||||
field=models.CharField(blank=True, db_index=True, default='',
|
||||
max_length=36),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='session',
|
||||
name='system_user_id',
|
||||
field=models.CharField(blank=True, db_index=True, default='',
|
||||
max_length=36),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='session',
|
||||
name='user_id',
|
||||
field=models.CharField(blank=True, db_index=True, default='',
|
||||
max_length=36),
|
||||
),
|
||||
migrations.AlterField(
|
||||
model_name='session',
|
||||
name='asset',
|
||||
field=models.CharField(db_index=True, max_length=1024,
|
||||
verbose_name='Asset'),
|
||||
),
|
||||
migrations.AlterField(
|
||||
model_name='session',
|
||||
name='protocol',
|
||||
field=models.CharField(
|
||||
choices=[('ssh', 'ssh'), ('rdp', 'rdp'), ('vnc', 'vnc'),
|
||||
('telnet', 'telnet')], db_index=True, default='ssh',
|
||||
max_length=8),
|
||||
),
|
||||
migrations.AlterField(
|
||||
model_name='session',
|
||||
name='system_user',
|
||||
field=models.CharField(db_index=True, max_length=128,
|
||||
verbose_name='System user'),
|
||||
),
|
||||
migrations.AlterField(
|
||||
model_name='session',
|
||||
name='user',
|
||||
field=models.CharField(db_index=True, max_length=128,
|
||||
verbose_name='User'),
|
||||
),
|
||||
]
|
Reference in New Issue
Block a user