diff options
-rw-r--r-- | Gemfile.lock | 8 | ||||
-rw-r--r-- | README.md | 4 | ||||
-rw-r--r-- | components/providers/openai.rb | 2 | ||||
-rw-r--r-- | components/stream.rb | 4 | ||||
-rw-r--r-- | controllers/interfaces/tools.rb | 5 | ||||
-rw-r--r-- | controllers/session.rb | 21 | ||||
-rw-r--r-- | nano-bots.gemspec | 2 | ||||
-rw-r--r-- | static/cartridges/default.yml | 2 |
8 files changed, 32 insertions, 16 deletions
diff --git a/Gemfile.lock b/Gemfile.lock index b390ae7..a095e90 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -9,7 +9,7 @@ PATH pry (~> 0.14.2) rainbow (~> 3.1, >= 3.1.1) rbnacl (~> 7.1, >= 7.1.1) - ruby-openai (~> 6.3) + ruby-openai (~> 6.3, >= 6.3.1) sweet-moon (~> 0.0.7) GEM @@ -32,7 +32,7 @@ GEM multipart-post (~> 2) faraday-net_http (3.0.2) ffi (1.16.3) - json (2.7.0) + json (2.7.1) language_server-protocol (3.17.0.3) method_source (1.0.0) multipart-post (2.3.0) @@ -50,7 +50,7 @@ GEM rainbow (3.1.1) rbnacl (7.1.1) ffi - regexp_parser (2.8.2) + regexp_parser (2.8.3) rexml (3.2.6) rspec (3.12.0) rspec-core (~> 3.12.0) @@ -86,7 +86,7 @@ GEM rubocop (~> 1.40) rubocop-capybara (~> 2.17) rubocop-factory_bot (~> 2.22) - ruby-openai (6.3.0) + ruby-openai (6.3.1) event_stream_parser (>= 0.3.0, < 2.0.0) faraday (>= 1) faraday-multipart (>= 1) @@ -218,7 +218,7 @@ bot.eval('Hello', as: 'eval') bot.eval('Hello', as: 'repl') # When stream is enabled and available: -bot.eval('Hi!') do |content, fragment, finished| +bot.eval('Hi!') do |content, fragment, finished, meta| print fragment unless fragment.nil? end @@ -235,7 +235,7 @@ bot.boot bot.boot(as: 'eval') bot.boot(as: 'repl') -bot.boot do |content, fragment, finished| +bot.boot do |content, fragment, finished, meta| print fragment unless fragment.nil? end ``` diff --git a/components/providers/openai.rb b/components/providers/openai.rb index 87f2bc5..6384181 100644 --- a/components/providers/openai.rb +++ b/components/providers/openai.rb @@ -49,7 +49,7 @@ module NanoBot end end - %i[instruction backdrop directive].each do |key| + %i[backdrop directive].each do |key| next unless input[:behavior][key] messages.prepend( diff --git a/components/stream.rb b/components/stream.rb index 347eb87..73da8b0 100644 --- a/components/stream.rb +++ b/components/stream.rb @@ -13,9 +13,9 @@ module NanoBot @accumulated = "#{@accumulated.force_encoding('UTF-8')}#{args.first.force_encoding('UTF-8')}" end - @callback.call(@accumulated, args.first, false) + @callback.call(@accumulated, args.first, false, args[1]) end - super + super(args.first) end def callback=(block) diff --git a/controllers/interfaces/tools.rb b/controllers/interfaces/tools.rb index f079a2b..0f33105 100644 --- a/controllers/interfaces/tools.rb +++ b/controllers/interfaces/tools.rb @@ -72,7 +72,10 @@ module NanoBot message = "#{adapter[:prefix]}#{message}#{adapter[:suffix]}" - session.print(color.nil? ? message : Rainbow(message).send(color)) + session.print( + color.nil? ? message : Rainbow(message).send(color), + { tool: { action: feedback[:action].to_s } } + ) end def self.adapter(cartridge, mode, feedback) diff --git a/controllers/session.rb b/controllers/session.rb index 378a11d..aabcb41 100644 --- a/controllers/session.rb +++ b/controllers/session.rb @@ -11,6 +11,7 @@ require_relative '../logic/cartridge/streaming' require_relative '../logic/cartridge/interaction' require_relative '../logic/cartridge/fetch' require_relative 'interfaces/tools' +require_relative '../components/stream' require_relative '../components/storage' require_relative '../components/adapter' require_relative '../components/crypto' @@ -56,11 +57,19 @@ module NanoBot end def boot(mode:) - return unless Logic::Helpers::Hash.fetch(@cartridge, %i[behaviors boot instruction]) + instruction = Logic::Helpers::Hash.fetch(@cartridge, %i[behaviors boot instruction]) + return unless instruction behavior = Logic::Helpers::Hash.fetch(@cartridge, %i[behaviors boot]) || {} - input = { behavior:, history: [] } + @state[:history] << { + who: 'user', + mode: mode.to_s, + input: instruction, + message: instruction + } + + input = { behavior:, history: @state[:history] } process(input, mode:) end @@ -182,8 +191,12 @@ module NanoBot @stream.flush end - def print(content) - @stream.write(content) + def print(content, meta = nil) + if @stream.is_a?(NanoBot::Components::Stream) + @stream.write(content, meta) + else + @stream.write(content) + end end end end diff --git a/nano-bots.gemspec b/nano-bots.gemspec index 281b1b2..8cd70d3 100644 --- a/nano-bots.gemspec +++ b/nano-bots.gemspec @@ -38,7 +38,7 @@ Gem::Specification.new do |spec| spec.add_dependency 'pry', '~> 0.14.2' spec.add_dependency 'rainbow', '~> 3.1', '>= 3.1.1' spec.add_dependency 'rbnacl', '~> 7.1', '>= 7.1.1' - spec.add_dependency 'ruby-openai', '~> 6.3' + spec.add_dependency 'ruby-openai', '~> 6.3', '>= 6.3.1' spec.add_dependency 'sweet-moon', '~> 0.0.7' spec.metadata['rubygems_mfa_required'] = 'true' diff --git a/static/cartridges/default.yml b/static/cartridges/default.yml index 864d62b..98dd47b 100644 --- a/static/cartridges/default.yml +++ b/static/cartridges/default.yml @@ -9,8 +9,8 @@ interfaces: repl: output: stream: true - suffix: "\n" prefix: "\n" + suffix: "\n" prompt: - text: '🤖' - text: '> ' |