mirror of
https://github.com/ansible/awx.git
synced 2026-05-07 17:37:37 -02:30
@@ -1,20 +1,64 @@
|
|||||||
import json
|
import json
|
||||||
|
import urlparse
|
||||||
|
|
||||||
from channels import Group
|
from channels import Group
|
||||||
from channels.sessions import channel_session
|
from channels.sessions import channel_session
|
||||||
|
|
||||||
|
from django.contrib.auth.models import User
|
||||||
|
from awx.main.models.organization import AuthToken
|
||||||
|
|
||||||
|
|
||||||
def discard_groups(message):
|
def discard_groups(message):
|
||||||
if 'groups' in message.channel_session:
|
if 'groups' in message.channel_session:
|
||||||
for group in message.channel_session['groups']:
|
for group in message.channel_session['groups']:
|
||||||
Group(group).discard(message.reply_channel)
|
Group(group).discard(message.reply_channel)
|
||||||
|
|
||||||
|
|
||||||
|
def validate_token(token):
|
||||||
|
try:
|
||||||
|
auth_token = AuthToken.objects.get(key=token)
|
||||||
|
if not auth_token.in_valid_tokens:
|
||||||
|
return None
|
||||||
|
except AuthToken.DoesNotExist:
|
||||||
|
return None
|
||||||
|
return auth_token
|
||||||
|
|
||||||
|
|
||||||
|
def user_from_token(auth_token):
|
||||||
|
try:
|
||||||
|
return User.objects.get(pk=auth_token.user_id)
|
||||||
|
except User.DoesNotExist:
|
||||||
|
return None
|
||||||
|
|
||||||
|
@channel_session
|
||||||
|
def ws_connect(message):
|
||||||
|
token = None
|
||||||
|
qs = urlparse.parse_qs(message['query_string'])
|
||||||
|
if 'token' in qs:
|
||||||
|
if len(qs['token']) > 0:
|
||||||
|
token = qs['token'].pop()
|
||||||
|
message.channel_session['token'] = token
|
||||||
|
|
||||||
|
|
||||||
@channel_session
|
@channel_session
|
||||||
def ws_disconnect(message):
|
def ws_disconnect(message):
|
||||||
discard_groups(message)
|
discard_groups(message)
|
||||||
|
|
||||||
|
|
||||||
@channel_session
|
@channel_session
|
||||||
def ws_receive(message):
|
def ws_receive(message):
|
||||||
|
token = message.channel_session.get('token')
|
||||||
|
|
||||||
|
auth_token = validate_token(token)
|
||||||
|
if auth_token is None:
|
||||||
|
message.reply_channel.send({"text": json.dumps({"error": "invalid auth token"})})
|
||||||
|
return None
|
||||||
|
|
||||||
|
user = user_from_token(auth_token)
|
||||||
|
if user is None:
|
||||||
|
message.reply_channel.send({"text": json.dumps({"error": "no valid user"})})
|
||||||
|
return None
|
||||||
|
|
||||||
raw_data = message.content['text']
|
raw_data = message.content['text']
|
||||||
data = json.loads(raw_data)
|
data = json.loads(raw_data)
|
||||||
|
|
||||||
@@ -35,5 +79,4 @@ def ws_receive(message):
|
|||||||
|
|
||||||
|
|
||||||
def emit_channel_notification(group, payload):
|
def emit_channel_notification(group, payload):
|
||||||
payload = json.dumps(payload)
|
|
||||||
Group(group).send({"text": json.dumps(payload)})
|
Group(group).send({"text": json.dumps(payload)})
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ from channels.routing import route
|
|||||||
|
|
||||||
|
|
||||||
channel_routing = [
|
channel_routing = [
|
||||||
|
route("websocket.connect", "awx.main.consumers.ws_connect", path=r'^/websocket/$'),
|
||||||
route("websocket.disconnect", "awx.main.consumers.ws_disconnect", path=r'^/websocket/$'),
|
route("websocket.disconnect", "awx.main.consumers.ws_disconnect", path=r'^/websocket/$'),
|
||||||
route("websocket.receive", "awx.main.consumers.ws_receive", path=r'^/websocket/$'),
|
route("websocket.receive", "awx.main.consumers.ws_receive", path=r'^/websocket/$'),
|
||||||
]
|
]
|
||||||
|
|||||||
@@ -14,7 +14,8 @@ export default
|
|||||||
var self = this,
|
var self = this,
|
||||||
host = window.location.host,
|
host = window.location.host,
|
||||||
protocol,
|
protocol,
|
||||||
url;
|
url,
|
||||||
|
token = Authorization.getToken();
|
||||||
|
|
||||||
if($location.protocol() === 'http'){
|
if($location.protocol() === 'http'){
|
||||||
protocol = 'ws';
|
protocol = 'ws';
|
||||||
@@ -26,6 +27,7 @@ export default
|
|||||||
|
|
||||||
if (!$rootScope.sessionTimer || ($rootScope.sessionTimer && !$rootScope.sessionTimer.isExpired())) {
|
if (!$rootScope.sessionTimer || ($rootScope.sessionTimer && !$rootScope.sessionTimer.isExpired())) {
|
||||||
// We have a valid session token, so attempt socket connection
|
// We have a valid session token, so attempt socket connection
|
||||||
|
url = `${url}?token=${token}`;
|
||||||
$log.debug('Socket connecting to: ' + url);
|
$log.debug('Socket connecting to: ' + url);
|
||||||
|
|
||||||
self.socket = new ReconnectingWebSocket(url, null, {
|
self.socket = new ReconnectingWebSocket(url, null, {
|
||||||
@@ -73,9 +75,6 @@ export default
|
|||||||
// Function called when messages are received on by the UI from
|
// Function called when messages are received on by the UI from
|
||||||
// the API over the websocket. This will route each message to
|
// the API over the websocket. This will route each message to
|
||||||
// the appropriate controller for the current $state.
|
// the appropriate controller for the current $state.
|
||||||
e.data = e.data.replace(/\\/g, '');
|
|
||||||
e.data = e.data.substr(0, e.data.length-1);
|
|
||||||
e.data = e.data.substr(1);
|
|
||||||
$log.debug('Received From Server: ' + e.data);
|
$log.debug('Received From Server: ' + e.data);
|
||||||
|
|
||||||
var data = JSON.parse(e.data), str = "";
|
var data = JSON.parse(e.data), str = "";
|
||||||
|
|||||||
Reference in New Issue
Block a user