valar 0.0.7__tar.gz → 0.0.9__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.9/PKG-INFO ADDED
@@ -0,0 +1,107 @@
1
+ Metadata-Version: 2.2
2
+ Name: valar
3
+ Version: 0.0.9
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
+ # settings
22
+ ```python
23
+ from pathlib import Path
24
+
25
+ """ Compulsory settings """
26
+ DEBUG = True
27
+ BASE_DIR = Path(__file__).resolve().parent.parent
28
+ BASE_APP = str(BASE_DIR.name)
29
+ DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'
30
+
31
+ """ Minimized compulsory settings """
32
+
33
+ DATABASES = {
34
+ 'default': {
35
+ 'ENGINE': 'django.db.backends.sqlite3',
36
+ 'NAME': BASE_DIR / 'db.sqlite3',
37
+ }
38
+ }
39
+
40
+ INSTALLED_APPS = [
41
+ 'django.contrib.sessions',
42
+ "corsheaders",
43
+ 'channels',
44
+ 'valar.dao'
45
+ ]
46
+
47
+ MIDDLEWARE = [
48
+ 'django.contrib.sessions.middleware.SessionMiddleware',
49
+ 'corsheaders.middleware.CorsMiddleware',
50
+ 'django.middleware.common.CommonMiddleware',
51
+ 'valar.Middleware'
52
+ ]
53
+
54
+ CHANNEL_LAYERS = {
55
+ "default": {
56
+ "BACKEND": "channels.layers.InMemoryChannelLayer"
57
+ }
58
+ }
59
+
60
+ CORS_ORIGIN_ALLOW_ALL = True
61
+ CORS_ALLOW_CREDENTIALS = True
62
+ ROOT_URLCONF = "%s.urls" % BASE_APP
63
+ ASGI_APPLICATION = "%s.asgi.application" % BASE_APP
64
+ VALAR_CHANNEL_HANDLER_MAPPING = "%s.urls.channel_handler_mapping" % BASE_APP
65
+
66
+ """ Optional settings """
67
+ # ALLOWED_HOSTS = ['*']
68
+ # LANGUAGE_CODE = 'en-us'
69
+ # TIME_ZONE = 'Asia/Shanghai'
70
+ # USE_I18N = True
71
+ # USE_TZ = False
72
+ # SESSION_SAVE_EVERY_REQUEST = True
73
+ # SESSION_COOKIE_AGE = 60 * 60
74
+ # FILE_UPLOAD_MAX_MEMORY_SIZE = 1024 * 1024 * 100
75
+ # DATA_UPLOAD_MAX_MEMORY_SIZE = 1024 * 1024 * 100
76
+ ```
77
+
78
+ # root urls
79
+
80
+
81
+
82
+
83
+
84
+ # prepare
85
+ ```sh
86
+ python -m pip install --upgrade pip
87
+ ```
88
+ ```sh
89
+ pip install --upgrade build
90
+ ```
91
+ ```sh
92
+ pip install twine
93
+ ```
94
+
95
+ # publish
96
+ ```sh
97
+ rm -r dist
98
+ ```
99
+ ```sh
100
+ python -m build
101
+ ```
102
+ ```sh
103
+ twine check dist/*
104
+ ```
105
+ ```sh
106
+ twine upload dist/*
107
+ ```
valar-0.0.9/README.md ADDED
@@ -0,0 +1,89 @@
1
+ valar for morghulis
2
+
3
+ # settings
4
+ ```python
5
+ from pathlib import Path
6
+
7
+ """ Compulsory settings """
8
+ DEBUG = True
9
+ BASE_DIR = Path(__file__).resolve().parent.parent
10
+ BASE_APP = str(BASE_DIR.name)
11
+ DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'
12
+
13
+ """ Minimized compulsory settings """
14
+
15
+ DATABASES = {
16
+ 'default': {
17
+ 'ENGINE': 'django.db.backends.sqlite3',
18
+ 'NAME': BASE_DIR / 'db.sqlite3',
19
+ }
20
+ }
21
+
22
+ INSTALLED_APPS = [
23
+ 'django.contrib.sessions',
24
+ "corsheaders",
25
+ 'channels',
26
+ 'valar.dao'
27
+ ]
28
+
29
+ MIDDLEWARE = [
30
+ 'django.contrib.sessions.middleware.SessionMiddleware',
31
+ 'corsheaders.middleware.CorsMiddleware',
32
+ 'django.middleware.common.CommonMiddleware',
33
+ 'valar.Middleware'
34
+ ]
35
+
36
+ CHANNEL_LAYERS = {
37
+ "default": {
38
+ "BACKEND": "channels.layers.InMemoryChannelLayer"
39
+ }
40
+ }
41
+
42
+ CORS_ORIGIN_ALLOW_ALL = True
43
+ CORS_ALLOW_CREDENTIALS = True
44
+ ROOT_URLCONF = "%s.urls" % BASE_APP
45
+ ASGI_APPLICATION = "%s.asgi.application" % BASE_APP
46
+ VALAR_CHANNEL_HANDLER_MAPPING = "%s.urls.channel_handler_mapping" % BASE_APP
47
+
48
+ """ Optional settings """
49
+ # ALLOWED_HOSTS = ['*']
50
+ # LANGUAGE_CODE = 'en-us'
51
+ # TIME_ZONE = 'Asia/Shanghai'
52
+ # USE_I18N = True
53
+ # USE_TZ = False
54
+ # SESSION_SAVE_EVERY_REQUEST = True
55
+ # SESSION_COOKIE_AGE = 60 * 60
56
+ # FILE_UPLOAD_MAX_MEMORY_SIZE = 1024 * 1024 * 100
57
+ # DATA_UPLOAD_MAX_MEMORY_SIZE = 1024 * 1024 * 100
58
+ ```
59
+
60
+ # root urls
61
+
62
+
63
+
64
+
65
+
66
+ # prepare
67
+ ```sh
68
+ python -m pip install --upgrade pip
69
+ ```
70
+ ```sh
71
+ pip install --upgrade build
72
+ ```
73
+ ```sh
74
+ pip install twine
75
+ ```
76
+
77
+ # publish
78
+ ```sh
79
+ rm -r dist
80
+ ```
81
+ ```sh
82
+ python -m build
83
+ ```
84
+ ```sh
85
+ twine check dist/*
86
+ ```
87
+ ```sh
88
+ twine upload dist/*
89
+ ```
@@ -10,7 +10,7 @@ requires = ['channels==3.0.3']
10
10
 
11
11
  setup(
12
12
  name="valar", # 包名
13
- version="0.0.7", # 版本号
13
+ version="0.0.9", # 版本号
14
14
  author="LYP", # 作者
15
15
  author_email="liuyinpeng@buaa.edu.cn", # 邮箱
16
16
  description="valar for morghulis", # 简短描述
@@ -0,0 +1,21 @@
1
+ from django.http import JsonResponse, HttpRequest
2
+ from django.utils.deprecation import MiddlewareMixin
3
+
4
+ class ValarResponse(JsonResponse):
5
+ def __init__(self, data, message='', code='info'):
6
+ self.message = message
7
+ self.code = code
8
+ super(ValarResponse, self).__init__(data, safe=False)
9
+
10
+
11
+ class Middleware(MiddlewareMixin):
12
+ @staticmethod
13
+ def process_response(request: HttpRequest, response: ValarResponse):
14
+ message, code = response.message, response.code
15
+ user_id = request.session.get('USER_ID')
16
+ headers = response.headers
17
+ headers['valar_message'] = message
18
+ headers['valar_code'] = code
19
+ if user_id:
20
+ headers['user_id'] = user_id
21
+ return response
@@ -0,0 +1,101 @@
1
+ from datetime import datetime
2
+
3
+ from channels.layers import get_channel_layer
4
+
5
+ from channels.generic.websocket import AsyncJsonWebsocketConsumer
6
+ from django.conf import settings
7
+
8
+ try:
9
+ GROUP = settings.VALAR_CHANNEL_GROUP_NAME
10
+ except AttributeError:
11
+ GROUP = 'VALAR'
12
+
13
+ class ValarSocketSender:
14
+ def __init__(self, handler: str, client: str, uid):
15
+ self.client = client
16
+ self.uid = uid
17
+ self.handler = handler
18
+ self.send = get_channel_layer().group_send
19
+
20
+ def __convert_body(self, emit, data ,clients = None, users = None):
21
+ return {
22
+ 'type': emit,
23
+ 'data': {
24
+ 'handler': self.handler,
25
+ 'payload': data,
26
+ 'timestamp': datetime.now().timestamp()
27
+ },
28
+ 'clients': clients or [],
29
+ 'users': users or [],
30
+ }
31
+
32
+
33
+ async def to_users(self, data, *users):
34
+ body = self.__convert_body('user.emit', data, users=users)
35
+ await self.send(GROUP, body)
36
+
37
+ async def to_clients(self,data, *clients):
38
+ body = self.__convert_body('client.emit', data, clients=clients)
39
+ await self.send(GROUP, body)
40
+
41
+ async def broadcast(self, data):
42
+ body = self.__convert_body('broadcast.emit', data)
43
+ await self.send(GROUP, body)
44
+
45
+ async def register(self):
46
+ body = self.__convert_body('register.emit', None,[self.client], [self.uid])
47
+ await self.send(GROUP, body)
48
+
49
+
50
+ class ValarConsumer(AsyncJsonWebsocketConsumer):
51
+
52
+ def __init__(self):
53
+ self.client = None
54
+ self.uid = None
55
+ super().__init__()
56
+
57
+ async def connect(self):
58
+ params = self.scope['url_route']['kwargs']
59
+ self.client = params.get('client')
60
+ await self.channel_layer.group_add(GROUP, self.channel_name)
61
+ await self.accept()
62
+
63
+ async def disconnect(self, code):
64
+ await self.channel_layer.group_discard(GROUP, self.channel_name)
65
+ await self.close(code)
66
+
67
+ async def receive_json(self, data, *args, **kwargs):
68
+ pass
69
+
70
+ async def user_emit(self, event):
71
+ users: list = event.get('users',[])
72
+ data = event.get('data',{})
73
+ if self.uid in users:
74
+ await self.send_json(data)
75
+
76
+
77
+ async def client_emit(self, event):
78
+ clients: list = event.get('clients',[])
79
+ data = event.get('data',{})
80
+ if self.client in clients:
81
+ await self.send_json(data)
82
+
83
+ async def broadcast_emit(self, event):
84
+ data = event.get('data',{})
85
+ await self.send_json(data)
86
+
87
+ async def register_emit(self, event):
88
+ users: list = event.get('users', [])
89
+ clients: list = event.get('clients',[])
90
+ if self.client in clients:
91
+ self.uid = users[0]
92
+
93
+
94
+
95
+
96
+
97
+
98
+
99
+
100
+
101
+
@@ -0,0 +1,46 @@
1
+ import asyncio
2
+ import importlib
3
+ import json
4
+ from django.core.exceptions import ImproperlyConfigured
5
+ from django.conf import settings
6
+
7
+ from src.valar import ValarResponse
8
+ from src.valar.channels import ValarSocketSender
9
+
10
+
11
+
12
+
13
+
14
+ async def handel_channel(request, handler):
15
+ client = request.headers.get('CLIENT')
16
+ uid = request.session.get('UID')
17
+ data = json.loads(request.body)
18
+ method = get_valar_channel_handler(handler)
19
+ sender = ValarSocketSender(handler, client, uid)
20
+ if uid and client:
21
+ await sender.register()
22
+ loop = asyncio.get_event_loop()
23
+ loop.create_task(method(data, sender))
24
+ return ValarResponse({'status':'OK'}, message='OK', code= 'success')
25
+
26
+
27
+
28
+
29
+ def get_valar_channel_handler(handler):
30
+ try:
31
+ root = settings.VALAR_CHANNEL_HANDLER_MAPPING
32
+ path, name = root.rsplit(".", 1)
33
+ except (ValueError, AttributeError):
34
+ raise ImproperlyConfigured("Cannot find VALAR_CHANNEL_HANDLER_MAPPING setting.")
35
+ try:
36
+ module = importlib.import_module(path)
37
+ mapping = getattr(module, name)
38
+ except ImportError:
39
+ raise ImproperlyConfigured("Cannot import VALAR_CHANNEL_HANDLER_MAPPING module %r" % path)
40
+ except AttributeError:
41
+ raise ImproperlyConfigured("module %r has no attribute %r" % (path, name))
42
+ try:
43
+ method = mapping[handler]
44
+ except KeyError:
45
+ raise ImproperlyConfigured("Cannot find handler in %r" % root)
46
+ return method
@@ -0,0 +1,22 @@
1
+ # Generated by Django 4.2.20 on 2025-03-08 12:34
2
+
3
+ from django.db import migrations, models
4
+
5
+
6
+ class Migration(migrations.Migration):
7
+
8
+ initial = True
9
+
10
+ dependencies = [
11
+ ]
12
+
13
+ operations = [
14
+ migrations.CreateModel(
15
+ name='Example',
16
+ fields=[
17
+ ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
18
+ ('title', models.CharField(max_length=100)),
19
+ ('content', models.TextField()),
20
+ ],
21
+ ),
22
+ ]
File without changes
@@ -0,0 +1,7 @@
1
+ from django.db import models
2
+
3
+ # Create your models here.
4
+
5
+ class Example(models.Model):
6
+ title = models.CharField(max_length=100)
7
+ content = models.TextField()
@@ -0,0 +1,3 @@
1
+ from django.shortcuts import render
2
+
3
+ # Create your views here.
@@ -0,0 +1,107 @@
1
+ Metadata-Version: 2.2
2
+ Name: valar
3
+ Version: 0.0.9
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
+ # settings
22
+ ```python
23
+ from pathlib import Path
24
+
25
+ """ Compulsory settings """
26
+ DEBUG = True
27
+ BASE_DIR = Path(__file__).resolve().parent.parent
28
+ BASE_APP = str(BASE_DIR.name)
29
+ DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'
30
+
31
+ """ Minimized compulsory settings """
32
+
33
+ DATABASES = {
34
+ 'default': {
35
+ 'ENGINE': 'django.db.backends.sqlite3',
36
+ 'NAME': BASE_DIR / 'db.sqlite3',
37
+ }
38
+ }
39
+
40
+ INSTALLED_APPS = [
41
+ 'django.contrib.sessions',
42
+ "corsheaders",
43
+ 'channels',
44
+ 'valar.dao'
45
+ ]
46
+
47
+ MIDDLEWARE = [
48
+ 'django.contrib.sessions.middleware.SessionMiddleware',
49
+ 'corsheaders.middleware.CorsMiddleware',
50
+ 'django.middleware.common.CommonMiddleware',
51
+ 'valar.Middleware'
52
+ ]
53
+
54
+ CHANNEL_LAYERS = {
55
+ "default": {
56
+ "BACKEND": "channels.layers.InMemoryChannelLayer"
57
+ }
58
+ }
59
+
60
+ CORS_ORIGIN_ALLOW_ALL = True
61
+ CORS_ALLOW_CREDENTIALS = True
62
+ ROOT_URLCONF = "%s.urls" % BASE_APP
63
+ ASGI_APPLICATION = "%s.asgi.application" % BASE_APP
64
+ VALAR_CHANNEL_HANDLER_MAPPING = "%s.urls.channel_handler_mapping" % BASE_APP
65
+
66
+ """ Optional settings """
67
+ # ALLOWED_HOSTS = ['*']
68
+ # LANGUAGE_CODE = 'en-us'
69
+ # TIME_ZONE = 'Asia/Shanghai'
70
+ # USE_I18N = True
71
+ # USE_TZ = False
72
+ # SESSION_SAVE_EVERY_REQUEST = True
73
+ # SESSION_COOKIE_AGE = 60 * 60
74
+ # FILE_UPLOAD_MAX_MEMORY_SIZE = 1024 * 1024 * 100
75
+ # DATA_UPLOAD_MAX_MEMORY_SIZE = 1024 * 1024 * 100
76
+ ```
77
+
78
+ # root urls
79
+
80
+
81
+
82
+
83
+
84
+ # prepare
85
+ ```sh
86
+ python -m pip install --upgrade pip
87
+ ```
88
+ ```sh
89
+ pip install --upgrade build
90
+ ```
91
+ ```sh
92
+ pip install twine
93
+ ```
94
+
95
+ # publish
96
+ ```sh
97
+ rm -r dist
98
+ ```
99
+ ```sh
100
+ python -m build
101
+ ```
102
+ ```sh
103
+ twine check dist/*
104
+ ```
105
+ ```sh
106
+ twine upload dist/*
107
+ ```
@@ -0,0 +1,16 @@
1
+ LICENSE
2
+ README.md
3
+ setup.py
4
+ src/valar/__init__.py
5
+ src/valar.egg-info/PKG-INFO
6
+ src/valar.egg-info/SOURCES.txt
7
+ src/valar.egg-info/dependency_links.txt
8
+ src/valar.egg-info/requires.txt
9
+ src/valar.egg-info/top_level.txt
10
+ src/valar/channels/__init__.py
11
+ src/valar/channels/views.py
12
+ src/valar/dao/__init__.py
13
+ src/valar/dao/models.py
14
+ src/valar/dao/views.py
15
+ src/valar/dao/migrations/0001_initial.py
16
+ src/valar/dao/migrations/__init__.py
valar-0.0.7/PKG-INFO DELETED
@@ -1,44 +0,0 @@
1
- Metadata-Version: 2.2
2
- Name: valar
3
- Version: 0.0.7
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
- ```sh
23
- python -m pip install --upgrade pip
24
- ```
25
- ```sh
26
- pip install --upgrade build
27
- ```
28
- ```sh
29
- pip install twine
30
- ```
31
-
32
- # publish
33
- ```sh
34
- rm -r dist
35
- ```
36
- ```sh
37
- python -m build
38
- ```
39
- ```sh
40
- twine check dist/*
41
- ```
42
- ```sh
43
- twine upload dist/*
44
- ```
valar-0.0.7/README.md DELETED
@@ -1,26 +0,0 @@
1
- valar for morghulis
2
-
3
- # prepare
4
- ```sh
5
- python -m pip install --upgrade pip
6
- ```
7
- ```sh
8
- pip install --upgrade build
9
- ```
10
- ```sh
11
- pip install twine
12
- ```
13
-
14
- # publish
15
- ```sh
16
- rm -r dist
17
- ```
18
- ```sh
19
- python -m build
20
- ```
21
- ```sh
22
- twine check dist/*
23
- ```
24
- ```sh
25
- twine upload dist/*
26
- ```
@@ -1,136 +0,0 @@
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
-
@@ -1,44 +0,0 @@
1
- Metadata-Version: 2.2
2
- Name: valar
3
- Version: 0.0.7
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
- ```sh
23
- python -m pip install --upgrade pip
24
- ```
25
- ```sh
26
- pip install --upgrade build
27
- ```
28
- ```sh
29
- pip install twine
30
- ```
31
-
32
- # publish
33
- ```sh
34
- rm -r dist
35
- ```
36
- ```sh
37
- python -m build
38
- ```
39
- ```sh
40
- twine check dist/*
41
- ```
42
- ```sh
43
- twine upload dist/*
44
- ```
@@ -1,10 +0,0 @@
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
File without changes
File without changes