🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

1回答

922閲覧

rails6 ActionCableでchat機能は付けられましたが非同期処理内で送信者と受信者でviewの見え方を変えたい

ukiuki

総合スコア4

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2019/10/03 10:50

前提・実現したいこと

rails6でactioncableとbroadcastでLineのグループ機能のようなものを作っています
現段階ではチャット機能はできていて
非同期処理の中でifを使ってメッセージの送信者と見ている人のidを比較し、送信者と見ている人でメッセージの見え方を変えたいです

発生している問題・エラーメッセージ

broadcast(非同期)内で'gem devise'のヘルパーメソッドのcurrent_userで値を取りたいのですがうまくいきません

html

1<div class="message"> 2 <% if message.user_id == #current_user.id# %> 3 ... 4 <% else %> 5 ... 6 <% end %> 7</div>

該当のソースコード

broadcastjob

1class MessageBroadcastJob < ApplicationJob 2 queue_as :default 3 4 def perform(message) 5 ActionCable.server.broadcast "room_channel_#{message.room_id}", message: render_message(message) 6 end 7 8 private 9 10 def render_message(message) 11 ApplicationController.renderer.render partial: 'messages/message', locals: { message: message } 12 end 13end

channelRuby

1class RoomChannel < ApplicationCable::Channel 2 def subscribed 3 stream_from "room_channel_#{params['room']}" 4 end 5 6 def unsubscribed 7 # Any cleanup needed when channel is unsubscribed 8 end 9 10 def speak(data) 11 Message.create!(content: data['message'], user_id: current_user.id, room_id: params['room']) 12 end 13end 14

channelJS

1import consumer from "./consumer" 2 3$(function() { 4 const chatChannel = consumer.subscriptions.create({ channel: 'RoomChannel', room: $('#messages').data('room_id') }, { 5 connected() { 6 // Called when the subscription is ready for use on the server 7 }, 8 9 disconnected() { 10 // Called when the subscription has been terminated by the server 11 }, 12 13 received: function(data) { 14 return $('#messages').append(data['message']); 15 }, 16 17 speak: function(message) { 18 return this.perform('speak', { 19 message: message 20 }); 21 } 22 }); 23 24 $(document).on('keypress', '[data-behavior~=room_speaker]', function(event) { 25 if (event.keyCode === 13) { 26 chatChannel.speak(event.target.value); 27 event.target.value = ''; 28 return event.preventDefault(); 29 } 30 }); 31});

試したこと

current_userの値を非同期で取れないか試行錯誤しています

補足情報(FW/ツールのバージョンなど)

cloud9 ubuntu
rails6
ruby 2.6.3
devise 4.7.1

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

WebSocket側からdeviseのcurrent_userを直接扱うことはできません。
app/channels/application_cable/connection.rb
で別途current_userを用意してください。

投稿2019/10/04 00:21

Mugheart

総合スコア2349

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問