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 +107 -0
- valar-0.0.9/README.md +89 -0
- {valar-0.0.7 → valar-0.0.9}/setup.py +1 -1
- valar-0.0.9/src/valar/__init__.py +21 -0
- valar-0.0.9/src/valar/channels/__init__.py +101 -0
- valar-0.0.9/src/valar/channels/views.py +46 -0
- valar-0.0.9/src/valar/dao/migrations/0001_initial.py +22 -0
- valar-0.0.9/src/valar/dao/migrations/__init__.py +0 -0
- valar-0.0.9/src/valar/dao/models.py +7 -0
- valar-0.0.9/src/valar/dao/views.py +3 -0
- valar-0.0.9/src/valar.egg-info/PKG-INFO +107 -0
- valar-0.0.9/src/valar.egg-info/SOURCES.txt +16 -0
- valar-0.0.7/PKG-INFO +0 -44
- valar-0.0.7/README.md +0 -26
- valar-0.0.7/src/valar/channels.py +0 -136
- valar-0.0.7/src/valar.egg-info/PKG-INFO +0 -44
- valar-0.0.7/src/valar.egg-info/SOURCES.txt +0 -10
- {valar-0.0.7 → valar-0.0.9}/LICENSE +0 -0
- {valar-0.0.7 → valar-0.0.9}/setup.cfg +0 -0
- {valar-0.0.7/src/valar → valar-0.0.9/src/valar/dao}/__init__.py +0 -0
- {valar-0.0.7 → valar-0.0.9}/src/valar.egg-info/dependency_links.txt +0 -0
- {valar-0.0.7 → valar-0.0.9}/src/valar.egg-info/requires.txt +0 -0
- {valar-0.0.7 → valar-0.0.9}/src/valar.egg-info/top_level.txt +0 -0
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
|
+
```
|
|
@@ -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,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
|
-
```
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|