Mercurial Hosting > lang
diff src/lib/ai/claude/Chat.luan @ 6:025bb19b65b1
use claude
author | Franklin Schmidt <fschmidt@gmail.com> |
---|---|
date | Thu, 17 Jul 2025 23:19:22 -0600 |
parents | src/lib/ai/chatgpt/Chat.luan@a970b7a01a74 |
children | 255c36830154 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/lib/ai/claude/Chat.luan Thu Jul 17 23:19:22 2025 -0600 @@ -0,0 +1,98 @@ +local Luan = require "luan:Luan.luan" +local error = Luan.error +local ipairs = Luan.ipairs or error() +local type = Luan.type or error() +local String = require "luan:String.luan" +local starts_with = String.starts_with or error() +local Html = require "luan:Html.luan" +local html_encode = Html.encode or error() +local Parsers = require "luan:Parsers.luan" +local json_parse = Parsers.json_parse or error() +local json_string = Parsers.json_string or error() +local Claude = require "site:/lib/ai/claude/Claude.luan" +local claude_chat = Claude.chat or error() +local Logging = require "luan:logging/Logging.luan" +local logger = Logging.logger "claude/Chat" +local Thread = require "luan:Thread.luan" + + +local Chat = {} + +function Chat.output_messages_html(thread) + local messages = thread and json_parse(thread) or {nil} + for _, message in ipairs(messages) do + local role = message.role or error() + local who + if role=="assistant" then + who = "Claude" + elseif role=="user" then + who = "You" + else + error(role) + end + local function output(text) + if not starts_with( text, "[INTERNAL_UPDATE]" ) then +%> + <h3><%=who%></h3> + <div role="<%=role%>"><%=html_encode(text)%></div> +<% + end + end + local content = message.content or error() + if type(content) == "string" then + output(content) + else + for _, part in ipairs(content) do + if part.type=="text" then + local text = part.text or error() + output(text) + end + end + end + end_for +end + +function Chat.ask(thread,input) + local messages = thread and json_parse(thread) or {nil} + messages[#messages+1] = { + role = "user" + content = input + } +--[=[ + messages[#messages+1] = { + role = "assistant" + content = [[ +- 1 +- 2 +- 3 +- 4 +- 5 +- 6 +- 7 +- 8 +- 9 +- 10 +]] + Thread.sleep(5000) + } + if true then + return json_string(messages) + end +--]=] + local resultJson = claude_chat{ + messages = messages + } + local result = json_parse(resultJson) + -- logger.info(json_string(result)) + result.type == "message" or error() + result.role == "assistant" or error() + result.stop_reason == "end_turn" or result.stop_reason == "tool_use" or error() + local content = result.content or error() + messages[#messages+1] = { + role = "assistant" + content = content + } + return json_string(messages) +end + +return Chat