Page Menu
Home
Phabricator
Search
Configure Global Search
Log In
Files
F7159367
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Flag For Later
Size
6 KB
Referenced Files
None
Subscribers
None
View Options
diff --git a/sylk/applications/webrtcgateway/models/sylkpush.py b/sylk/applications/webrtcgateway/models/sylkpush.py
index 39c3dc5..4ea1699 100644
--- a/sylk/applications/webrtcgateway/models/sylkpush.py
+++ b/sylk/applications/webrtcgateway/models/sylkpush.py
@@ -1,60 +1,42 @@
-from .jsonobjects import IntegerProperty, StringProperty, FixedValueProperty, ObjectProperty, AbstractObjectProperty
+from .jsonobjects import IntegerProperty, StringProperty, FixedValueProperty
from .jsonobjects import JSONObject
-class PushBody(JSONObject):
- _content = AbstractObjectProperty(optional=True)
-
-
-class PushData(JSONObject):
- body = ObjectProperty(PushBody)
- call_id = StringProperty()
- token = StringProperty()
- reason = StringProperty()
- url = StringProperty()
-
-
-class PushReply(JSONObject):
- code = IntegerProperty()
- description = StringProperty()
- data = ObjectProperty(PushData)
-
-
# Event base classes (abstract, should not be used directly)
class SylkRTCEventBase(JSONObject):
platform = StringProperty(optional=True)
app_id = StringProperty(optional=True)
token = StringProperty()
device_id = StringProperty(optional=True)
media_type = FixedValueProperty('video')
silent = IntegerProperty(optional=True, default=0)
call_id = StringProperty()
def __init__(self, **kw):
super(SylkRTCEventBase, self).__init__(**kw)
class CallEventBase(SylkRTCEventBase):
event = None # specified by subclass
originator = StringProperty()
from_display_name = StringProperty(optional=True, default=None)
# Events to use used in a SylkPushRequest
class ConferenceInviteEvent(CallEventBase):
event = FixedValueProperty('incoming_conference_request')
to = StringProperty()
@property
def __data__(self):
data = super(ConferenceInviteEvent, self).__data__
for key in data:
# Fixup keys
data[key.replace('_', '-')] = data.pop(key)
data['from'] = data.pop('originator')
return data
diff --git a/sylk/applications/webrtcgateway/push.py b/sylk/applications/webrtcgateway/push.py
index bf43798..e666519 100644
--- a/sylk/applications/webrtcgateway/push.py
+++ b/sylk/applications/webrtcgateway/push.py
@@ -1,99 +1,83 @@
import json
from twisted.internet import defer, reactor
from twisted.web.client import Agent, readBody
from twisted.web.iweb import IBodyProducer
from twisted.web.http_headers import Headers
from zope.interface import implementer
from .configuration import GeneralConfig
from .logger import log
from .models import sylkpush
from .storage import TokenStorage
__all__ = 'conference_invite'
agent = Agent(reactor)
headers = Headers({'User-Agent': ['SylkServer'],
'Content-Type': ['application/json']})
@implementer(IBodyProducer)
class StringProducer(object):
def __init__(self, data):
self.body = data
self.length = len(data)
def startProducing(self, consumer):
consumer.write(self.body)
return defer.succeed(None)
def pauseProducing(self):
pass
def stopProducing(self):
pass
def _construct_and_send(result, request, destination):
for device_token, push_parameters in result.iteritems():
try:
request.token = device_token.split('#')[0]
except IndexError:
request.token = device_token
request.app_id = push_parameters['app']
request.platform = push_parameters['platform']
request.device_id = push_parameters['device_id']
_send_push_notification(json.dumps(request.__data__), destination)
def conference_invite(originator, destination, room, call_id):
tokens = TokenStorage()
request = sylkpush.ConferenceInviteEvent(token='dummy', app_id='dummy', platform='dummy', device_id='dummy',
originator=originator.uri, from_display_name=originator.display_name, to=room, call_id=str(call_id))
user_tokens = tokens[destination]
if isinstance(user_tokens, set):
return
else:
if isinstance(user_tokens, defer.Deferred):
user_tokens.addCallback(lambda result: _construct_and_send(result, request, destination))
else:
_construct_and_send(user_tokens, request, destination)
@defer.inlineCallbacks
def _send_push_notification(payload, destination):
if GeneralConfig.sylk_push_url:
try:
r = yield agent.request('POST', GeneralConfig.sylk_push_url, headers, StringProducer(payload))
except Exception as e:
log.info('Error sending push notification to %s: %s', GeneralConfig.sylk_push_url, e)
else:
if r.code != 200:
- log.warning('Error sending push notification: %s', r.phrase)
- else:
- try:
- body = yield readBody(r)
- except Exception as e:
- log.warning("Error reading body: %s", e)
+ if r.code == 410:
+ log.info("Token expired, purging old token from storage")
+ tokens = TokenStorage()
+ tokens.remove(destination, body.data.token)
else:
- if "application/json" in r.headers.getRawHeaders('content-type'):
- _maybe_purge_token(body, destination)
+ log.warning('Error sending push notification: %s', r.phrase)
+ else:
log.debug('Sent push notification: %s', payload)
else:
log.warning('Cannot send push notification: no Sylk push server configured')
-
-def _maybe_purge_token(body, destination):
- body = sylkpush.PushReply(**json.loads(body))
- reply_body = body.data.body
- try:
- failure = reply_body._content.failure
- if failure == 1:
- reason = reply_body._content.results[0]['error']
- if reason == 'NotRegistered':
- log.info("Token expired, purging old token from storage")
- tokens = TokenStorage()
- tokens.remove(destination, body.data.token)
- except AttributeError, KeyError:
- pass
File Metadata
Details
Attached
Mime Type
text/x-diff
Expires
Sat, Nov 23, 4:51 AM (1 d, 3 h)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
3408826
Default Alt Text
(6 KB)
Attached To
Mode
rSYLK SylkServer
Attached
Detach File
Event Timeline
Log In to Comment