2023-03-17 14:14:19 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
class CompletionPrompt < ActiveRecord::Base
|
2023-11-27 07:33:31 -05:00
|
|
|
# TODO(roman): Remove may 2024.
|
|
|
|
self.ignored_columns = ["provider"]
|
|
|
|
|
|
|
|
TRANSLATE = -301
|
2023-11-28 10:52:22 -05:00
|
|
|
GENERATE_TITLES = -307
|
2023-11-27 07:33:31 -05:00
|
|
|
PROOFREAD = -303
|
|
|
|
MARKDOWN_TABLE = -304
|
|
|
|
CUSTOM_PROMPT = -305
|
|
|
|
EXPLAIN = -306
|
2023-03-21 11:04:59 -04:00
|
|
|
|
2023-03-17 14:14:19 -04:00
|
|
|
enum :prompt_type, { text: 0, list: 1, diff: 2 }
|
2023-03-21 11:04:59 -04:00
|
|
|
|
|
|
|
validates :messages, length: { maximum: 20 }
|
|
|
|
validate :each_message_length
|
|
|
|
|
2023-11-27 07:33:31 -05:00
|
|
|
def self.enabled_by_name(name)
|
|
|
|
where(enabled: true).find_by(name: name)
|
|
|
|
end
|
2023-10-23 10:41:36 -04:00
|
|
|
|
2023-12-11 17:26:56 -05:00
|
|
|
attr_accessor :custom_instruction
|
|
|
|
|
2023-11-27 07:33:31 -05:00
|
|
|
def messages_with_input(input)
|
|
|
|
return unless input
|
2023-09-25 14:12:54 -04:00
|
|
|
|
2023-12-11 17:26:56 -05:00
|
|
|
user_input =
|
|
|
|
if id == CUSTOM_PROMPT && custom_instruction.present?
|
|
|
|
"#{custom_instruction}:\n#{input}"
|
|
|
|
else
|
|
|
|
input
|
|
|
|
end
|
|
|
|
|
|
|
|
messages_hash.merge(input: <<~TEXT)
|
|
|
|
<input>
|
|
|
|
#{user_input}
|
|
|
|
</input>
|
|
|
|
TEXT
|
2023-03-21 11:04:59 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
2023-11-27 07:33:31 -05:00
|
|
|
def messages_hash
|
|
|
|
@messages_hash ||= messages.symbolize_keys!
|
|
|
|
end
|
|
|
|
|
2023-03-21 11:04:59 -04:00
|
|
|
def each_message_length
|
|
|
|
messages.each_with_index do |msg, idx|
|
|
|
|
next if msg["content"].length <= 1000
|
|
|
|
|
|
|
|
errors.add(:messages, I18n.t("errors.prompt_message_length", idx: idx + 1))
|
|
|
|
end
|
|
|
|
end
|
2023-03-17 14:14:19 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: completion_prompts
|
|
|
|
#
|
|
|
|
# id :bigint not null, primary key
|
|
|
|
# name :string not null
|
|
|
|
# translated_name :string
|
|
|
|
# prompt_type :integer default("text"), not null
|
|
|
|
# enabled :boolean default(TRUE), not null
|
|
|
|
# created_at :datetime not null
|
|
|
|
# updated_at :datetime not null
|
2023-04-10 10:04:42 -04:00
|
|
|
# messages :jsonb
|
2023-03-17 14:14:19 -04:00
|
|
|
#
|
|
|
|
# Indexes
|
|
|
|
#
|
2023-04-10 10:04:42 -04:00
|
|
|
# index_completion_prompts_on_name (name)
|
2023-03-17 14:14:19 -04:00
|
|
|
#
|