2017-05-01 64 views
0

我在執行下面我試圖從ember-simple-auth-token獲得令牌和一個網址,用來與ActionCable連接使用:如何從ember-simple-auth-token獲取令牌以使用Websocket?

... 

export default Route.extend({ 
    store: service(), 
    currentUser: service(), 
    session: service(), 
    cable: service(), 

    setupConsumer: on('init', function() { 
    let token = this.get('session.data.authenticated.jwt'); 
    let consumer = this.get('cable') 
     .createConsumer(`wss://api.${config.APP.host}/cable?token=${token}`); 

    let channelMixin = Mixin.create({ 
     received(data) { 
     this.get('store').pushPayload(data); 
     } 
    }); 

    consumer.subscriptions.create({ 
     channel: 'ChatroomsChannel' 
    }, channelMixin); 
    }), 

    ... 
}); 

這種方法只適用於第一次請求。我需要將這個存儲在cookie中?謝謝。

回答

1

後續代碼解決了我的問題:

import Route from 'ember-route'; 
import service from 'ember-service/inject'; 
import Mixin from 'ember-metal/mixin'; 
import config from 'apollo-enterprise/config/environment'; 

export default Route.extend({ 
    session: service(), 
    cable: service(), 

    afterModel(model) { 
    this.get('session.store').restore().then((data) => { 
     let token = data.authenticated.jwt; 
     let consumer = this.get('cable') 
     .createConsumer(`wss://api.${config.APP.host}/cable?token=${token}`); 

     let channelMixin = Mixin.create({ 
     store: service(), 

     received(data) { 
      this.get('store').pushPayload(data); 
     } 
     }); 

     consumer.subscriptions.create({ 
     channel: 'MessagesChannel', 
     chatroom_id: model.id 
     }, channelMixin); 
    }); 
    }, 

    setupController(controller) { 
    this._super(...arguments); 

    controller.set('message', {}); 
    }, 

    actions: { 
    sendMessage(params) { 
     let chatroom = this.controller.get('model'); 
     let message = this.get('store').createRecord('message', params); 

     message.set('chatroom', chatroom); 
     message.save().then(() => { 
     this.controller.set('message', {}); 
     }); 
    } 
    } 
}); 
相關問題