Почему мой канал останавливается после отправки нескольких сообщений? - PullRequest
0 голосов
/ 04 июня 2019

У меня есть приложение в Rails 5.0, я пытаюсь пообщаться с ActionCable и React на стороне клиента, и оно работает. Но после отправки нескольких сообщений, кажется, прекращается передача канала.

Это регистр моей консоли ruby ​​на рельсах

  Message Create (1.1ms)  INSERT INTO "messages" ("text", "conversation_id", "created_at", "updated_at", "user_send_id") VALUES ($1, $2, $3, $4, $5) RETURNING "id"  [["text", "hola"], ["conversation_id", 66], ["created_at", "2019-06-04 10:33:49.164259"], ["updated_at", "2019-06-04 10:33:49.164259"], ["user_send_id", 1]]
  ↳ app/controllers/messages_controller.rb:10
   (18.8ms)  COMMIT
  ↳ app/controllers/messages_controller.rb:10
[ActionCable] Broadcasting to messages:Z2lkOi8vY2hhdC1hcGkvQ29udmVyc2F0aW9uLzY2: {:message=>{:id=>188, :conversation_id=>66, :text=>"hola", :created_at=>Tue, 04 Jun 2019 10:33:49 UTC +00:00, :conversation=>{:id=>66}, :user_send=>{:id=>1, :email=>"castrodaniel244@gmail.com", :nickname=>nil, :name=>nil}}}
[active_model_serializers] Rendered ActiveModel::Serializer::Null with Hash (0.25ms)
MessagesChannel transmitting {"message"=>{"id"=>188, "conversation_id"=>66, "text"=>"hola", "created_at"=>"2019-06-04T10:33:49.164Z", "conversation"=>{"id"=>66}, "user_send"=>{"id"=>1, "email"=>"castrodaniel244@gmail.com", "nickname"=>nil, "name"=>nil}}} (via streamed from messages:Z2lkOi8vY2hhdC1hcGkvQ29udmVyc2F0aW9uLzY2)
  User Load (0.5ms)  SELECT  "users".* FROM "users" WHERE "users"."id" = $1 LIMIT $2  [["id", 1], ["LIMIT", 1]]
  ↳ /var/lib/gems/2.5.0/gems/activerecord-5.2.3/lib/active_record/log_subscriber.rb:98
Completed 200 OK in 46ms (Views: 1.0ms | ActiveRecord: 22.3ms)


Unsubscribing from channel: {"channel":"MessagesChannel","conversation":66}
Unsubscribing from channel: {"channel":"MessagesChannel","conversation":67}
MessagesChannel stopped streaming from messages:Z2lkOi8vY2hhdC1hcGkvQ29udmVyc2F0aW9uLzY3
MessagesChannel stopped streaming from messages:Z2lkOi8vY2hhdC1hcGkvQ29udmVyc2F0aW9uLzY2
Unsubscribing from channel: {"channel":"MessagesChannel","conversation":68}
MessagesChannel stopped streaming from messages:Z2lkOi8vY2hhdC1hcGkvQ29udmVyc2F0aW9uLzY4
  Conversation Load (0.5ms)  SELECT  "conversations".* FROM "conversations" WHERE "conversations"."id" = $1 LIMIT $2  [["id", 67], ["LIMIT", 1]]
Unsubscribing from channel: {"channel":"ConversationsChannel","user_id":1}
  ↳ app/channels/messages_channel.rb:3
ConversationsChannel stopped streaming from conversations_channel_1
MessagesChannel is transmitting the subscription confirmation
MessagesChannel is streaming from messages:Z2lkOi8vY2hhdC1hcGkvQ29udmVyc2F0aW9uLzY3
Started POST "/messages" for ::1 at 2019-06-04 12:33:52 +0200
Processing by MessagesController#create as JSON
  Parameters: {"conversation_id"=>66, "text"=>"hola parte2", "message"=>{"text"=>"hola parte2", "conversation_id"=>66}}
  User Load (0.5ms)  SELECT  "users".* FROM "users" WHERE "users"."uid" = $1 LIMIT $2  [["uid", "castrodaniel244@gmail.com"], ["LIMIT", 1]]
  ↳ /var/lib/gems/2.5.0/gems/activerecord-5.2.3/lib/active_record/log_subscriber.rb:98
  User Load (0.4ms)  SELECT "users".* FROM "users" WHERE "users"."email" = $1  [["email", "castrodaniel244@gmail.com"]]
  ↳ app/controllers/messages_controller.rb:27
Unpermitted parameter: :message
  Conversation Load (0.4ms)  SELECT  "conversations".* FROM "conversations" WHERE "conversations"."id" = $1 LIMIT $2  [["id", 66], ["LIMIT", 1]]
  ↳ app/controllers/messages_controller.rb:8
  User Load (0.4ms)  SELECT  "users".* FROM "users" WHERE "users"."id" = $1 LIMIT $2  [["id", 1], ["LIMIT", 1]]
  ↳ app/controllers/messages_controller.rb:8
Unpermitted parameter: :message
  CACHE Conversation Load (0.0ms)  SELECT  "conversations".* FROM "conversations" WHERE "conversations"."id" = $1 LIMIT $2  [["id", 66], ["LIMIT", 1]]
  ↳ app/controllers/messages_controller.rb:9
   (0.3ms)  BEGIN
  ↳ app/controllers/messages_controller.rb:10
  Message Create (0.7ms)  INSERT INTO "messages" ("text", "conversation_id", "created_at", "updated_at", "user_send_id") VALUES ($1, $2, $3, $4, $5) RETURNING "id"  [["text", "hola parte2"], ["conversation_id", 66], ["created_at", "2019-06-04 10:33:52.950716"], ["updated_at", "2019-06-04 10:33:52.950716"], ["user_send_id", 1]]
  ↳ app/controllers/messages_controller.rb:10
   (99.3ms)  COMMIT
  ↳ app/controllers/messages_controller.rb:10
[ActionCable] Broadcasting to messages:Z2lkOi8vY2hhdC1hcGkvQ29udmVyc2F0aW9uLzY2: {:message=>{:id=>189, :conversation_id=>66, :text=>"hola parte2", :created_at=>Tue, 04 Jun 2019 10:33:52 UTC +00:00, :conversation=>{:id=>66}, :user_send=>{:id=>1, :email=>"castrodaniel244@gmail.com", :nickname=>nil, :name=>nil}}}
[active_model_serializers] Rendered ActiveModel::Serializer::Null with Hash (0.22ms)
  User Load (0.4ms)  SELECT  "users".* FROM "users" WHERE "users"."id" = $1 LIMIT $2  [["id", 1], ["LIMIT", 1]]
  ↳ /var/lib/gems/2.5.0/gems/activerecord-5.2.3/lib/active_record/log_subscriber.rb:98
Completed 200 OK in 117ms (Views: 0.7ms | ActiveRecord: 102.3ms)

У меня есть контроллер для сообщений

class MessagesController < ApplicationController
    before_action :authenticate_user!
    before_action :set_user_id_loggued, only: [:create]

    def create
        message = Message.new(message_params)

        if message.valid?
            conversation = Conversation.find(message_params[:conversation_id])
            message.save
            serialized_data = ActiveModelSerializers::Adapter::Json.new(MessageSerializer.new(message)).serializable_hash
            MessagesChannel.broadcast_to conversation, serialized_data
            render json: {data: serialized_data}
        else
            render json: {messages: message.errors.full_messages }, status: 422
        end
    end

    private

    def message_params
        params[:user_send_id] = @user_id
        params.permit(:text, :conversation_id, :user_send_id)
    end

    def set_user_id_loggued
        @user_id = User.where(email: request.headers["uid"])[0].id
    end
end

Здесь менеджер каналов для сообщений

class MessagesChannel < ApplicationCable::Channel
  def subscribed
    conversation = Conversation.find(params[:conversation])
    stream_for conversation
  end

  def unsubscribed
    # Any cleanup needed when channel is unsubscribed
  end
end

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...