mirror of
https://github.com/we-promise/sure.git
synced 2026-04-07 22:34:47 +00:00
Backend fixes: - Fix duplicate AssistantResponseJob triggering causing duplicate AI responses - UserMessage model already handles job triggering via after_create_commit callback - Remove redundant job enqueue in chats_controller and messages_controller Mobile app features: - Implement complete AI chat interface and conversation management - Add Chat, Message, and ToolCall data models - Add ChatProvider for state management with polling mechanism - Add ChatService to handle all chat-related API requests - Add chat list screen (ChatListScreen) - Add conversation detail screen (ChatConversationScreen) - Refactor navigation structure with bottom navigation bar (MainNavigationScreen) - Add settings screen (SettingsScreen) - Optimize TransactionsProvider to support account filtering Technical details: - Implement message polling mechanism for real-time AI responses - Support chat creation, deletion, retry and other operations - Integrate Material Design 3 design language - Improve user experience and error handling Co-authored-by: dwvwdv <dwvwdv@protonmail.com>
61 lines
1.9 KiB
Ruby
61 lines
1.9 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class Api::V1::MessagesController < Api::V1::BaseController
|
|
before_action :require_ai_enabled
|
|
before_action :ensure_write_scope, only: [ :create, :retry ]
|
|
before_action :set_chat
|
|
|
|
def create
|
|
@message = @chat.messages.build(
|
|
content: message_params[:content],
|
|
type: "UserMessage",
|
|
ai_model: message_params[:model].presence || Chat.default_model
|
|
)
|
|
|
|
if @message.save
|
|
# NOTE: Commenting out duplicate job enqueue to fix mobile app receiving duplicate AI responses
|
|
# UserMessage model already triggers AssistantResponseJob via after_create_commit callback
|
|
# in app/models/user_message.rb:10-12, so this manual enqueue causes the job to run twice,
|
|
# resulting in duplicate AI responses with different content and wasted tokens.
|
|
# See: https://github.com/dwvwdv/sure (mobile app integration issue)
|
|
# AssistantResponseJob.perform_later(@message)
|
|
render :show, status: :created
|
|
else
|
|
render json: { error: "Failed to create message", details: @message.errors.full_messages }, status: :unprocessable_entity
|
|
end
|
|
end
|
|
|
|
def retry
|
|
last_message = @chat.messages.ordered.last
|
|
|
|
if last_message&.type == "AssistantMessage"
|
|
new_message = @chat.messages.create!(
|
|
type: "AssistantMessage",
|
|
content: "",
|
|
ai_model: last_message.ai_model
|
|
)
|
|
|
|
AssistantResponseJob.perform_later(new_message)
|
|
render json: { message: "Retry initiated", message_id: new_message.id }, status: :accepted
|
|
else
|
|
render json: { error: "No assistant message to retry" }, status: :unprocessable_entity
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def ensure_write_scope
|
|
authorize_scope!(:write)
|
|
end
|
|
|
|
def set_chat
|
|
@chat = Current.user.chats.find(params[:chat_id])
|
|
rescue ActiveRecord::RecordNotFound
|
|
render json: { error: "Chat not found" }, status: :not_found
|
|
end
|
|
|
|
def message_params
|
|
params.permit(:content, :model)
|
|
end
|
|
end
|