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.

@@ -1,4 +1,4 @@
1
- Copyright (c) 2024 Valar Margulis
1
+ Copyright (c) 2018 The Python Packaging Authority
2
2
 
3
3
  Permission is hereby granted, free of charge, to any person obtaining a copy
4
4
  of this software and associated documentation files (the "Software"), to deal
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
@@ -0,0 +1,17 @@
1
+ valar for morghulis
2
+
3
+ # prepare
4
+ ```
5
+ python -m pip install --upgrade pip
6
+ pip install --upgrade build
7
+ pip install twine
8
+ ```
9
+
10
+ # publish
11
+ ```
12
+ rm -r dist
13
+ python -m build
14
+ twine check dist/*
15
+ twine upload dist/*
16
+ ```
17
+
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,10 @@
1
+ LICENSE
2
+ README.md
3
+ setup.py
4
+ src/valar/__init__.py
5
+ src/valar/channels.py
6
+ src/valar.egg-info/PKG-INFO
7
+ src/valar.egg-info/SOURCES.txt
8
+ src/valar.egg-info/dependency_links.txt
9
+ src/valar.egg-info/requires.txt
10
+ src/valar.egg-info/top_level.txt
@@ -0,0 +1 @@
1
+ channels==3.0.3
@@ -0,0 +1 @@
1
+ valar
valar-0.0.4/PKG-INFO DELETED
@@ -1,9 +0,0 @@
1
- Metadata-Version: 2.1
2
- Name: valar
3
- Version: 0.0.4
4
- Summary: Valar Margulis
5
- Home-page: https://gitee.com/GRIFFIN120/valar
6
- Author: 刘寅鹏
7
- Author-email: liuyinpeng@buaa.edu.cn
8
- License: MIT License
9
- License-File: LICENSE.txt
valar-0.0.4/README.md DELETED
@@ -1,10 +0,0 @@
1
- Valar Margulis
2
-
3
- write readme latter.
4
-
5
- python setup.py sdist
6
- twine upload dist/*
7
-
8
- pip install --upgrade pip
9
- pip install --upgrade valar
10
-
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,9 +0,0 @@
1
- Metadata-Version: 2.1
2
- Name: valar
3
- Version: 0.0.4
4
- Summary: Valar Margulis
5
- Home-page: https://gitee.com/GRIFFIN120/valar
6
- Author: 刘寅鹏
7
- Author-email: liuyinpeng@buaa.edu.cn
8
- License: MIT License
9
- License-File: LICENSE.txt
@@ -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
@@ -1,3 +0,0 @@
1
- valar_base
2
- valar_common
3
- valar_meta
@@ -1,6 +0,0 @@
1
- from django.apps import AppConfig
2
-
3
-
4
- class BaseConfig(AppConfig):
5
- default_auto_field = 'django.db.models.BigAutoField'
6
- name = 'valar_base'
@@ -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
@@ -1,11 +0,0 @@
1
- from django.http import JsonResponse
2
-
3
-
4
- class ValaResponse(JsonResponse):
5
- def __init__(self, data, message='', _type='info'):
6
- data = {
7
- 'result': data,
8
- 'message': message,
9
- 'type': _type
10
- }
11
- super(ValaResponse, self).__init__(data, safe=False)
@@ -1,8 +0,0 @@
1
- from django.urls import path
2
-
3
- from views import search
4
-
5
- urlpatterns = [
6
-
7
- path("get/<int:_id>", search.get),
8
- ]
File without changes
File without changes
File without changes