valar 1.0.28__py3-none-any.whl → 1.1.0__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- migrations/0001_initial.py +141 -0
- models/__init__.py +1 -0
- models/frame.py +30 -0
- valar/data/models.py → models/meta.py +7 -36
- {valar-1.0.28.dist-info → valar-1.1.0.dist-info}/METADATA +1 -1
- valar-1.1.0.dist-info/RECORD +12 -0
- valar-1.1.0.dist-info/top_level.txt +3 -0
- valar/channels/__init__.py +0 -1
- valar/channels/consumer.py +0 -48
- valar/channels/executer.py +0 -13
- valar/channels/mapping.py +0 -21
- valar/channels/sender.py +0 -60
- valar/channels/views.py +0 -12
- valar/core/counter.py +0 -9
- valar/core/dao/__init__.py +0 -0
- valar/core/dao/_mon_array2tree.py +0 -18
- valar/core/dao/dao_base.py +0 -50
- valar/core/dao/dao_mon.py +0 -76
- valar/core/dao/dao_orm.py +0 -96
- valar/core/dao/engine.py +0 -12
- valar/core/dao/engine_minio.py +0 -90
- valar/core/dao/engine_mon.py +0 -34
- valar/core/dao/engine_orm.py +0 -25
- valar/core/dao/model_mon.py +0 -24
- valar/core/dao/model_orm.py +0 -195
- valar/core/dao/query_mon.py +0 -12
- valar/core/dao/query_orm.py +0 -43
- valar/core/dao/utils_orm.py +0 -87
- valar/core/dao_abstract.py +0 -63
- valar/core/meta/__init__.py +0 -0
- valar/core/meta/defaults/__init__.py +0 -0
- valar/core/meta/defaults/field_keys_default.py +0 -17
- valar/core/meta/defaults/field_values_default.py +0 -85
- valar/core/meta/defaults/frame_defaults.py +0 -136
- valar/core/meta/defaults/view_defaults.py +0 -7
- valar/core/meta/field_orm.py +0 -144
- valar/core/meta/init_meta_frame.py +0 -30
- valar/core/meta/meta_orm.py +0 -69
- valar/core/middleware.py +0 -20
- valar/core/response.py +0 -7
- valar/core/singleton_meta.py +0 -6
- valar/data/__init__.py +0 -0
- valar/data/migrations/__init__.py +0 -0
- valar/data/urls.py +0 -18
- valar/data/views/__init__.py +0 -0
- valar/data/views/handler.py +0 -41
- valar/data/views/rest.py +0 -89
- valar-1.0.28.dist-info/RECORD +0 -49
- valar-1.0.28.dist-info/top_level.txt +0 -1
- {valar → frame}/__init__.py +0 -0
- {valar/core → migrations}/__init__.py +0 -0
- /valar/core/valar_models.py → /models/core.py +0 -0
- {valar-1.0.28.dist-info → valar-1.1.0.dist-info}/WHEEL +0 -0
- {valar-1.0.28.dist-info → valar-1.1.0.dist-info}/licenses/LICENSE +0 -0
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
__mf_common__ = ['prop','name']
|
|
2
|
-
|
|
3
|
-
meta_field_key_defaults = {
|
|
4
|
-
'data.Meta': {
|
|
5
|
-
'default': ('pick', ['entity','name']),
|
|
6
|
-
},
|
|
7
|
-
'data.MetaView': {
|
|
8
|
-
'list': ('pick', ['meta_id','code','view_name']),
|
|
9
|
-
},
|
|
10
|
-
'data.MetaField': {
|
|
11
|
-
'add': ('pick',['prop','domain','name']),
|
|
12
|
-
'tool': ('pick',[*__mf_common__,'domain','tool','refer','format']),
|
|
13
|
-
'rest': ('pick',[*__mf_common__,'not_null','allow_edit','allow_sort','allow_search','allow_download','allow_upload','allow_update']),
|
|
14
|
-
'table': ('pick',[*__mf_common__,'unit','column_width','fixed','align','edit_on_table','hide_on_table','header_color','cell_color']),
|
|
15
|
-
'form': ('pick',[*__mf_common__,'hide_on_form','hide_on_form_insert','hide_on_form_edit','hide_on_form_branch','hide_on_form_leaf','span']),
|
|
16
|
-
}
|
|
17
|
-
}
|
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
meta_field_value_defaults = {
|
|
3
|
-
'data.MetaFieldDomain':{
|
|
4
|
-
"__init__":{
|
|
5
|
-
"default_id":{
|
|
6
|
-
"tool":"tree"
|
|
7
|
-
},
|
|
8
|
-
"search_id":{
|
|
9
|
-
"tool":"tree"
|
|
10
|
-
},
|
|
11
|
-
"tools":{
|
|
12
|
-
"tool":"tree",
|
|
13
|
-
"refer": {
|
|
14
|
-
"display":"code"
|
|
15
|
-
}
|
|
16
|
-
},
|
|
17
|
-
"align":{
|
|
18
|
-
"tool":"set",
|
|
19
|
-
"format":{
|
|
20
|
-
"set": {
|
|
21
|
-
'left':'左对齐',
|
|
22
|
-
'right':'右对齐',
|
|
23
|
-
'center':'剧中对齐',
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
},
|
|
29
|
-
'data.MetaField':{
|
|
30
|
-
"__init__":{
|
|
31
|
-
"column_width":{
|
|
32
|
-
'unit':'px'
|
|
33
|
-
},
|
|
34
|
-
"fixed":{
|
|
35
|
-
"tool":"set",
|
|
36
|
-
"format":{
|
|
37
|
-
"set": {
|
|
38
|
-
'left':'左侧固定',
|
|
39
|
-
'right':'右侧固定',
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
},
|
|
43
|
-
"align":{
|
|
44
|
-
"tool":"set",
|
|
45
|
-
"format":{
|
|
46
|
-
"set": {
|
|
47
|
-
'left':'左对齐',
|
|
48
|
-
'right':'右对齐',
|
|
49
|
-
'center':'剧中对齐',
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
},
|
|
53
|
-
"prop":{
|
|
54
|
-
'allow_edit': False,
|
|
55
|
-
'column_width': 120
|
|
56
|
-
},
|
|
57
|
-
"domain":{
|
|
58
|
-
'allow_edit': False,
|
|
59
|
-
'column_width': 120,
|
|
60
|
-
},
|
|
61
|
-
"tool":{
|
|
62
|
-
'column_width': 100,
|
|
63
|
-
'tool': 'tree',
|
|
64
|
-
'refer': {
|
|
65
|
-
'entity':'data.MetaFieldTool',
|
|
66
|
-
'includes': {'metafielddomain__name':'$domain'},
|
|
67
|
-
'value': 'code'
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
},
|
|
71
|
-
"span":{
|
|
72
|
-
'column_width': 100,
|
|
73
|
-
"format": { "min": 0, "max": 24, "step": 1, "precision": 0, "step_strictly": True }
|
|
74
|
-
},
|
|
75
|
-
"refer":{
|
|
76
|
-
'allow_edit': False,
|
|
77
|
-
'column_width': 80
|
|
78
|
-
},
|
|
79
|
-
"format":{
|
|
80
|
-
'allow_edit': False,
|
|
81
|
-
'column_width': 80
|
|
82
|
-
},
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
}
|
|
@@ -1,136 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
meta_field_tool = [
|
|
3
|
-
{'id': 2, 'sort': 32, 'pid': 7, 'isLeaf': True, 'name': '输入框', 'code': 'text'},
|
|
4
|
-
{'id': 3, 'sort': 17, 'pid': 0, 'isLeaf': False, 'name': 'SPEC', 'code': '特殊工具集'},
|
|
5
|
-
{'id': 5, 'sort': 22, 'pid': 0, 'isLeaf': False, 'name': 'DATE', 'code': '日期时间工具集'},
|
|
6
|
-
{'id': 6, 'sort': 21, 'pid': 8, 'isLeaf': True, 'name': '数字输入', 'code': 'number'},
|
|
7
|
-
{'id': 7, 'sort': 36, 'pid': 0, 'isLeaf': False, 'name': 'TEXT', 'code': '文本工具集'},
|
|
8
|
-
{'id': 8, 'sort': 26, 'pid': 0, 'isLeaf': False, 'name': 'NUMB', 'code': '数字工具集'},
|
|
9
|
-
{'id': 9, 'sort': 10, 'pid': 0, 'isLeaf': False, 'name': 'FILE', 'code': '文件工具集'},
|
|
10
|
-
{'id': 10, 'sort': 27, 'pid': 0, 'isLeaf': False, 'name': 'BOOL', 'code': '逻辑工具集'},
|
|
11
|
-
{'id': 11, 'sort': 31, 'pid': 0, 'isLeaf': False, 'name': 'LIST', 'code': '列表工具集'},
|
|
12
|
-
{'id': 12, 'sort': 8, 'pid': 3, 'isLeaf': True, 'name': '对象', 'code': 'object'},
|
|
13
|
-
{'id': 13, 'sort': 5, 'pid': 9, 'isLeaf': True, 'name': '图片上传', 'code': 'image'},
|
|
14
|
-
{'id': 14, 'sort': 2, 'pid': 9, 'isLeaf': True, 'name': '文件上传', 'code': 'file'},
|
|
15
|
-
{'id': 15, 'sort': 13, 'pid': 9, 'isLeaf': True, 'name': '富文本', 'code': 'rich'},
|
|
16
|
-
{'id': 17, 'sort': 11, 'pid': 10, 'isLeaf': True, 'name': '开关', 'code': 'switch'},
|
|
17
|
-
{'id': 18, 'sort': 7, 'pid': 3, 'isLeaf': True, 'name': '元数据', 'code': 'meta'},
|
|
18
|
-
{'id': 19, 'sort': 9, 'pid': 7, 'isLeaf': True, 'name': '颜色选择', 'code': 'color'},
|
|
19
|
-
{'id': 20, 'sort': 14, 'pid': 11, 'isLeaf': True, 'name': '穿梭框', 'code': 'transfer'},
|
|
20
|
-
{'id': 21, 'sort': 16, 'pid': 7, 'isLeaf': True, 'name': '自动填充', 'code': 'auto'},
|
|
21
|
-
{'id': 22, 'sort': 35, 'pid': 5, 'isLeaf': True, 'name': '日期选择', 'code': 'date'},
|
|
22
|
-
{'id': 23, 'sort': 12, 'pid': 10, 'isLeaf': True, 'name': '逻辑选择', 'code': 'boolean'},
|
|
23
|
-
{'id': 24, 'sort': 24, 'pid': 11, 'isLeaf': True, 'name': '列表选择', 'code': 'select'},
|
|
24
|
-
{'id': 25, 'sort': 15, 'pid': 11, 'isLeaf': True, 'name': '树形选择', 'code': 'tree'},
|
|
25
|
-
{'id': 26, 'sort': 23, 'pid': 11, 'isLeaf': True, 'name': '及联选择', 'code': 'cascade'},
|
|
26
|
-
{'id': 28, 'sort': 25, 'pid': 7, 'isLeaf': True, 'name': '图标', 'code': 'icon'},
|
|
27
|
-
{'id': 31, 'sort': 6, 'pid': 0, 'isLeaf': True, 'name': '无', 'code': 'none'},
|
|
28
|
-
{'id': 32, 'sort': 30, 'pid': 7, 'isLeaf': True, 'name': '文本框', 'code': 'textarea'},
|
|
29
|
-
{'id': 33, 'sort': 18, 'pid': 36, 'isLeaf': True, 'name': '时间区间', 'code': 'timerange'},
|
|
30
|
-
{'id': 35, 'sort': 33, 'pid': 5, 'isLeaf': True, 'name': '时间选择', 'code': 'time'},
|
|
31
|
-
{'id': 36, 'sort': 20, 'pid': 0, 'isLeaf': False, 'name': 'RANGE', 'code': '区间工具集'},
|
|
32
|
-
{'id': 37, 'sort': 38, 'pid': 36, 'isLeaf': True, 'name': '日期区间', 'code': 'daterange'},
|
|
33
|
-
{'id': 39, 'sort': 3, 'pid': 36, 'isLeaf': True, 'name': '多日期', 'code': 'dates'},
|
|
34
|
-
{'id': 54, 'sort': 54, 'pid': 7, 'isLeaf': True, 'name': '集合', 'code': 'set'}
|
|
35
|
-
]
|
|
36
|
-
|
|
37
|
-
meta_field_domain = [
|
|
38
|
-
{
|
|
39
|
-
'name': 'CharField',
|
|
40
|
-
'default_id': 'text', 'align': 'left',
|
|
41
|
-
'tools': [
|
|
42
|
-
'text', 'number', 'meta', 'color', 'auto', 'date', 'select', 'tree', 'cascade', 'icon',
|
|
43
|
-
'textarea', 'timerange', 'daterange', 'dates', 'set'
|
|
44
|
-
]
|
|
45
|
-
},
|
|
46
|
-
{
|
|
47
|
-
'name': 'TextField',
|
|
48
|
-
'default_id': 'textarea', 'align': 'left',
|
|
49
|
-
'tools': ['text', 'textarea']
|
|
50
|
-
},
|
|
51
|
-
{
|
|
52
|
-
'name': 'BooleanField',
|
|
53
|
-
'default_id': 'switch', 'align': 'center',
|
|
54
|
-
'tools': ['switch', 'boolean']
|
|
55
|
-
},
|
|
56
|
-
{
|
|
57
|
-
'name': 'IntegerField',
|
|
58
|
-
'default_id': 'number', 'align': 'right',
|
|
59
|
-
'tools': ['number']
|
|
60
|
-
},
|
|
61
|
-
{
|
|
62
|
-
'name': 'FloatField',
|
|
63
|
-
'default_id': 'number', 'align': 'right',
|
|
64
|
-
'tools': ['number']
|
|
65
|
-
},
|
|
66
|
-
{
|
|
67
|
-
'name': 'ForeignKey',
|
|
68
|
-
'default_id': 'select', 'align': 'left',
|
|
69
|
-
'tools': ['select', 'tree', 'cascade']
|
|
70
|
-
},
|
|
71
|
-
{
|
|
72
|
-
'name': 'ManyToOneRel',
|
|
73
|
-
'default_id': 'select', 'align': 'center',
|
|
74
|
-
'tools': ['transfer', 'select', 'tree', 'cascade']
|
|
75
|
-
},
|
|
76
|
-
{
|
|
77
|
-
'name': 'ManyToManyField',
|
|
78
|
-
'default_id': 'select', 'align': 'center',
|
|
79
|
-
'tools': [ 'transfer', 'select', 'tree', 'cascade']
|
|
80
|
-
},
|
|
81
|
-
{
|
|
82
|
-
'name': 'ManyToManyRel',
|
|
83
|
-
'default_id': 'select', 'align': 'center',
|
|
84
|
-
'tools': ['transfer', 'select', 'tree', 'cascade']
|
|
85
|
-
},
|
|
86
|
-
{
|
|
87
|
-
'name': 'OneToOneRel',
|
|
88
|
-
'default_id': 'none', 'align': 'left',
|
|
89
|
-
'tools': []
|
|
90
|
-
},
|
|
91
|
-
{
|
|
92
|
-
'name': 'OneToOneField',
|
|
93
|
-
'default_id': 'none', 'align': 'left',
|
|
94
|
-
'tools': []
|
|
95
|
-
},
|
|
96
|
-
{
|
|
97
|
-
'name': 'DateField',
|
|
98
|
-
'default_id': 'date', 'align': 'center',
|
|
99
|
-
'tools': ['date']
|
|
100
|
-
},
|
|
101
|
-
{
|
|
102
|
-
'name': 'TimeField',
|
|
103
|
-
'default_id': 'time', 'align': 'center',
|
|
104
|
-
'tools': ['time']
|
|
105
|
-
},
|
|
106
|
-
{
|
|
107
|
-
'name': 'DateTimeField',
|
|
108
|
-
'default_id': 'date', 'align': 'center',
|
|
109
|
-
'tools': ['date']
|
|
110
|
-
},
|
|
111
|
-
{
|
|
112
|
-
'name': 'JSONField',
|
|
113
|
-
'default_id': 'object', 'align': 'center',
|
|
114
|
-
'tools': ['object']
|
|
115
|
-
},
|
|
116
|
-
{
|
|
117
|
-
'name': 'FileField',
|
|
118
|
-
'default_id': 'file', 'align': 'center',
|
|
119
|
-
'tools': ['image', 'file', 'rich']
|
|
120
|
-
},
|
|
121
|
-
{
|
|
122
|
-
'name': 'BigAutoField',
|
|
123
|
-
'default_id': 'none', 'align': 'right',
|
|
124
|
-
'tools': []
|
|
125
|
-
},
|
|
126
|
-
{
|
|
127
|
-
'name': 'UUIDField',
|
|
128
|
-
'default_id': 'none', 'align': 'left',
|
|
129
|
-
'tools': []
|
|
130
|
-
},
|
|
131
|
-
{
|
|
132
|
-
'name': 'Custom',
|
|
133
|
-
'default_id': 'none', 'align': 'left',
|
|
134
|
-
'tools': []
|
|
135
|
-
},
|
|
136
|
-
]
|
valar/core/meta/field_orm.py
DELETED
|
@@ -1,144 +0,0 @@
|
|
|
1
|
-
from deepmerge import always_merger
|
|
2
|
-
from django.db.models import ManyToOneRel, ForeignKey, ManyToManyRel, ManyToManyField,OneToOneField,OneToOneRel
|
|
3
|
-
from django.db.models import IntegerField, BooleanField, FloatField,TextField, CharField
|
|
4
|
-
from django.db.models import FileField, JSONField
|
|
5
|
-
from django.db.models import DateTimeField, TimeField, DateField
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
class OrmField:
|
|
10
|
-
|
|
11
|
-
def __init__(self, entity, field, is_tree):
|
|
12
|
-
self.entity = entity
|
|
13
|
-
self.model_field = field
|
|
14
|
-
self.is_tree = is_tree
|
|
15
|
-
self.not_null = not field.null
|
|
16
|
-
self.clazz = type(field)
|
|
17
|
-
self.multiple = self.clazz in [ManyToOneRel, ManyToManyField, ManyToManyRel]
|
|
18
|
-
|
|
19
|
-
self.prop = self.__prop__()
|
|
20
|
-
self.domain = self.__domain__()
|
|
21
|
-
self.model = self.__model__()
|
|
22
|
-
self.label = self.__label__()
|
|
23
|
-
self.column_width = self.__column_width__()
|
|
24
|
-
self.refer = self.__refer__()
|
|
25
|
-
self.align = self.___align__()
|
|
26
|
-
self.format = self.__formating__()
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
def json(self):
|
|
33
|
-
_field = {
|
|
34
|
-
"prop": self.prop,
|
|
35
|
-
"label": self.label,
|
|
36
|
-
"name": self.label,
|
|
37
|
-
"domain": self.domain,
|
|
38
|
-
"refer": self.refer,
|
|
39
|
-
"format": self.format,
|
|
40
|
-
"not_null": self.not_null,
|
|
41
|
-
"align": self.align,
|
|
42
|
-
"column_width": self.column_width,
|
|
43
|
-
}
|
|
44
|
-
if self.is_tree:
|
|
45
|
-
if self.prop in ['pid', 'isLeaf']:
|
|
46
|
-
_field['hide_on_table'] = True
|
|
47
|
-
_field['hide_on_form'] = True
|
|
48
|
-
_field['hide_on_form_branch'] = True
|
|
49
|
-
_field['hide_on_form_leaf'] = True
|
|
50
|
-
elif self.prop in ['icon']:
|
|
51
|
-
_field['tool'] = 'icon'
|
|
52
|
-
return _field
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
def __column_width__(self):
|
|
56
|
-
if self.clazz in [BooleanField, FileField, JSONField]:
|
|
57
|
-
return 100
|
|
58
|
-
elif self.clazz in [DateField, DateTimeField, TimeField]:
|
|
59
|
-
return 120
|
|
60
|
-
return 0
|
|
61
|
-
|
|
62
|
-
def __label__(self):
|
|
63
|
-
return self.model._meta.verbose_name \
|
|
64
|
-
if self.clazz in [ManyToOneRel, ManyToManyField, ManyToManyRel, OneToOneRel, OneToOneField] \
|
|
65
|
-
else self.model_field.verbose_name
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
def __model__(self):
|
|
69
|
-
return self.model_field.related_model \
|
|
70
|
-
if self.clazz in [ManyToOneRel, ManyToManyField, ManyToManyRel, OneToOneRel, OneToOneField, ForeignKey] \
|
|
71
|
-
else None
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
def __domain__(self):
|
|
75
|
-
return self.clazz.__name__ \
|
|
76
|
-
if self.clazz in [ManyToOneRel, ManyToManyField, ManyToManyRel ,OneToOneRel, OneToOneField] \
|
|
77
|
-
else self.model_field.get_internal_type()
|
|
78
|
-
|
|
79
|
-
def __prop__(self):
|
|
80
|
-
return self.model_field.name + "_id" \
|
|
81
|
-
if self.clazz in [ForeignKey,OneToOneRel, OneToOneField] \
|
|
82
|
-
else self.model_field.name
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
def ___align__(self):
|
|
86
|
-
if self.clazz in [FloatField, IntegerField]:
|
|
87
|
-
return 'right'
|
|
88
|
-
elif self.clazz in [BooleanField, FileField, JSONField, DateField, DateTimeField, TimeField]:
|
|
89
|
-
return 'center'
|
|
90
|
-
return 'left'
|
|
91
|
-
|
|
92
|
-
def __refer__(self):
|
|
93
|
-
refer = {
|
|
94
|
-
"entity": None,
|
|
95
|
-
"value": "name", "label": 'name', "display": "id",
|
|
96
|
-
"multiple": self.multiple, "strict": False, "remote": False,
|
|
97
|
-
"includes": {}, "excludes": {},
|
|
98
|
-
"root": 0, "isTree": self.is_tree
|
|
99
|
-
}
|
|
100
|
-
if self.model:
|
|
101
|
-
module, name = self.model.__module__, self.model.__name__
|
|
102
|
-
refer['entity'] = '%s.%s' % (module.replace('.models', '').split('.')[-1], name)
|
|
103
|
-
return refer
|
|
104
|
-
|
|
105
|
-
def __formating__(self):
|
|
106
|
-
_format = {
|
|
107
|
-
# 文本
|
|
108
|
-
"maxlength": 0,
|
|
109
|
-
"type": 'text',
|
|
110
|
-
|
|
111
|
-
# 数值
|
|
112
|
-
"min": None,
|
|
113
|
-
"max": None,
|
|
114
|
-
"step": 1,
|
|
115
|
-
"precision": None,
|
|
116
|
-
"step_strictly": False,
|
|
117
|
-
|
|
118
|
-
# 日期
|
|
119
|
-
"frequency": "date",
|
|
120
|
-
|
|
121
|
-
# 文件
|
|
122
|
-
"maximum": 5,
|
|
123
|
-
"accept": [],
|
|
124
|
-
"width": 800,
|
|
125
|
-
"height": 0,
|
|
126
|
-
"file_name_field":None,
|
|
127
|
-
"locked": False,
|
|
128
|
-
|
|
129
|
-
#集合
|
|
130
|
-
"set": {}
|
|
131
|
-
}
|
|
132
|
-
if self.clazz == CharField:
|
|
133
|
-
_format['maxlength'] = self.model_field.max_length
|
|
134
|
-
if self.clazz == TextField:
|
|
135
|
-
_format['type'] = "textarea"
|
|
136
|
-
elif self.clazz == DateTimeField:
|
|
137
|
-
_format['frequency'] = "datetime"
|
|
138
|
-
elif self.clazz == IntegerField:
|
|
139
|
-
_format['precision'] = 0
|
|
140
|
-
_format['step_strictly'] = True
|
|
141
|
-
return _format
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import copy
|
|
2
|
-
|
|
3
|
-
from .defaults.frame_defaults import meta_field_tool, meta_field_domain
|
|
4
|
-
|
|
5
|
-
from ...data.models import MetaFieldDomain, MetaFieldTool
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
def init_meta_frame():
|
|
9
|
-
from ..dao.dao_orm import OrmDao
|
|
10
|
-
tool_dao = OrmDao('data.MetaFieldTool')
|
|
11
|
-
domain_dao = OrmDao('data.MetaFieldDomain')
|
|
12
|
-
mapping = {}
|
|
13
|
-
for item in meta_field_tool:
|
|
14
|
-
_id, code = item['id'], item['code']
|
|
15
|
-
item.update({"saved": True})
|
|
16
|
-
if item['isLeaf']:
|
|
17
|
-
mapping[code] = _id
|
|
18
|
-
tool_dao.save_one(item)
|
|
19
|
-
|
|
20
|
-
for row in meta_field_domain:
|
|
21
|
-
default_id, tools = row['default_id'], row['tools']
|
|
22
|
-
print(mapping[default_id])
|
|
23
|
-
_row = copy.deepcopy(row)
|
|
24
|
-
_row.update({
|
|
25
|
-
'default_id': mapping[default_id],
|
|
26
|
-
'tools': [mapping[tool] for tool in tools],
|
|
27
|
-
"saved": True
|
|
28
|
-
})
|
|
29
|
-
domain_dao.save_one(_row)
|
|
30
|
-
return MetaFieldDomain.objects.all()
|
valar/core/meta/meta_orm.py
DELETED
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
from deepmerge import always_merger
|
|
2
|
-
|
|
3
|
-
from .defaults.view_defaults import meta_view_default_values
|
|
4
|
-
from ...core.dao.dao_orm import OrmDao
|
|
5
|
-
from ...data.models import MetaView, Meta
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
class OrmMeta:
|
|
9
|
-
|
|
10
|
-
def __init__(self, entity, code):
|
|
11
|
-
self.entity = entity
|
|
12
|
-
self.dao = OrmDao(entity)
|
|
13
|
-
self.code = code or 'default'
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
# load_meta
|
|
17
|
-
meta_dao = OrmDao('data.Meta')
|
|
18
|
-
_meta = {"entity": entity}
|
|
19
|
-
meta: Meta = meta_dao.search(_meta).first()
|
|
20
|
-
if meta is None:
|
|
21
|
-
_meta.update({"name": self.dao.model.name, 'saved': True})
|
|
22
|
-
meta = meta_dao.save_one(_meta)
|
|
23
|
-
self.meta = meta
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
# load_view
|
|
27
|
-
view_dao = OrmDao('data.MetaView')
|
|
28
|
-
_view = {"code": self.code, "meta_id": meta.id}
|
|
29
|
-
view: MetaView = view_dao.search(_view).first()
|
|
30
|
-
if view is None:
|
|
31
|
-
_view.update({"name": self.code.upper(), "saved": True})
|
|
32
|
-
view = view_dao.save_one(_view)
|
|
33
|
-
self.__init_view__(view)
|
|
34
|
-
self.view = view
|
|
35
|
-
|
|
36
|
-
# load_fields
|
|
37
|
-
if view.metafield_set.count() == 0:
|
|
38
|
-
field_dao = OrmDao('data.MetaField')
|
|
39
|
-
_fields = self.dao.model.initial_fields(code)
|
|
40
|
-
for _field in _fields:
|
|
41
|
-
_field.update({'view_id':view.id, "saved": True })
|
|
42
|
-
field_dao.save_one(_field)
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
def get_view(self):
|
|
46
|
-
_view = self.view.json()
|
|
47
|
-
meta = self.meta.json()
|
|
48
|
-
name, entity = meta['name'], meta['entity']
|
|
49
|
-
fields = self.view.metafield_set.all().order_by('-sort')
|
|
50
|
-
_fields = {field.prop: field.json(entity=entity, code=self.code, db='orm') for field in fields}
|
|
51
|
-
_view.update({
|
|
52
|
-
'$db': 'orm',
|
|
53
|
-
'$entity': entity,
|
|
54
|
-
'$code': self.code,
|
|
55
|
-
'$meta_name': name,
|
|
56
|
-
'$is_tree': self.dao.model.is_tree,
|
|
57
|
-
'$fields': _fields
|
|
58
|
-
})
|
|
59
|
-
return _view
|
|
60
|
-
|
|
61
|
-
def __init_view__(self, view: MetaView):
|
|
62
|
-
default_view = meta_view_default_values.get(self.entity, {})
|
|
63
|
-
default_values = default_view.get('__init__',{})
|
|
64
|
-
code_values = default_view.get(self.code, {})
|
|
65
|
-
values = always_merger.merge(default_values, code_values)
|
|
66
|
-
if len(values) > 0:
|
|
67
|
-
for key, value in values.items():
|
|
68
|
-
setattr(view, key, value)
|
|
69
|
-
view.save()
|
valar/core/middleware.py
DELETED
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
from django.http import HttpRequest
|
|
2
|
-
from django.utils.deprecation import MiddlewareMixin
|
|
3
|
-
from response import ValarResponse
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
class Middleware(MiddlewareMixin):
|
|
7
|
-
@staticmethod
|
|
8
|
-
def process_response(request: HttpRequest, response: ValarResponse):
|
|
9
|
-
headers = response.headers
|
|
10
|
-
if type(response)==ValarResponse:
|
|
11
|
-
message, code = response.message, response.code
|
|
12
|
-
headers['valar_message'] = message
|
|
13
|
-
headers['valar_code'] = code
|
|
14
|
-
|
|
15
|
-
keys = ['client','auth','uid']
|
|
16
|
-
for key in keys:
|
|
17
|
-
value = request.headers.get(key)
|
|
18
|
-
if value:
|
|
19
|
-
headers[key] = value
|
|
20
|
-
return response
|
valar/core/response.py
DELETED
valar/core/singleton_meta.py
DELETED
valar/data/__init__.py
DELETED
|
File without changes
|
|
File without changes
|
valar/data/urls.py
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
from django.urls import path
|
|
2
|
-
|
|
3
|
-
from ..channels.views import handel_channel
|
|
4
|
-
from .views.rest import save_many,delete_many,save_one,delete_one,find_one,find,update,table, tree, meta_view
|
|
5
|
-
|
|
6
|
-
urlpatterns = [
|
|
7
|
-
path('socket/<str:handler>', handel_channel),
|
|
8
|
-
path('save_many', save_many),
|
|
9
|
-
path('delete_many', delete_many),
|
|
10
|
-
path('<str:db>/<str:entity>/save_one', save_one),
|
|
11
|
-
path('<str:db>/<str:entity>/delete_one', delete_one),
|
|
12
|
-
path('<str:db>/<str:entity>/find_one', find_one),
|
|
13
|
-
path('<str:db>/<str:entity>/find', find),
|
|
14
|
-
path('<str:db>/<str:entity>/update', update),
|
|
15
|
-
path('<str:db>/<str:entity>/table', table),
|
|
16
|
-
path('<str:db>/<str:entity>/tree', tree),
|
|
17
|
-
path('<str:db>/<str:entity>/meta_view', meta_view),
|
|
18
|
-
]
|
valar/data/views/__init__.py
DELETED
|
File without changes
|
valar/data/views/handler.py
DELETED
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
from ...channels.sender import ValarSocketSender
|
|
2
|
-
from ...core.counter import Counter
|
|
3
|
-
from ...core.dao.dao_base import Dao
|
|
4
|
-
from ...core.dao.dao_mon import MonDao
|
|
5
|
-
from ...core.dao.dao_orm import OrmDao
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
def save_many_handler(sender: ValarSocketSender):
|
|
11
|
-
data = sender.data
|
|
12
|
-
entity, array, db = data.get("entity"), data.get("array",[]), data.get("db")
|
|
13
|
-
dao = Dao(entity, db)
|
|
14
|
-
counter = Counter(array)
|
|
15
|
-
for item in array:
|
|
16
|
-
item['saved'] = True
|
|
17
|
-
dao.save_one(item)
|
|
18
|
-
payload = counter.tick()
|
|
19
|
-
sender.to_clients(payload, sender.client, wait=True)
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
def delete_many_handler(sender: ValarSocketSender):
|
|
24
|
-
data = sender.data
|
|
25
|
-
entity, conditions, db = data.get("entity"), data.get("conditions", []), data.get("db")
|
|
26
|
-
if db == 'orm':
|
|
27
|
-
dao = OrmDao(entity)
|
|
28
|
-
query_set, _ = dao.find(conditions)
|
|
29
|
-
paths = dao.model.get_file_paths(query_set)
|
|
30
|
-
query_set.delete()
|
|
31
|
-
counter = Counter(len(paths))
|
|
32
|
-
for path in paths:
|
|
33
|
-
dao.model.minio.remove_path(path)
|
|
34
|
-
payload = counter.tick()
|
|
35
|
-
sender.to_clients(payload, sender.client, wait=True)
|
|
36
|
-
else:
|
|
37
|
-
dao = MonDao(entity)
|
|
38
|
-
dao.delete(conditions)
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|