ref: b717d027b8f6705d6b6eb11dd6ea2ecd0c1cb980
dir: /test.rb/
require 'rubygems'
require 'net/yail'
require 'net/http'
require 'uri'
require 'json'
require 'concurrent'
require 'async'
require 'async/http/internet'
require 'async/http/endpoint'
require 'IRC'
# executor = Concurrent::ThreadPoolExecutor.new(
# min_threads: 2,
# max_threads: 5,
# max_queue: 10
# )
config = File.read('CONFIG')
parsed_config = JSON.parse(config)
Server = parsed_config['IRCServer']
BotNick = parsed_config['BotNickName']
$URL = parsed_config['SessionUrl']
$Cookie = parsed_config['SessionCookie']
$irc = Net::YAIL.new(
:address => 'irc.ircnow.org',
:username => 'Moz_Bot',
:realname => 'Moz_Mozak',
:nicknames => ['h2o-bot0']
)
$bot = IRC.new(
BotNick,
Server,
"6667",
"H2O")
$is = false
$currentid = ''
$irc.on_welcome proc { |event| $irc.join('#fpc') }
$irc.on_invite { |event| $irc.join(event.channel) }
$irc.set_callback(:incoming_invite) { |event| $irc.join(event.channel) }
$irc.hearing_ping {|event| $stderr.puts event.inspect}
$irc.hearing_message(:if => {:pm? => true}) do |event|
event.handle!
end
$irc.on_invite { |e| $irc.join(e.channel) }
#:if => {:message => "bah"}
@stack = []
def Push(a,b)
@stack << {:peer => a, :message => b}
end
def Send
$bot.send_message(@stack[0][':peer'], @stack[0][':message'])
end
class Sender
include Concurrent::Async
$irc0 = Net::YAIL.new(
:address => 'irc.ircnow.org',
:username => 'Moz_Bot',
:realname => 'Moz_Mozak',
:nicknames => ['h2o-bot0']
)
def Wait(peer)
$irc.msg(peer, 'Im thinking...')
end
def SendReq(peer, input, c)
uri = URI($URL)
https = Net::HTTP.new(uri.host, uri.port)
https.use_ssl = true
request = Net::HTTP::Post.new(uri.path)
request['Content-Type'] = 'application/json; charset=UTF-8'
request['User-Agent'] = 'Pedaret Mozilla/5.0 Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/113.0.5672.127 Safari/537.36'
request['Cookie'] = $Cookie
request.body = '{"inputs":"'+ input.to_s() +'","parameters":{"temperature":0.1,"truncate":2048,"max_new_tokens":1024,"do_sample":true,"repetition_penalty":1.2,"return_full_text":false},"stream":true,"options":{"id":"6543eb99-e311-4f4e-b791-7af4fcbe556b","response_id":"b194833d-e13c-4390-9d7f-3cf4e4d95430","is_retry":false,"use_cache":false,"web_search_id":""}}'
# Async do |task|
# Async do
# endpoint = Async::HTTP::Endpoint.parse('https://gpt-gm.h2o.ai/conversation/64ac1344245bd909c99ed909')
# http = Async::HTTP::Internet.new
#
# request = Async::HTTP::Request.new(:post, endpoint.path,
# {'Content-Type' => 'application/json; charset=UTF-8'},
# {'Cookie' => 'h2ogpt-chat=a4fc9f08-6c67-466c-8d36-dd425702d6b4'},
# '{"inputs":"'+ input.to_s() +'","parameters":{"temperature":0.1,"truncate":2048,"max_new_tokens":1024,"do_sample":true,"repetition_penalty":1.2,"return_full_text":false},"stream":true,"options":{"id":"6543eb99-e311-4f4e-b791-7af4fcbe556b","response_id":"b194833d-e13c-4390-9d7f-3cf4e4d95430","is_retry":false,"use_cache":false,"web_search_id":""}}')
#
# response = http.call(endpoint, request)
#
# # Process the response
# puts "Response code: #{response.status}"
# puts "Response body: #{response.read}"
#
#
# end
# request = Async::HTTP::Internet.new
#
# request['Content-Type'] = 'application/json; charset=UTF-8'
# request['User-Agent'] = 'Mozilla/5.0 Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/113.0.5672.127 Safari/537.36'
# request['Cookie'] = 'h2ogpt-chat=a4fc9f08-6c67-466c-8d36-dd425702d6b4'
#
# request.body = '{"inputs":"'+ input.to_s() +'","parameters":{"temperature":0.1,"truncate":2048,"max_new_tokens":1024,"do_sample":true,"repetition_penalty":1.2,"return_full_text":false},"stream":true,"options":{"id":"6543eb99-e311-4f4e-b791-7af4fcbe556b","response_id":"b194833d-e13c-4390-9d7f-3cf4e4d95430","is_retry":false,"use_cache":false,"web_search_id":""}}'
#
# task.async do
# request.post(uri.host)
# end
# end
begin
response = https.request(request)
#$irc.msg('#fpc', e.message)
json_strings = response.body.split('data:')
parsed_json_objects = []
json_strings.each do |json_str|
if json_str != ''
parsed_json_objects << JSON.parse(json_str)
end
end
counts = 0
b = ''
parsed_json_objects.each do |json_obj|
result = json_obj['token']['text']
if result == '<|endoftext|>' then
break
elsif counts >= 50
begin
$bot.send_message(peer, 'limit reached!')
break
end
elsif result.include?("\n")
begin
$bot.send_message(peer, b)
sleep(0.2)
counts += 1
#$irc.msg(peer, b)
b = ''
end
else
b += result
end
end
$bot.send_message(peer, b)
#$irc.msg(peer, b)
rescue StandardError => e
$bot.send_message(peer, e)
#$irc.msg(peer, e)
end
end
end
sender = Sender.new
IRCConnection.add_IO_socket(STDIN)
IRCEvent.add_callback('endofmotd') { |event| $bot.add_channel('#fpc') }
IRCEvent.add_callback('invite') do |event|
puts event.message
puts event.channel
$bot.add_channel(event.message)
end
# IRCEvent.add_callback('join') { |event|
# bot.send_message(event.channel, "Hello #{event.from}")
IRCEvent.add_callback('privmsg') {|event|
if event.channel.eql?(BotNick)
begin
if (event.message.start_with?(".invite"))
begin
event.message.slice! ".invite "
$bot.add_channel(event.message)
end
else
$bot.send_message(event.from, "I'm thinking...")
sender.SendReq(event.from, event.message, '')
end
end
else
if (event.message.start_with?("h2o"))
Push(event.channel, 'Im')
Send()
# IRCConnection.output_push("PRIVMSG #{event.channel} : moz")
$bot.send_message(event.channel, "#{event.from}, I'm thinking...")
sender.SendReq(event.channel, event.message, '')
end
end
}
# }
$bot.connect
$irc.heard_msg(:if => {:pm? => true}) do |e|
puts(e.nick)
sender.async.Wait(e.nick)
sender.async.SendReq(e.nick, e.message, $irc)
puts('e')
end
$irc.heard_msg(:if => {:pm? => false}) do |e|
if (e.message.start_with?("h2o"))
puts(e.channel)
sender.async.Wait(e.channel)
sender.async.SendReq(e.channel, e.message, $irc)
puts('e')
end
end
#$irc.start_listening!
futures = []
3.times do |i|
futures << Concurrent::Future.execute(executor: executor) do
end
end
futures.each(&:wait)
executor.shutdown