push x
This commit is contained in:
parent
57fc83567d
commit
ab311c54d8
3
.gitignore
vendored
3
.gitignore
vendored
@ -206,3 +206,6 @@ fabric.properties
|
||||
|
||||
# Others
|
||||
*.db
|
||||
/v25pushx/
|
||||
/report.sql
|
||||
/vapidkeys.json
|
||||
|
7
.idea/sqldialects.xml
Normal file
7
.idea/sqldialects.xml
Normal file
@ -0,0 +1,7 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="SqlDialectMappings">
|
||||
<file url="file://$PROJECT_DIR$/report.sql" dialect="GenericSQL" />
|
||||
<file url="PROJECT" dialect="SQLite" />
|
||||
</component>
|
||||
</project>
|
@ -2,6 +2,7 @@
|
||||
<module type="PYTHON_MODULE" version="4">
|
||||
<component name="NewModuleRootManager">
|
||||
<content url="file://$MODULE_DIR$">
|
||||
<excludeFolder url="file://$MODULE_DIR$/v25pushx" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/venv" />
|
||||
</content>
|
||||
<orderEntry type="inheritedJdk" />
|
||||
|
@ -2,5 +2,6 @@
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="$PROJECT_DIR$" vcs="Git" />
|
||||
<mapping directory="$PROJECT_DIR$/v25pushx" vcs="Git" />
|
||||
</component>
|
||||
</project>
|
@ -1,7 +1,7 @@
|
||||
from flask import Flask
|
||||
from werkzeug.middleware.dispatcher import DispatcherMiddleware
|
||||
|
||||
import config25
|
||||
from v25 import config
|
||||
from v25.storage.dbstorage import DBStorage
|
||||
from v25.web.server.api import API
|
||||
|
||||
@ -11,8 +11,8 @@ def simple(_env, resp):
|
||||
return []
|
||||
|
||||
|
||||
d = config25.get_config('dev-config.json')
|
||||
config25.from_config(d)
|
||||
d = config.get_config('dev-config.json')
|
||||
config.from_config(d)
|
||||
|
||||
app = Flask(__name__)
|
||||
app.wsgi_app = DispatcherMiddleware(simple, {
|
||||
|
@ -1,7 +1,7 @@
|
||||
from flask import Flask
|
||||
from werkzeug.middleware.dispatcher import DispatcherMiddleware
|
||||
|
||||
import config25
|
||||
from v25 import config
|
||||
from v25.storage.dbstorage import DBStorage
|
||||
from v25.web.server.api import API
|
||||
|
||||
@ -11,8 +11,8 @@ def simple(_env, resp):
|
||||
return []
|
||||
|
||||
|
||||
d = config25.get_config('staging-config.json')
|
||||
config25.from_config(d)
|
||||
d = config.get_config('staging-config.json')
|
||||
config.from_config(d)
|
||||
|
||||
app = Flask(__name__)
|
||||
app.wsgi_app = DispatcherMiddleware(simple, {
|
||||
|
@ -4,7 +4,7 @@ from typing import Dict, Any, Union
|
||||
from v25.storage.dbstorage import DBStorage
|
||||
|
||||
|
||||
_d_type = Dict[Any, Union[str, Dict[str, Any]]]
|
||||
_d_type = Dict[str, Union[str, Dict[str, Any]]]
|
||||
|
||||
|
||||
def get_config(file: str) -> _d_type:
|
@ -1,10 +1,10 @@
|
||||
import json
|
||||
from subprocess import Popen, PIPE
|
||||
from sys import stderr
|
||||
from threading import Thread
|
||||
from time import time, sleep
|
||||
from typing import Tuple, Optional, Iterable, List
|
||||
|
||||
import requests
|
||||
from nacl.bindings import crypto_sign_PUBLICKEYBYTES
|
||||
from sqlalchemy import create_engine, LargeBinary, Column, REAL, BLOB, String, or_, and_, ForeignKeyConstraint, \
|
||||
Integer, UniqueConstraint, Index, Boolean
|
||||
@ -342,14 +342,16 @@ class DBStorage(PushStorage):
|
||||
|
||||
@staticmethod
|
||||
def pushsubscription(subscription: dict):
|
||||
assert requests.post('http://localhost:5025/api/push', json={
|
||||
p = Popen(["node", "v25pushx/push.js"], stdin=PIPE, shell=True)
|
||||
p.communicate(json.dumps({
|
||||
"subscription": subscription,
|
||||
"notification": {
|
||||
"notification": {
|
||||
"title": "New Message (V25PUSH)"
|
||||
}
|
||||
}
|
||||
}).status_code == 200, "push failed"
|
||||
}).encode())
|
||||
assert not p.wait(), "push subprocess failed"
|
||||
|
||||
def pushpush(self, subject: Subject):
|
||||
session = self.Session()
|
||||
|
Loading…
Reference in New Issue
Block a user