valar 1.3.4__py3-none-any.whl → 1.3.5__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.
Potentially problematic release.
This version of valar might be problematic. Click here for more details.
- valar/channels/sender.py +4 -1
- valar/dao/defaults/field_keys_default.py +1 -1
- valar/dao/meta.py +2 -1
- valar/dao/orm_dao.py +1 -0
- valar/models/auth.py +1 -1
- valar/views/auth.py +1 -1
- valar/views/handler.py +29 -22
- valar/views/rest.py +3 -0
- {valar-1.3.4.dist-info → valar-1.3.5.dist-info}/METADATA +1 -1
- {valar-1.3.4.dist-info → valar-1.3.5.dist-info}/RECORD +13 -13
- {valar-1.3.4.dist-info → valar-1.3.5.dist-info}/WHEEL +0 -0
- {valar-1.3.4.dist-info → valar-1.3.5.dist-info}/licenses/LICENSE +0 -0
- {valar-1.3.4.dist-info → valar-1.3.5.dist-info}/top_level.txt +0 -0
valar/channels/sender.py
CHANGED
|
@@ -39,7 +39,7 @@ class Sender:
|
|
|
39
39
|
|
|
40
40
|
def __init__(self, request: HttpRequest):
|
|
41
41
|
self.client = request.headers.get('CLIENT')
|
|
42
|
-
self.uid = request.session.get('UID')
|
|
42
|
+
# self.uid = request.session.get('UID')
|
|
43
43
|
self.group_send = async_to_sync(get_channel_layer().group_send)
|
|
44
44
|
|
|
45
45
|
|
|
@@ -88,6 +88,9 @@ class ValarChannelSender(Sender):
|
|
|
88
88
|
def done(self, payload):
|
|
89
89
|
self.__emit__('done', payload)
|
|
90
90
|
|
|
91
|
+
def error(self, payload):
|
|
92
|
+
self.__emit__('error', payload)
|
|
93
|
+
|
|
91
94
|
def __emit__(self, status='proceed', data=None):
|
|
92
95
|
scope = 'broadcast' if self.__channel__.broadcast else 'client'
|
|
93
96
|
body = {
|
|
@@ -46,7 +46,7 @@ meta_field_key_defaults = {
|
|
|
46
46
|
'ref': ('pick', ['id', 'name', 'm2o', 'm2m', 'o2o_id']),
|
|
47
47
|
},
|
|
48
48
|
'valar.Account': {
|
|
49
|
-
'auth': ('pick', ['user_id', 'username', 'email', 'is_active', 'is_admin', 'roles']),
|
|
49
|
+
'auth': ('pick', ['user_id', 'username', 'email', 'password', 'is_active', 'is_admin', 'roles']),
|
|
50
50
|
},
|
|
51
51
|
'valar.Role': {
|
|
52
52
|
'auth': ('pick', ['name', 'duty', 'menu', 'account']),
|
valar/dao/meta.py
CHANGED
|
@@ -45,7 +45,8 @@ class ValarMeta:
|
|
|
45
45
|
if view.metafield_set.count() == 0:
|
|
46
46
|
_fields = self.__initial_fields__()
|
|
47
47
|
for _field in _fields:
|
|
48
|
-
if _field['prop'] not in ['sort', 'create_time', 'modify_time', 'saved']
|
|
48
|
+
if (_field['prop'] not in ['id', 'sort', 'create_time', 'modify_time', 'saved', 'disabled']
|
|
49
|
+
and _field['domain'] not in ['ManyToManyRel', 'OneToOneRel', 'ManyToOneRel']):
|
|
49
50
|
_field.update({'view_id': view.id, "saved": True})
|
|
50
51
|
field_dao.save_one(_field)
|
|
51
52
|
|
valar/dao/orm_dao.py
CHANGED
|
@@ -77,6 +77,7 @@ class OrmDao(AbstractDao):
|
|
|
77
77
|
return self.manager.filter(id=oid).first() if oid is not None else None
|
|
78
78
|
|
|
79
79
|
def find(self, conditions=None, orders=None, size=0, page=1):
|
|
80
|
+
|
|
80
81
|
includes, excludes, orders = Query(conditions, orders).orm()
|
|
81
82
|
query_set = self.manager.filter(includes).exclude(excludes).order_by(*orders)
|
|
82
83
|
total = query_set.count()
|
valar/models/auth.py
CHANGED
|
@@ -13,7 +13,7 @@ class Role(VModel):
|
|
|
13
13
|
class Account(VModel):
|
|
14
14
|
"""账户核心信息"""
|
|
15
15
|
username = models.CharField(max_length=255, null=True, unique=True, verbose_name='账号')
|
|
16
|
-
password = models.CharField(max_length=255, verbose_name='密码')
|
|
16
|
+
password = models.CharField(max_length=255, null=True, verbose_name='密码')
|
|
17
17
|
email = models.CharField(max_length=255, null=True, unique=True, verbose_name='邮箱')
|
|
18
18
|
"""权限"""
|
|
19
19
|
is_admin = models.BooleanField(default=False, verbose_name='超级管理员')
|
valar/views/auth.py
CHANGED
|
@@ -41,7 +41,7 @@ def sign_in(request):
|
|
|
41
41
|
})
|
|
42
42
|
return ValarResponse(jwt.encode({
|
|
43
43
|
"user_id": account.id,
|
|
44
|
-
"exp": datetime.datetime.utcnow() + datetime.timedelta(
|
|
44
|
+
"exp": datetime.datetime.utcnow() + datetime.timedelta(hours=2)
|
|
45
45
|
}, settings.SECRET_KEY, algorithm="HS256"))
|
|
46
46
|
|
|
47
47
|
|
valar/views/handler.py
CHANGED
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
import traceback
|
|
2
|
+
|
|
1
3
|
from ..channels.counter import Counter
|
|
2
4
|
from ..channels.sender import ValarChannelSender
|
|
3
5
|
from ..dao import Dao
|
|
@@ -22,25 +24,30 @@ def batch_handler(sender: ValarChannelSender):
|
|
|
22
24
|
entity, db, method = data.get("entity"), data.get("db"), data.get("method")
|
|
23
25
|
dao = Dao(entity, db)
|
|
24
26
|
body = {"method": method}
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
minio.
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
27
|
+
|
|
28
|
+
try:
|
|
29
|
+
if method == 'save_many':
|
|
30
|
+
array = data.get("array", [])
|
|
31
|
+
counter = Counter(array)
|
|
32
|
+
keys = []
|
|
33
|
+
for item in array:
|
|
34
|
+
item.update({'saved': True})
|
|
35
|
+
bean = dao.save_one(item)
|
|
36
|
+
keys.append(bean.id)
|
|
37
|
+
payload = counter.tick()
|
|
38
|
+
sender.load(payload)
|
|
39
|
+
body.update({'keys': keys})
|
|
40
|
+
sender.done(body)
|
|
41
|
+
elif method == 'delete_many':
|
|
42
|
+
conditions = data.get("conditions", [])
|
|
43
|
+
paths = dao.delete(conditions)
|
|
44
|
+
counter = Counter(len(paths))
|
|
45
|
+
minio = ValarEngine().get_minio_bucket(entity)
|
|
46
|
+
for path in paths:
|
|
47
|
+
minio.remove(path)
|
|
48
|
+
payload = counter.tick()
|
|
49
|
+
sender.load(payload)
|
|
50
|
+
sender.done(body)
|
|
51
|
+
except Exception as e:
|
|
52
|
+
traceback.print_exc()
|
|
53
|
+
sender.error(str(e))
|
valar/views/rest.py
CHANGED
|
@@ -9,7 +9,7 @@ valar/channels/consumer.py,sha256=fEP52wBHWccturn2QAkqOt9-_Fr8akiw95AoVc6dEMM,13
|
|
|
9
9
|
valar/channels/counter.py,sha256=K8aQUI1RiIrSOg3280tV102soC-ZC1qSRZvBXuwNYQ0,377
|
|
10
10
|
valar/channels/executer.py,sha256=_Ap859nvxRl8Ln0BWMqhnL6cQNl-1NQSmMR4Akh-afY,333
|
|
11
11
|
valar/channels/mapping.py,sha256=1SBqxEYO4epbRkSOUw5zm6gau15imz1gokrRTQcy94A,755
|
|
12
|
-
valar/channels/sender.py,sha256=
|
|
12
|
+
valar/channels/sender.py,sha256=65hylPGXreN4hDetg5Ysl_72BbbRIVF2ERDk7Nky1Lg,3805
|
|
13
13
|
valar/channels/views.py,sha256=4J_f-Bn3VR0o0spOa9D52aRcxMRZ0YYgo-dMzJqFrd4,375
|
|
14
14
|
valar/classes/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
15
15
|
valar/classes/singleton_meta.py,sha256=aa9DZKG4Q9Cr67ZWrQ0yaFLrEjwFoTMQbDrpoIqgJZs,245
|
|
@@ -22,32 +22,32 @@ valar/dao/__init__.py,sha256=WGjXrnjmgcfOvtTYIVjtdsmh9mlc0IJCrZD2ScZ6Kx0,1335
|
|
|
22
22
|
valar/dao/abstract.py,sha256=wBqSwfZkPrkhlGX7Ue__UmhblIllP87Bwt5G7shWX8E,2449
|
|
23
23
|
valar/dao/engine.py,sha256=YM8YdhWmdO2BX_T51u9q64a2GAaVCdaYHBmOpCKM4sA,3023
|
|
24
24
|
valar/dao/frame.py,sha256=9vDsJfB-Ztb4YN8Lt6pHJeF_RndqHsVeA_ygWIOgALM,7468
|
|
25
|
-
valar/dao/meta.py,sha256=
|
|
25
|
+
valar/dao/meta.py,sha256=2o720rFqPdDxQ0yXW74zHU0m914PfKkzvLwPINtiRbg,5051
|
|
26
26
|
valar/dao/mon_dao.py,sha256=TRrHUBdWBbOn47uV5ot_B2GcvWGoNpadJW_CkS0TEhc,3588
|
|
27
27
|
valar/dao/mon_field.py,sha256=AJp-KS19oRiRHtMidC_1uTv2oCplqO4-bdKNDLMllWU,570
|
|
28
|
-
valar/dao/orm_dao.py,sha256=
|
|
28
|
+
valar/dao/orm_dao.py,sha256=su3ah1lhpAlZj-yytPJpwfyzxCEcFIqI8t_sKv6GEJQ,12323
|
|
29
29
|
valar/dao/orm_field.py,sha256=qADDGPM_EUVxP2VEGfnb2m97gYeSFxXt5fOmY2Df11c,4981
|
|
30
30
|
valar/dao/query.py,sha256=7MqCdwjdhXWBWjEggHVFQfC0zlZH3TrwuVxKE7E0OKA,1049
|
|
31
31
|
valar/dao/defaults/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
32
|
-
valar/dao/defaults/field_keys_default.py,sha256=
|
|
32
|
+
valar/dao/defaults/field_keys_default.py,sha256=ZgF-7s4yABz2uoInxuhg4uy9flbAR7btHDipJkqZj0M,2153
|
|
33
33
|
valar/dao/defaults/field_values_default.py,sha256=6zKPqbw0vJKW_9ilj6PC7IgDyayiWjHsNc4y7aVzuNw,3552
|
|
34
34
|
valar/dao/defaults/view_defaults.py,sha256=v2wEgiaXqEcM4lcjM2uV83cLA5EJZf6qHfLZ7YJikIg,572
|
|
35
35
|
valar/migrations/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
36
36
|
valar/models/__init__.py,sha256=ueEan3T0sdZRiKJJrIpwrRj_6BXdKfMecIqKIqOGnzA,44
|
|
37
|
-
valar/models/auth.py,sha256=
|
|
37
|
+
valar/models/auth.py,sha256=ymjg4B-Xj9h0_DvyG8o1dlo7ahgpoqAUHxI814NMxvs,1621
|
|
38
38
|
valar/models/core.py,sha256=ghtfs8uFH6SC0xvd-gkARr-FUWDXG0IMGWSuETOvecw,3695
|
|
39
39
|
valar/models/frame.py,sha256=N13Bok7XNJDLoYDCpCIq8tEUktQVNerrLtk_U0KDJAE,851
|
|
40
40
|
valar/models/meta.py,sha256=JPa-Rap2sdSYnG6Sk7_vFrg5flP3r6fAM7tRvlwb4Vw,4871
|
|
41
41
|
valar/models/test.py,sha256=3yfyZHJgviEybV1NyN4Qs1BGKE3DvAtb_e4oFI2MVos,1319
|
|
42
42
|
valar/views/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
43
|
-
valar/views/auth.py,sha256=
|
|
43
|
+
valar/views/auth.py,sha256=KZiWPEcL_ZpF6DT99D3U3EdX0qjhOBFNAmnLWNJCXsU,4094
|
|
44
44
|
valar/views/file.py,sha256=NxfbxT4EJRDFgXol06kD0vcSp4lN4BCVJ5wq43rh8Yg,1537
|
|
45
|
-
valar/views/handler.py,sha256=
|
|
45
|
+
valar/views/handler.py,sha256=KlXWhVU-b_b5uxrUwQBHW7H4shSPy4NnXj6AINM_Joo,1619
|
|
46
46
|
valar/views/meta.py,sha256=H3_raG-LEcfg1p_CBpluhPXBsLFQB_jtaI5CKGgYOKk,4774
|
|
47
47
|
valar/views/password.py,sha256=O094qG8Sh4ilT_wpEMw4IZtAlcQjrDVcFD5BHaWKg2Q,2127
|
|
48
|
-
valar/views/rest.py,sha256=
|
|
49
|
-
valar-1.3.
|
|
50
|
-
valar-1.3.
|
|
51
|
-
valar-1.3.
|
|
52
|
-
valar-1.3.
|
|
53
|
-
valar-1.3.
|
|
48
|
+
valar/views/rest.py,sha256=_KC2BPsAiTdYCDd3RPt5MTvaWiHd9W3PEx_3l7EwOWE,2383
|
|
49
|
+
valar-1.3.5.dist-info/licenses/LICENSE,sha256=2bm9uFabQZ3Ykb_SaSU_uUbAj2-htc6WJQmS_65qD00,1073
|
|
50
|
+
valar-1.3.5.dist-info/METADATA,sha256=ZkkGNPXArta8QA3ANkeIrGa10uA8mSBFAT60J3bFgN4,5142
|
|
51
|
+
valar-1.3.5.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
|
|
52
|
+
valar-1.3.5.dist-info/top_level.txt,sha256=TVi6VcvvYfVYZ_WnUVwT4psI8p6inaP3KfmQEWrrvYg,6
|
|
53
|
+
valar-1.3.5.dist-info/RECORD,,
|
|
File without changes
|
|
File without changes
|
|
File without changes
|