valar 0.0.4__tar.gz → 0.0.6__tar.gz
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-0.0.4/LICENSE.txt → valar-0.0.6/LICENSE +1 -1
- valar-0.0.6/PKG-INFO +35 -0
- valar-0.0.6/README.md +17 -0
- valar-0.0.6/setup.py +25 -0
- valar-0.0.6/src/valar/channels.py +136 -0
- valar-0.0.6/src/valar.egg-info/PKG-INFO +35 -0
- valar-0.0.6/src/valar.egg-info/SOURCES.txt +10 -0
- valar-0.0.6/src/valar.egg-info/requires.txt +1 -0
- valar-0.0.6/src/valar.egg-info/top_level.txt +1 -0
- valar-0.0.4/PKG-INFO +0 -9
- valar-0.0.4/README.md +0 -10
- valar-0.0.4/setup.py +0 -16
- valar-0.0.4/valar.egg-info/PKG-INFO +0 -9
- valar-0.0.4/valar.egg-info/SOURCES.txt +0 -14
- valar-0.0.4/valar.egg-info/top_level.txt +0 -3
- valar-0.0.4/valar_base/apps.py +0 -6
- valar-0.0.4/valar_base/models.py +0 -93
- valar-0.0.4/valar_base/network.py +0 -11
- valar-0.0.4/valar_base/urls.py +0 -8
- valar-0.0.4/valar_common/__init__.py +0 -0
- valar-0.0.4/valar_meta/__init__.py +0 -0
- {valar-0.0.4 → valar-0.0.6}/setup.cfg +0 -0
- {valar-0.0.4/valar_base → valar-0.0.6/src/valar}/__init__.py +0 -0
- {valar-0.0.4 → valar-0.0.6/src}/valar.egg-info/dependency_links.txt +0 -0
valar-0.0.6/PKG-INFO
ADDED
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
Metadata-Version: 2.2
|
|
2
|
+
Name: valar
|
|
3
|
+
Version: 0.0.6
|
|
4
|
+
Summary: valar for morghulis
|
|
5
|
+
Author: LYP
|
|
6
|
+
Author-email: liuyinpeng@buaa.edu.cn
|
|
7
|
+
Requires-Python: >=3.9
|
|
8
|
+
Description-Content-Type: text/markdown
|
|
9
|
+
License-File: LICENSE
|
|
10
|
+
Requires-Dist: channels==3.0.3
|
|
11
|
+
Dynamic: author
|
|
12
|
+
Dynamic: author-email
|
|
13
|
+
Dynamic: description
|
|
14
|
+
Dynamic: description-content-type
|
|
15
|
+
Dynamic: requires-dist
|
|
16
|
+
Dynamic: requires-python
|
|
17
|
+
Dynamic: summary
|
|
18
|
+
|
|
19
|
+
valar for morghulis
|
|
20
|
+
|
|
21
|
+
# prepare
|
|
22
|
+
```
|
|
23
|
+
python -m pip install --upgrade pip
|
|
24
|
+
pip install --upgrade build
|
|
25
|
+
pip install twine
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
# publish
|
|
29
|
+
```
|
|
30
|
+
rm -r dist
|
|
31
|
+
python -m build
|
|
32
|
+
twine check dist/*
|
|
33
|
+
twine upload dist/*
|
|
34
|
+
```
|
|
35
|
+
|
valar-0.0.6/README.md
ADDED
valar-0.0.6/setup.py
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
from setuptools import setup, find_packages
|
|
2
|
+
|
|
3
|
+
with open("README.md", "r", encoding="utf-8") as f:
|
|
4
|
+
long_description = f.read()
|
|
5
|
+
|
|
6
|
+
# with open('requirements.txt', "r", encoding="utf-8") as f:
|
|
7
|
+
# required = f.read().splitlines()
|
|
8
|
+
|
|
9
|
+
requires = ['channels==3.0.3']
|
|
10
|
+
|
|
11
|
+
setup(
|
|
12
|
+
name="valar", # 包名
|
|
13
|
+
version="0.0.6", # 版本号
|
|
14
|
+
author="LYP", # 作者
|
|
15
|
+
author_email="liuyinpeng@buaa.edu.cn", # 邮箱
|
|
16
|
+
description="valar for morghulis", # 简短描述
|
|
17
|
+
long_description=long_description, # 详细说明
|
|
18
|
+
long_description_content_type="text/markdown", # 详细说明使用标记类型
|
|
19
|
+
# url="https://github.com/", # 项目主页
|
|
20
|
+
packages=find_packages(where="src"), # 需要打包的部分
|
|
21
|
+
package_dir={"": "src"}, # 设置src目录为根目录
|
|
22
|
+
python_requires=">=3.9", # 项目支持的Python版本
|
|
23
|
+
install_requires=requires, # 项目必须的依赖
|
|
24
|
+
include_package_data=False # 是否包含非Python文件(如资源文件)
|
|
25
|
+
)
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
import asyncio
|
|
2
|
+
import importlib
|
|
3
|
+
import json
|
|
4
|
+
from datetime import datetime
|
|
5
|
+
|
|
6
|
+
from channels.layers import get_channel_layer
|
|
7
|
+
|
|
8
|
+
from channels.generic.websocket import AsyncJsonWebsocketConsumer
|
|
9
|
+
from django.core.exceptions import ImproperlyConfigured
|
|
10
|
+
from django.http import JsonResponse
|
|
11
|
+
from django.conf import settings
|
|
12
|
+
|
|
13
|
+
GROUP = 'VALAR'
|
|
14
|
+
|
|
15
|
+
class ValarSocketSender:
|
|
16
|
+
def __init__(self, data: dict, handler: str, message = None, code = None):
|
|
17
|
+
self.data = data
|
|
18
|
+
self.handler = handler
|
|
19
|
+
self.send = get_channel_layer().group_send
|
|
20
|
+
self.message = message
|
|
21
|
+
self.code = code
|
|
22
|
+
|
|
23
|
+
def __convert_body(self, emit, clients = None, users = None):
|
|
24
|
+
return {
|
|
25
|
+
'type': emit,
|
|
26
|
+
'data': {
|
|
27
|
+
'handler': self.handler,
|
|
28
|
+
'payload': self.data,
|
|
29
|
+
'message': self.message,
|
|
30
|
+
'type': self.code,
|
|
31
|
+
'timestamp': datetime.now().timestamp()
|
|
32
|
+
},
|
|
33
|
+
'clients': clients or [],
|
|
34
|
+
'users': users or [],
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
async def set_message(self, message, code):
|
|
38
|
+
self.message = message
|
|
39
|
+
self.code = code
|
|
40
|
+
|
|
41
|
+
async def to_users(self, *users):
|
|
42
|
+
body = self.__convert_body('user.emit', users=users)
|
|
43
|
+
await self.send(GROUP, body)
|
|
44
|
+
|
|
45
|
+
async def to_clients(self, *clients):
|
|
46
|
+
body = self.__convert_body('client.emit', clients=clients)
|
|
47
|
+
await self.send(GROUP, body)
|
|
48
|
+
|
|
49
|
+
async def broadcast(self):
|
|
50
|
+
body = self.__convert_body('broadcast.emit')
|
|
51
|
+
await self.send(GROUP, body)
|
|
52
|
+
|
|
53
|
+
async def register(self, client, uid):
|
|
54
|
+
body = self.__convert_body('register.emit', [client], [uid])
|
|
55
|
+
await self.send(GROUP, body)
|
|
56
|
+
|
|
57
|
+
|
|
58
|
+
class ValarConsumer(AsyncJsonWebsocketConsumer):
|
|
59
|
+
|
|
60
|
+
def __init__(self):
|
|
61
|
+
self.client = None
|
|
62
|
+
self.uid = None
|
|
63
|
+
super().__init__()
|
|
64
|
+
|
|
65
|
+
|
|
66
|
+
async def connect(self):
|
|
67
|
+
params = self.scope['url_route']['kwargs']
|
|
68
|
+
self.client = params.get('client')
|
|
69
|
+
await self.channel_layer.group_add(GROUP, self.channel_name)
|
|
70
|
+
await self.accept()
|
|
71
|
+
|
|
72
|
+
async def disconnect(self, code):
|
|
73
|
+
await self.channel_layer.group_discard(GROUP, self.channel_name)
|
|
74
|
+
await self.close(code)
|
|
75
|
+
|
|
76
|
+
async def receive_json(self, data, *args, **kwargs):
|
|
77
|
+
print(data)
|
|
78
|
+
pass
|
|
79
|
+
|
|
80
|
+
async def user_emit(self, event):
|
|
81
|
+
users: list = event.get('users',[])
|
|
82
|
+
data = event.get('data',{})
|
|
83
|
+
if self.uid in users:
|
|
84
|
+
await self.send_json(data)
|
|
85
|
+
|
|
86
|
+
|
|
87
|
+
async def client_emit(self, event):
|
|
88
|
+
clients: list = event.get('clients',[])
|
|
89
|
+
data = event.get('data',{})
|
|
90
|
+
if self.client in clients:
|
|
91
|
+
await self.send_json(data)
|
|
92
|
+
|
|
93
|
+
async def broadcast_emit(self, event):
|
|
94
|
+
data = event.get('data',{})
|
|
95
|
+
await self.send_json(data)
|
|
96
|
+
|
|
97
|
+
async def register_emit(self, event):
|
|
98
|
+
users: list = event.get('users', [])
|
|
99
|
+
clients: list = event.get('clients',[])
|
|
100
|
+
if self.client in clients:
|
|
101
|
+
self.uid = users[0]
|
|
102
|
+
|
|
103
|
+
|
|
104
|
+
|
|
105
|
+
def get_valar_channel_handler(handler):
|
|
106
|
+
try:
|
|
107
|
+
root = settings.VALAR_CHANNEL_HANDLER_MAPPING
|
|
108
|
+
path, name = root.rsplit(".", 1)
|
|
109
|
+
except (ValueError, AttributeError):
|
|
110
|
+
raise ImproperlyConfigured("Cannot find VALAR_CHANNEL_HANDLER_MAPPING setting.")
|
|
111
|
+
try:
|
|
112
|
+
module = importlib.import_module(path)
|
|
113
|
+
mapping = getattr(module, name)
|
|
114
|
+
except ImportError:
|
|
115
|
+
raise ImproperlyConfigured("Cannot import VALAR_CHANNEL_HANDLER_MAPPING module %r" % path)
|
|
116
|
+
except AttributeError:
|
|
117
|
+
raise ImproperlyConfigured("module %r has no attribute %r" % (path, name))
|
|
118
|
+
try:
|
|
119
|
+
method = mapping[handler]
|
|
120
|
+
except KeyError:
|
|
121
|
+
raise ImproperlyConfigured("Cannot find handler in %r" % root)
|
|
122
|
+
return method
|
|
123
|
+
|
|
124
|
+
|
|
125
|
+
|
|
126
|
+
|
|
127
|
+
async def socket(request, handler):
|
|
128
|
+
client = request.headers.get('CLIENT')
|
|
129
|
+
uid = request.session.get('UID')
|
|
130
|
+
data = json.loads(request.body)
|
|
131
|
+
method = get_valar_channel_handler(handler)
|
|
132
|
+
loop = asyncio.get_event_loop()
|
|
133
|
+
loop.create_task(method(data, handler, client, uid))
|
|
134
|
+
return JsonResponse({'status':'OK'}, safe=False)
|
|
135
|
+
|
|
136
|
+
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
Metadata-Version: 2.2
|
|
2
|
+
Name: valar
|
|
3
|
+
Version: 0.0.6
|
|
4
|
+
Summary: valar for morghulis
|
|
5
|
+
Author: LYP
|
|
6
|
+
Author-email: liuyinpeng@buaa.edu.cn
|
|
7
|
+
Requires-Python: >=3.9
|
|
8
|
+
Description-Content-Type: text/markdown
|
|
9
|
+
License-File: LICENSE
|
|
10
|
+
Requires-Dist: channels==3.0.3
|
|
11
|
+
Dynamic: author
|
|
12
|
+
Dynamic: author-email
|
|
13
|
+
Dynamic: description
|
|
14
|
+
Dynamic: description-content-type
|
|
15
|
+
Dynamic: requires-dist
|
|
16
|
+
Dynamic: requires-python
|
|
17
|
+
Dynamic: summary
|
|
18
|
+
|
|
19
|
+
valar for morghulis
|
|
20
|
+
|
|
21
|
+
# prepare
|
|
22
|
+
```
|
|
23
|
+
python -m pip install --upgrade pip
|
|
24
|
+
pip install --upgrade build
|
|
25
|
+
pip install twine
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
# publish
|
|
29
|
+
```
|
|
30
|
+
rm -r dist
|
|
31
|
+
python -m build
|
|
32
|
+
twine check dist/*
|
|
33
|
+
twine upload dist/*
|
|
34
|
+
```
|
|
35
|
+
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
channels==3.0.3
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
valar
|
valar-0.0.4/PKG-INFO
DELETED
valar-0.0.4/README.md
DELETED
valar-0.0.4/setup.py
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
from setuptools import setup
|
|
2
|
-
NAME = 'valar'
|
|
3
|
-
VERSION = '0.0.4'
|
|
4
|
-
|
|
5
|
-
setup(
|
|
6
|
-
name=NAME,
|
|
7
|
-
version=VERSION,
|
|
8
|
-
packages=['valar_base','valar_common','valar_meta'],
|
|
9
|
-
url='https://gitee.com/GRIFFIN120/valar',
|
|
10
|
-
license='MIT License',
|
|
11
|
-
author='刘寅鹏',
|
|
12
|
-
author_email='liuyinpeng@buaa.edu.cn',
|
|
13
|
-
description='Valar Margulis'
|
|
14
|
-
)
|
|
15
|
-
|
|
16
|
-
print(f'twine upload dist/{NAME}-{VERSION}.tar.gz ')
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
LICENSE.txt
|
|
2
|
-
README.md
|
|
3
|
-
setup.py
|
|
4
|
-
valar.egg-info/PKG-INFO
|
|
5
|
-
valar.egg-info/SOURCES.txt
|
|
6
|
-
valar.egg-info/dependency_links.txt
|
|
7
|
-
valar.egg-info/top_level.txt
|
|
8
|
-
valar_base/__init__.py
|
|
9
|
-
valar_base/apps.py
|
|
10
|
-
valar_base/models.py
|
|
11
|
-
valar_base/network.py
|
|
12
|
-
valar_base/urls.py
|
|
13
|
-
valar_common/__init__.py
|
|
14
|
-
valar_meta/__init__.py
|
valar-0.0.4/valar_base/apps.py
DELETED
valar-0.0.4/valar_base/models.py
DELETED
|
@@ -1,93 +0,0 @@
|
|
|
1
|
-
import uuid
|
|
2
|
-
|
|
3
|
-
from django.db import models
|
|
4
|
-
from django.db.models.fields.files import FieldFile
|
|
5
|
-
|
|
6
|
-
'''
|
|
7
|
-
基类,配合Dao使用
|
|
8
|
-
'''
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
class BaseModel(models.Model):
|
|
12
|
-
uuid = models.UUIDField(default=uuid.uuid4, editable=False, verbose_name='标识')
|
|
13
|
-
sort = models.IntegerField(null=True, unique=True, verbose_name='序号')
|
|
14
|
-
name = models.CharField(max_length=255, null=True, verbose_name='名称')
|
|
15
|
-
description = models.TextField(null=True, verbose_name='描述')
|
|
16
|
-
date = models.DateField(null=True, verbose_name='日期')
|
|
17
|
-
enable = models.BooleanField(default=True, verbose_name='是否启用')
|
|
18
|
-
create_time = models.DateTimeField(auto_now_add=True, null=True, verbose_name='创建时间')
|
|
19
|
-
modify_time = models.DateTimeField(auto_now=True, null=True, verbose_name='修改时间')
|
|
20
|
-
_enable = models.BooleanField(default=True)
|
|
21
|
-
|
|
22
|
-
class Meta:
|
|
23
|
-
abstract = True
|
|
24
|
-
|
|
25
|
-
@property
|
|
26
|
-
def mapping(self):
|
|
27
|
-
mapping = {}
|
|
28
|
-
for field in self._meta.get_fields():
|
|
29
|
-
prop = field.name
|
|
30
|
-
domain = type(field).__name__
|
|
31
|
-
mapping[prop] = {'prop': prop, 'domain': domain, 'field': field}
|
|
32
|
-
return mapping
|
|
33
|
-
|
|
34
|
-
"""
|
|
35
|
-
只序列化基础字段:能用value_from_object直接取出的字段。与values等价
|
|
36
|
-
"""
|
|
37
|
-
|
|
38
|
-
@property
|
|
39
|
-
def json(self, fields={}):
|
|
40
|
-
mapping = self.mapping
|
|
41
|
-
excludes = ['ManyToOneRel', 'OneToOneRel', 'ManyToManyRel', 'ManyToManyField', 'UUIDField']
|
|
42
|
-
mapping = {prop: mapping[prop] for prop in mapping if mapping[prop]['domain'] not in excludes}
|
|
43
|
-
data = {}
|
|
44
|
-
for prop in mapping:
|
|
45
|
-
field = mapping[prop]['field']
|
|
46
|
-
domain = mapping[prop]['domain']
|
|
47
|
-
value = field.value_from_object(self)
|
|
48
|
-
if domain in ['ForeignKey', 'OneToOneField']:
|
|
49
|
-
prop = prop + '_id'
|
|
50
|
-
elif domain in ['DateField']:
|
|
51
|
-
value = value.strftime('%Y-%m-%d') if value else None
|
|
52
|
-
elif domain in ['DateTimeField']:
|
|
53
|
-
value = value.strftime('%Y-%m-%d %H:%M:%S') if value else None
|
|
54
|
-
elif domain in ['FileField']:
|
|
55
|
-
file: FieldFile = value
|
|
56
|
-
value = file.name
|
|
57
|
-
# elif domain in ['BigAutoField']:
|
|
58
|
-
# value = str(value)
|
|
59
|
-
data[prop] = value
|
|
60
|
-
return data
|
|
61
|
-
|
|
62
|
-
@property
|
|
63
|
-
def full(self):
|
|
64
|
-
data = self.json
|
|
65
|
-
mapping = self.mapping
|
|
66
|
-
excludes = ['ManyToManyField', 'ManyToManyRel', 'ForeignKey', 'ManyToOneRel', 'OneToOneField', 'OneToOneRel']
|
|
67
|
-
mapping = {prop: mapping[prop] for prop in mapping if mapping[prop]['domain'] in excludes}
|
|
68
|
-
for prop in mapping:
|
|
69
|
-
field = mapping[prop]['field']
|
|
70
|
-
domain = mapping[prop]['domain']
|
|
71
|
-
if domain in ['ForeignKey', 'OneToOneField', 'OneToOneRel']:
|
|
72
|
-
if hasattr(self, prop):
|
|
73
|
-
bean: BaseModel = getattr(self, prop)
|
|
74
|
-
data[prop] = bean.json if bean else None
|
|
75
|
-
elif domain in ['ManyToManyField', 'ManyToManyRel', 'ManyToOneRel']:
|
|
76
|
-
accessor = prop if domain == 'ManyToManyField' else field.get_accessor_name()
|
|
77
|
-
try:
|
|
78
|
-
_set = getattr(self, accessor).all()
|
|
79
|
-
data[prop] = [item.id for item in _set]
|
|
80
|
-
data[f'{prop}_set'] = [item.json for item in _set]
|
|
81
|
-
except Exception as e:
|
|
82
|
-
print(e)
|
|
83
|
-
pass
|
|
84
|
-
return data
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
class BaseTree(BaseModel):
|
|
88
|
-
pid = models.IntegerField(null=False, default=0, verbose_name='父节点')
|
|
89
|
-
node_type = models.IntegerField(null=False, default=1, verbose_name='节点类型') # 0 中间节点 1 末端节点
|
|
90
|
-
icon = models.CharField(max_length=255, null=True, verbose_name='图标')
|
|
91
|
-
|
|
92
|
-
class Meta:
|
|
93
|
-
abstract = True
|
valar-0.0.4/valar_base/urls.py
DELETED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|