boxcars 0.4.10 → 0.6.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +52 -1
- data/Gemfile +5 -5
- data/Gemfile.lock +94 -88
- data/boxcars.gemspec +1 -1
- data/lib/boxcars/boxcar/active_record.rb +4 -4
- data/lib/boxcars/boxcar/calculator.rb +2 -1
- data/lib/boxcars/boxcar/json_engine_boxcar.rb +7 -3
- data/lib/boxcars/boxcar/ruby_calculator.rb +1 -1
- data/lib/boxcars/boxcar/sql_active_record.rb +1 -1
- data/lib/boxcars/boxcar/sql_sequel.rb +1 -1
- data/lib/boxcars/boxcar/url_text.rb +1 -1
- data/lib/boxcars/boxcar/wikipedia_search.rb +1 -1
- data/lib/boxcars/boxcar.rb +2 -1
- data/lib/boxcars/conversation.rb +18 -1
- data/lib/boxcars/engine/anthropic.rb +64 -10
- data/lib/boxcars/engine/openai.rb +1 -1
- data/lib/boxcars/prompt.rb +1 -1
- data/lib/boxcars/vector_store.rb +2 -3
- data/lib/boxcars/version.rb +1 -1
- metadata +4 -4
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 71b72b7d30bda72b5dd0b3150773a233eac72e15ab3efa66d7643d5278770793
|
4
|
+
data.tar.gz: '080addca8e8c89f982db5ae91d9f12e67db15fb37f58d4787857b209848c1006'
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 330aa8094b7069084a7e06c7d656b30bd1935f1e12cfefded4788f23d92c62dbbbb92458328e37b95cbf5e446afd73b9170916329f409490e532ae329ac20a79
|
7
|
+
data.tar.gz: 1730d2356b2ddae5e19ee6d0ec0b4b6150eb9a9efb2305863b8e946ccd0184124a3ab22ef6fa37c4cfdacebed7a8fbf520f2d18243f9d05de7f547764d3625ef
|
data/CHANGELOG.md
CHANGED
@@ -1,5 +1,56 @@
|
|
1
1
|
# Changelog
|
2
2
|
|
3
|
+
## [v0.5.1](https://github.com/BoxcarsAI/boxcars/tree/v0.5.1) (2024-06-14)
|
4
|
+
|
5
|
+
[Full Changelog](https://github.com/BoxcarsAI/boxcars/compare/v0.4.10...v0.5.1)
|
6
|
+
|
7
|
+
**Merged pull requests:**
|
8
|
+
|
9
|
+
- Fix `Boxcars::SecurityError` error when we have newline [\#192](https://github.com/BoxcarsAI/boxcars/pull/192) ([moustafasallam](https://github.com/moustafasallam))
|
10
|
+
- \[infra\] Bump rubocop from 1.64.0 to 1.64.1 [\#190](https://github.com/BoxcarsAI/boxcars/pull/190) ([dependabot[bot]](https://github.com/apps/dependabot))
|
11
|
+
- \[infra\] Bump rubocop-rspec from 2.29.1 to 2.30.0 [\#188](https://github.com/BoxcarsAI/boxcars/pull/188) ([dependabot[bot]](https://github.com/apps/dependabot))
|
12
|
+
- \[infra\] Bump webmock from 3.23.0 to 3.23.1 [\#186](https://github.com/BoxcarsAI/boxcars/pull/186) ([dependabot[bot]](https://github.com/apps/dependabot))
|
13
|
+
- \[infra\] Bump rubocop from 1.60.2 to 1.64.0 [\#183](https://github.com/BoxcarsAI/boxcars/pull/183) ([dependabot[bot]](https://github.com/apps/dependabot))
|
14
|
+
- \[infra\] Bump rexml from 3.2.6 to 3.2.8 [\#182](https://github.com/BoxcarsAI/boxcars/pull/182) ([dependabot[bot]](https://github.com/apps/dependabot))
|
15
|
+
- \[infra\] Bump nokogiri from 1.16.2 to 1.16.5 [\#181](https://github.com/BoxcarsAI/boxcars/pull/181) ([dependabot[bot]](https://github.com/apps/dependabot))
|
16
|
+
- \[infra\] Bump anthropic from 0.1.0 to 0.2.0 [\#180](https://github.com/BoxcarsAI/boxcars/pull/180) ([dependabot[bot]](https://github.com/apps/dependabot))
|
17
|
+
- \[infra\] Bump debug from 1.9.1 to 1.9.2 [\#179](https://github.com/BoxcarsAI/boxcars/pull/179) ([dependabot[bot]](https://github.com/apps/dependabot))
|
18
|
+
- \[infra\] Bump dotenv from 3.1.0 to 3.1.2 [\#177](https://github.com/BoxcarsAI/boxcars/pull/177) ([dependabot[bot]](https://github.com/apps/dependabot))
|
19
|
+
- \[infra\] Bump async from 1.31.0 to 1.32.1 [\#175](https://github.com/BoxcarsAI/boxcars/pull/175) ([dependabot[bot]](https://github.com/apps/dependabot))
|
20
|
+
- \[infra\] Update ruby-openai requirement from \>= 4.2, \< 7.0 to \>= 4.2, \< 8.0 [\#174](https://github.com/BoxcarsAI/boxcars/pull/174) ([dependabot[bot]](https://github.com/apps/dependabot))
|
21
|
+
- \[infra\] Bump rake from 13.1.0 to 13.2.1 [\#168](https://github.com/BoxcarsAI/boxcars/pull/168) ([dependabot[bot]](https://github.com/apps/dependabot))
|
22
|
+
|
23
|
+
## [v0.4.10](https://github.com/BoxcarsAI/boxcars/tree/v0.4.10) (2024-04-19)
|
24
|
+
|
25
|
+
[Full Changelog](https://github.com/BoxcarsAI/boxcars/compare/v0.4.9...v0.4.10)
|
26
|
+
|
27
|
+
**Merged pull requests:**
|
28
|
+
|
29
|
+
- Add llms [\#169](https://github.com/BoxcarsAI/boxcars/pull/169) ([francis](https://github.com/francis))
|
30
|
+
- \[infra\] Bump pg from 1.5.5 to 1.5.6 [\#163](https://github.com/BoxcarsAI/boxcars/pull/163) ([dependabot[bot]](https://github.com/apps/dependabot))
|
31
|
+
- \[infra\] Bump rubocop-rspec from 2.26.1 to 2.29.1 [\#160](https://github.com/BoxcarsAI/boxcars/pull/160) ([dependabot[bot]](https://github.com/apps/dependabot))
|
32
|
+
- \[infra\] Bump rdoc from 6.6.2 to 6.6.3.1 [\#158](https://github.com/BoxcarsAI/boxcars/pull/158) ([dependabot[bot]](https://github.com/apps/dependabot))
|
33
|
+
- \[infra\] Bump dotenv from 3.0.2 to 3.1.0 [\#152](https://github.com/BoxcarsAI/boxcars/pull/152) ([dependabot[bot]](https://github.com/apps/dependabot))
|
34
|
+
- \[infra\] Bump webmock from 3.22.0 to 3.23.0 [\#150](https://github.com/BoxcarsAI/boxcars/pull/150) ([dependabot[bot]](https://github.com/apps/dependabot))
|
35
|
+
- \[infra\] Bump webmock from 3.20.0 to 3.22.0 [\#148](https://github.com/BoxcarsAI/boxcars/pull/148) ([dependabot[bot]](https://github.com/apps/dependabot))
|
36
|
+
- \[infra\] Bump dotenv from 2.8.1 to 3.0.2 [\#146](https://github.com/BoxcarsAI/boxcars/pull/146) ([dependabot[bot]](https://github.com/apps/dependabot))
|
37
|
+
- \[infra\] Bump pg from 1.5.4 to 1.5.5 [\#144](https://github.com/BoxcarsAI/boxcars/pull/144) ([dependabot[bot]](https://github.com/apps/dependabot))
|
38
|
+
- \[infra\] Bump webmock from 3.19.1 to 3.20.0 [\#142](https://github.com/BoxcarsAI/boxcars/pull/142) ([dependabot[bot]](https://github.com/apps/dependabot))
|
39
|
+
- \[infra\] Bump nokogiri from 1.16.0 to 1.16.2 [\#141](https://github.com/BoxcarsAI/boxcars/pull/141) ([dependabot[bot]](https://github.com/apps/dependabot))
|
40
|
+
- \[infra\] Bump rspec from 3.12.0 to 3.13.0 [\#140](https://github.com/BoxcarsAI/boxcars/pull/140) ([dependabot[bot]](https://github.com/apps/dependabot))
|
41
|
+
- \[infra\] Bump sqlite3 from 1.7.1 to 1.7.2 [\#139](https://github.com/BoxcarsAI/boxcars/pull/139) ([dependabot[bot]](https://github.com/apps/dependabot))
|
42
|
+
|
43
|
+
## [v0.4.9](https://github.com/BoxcarsAI/boxcars/tree/v0.4.9) (2024-01-25)
|
44
|
+
|
45
|
+
[Full Changelog](https://github.com/BoxcarsAI/boxcars/compare/v0.4.8...v0.4.9)
|
46
|
+
|
47
|
+
**Merged pull requests:**
|
48
|
+
|
49
|
+
- use newest models by default from Open AI [\#138](https://github.com/BoxcarsAI/boxcars/pull/138) ([francis](https://github.com/francis))
|
50
|
+
- \[infra\] Bump sqlite3 from 1.7.0 to 1.7.1 [\#137](https://github.com/BoxcarsAI/boxcars/pull/137) ([dependabot[bot]](https://github.com/apps/dependabot))
|
51
|
+
- \[infra\] Bump rubocop from 1.60.0 to 1.60.2 [\#136](https://github.com/BoxcarsAI/boxcars/pull/136) ([dependabot[bot]](https://github.com/apps/dependabot))
|
52
|
+
- \[infra\] Bump rubocop from 1.59.0 to 1.60.0 [\#133](https://github.com/BoxcarsAI/boxcars/pull/133) ([dependabot[bot]](https://github.com/apps/dependabot))
|
53
|
+
|
3
54
|
## [v0.4.8](https://github.com/BoxcarsAI/boxcars/tree/v0.4.8) (2024-01-08)
|
4
55
|
|
5
56
|
[Full Changelog](https://github.com/BoxcarsAI/boxcars/compare/v0.4.7...v0.4.8)
|
@@ -174,7 +225,7 @@
|
|
174
225
|
|
175
226
|
- Chore/refactored vector stores [\#92](https://github.com/BoxcarsAI/boxcars/pull/92) ([jaigouk](https://github.com/jaigouk))
|
176
227
|
- Fix the issue of calling the wrong method in vector\_answer.rb. [\#91](https://github.com/BoxcarsAI/boxcars/pull/91) ([xleotranx](https://github.com/xleotranx))
|
177
|
-
- issue\_83 Fix readme 404 [\#87](https://github.com/BoxcarsAI/boxcars/pull/87) ([
|
228
|
+
- issue\_83 Fix readme 404 [\#87](https://github.com/BoxcarsAI/boxcars/pull/87) ([ntabernacle](https://github.com/ntabernacle))
|
178
229
|
|
179
230
|
## [v0.2.13](https://github.com/BoxcarsAI/boxcars/tree/v0.2.13) (2023-05-24)
|
180
231
|
|
data/Gemfile
CHANGED
@@ -9,11 +9,11 @@ gem "debug", "~> 1.9"
|
|
9
9
|
|
10
10
|
gem "dotenv", "~> 3.1"
|
11
11
|
|
12
|
-
gem "rake", "~> 13.
|
12
|
+
gem "rake", "~> 13.2"
|
13
13
|
|
14
14
|
gem "sqlite3", "~> 1.7"
|
15
15
|
|
16
|
-
gem "async", "~>1.
|
16
|
+
gem "async", "~>1.32.1"
|
17
17
|
|
18
18
|
gem "activerecord", "~> 7.0"
|
19
19
|
|
@@ -32,9 +32,9 @@ gem "pgvector", "~> 0.2.2"
|
|
32
32
|
|
33
33
|
group :development, :test do
|
34
34
|
gem "rspec", "~> 3.13"
|
35
|
-
gem "rubocop", "~> 1.
|
35
|
+
gem "rubocop", "~> 1.64"
|
36
36
|
gem "vcr", "~> 6.2.0"
|
37
|
-
gem "webmock", "~> 3.23.
|
37
|
+
gem "webmock", "~> 3.23.1"
|
38
38
|
gem "rubocop-rake", "~> 0.6.0"
|
39
|
-
gem "rubocop-rspec", "~>
|
39
|
+
gem "rubocop-rspec", "~> 3.0"
|
40
40
|
end
|
data/Gemfile.lock
CHANGED
@@ -1,72 +1,83 @@
|
|
1
1
|
PATH
|
2
2
|
remote: .
|
3
3
|
specs:
|
4
|
-
boxcars (0.
|
4
|
+
boxcars (0.6.1)
|
5
5
|
anthropic (~> 0.1)
|
6
6
|
google_search_results (~> 2.2)
|
7
7
|
gpt4all (~> 0.0.4)
|
8
8
|
hnswlib (~> 0.8)
|
9
9
|
nokogiri (~> 1.16)
|
10
10
|
pgvector (~> 0.2)
|
11
|
-
ruby-openai (>= 4.2, <
|
11
|
+
ruby-openai (>= 4.2, < 8.0)
|
12
12
|
|
13
13
|
GEM
|
14
14
|
remote: https://rubygems.org/
|
15
15
|
specs:
|
16
|
-
activemodel (7.
|
17
|
-
activesupport (= 7.
|
18
|
-
activerecord (7.
|
19
|
-
activemodel (= 7.
|
20
|
-
activesupport (= 7.
|
21
|
-
|
16
|
+
activemodel (7.1.3.4)
|
17
|
+
activesupport (= 7.1.3.4)
|
18
|
+
activerecord (7.1.3.4)
|
19
|
+
activemodel (= 7.1.3.4)
|
20
|
+
activesupport (= 7.1.3.4)
|
21
|
+
timeout (>= 0.4.0)
|
22
|
+
activesupport (7.1.3.4)
|
23
|
+
base64
|
24
|
+
bigdecimal
|
22
25
|
concurrent-ruby (~> 1.0, >= 1.0.2)
|
26
|
+
connection_pool (>= 2.2.5)
|
27
|
+
drb
|
23
28
|
i18n (>= 1.6, < 2)
|
24
29
|
minitest (>= 5.1)
|
30
|
+
mutex_m
|
25
31
|
tzinfo (~> 2.0)
|
26
|
-
addressable (2.8.
|
27
|
-
public_suffix (>= 2.0.2, <
|
28
|
-
anthropic (0.
|
32
|
+
addressable (2.8.7)
|
33
|
+
public_suffix (>= 2.0.2, < 7.0)
|
34
|
+
anthropic (0.3.0)
|
35
|
+
event_stream_parser (>= 0.3.0, < 2.0.0)
|
29
36
|
faraday (>= 1)
|
30
37
|
faraday-multipart (>= 1)
|
31
38
|
ast (2.4.2)
|
32
|
-
async (1.
|
39
|
+
async (1.32.1)
|
33
40
|
console (~> 1.10)
|
34
41
|
nio4r (~> 2.3)
|
35
42
|
timers (~> 4.1)
|
36
|
-
async-http (0.
|
43
|
+
async-http (0.64.2)
|
37
44
|
async (>= 1.25)
|
38
45
|
async-io (>= 1.28)
|
39
46
|
async-pool (>= 0.2)
|
40
|
-
protocol-http (~> 0.
|
41
|
-
protocol-http1 (~> 0.
|
42
|
-
protocol-http2 (~> 0.
|
47
|
+
protocol-http (~> 0.26.0)
|
48
|
+
protocol-http1 (~> 0.19.0)
|
49
|
+
protocol-http2 (~> 0.16.0)
|
43
50
|
traces (>= 0.10.0)
|
44
|
-
async-http-faraday (0.
|
51
|
+
async-http-faraday (0.14.0)
|
45
52
|
async-http (~> 0.42)
|
46
53
|
faraday
|
47
|
-
async-io (1.
|
54
|
+
async-io (1.43.2)
|
48
55
|
async
|
49
|
-
async-pool (0.
|
56
|
+
async-pool (0.7.0)
|
50
57
|
async (>= 1.25)
|
51
|
-
|
52
|
-
|
53
|
-
|
58
|
+
base64 (0.2.0)
|
59
|
+
bigdecimal (3.1.8)
|
60
|
+
concurrent-ruby (1.3.3)
|
61
|
+
connection_pool (2.4.1)
|
62
|
+
console (1.27.0)
|
54
63
|
fiber-annotation
|
55
|
-
fiber-local
|
64
|
+
fiber-local (~> 1.1)
|
65
|
+
json
|
56
66
|
crack (1.0.0)
|
57
67
|
bigdecimal
|
58
68
|
rexml
|
59
|
-
debug (1.9.
|
69
|
+
debug (1.9.2)
|
60
70
|
irb (~> 1.10)
|
61
71
|
reline (>= 0.3.8)
|
62
72
|
diff-lcs (1.5.1)
|
63
|
-
domain_name (0.
|
64
|
-
|
65
|
-
|
73
|
+
domain_name (0.6.20240107)
|
74
|
+
dotenv (3.1.2)
|
75
|
+
drb (2.2.1)
|
66
76
|
event_stream_parser (1.0.0)
|
67
|
-
faraday (2.
|
77
|
+
faraday (2.10.0)
|
68
78
|
faraday-net_http (>= 2.0, < 3.2)
|
69
|
-
|
79
|
+
logger
|
80
|
+
faraday-http-cache (2.5.1)
|
70
81
|
faraday (>= 0.8)
|
71
82
|
faraday-multipart (1.0.4)
|
72
83
|
multipart-post (~> 2)
|
@@ -75,7 +86,9 @@ GEM
|
|
75
86
|
faraday-retry (2.2.1)
|
76
87
|
faraday (~> 2.0)
|
77
88
|
fiber-annotation (0.2.0)
|
78
|
-
fiber-local (1.
|
89
|
+
fiber-local (1.1.0)
|
90
|
+
fiber-storage
|
91
|
+
fiber-storage (0.1.2)
|
79
92
|
github_changelog_generator (1.16.4)
|
80
93
|
activesupport
|
81
94
|
async (>= 1.25.0)
|
@@ -93,104 +106,98 @@ GEM
|
|
93
106
|
hashdiff (1.1.0)
|
94
107
|
hnswlib (0.9.0)
|
95
108
|
http-accept (1.7.0)
|
96
|
-
http-cookie (1.0.
|
109
|
+
http-cookie (1.0.6)
|
97
110
|
domain_name (~> 0.5)
|
98
|
-
i18n (1.14.
|
111
|
+
i18n (1.14.5)
|
99
112
|
concurrent-ruby (~> 1.0)
|
100
|
-
io-console (0.7.
|
101
|
-
irb (1.
|
102
|
-
rdoc
|
103
|
-
reline (>= 0.
|
113
|
+
io-console (0.7.2)
|
114
|
+
irb (1.14.0)
|
115
|
+
rdoc (>= 4.0.0)
|
116
|
+
reline (>= 0.4.2)
|
104
117
|
json (2.7.2)
|
105
118
|
language_server-protocol (3.17.0.3)
|
106
|
-
|
119
|
+
logger (1.6.0)
|
120
|
+
mime-types (3.5.2)
|
107
121
|
mime-types-data (~> 3.2015)
|
108
|
-
mime-types-data (3.
|
109
|
-
minitest (5.
|
122
|
+
mime-types-data (3.2024.0702)
|
123
|
+
minitest (5.24.1)
|
110
124
|
multi_json (1.15.0)
|
111
|
-
multipart-post (2.
|
125
|
+
multipart-post (2.4.1)
|
126
|
+
mutex_m (0.2.0)
|
112
127
|
net-http (0.4.1)
|
113
128
|
uri
|
114
129
|
netrc (0.11.0)
|
115
|
-
nio4r (2.
|
116
|
-
nokogiri (1.16.
|
130
|
+
nio4r (2.7.3)
|
131
|
+
nokogiri (1.16.6-arm64-darwin)
|
117
132
|
racc (~> 1.4)
|
118
|
-
nokogiri (1.16.
|
133
|
+
nokogiri (1.16.6-x86_64-linux)
|
119
134
|
racc (~> 1.4)
|
120
135
|
octokit (4.25.1)
|
121
136
|
faraday (>= 1, < 3)
|
122
137
|
sawyer (~> 0.9)
|
123
138
|
os (1.1.4)
|
124
|
-
parallel (1.
|
125
|
-
parser (3.3.0
|
139
|
+
parallel (1.25.1)
|
140
|
+
parser (3.3.4.0)
|
126
141
|
ast (~> 2.4.1)
|
127
142
|
racc
|
128
143
|
pg (1.5.6)
|
129
144
|
pgvector (0.2.2)
|
130
|
-
protocol-hpack (1.4.
|
131
|
-
protocol-http (0.
|
132
|
-
protocol-http1 (0.
|
145
|
+
protocol-hpack (1.4.3)
|
146
|
+
protocol-http (0.26.8)
|
147
|
+
protocol-http1 (0.19.1)
|
133
148
|
protocol-http (~> 0.22)
|
134
|
-
protocol-http2 (0.
|
149
|
+
protocol-http2 (0.16.0)
|
135
150
|
protocol-hpack (~> 1.4)
|
136
151
|
protocol-http (~> 0.18)
|
137
152
|
psych (5.1.2)
|
138
153
|
stringio
|
139
|
-
public_suffix (
|
140
|
-
racc (1.
|
154
|
+
public_suffix (6.0.0)
|
155
|
+
racc (1.8.0)
|
141
156
|
rainbow (3.1.1)
|
142
|
-
rake (13.1
|
143
|
-
rdoc (6.
|
157
|
+
rake (13.2.1)
|
158
|
+
rdoc (6.7.0)
|
144
159
|
psych (>= 4.0.0)
|
145
|
-
regexp_parser (2.9.
|
146
|
-
reline (0.
|
160
|
+
regexp_parser (2.9.2)
|
161
|
+
reline (0.5.9)
|
147
162
|
io-console (~> 0.5)
|
148
163
|
rest-client (2.1.0)
|
149
164
|
http-accept (>= 1.7.0, < 2.0)
|
150
165
|
http-cookie (>= 1.0.2, < 2.0)
|
151
166
|
mime-types (>= 1.16, < 4.0)
|
152
167
|
netrc (~> 0.8)
|
153
|
-
rexml (3.2
|
168
|
+
rexml (3.3.2)
|
169
|
+
strscan
|
154
170
|
rspec (3.13.0)
|
155
171
|
rspec-core (~> 3.13.0)
|
156
172
|
rspec-expectations (~> 3.13.0)
|
157
173
|
rspec-mocks (~> 3.13.0)
|
158
174
|
rspec-core (3.13.0)
|
159
175
|
rspec-support (~> 3.13.0)
|
160
|
-
rspec-expectations (3.13.
|
176
|
+
rspec-expectations (3.13.1)
|
161
177
|
diff-lcs (>= 1.2.0, < 2.0)
|
162
178
|
rspec-support (~> 3.13.0)
|
163
|
-
rspec-mocks (3.13.
|
179
|
+
rspec-mocks (3.13.1)
|
164
180
|
diff-lcs (>= 1.2.0, < 2.0)
|
165
181
|
rspec-support (~> 3.13.0)
|
166
182
|
rspec-support (3.13.1)
|
167
|
-
rubocop (1.
|
183
|
+
rubocop (1.65.0)
|
168
184
|
json (~> 2.3)
|
169
185
|
language_server-protocol (>= 3.17.0)
|
170
186
|
parallel (~> 1.10)
|
171
187
|
parser (>= 3.3.0.2)
|
172
188
|
rainbow (>= 2.2.2, < 4.0)
|
173
|
-
regexp_parser (>=
|
189
|
+
regexp_parser (>= 2.4, < 3.0)
|
174
190
|
rexml (>= 3.2.5, < 4.0)
|
175
|
-
rubocop-ast (>= 1.
|
191
|
+
rubocop-ast (>= 1.31.1, < 2.0)
|
176
192
|
ruby-progressbar (~> 1.7)
|
177
193
|
unicode-display_width (>= 2.4.0, < 3.0)
|
178
|
-
rubocop-ast (1.31.
|
179
|
-
parser (>= 3.3.0
|
180
|
-
rubocop-capybara (2.20.0)
|
181
|
-
rubocop (~> 1.41)
|
182
|
-
rubocop-factory_bot (2.25.1)
|
183
|
-
rubocop (~> 1.41)
|
194
|
+
rubocop-ast (1.31.3)
|
195
|
+
parser (>= 3.3.1.0)
|
184
196
|
rubocop-rake (0.6.0)
|
185
197
|
rubocop (~> 1.0)
|
186
|
-
rubocop-rspec (
|
187
|
-
rubocop (~> 1.
|
188
|
-
|
189
|
-
rubocop-factory_bot (~> 2.22)
|
190
|
-
rubocop-rspec_rails (~> 2.28)
|
191
|
-
rubocop-rspec_rails (2.28.2)
|
192
|
-
rubocop (~> 1.40)
|
193
|
-
ruby-openai (6.3.1)
|
198
|
+
rubocop-rspec (3.0.3)
|
199
|
+
rubocop (~> 1.61)
|
200
|
+
ruby-openai (7.1.0)
|
194
201
|
event_stream_parser (>= 0.3.0, < 2.0.0)
|
195
202
|
faraday (>= 1)
|
196
203
|
faraday-multipart (>= 1)
|
@@ -198,10 +205,12 @@ GEM
|
|
198
205
|
sawyer (0.9.2)
|
199
206
|
addressable (>= 2.3.5)
|
200
207
|
faraday (>= 0.17.3, < 3)
|
201
|
-
sqlite3 (1.7.
|
202
|
-
sqlite3 (1.7.
|
203
|
-
stringio (3.1.
|
208
|
+
sqlite3 (1.7.3-arm64-darwin)
|
209
|
+
sqlite3 (1.7.3-x86_64-linux)
|
210
|
+
stringio (3.1.1)
|
204
211
|
strings-ansi (0.2.0)
|
212
|
+
strscan (3.1.0)
|
213
|
+
timeout (0.4.1)
|
205
214
|
timers (4.3.5)
|
206
215
|
traces (0.11.1)
|
207
216
|
tty-cursor (0.7.1)
|
@@ -210,16 +219,13 @@ GEM
|
|
210
219
|
tty-cursor (~> 0.7)
|
211
220
|
tty-screen (~> 0.8)
|
212
221
|
unicode-display_width (>= 1.6, < 3.0)
|
213
|
-
tty-screen (0.8.
|
222
|
+
tty-screen (0.8.2)
|
214
223
|
tzinfo (2.0.6)
|
215
224
|
concurrent-ruby (~> 1.0)
|
216
|
-
unf (0.1.4)
|
217
|
-
unf_ext
|
218
|
-
unf_ext (0.0.8.2)
|
219
225
|
unicode-display_width (2.5.0)
|
220
226
|
uri (0.13.0)
|
221
227
|
vcr (6.2.0)
|
222
|
-
webmock (3.23.
|
228
|
+
webmock (3.23.1)
|
223
229
|
addressable (>= 2.8.0)
|
224
230
|
crack (>= 0.3.2)
|
225
231
|
hashdiff (>= 0.4.0, < 2.0.0)
|
@@ -232,7 +238,7 @@ PLATFORMS
|
|
232
238
|
DEPENDENCIES
|
233
239
|
activerecord (~> 7.0)
|
234
240
|
activesupport (~> 7.0)
|
235
|
-
async (~> 1.
|
241
|
+
async (~> 1.32.1)
|
236
242
|
boxcars!
|
237
243
|
debug (~> 1.9)
|
238
244
|
dotenv (~> 3.1)
|
@@ -241,15 +247,15 @@ DEPENDENCIES
|
|
241
247
|
hnswlib (~> 0.9.0)
|
242
248
|
pg (~> 1.5)
|
243
249
|
pgvector (~> 0.2.2)
|
244
|
-
rake (~> 13.
|
250
|
+
rake (~> 13.2)
|
245
251
|
rest-client (~> 2.1)
|
246
252
|
rspec (~> 3.13)
|
247
|
-
rubocop (~> 1.
|
253
|
+
rubocop (~> 1.64)
|
248
254
|
rubocop-rake (~> 0.6.0)
|
249
|
-
rubocop-rspec (~>
|
255
|
+
rubocop-rspec (~> 3.0)
|
250
256
|
sqlite3 (~> 1.7)
|
251
257
|
vcr (~> 6.2.0)
|
252
|
-
webmock (~> 3.23.
|
258
|
+
webmock (~> 3.23.1)
|
253
259
|
|
254
260
|
BUNDLED WITH
|
255
261
|
2.4.16
|
data/boxcars.gemspec
CHANGED
@@ -37,7 +37,7 @@ Gem::Specification.new do |spec|
|
|
37
37
|
spec.add_dependency "hnswlib", "~> 0.8"
|
38
38
|
spec.add_dependency "nokogiri", "~> 1.16"
|
39
39
|
spec.add_dependency "pgvector", "~> 0.2"
|
40
|
-
spec.add_dependency "ruby-openai", ">= 4.2", "<
|
40
|
+
spec.add_dependency "ruby-openai", ">= 4.2", "< 8.0"
|
41
41
|
|
42
42
|
# For more information and examples about making a new gem, checkout our
|
43
43
|
# guide at: https://bundler.io/guides/creating_gem.html
|
@@ -99,10 +99,10 @@ module Boxcars
|
|
99
99
|
|
100
100
|
# check for dangerous code that is outside of ActiveRecord
|
101
101
|
def safe_to_run?(code)
|
102
|
-
bad_words = %w[commit drop_constraint drop_constraint! drop_extension drop_extension! drop_foreign_key drop_foreign_key!
|
103
|
-
drop_index drop_index! drop_join_table drop_join_table! drop_materialized_view drop_materialized_view!
|
104
|
-
drop_partition drop_partition! drop_schema drop_schema! drop_table drop_table! drop_trigger drop_trigger!
|
105
|
-
drop_view drop_view! eval instance_eval send system execute reset revoke rollback truncate
|
102
|
+
bad_words = %w[commit drop_constraint drop_constraint! drop_extension drop_extension! drop_foreign_key drop_foreign_key!
|
103
|
+
drop_index drop_index! drop_join_table drop_join_table! drop_materialized_view drop_materialized_view!
|
104
|
+
drop_partition drop_partition! drop_schema drop_schema! drop_table drop_table! drop_trigger drop_trigger!
|
105
|
+
drop_view drop_view! eval instance_eval send system execute reset revoke rollback truncate
|
106
106
|
encrypted_password].freeze
|
107
107
|
without_strings = code.gsub(/('([^'\\]*(\\.[^'\\]*)*)'|"([^"\\]*(\\.[^"\\]*)*"))/, 'XX')
|
108
108
|
|
@@ -48,7 +48,8 @@ module Boxcars
|
|
48
48
|
"use the following format and we’ll take care of the rest:\n",
|
49
49
|
"${{Question with hard calculation.}}\n",
|
50
50
|
"reply only with the following format:\n",
|
51
|
-
"```ruby\n${{only Ruby code that prints the answer
|
51
|
+
"```ruby\n${{only Ruby code that prints the answer. " \
|
52
|
+
"If you use puts, make sure to wrap the expression in paranthesis}}\n```\n",
|
52
53
|
"```output\n${{Output of your code}}\n```\n\n",
|
53
54
|
"Otherwise, you should use this simpler format:\n",
|
54
55
|
"${{Question without hard calculation}}\n",
|
@@ -5,23 +5,27 @@ module Boxcars
|
|
5
5
|
# For Boxcars that use an engine to do their work.
|
6
6
|
class JSONEngineBoxcar < EngineBoxcar
|
7
7
|
# A JSON Engine Boxcar is a container for a single tool to run.
|
8
|
-
attr_accessor :wanted_data, :data_description
|
8
|
+
attr_accessor :wanted_data, :data_description, :important
|
9
9
|
|
10
10
|
# @param prompt [Boxcars::Prompt] The prompt to use for this boxcar with sane defaults.
|
11
11
|
# @param wanted_data [String] The data to extract from.
|
12
12
|
# @param data_description [String] The description of the data.
|
13
|
+
# @param important [String] Any important instructions you want to give the LLM.
|
13
14
|
# @param kwargs [Hash] Additional arguments
|
14
|
-
def initialize(prompt: nil, wanted_data: nil, data_description: nil, **kwargs)
|
15
|
+
def initialize(prompt: nil, wanted_data: nil, data_description: nil, important: nil, **kwargs)
|
15
16
|
@wanted_data = wanted_data || "summarize the pertinent facts from the input data"
|
16
17
|
@data_description = data_description || "the input data"
|
18
|
+
@important = important
|
17
19
|
the_prompt = prompt || default_prompt
|
20
|
+
the_prompt.append("\n\nImportant: #{important}\n") if important.present?
|
18
21
|
kwargs[:description] ||= "JSON Engine Boxcar"
|
19
22
|
super(prompt: the_prompt, **kwargs)
|
20
23
|
end
|
21
24
|
|
22
25
|
def default_prompt
|
23
26
|
stock_prompt = <<~SYSPR
|
24
|
-
I will provide you with %<data_description>s
|
27
|
+
I will provide you with %<data_description>s.
|
28
|
+
Your job is to extract information as described below.
|
25
29
|
|
26
30
|
Your Output must be valid JSON with no lead in or post answer text in the output format below:
|
27
31
|
|
@@ -11,7 +11,7 @@ module Boxcars
|
|
11
11
|
# :name, :description, :prompt, :top_k, :stop, and :engine
|
12
12
|
def initialize(connection: nil, tables: nil, except_tables: nil, **kwargs)
|
13
13
|
connection ||= ::ActiveRecord::Base.connection
|
14
|
-
super
|
14
|
+
super
|
15
15
|
end
|
16
16
|
|
17
17
|
private
|
@@ -10,7 +10,7 @@ module Boxcars
|
|
10
10
|
# @param kwargs [Hash] Any other keyword arguments to pass to the parent class. This can include
|
11
11
|
# :name, :description, :prompt, :top_k, :stop, and :engine
|
12
12
|
def initialize(connection: nil, tables: nil, except_tables: nil, **kwargs)
|
13
|
-
super
|
13
|
+
super
|
14
14
|
end
|
15
15
|
|
16
16
|
private
|
@@ -10,7 +10,7 @@ module Boxcars
|
|
10
10
|
# @param name [String] The name of the boxcar. Defaults to classname.
|
11
11
|
# @param description [String] A description of the boxcar. Defaults to SERPDESC.
|
12
12
|
def initialize(name: "FetchURL", description: DESC)
|
13
|
-
super
|
13
|
+
super
|
14
14
|
end
|
15
15
|
|
16
16
|
# Get text from a url.
|
@@ -13,7 +13,7 @@ module Boxcars
|
|
13
13
|
# @param description [String] A description of the boxcar. Defaults to SERPDESC.
|
14
14
|
# @param serpapi_api_key [String] The API key to use for the SerpAPI. Defaults to Boxcars.configuration.serpapi_api_key.
|
15
15
|
def initialize(name: "Wikipedia", description: WDESC)
|
16
|
-
super
|
16
|
+
super
|
17
17
|
end
|
18
18
|
|
19
19
|
# Get an answer from Google using the SerpAPI.
|
data/lib/boxcars/boxcar.rb
CHANGED
@@ -165,7 +165,8 @@ module Boxcars
|
|
165
165
|
begin
|
166
166
|
output = call(inputs: inputs)
|
167
167
|
rescue StandardError => e
|
168
|
-
Boxcars.error "Error in #{name} boxcar#call: #{e}\nbt:#{
|
168
|
+
Boxcars.error "Error in #{name} boxcar#call: #{e}\nbt:#{e.backtrace[0..5].join("\n ")}", :red
|
169
|
+
Boxcars.error("Response Body: #{e.response[:body]}", :red) if e.respond_to?(:response)
|
169
170
|
raise e
|
170
171
|
end
|
171
172
|
validate_outputs(outputs: output.keys)
|
data/lib/boxcars/conversation.rb
CHANGED
@@ -20,7 +20,6 @@ module Boxcars
|
|
20
20
|
raise ArgumentError, "Conversation item must be a array" unless ln.is_a?(Array)
|
21
21
|
raise ArgumentError, "Conversation item must have 2 items, role and text" unless ln.size == 2
|
22
22
|
raise ArgumentError, "Conversation item must have a role #{ln} in (#{PEOPLE})" unless PEOPLE.include? ln[0]
|
23
|
-
raise ArgumentError, "Conversation value must be a string" unless ln[1].is_a?(String)
|
24
23
|
end
|
25
24
|
end
|
26
25
|
|
@@ -112,6 +111,24 @@ module Boxcars
|
|
112
111
|
raise KeyError, "Prompt format error: #{first_line}"
|
113
112
|
end
|
114
113
|
|
114
|
+
def process_content(content, inputs)
|
115
|
+
# If content is a string, treat it as text
|
116
|
+
if content.is_a?(String)
|
117
|
+
[{ type: "text", text: cformat(content, inputs) }]
|
118
|
+
# If content is an array, assume it's already in the new format
|
119
|
+
elsif content.is_a?(Array)
|
120
|
+
content.map do |item|
|
121
|
+
if item[:type] == "text"
|
122
|
+
{ type: "text", text: cformat(item[:text], inputs) }
|
123
|
+
else
|
124
|
+
item # Pass through non-text items (like images) without modification
|
125
|
+
end
|
126
|
+
end
|
127
|
+
else
|
128
|
+
raise ArgumentError, "Invalid content type: #{content.class}"
|
129
|
+
end
|
130
|
+
end
|
131
|
+
|
115
132
|
# special format that replaces lone percent signs with double percent signs
|
116
133
|
def cformat(*args)
|
117
134
|
args[0] = args[0].dup.gsub(/%(?!<)/, '%%') if args.length > 1
|
@@ -9,9 +9,9 @@ module Boxcars
|
|
9
9
|
|
10
10
|
# The default parameters to use when asking the engine.
|
11
11
|
DEFAULT_PARAMS = {
|
12
|
-
model: "claude-
|
13
|
-
|
14
|
-
temperature: 0.
|
12
|
+
model: "claude-3-5-sonnet-20240620",
|
13
|
+
max_tokens: 4096,
|
14
|
+
temperature: 0.1
|
15
15
|
}.freeze
|
16
16
|
|
17
17
|
# the default name of the engine
|
@@ -32,8 +32,8 @@ module Boxcars
|
|
32
32
|
super(description: description, name: name)
|
33
33
|
end
|
34
34
|
|
35
|
-
def conversation_model?(
|
36
|
-
|
35
|
+
def conversation_model?(model)
|
36
|
+
@conversation_model ||= (extract_model_version(model) > 3.49)
|
37
37
|
end
|
38
38
|
|
39
39
|
def anthropic_client(anthropic_api_key: nil)
|
@@ -46,13 +46,27 @@ module Boxcars
|
|
46
46
|
# Defaults to Boxcars.configuration.anthropic_api_key.
|
47
47
|
# @param kwargs [Hash] Additional parameters to pass to the engine if wanted.
|
48
48
|
def client(prompt:, inputs: {}, **kwargs)
|
49
|
+
model_params = llm_params.merge(kwargs)
|
49
50
|
api_key = Boxcars.configuration.anthropic_api_key(**kwargs)
|
50
51
|
aclient = anthropic_client(anthropic_api_key: api_key)
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
52
|
+
prompt = prompt.first if prompt.is_a?(Array)
|
53
|
+
|
54
|
+
if conversation_model?(model_params[:model])
|
55
|
+
params = convert_to_anthropic(prompt.as_messages(inputs).merge(model_params))
|
56
|
+
if Boxcars.configuration.log_prompts
|
57
|
+
Boxcars.debug(params[:messages].last(2).map { |p| ">>>>>> Role: #{p[:role]} <<<<<<\n#{p[:content]}" }.join("\n"), :cyan)
|
58
|
+
end
|
59
|
+
response = aclient.messages(parameters: params)
|
60
|
+
response['completion'] = response.dig('content', 0, 'text')
|
61
|
+
response.delete('content')
|
62
|
+
response
|
63
|
+
else
|
64
|
+
params = prompt.as_prompt(inputs: inputs, prefixes: default_prefixes, show_roles: true).merge(model_params)
|
65
|
+
params[:prompt] = "\n\n#{params[:prompt]}" unless params[:prompt].start_with?("\n\n")
|
66
|
+
params[:stop_sequences] = params.delete(:stop) if params.key?(:stop)
|
67
|
+
Boxcars.debug("Prompt after formatting:#{params[:prompt]}", :cyan) if Boxcars.configuration.log_prompts
|
68
|
+
aclient.complete(parameters: params)
|
69
|
+
end
|
56
70
|
end
|
57
71
|
|
58
72
|
# get an answer from the engine for a question.
|
@@ -165,6 +179,46 @@ module Boxcars
|
|
165
179
|
max_size - num_tokens
|
166
180
|
end
|
167
181
|
|
182
|
+
def extract_model_version(model_string)
|
183
|
+
# Use a regular expression to find the version number
|
184
|
+
match = model_string.match(/claude-(\d+)(?:-(\d+))?/)
|
185
|
+
|
186
|
+
raise ArgumentError, "No version number found in model string: #{model_string}" unless match
|
187
|
+
|
188
|
+
major = match[1].to_i
|
189
|
+
minor = match[2].to_i
|
190
|
+
|
191
|
+
# Combine major and minor versions
|
192
|
+
major + (minor.to_f / 10)
|
193
|
+
end
|
194
|
+
|
195
|
+
# convert generic parameters to Anthopic specific ones
|
196
|
+
def convert_to_anthropic(params)
|
197
|
+
params[:stop_sequences] = params.delete(:stop) if params.key?(:stop)
|
198
|
+
params[:system] = params[:messages].shift[:content] if params.dig(:messages, 0, :role) == :system
|
199
|
+
params[:messages].pop if params[:messages].last[:content].blank?
|
200
|
+
combine_assistant(params)
|
201
|
+
end
|
202
|
+
|
203
|
+
def combine_assistant(params)
|
204
|
+
params[:messages] = combine_assistant_entries(params[:messages])
|
205
|
+
params[:messages].last[:content].rstrip! if params[:messages].last[:role] == :assistant
|
206
|
+
params
|
207
|
+
end
|
208
|
+
|
209
|
+
# if we have multiple assistant entries in a row, we need to combine them
|
210
|
+
def combine_assistant_entries(hashes)
|
211
|
+
combined_hashes = []
|
212
|
+
hashes.each do |hash|
|
213
|
+
if combined_hashes.empty? || combined_hashes.last[:role] != :assistant || hash[:role] != :assistant
|
214
|
+
combined_hashes << hash
|
215
|
+
else
|
216
|
+
combined_hashes.last[:content].concat("\n", hash[:content].rstrip)
|
217
|
+
end
|
218
|
+
end
|
219
|
+
combined_hashes
|
220
|
+
end
|
221
|
+
|
168
222
|
def default_prefixes
|
169
223
|
{ system: "Human: ", user: "Human: ", assistant: "Assistant: ", history: :history }
|
170
224
|
end
|
data/lib/boxcars/prompt.rb
CHANGED
@@ -29,7 +29,7 @@ module Boxcars
|
|
29
29
|
# @param inputs [Hash] The inputs to use for the prompt.
|
30
30
|
# @return [Hash] The formatted prompt { prompt: "..."}
|
31
31
|
def as_messages(inputs)
|
32
|
-
{ messages: [{ role: :
|
32
|
+
{ messages: [{ role: :user, content: format(inputs) }] }
|
33
33
|
end
|
34
34
|
|
35
35
|
# tack on the ongoing conversation if present to the prompt
|
data/lib/boxcars/vector_store.rb
CHANGED
@@ -59,12 +59,11 @@ module Boxcars
|
|
59
59
|
end
|
60
60
|
|
61
61
|
def load_data_files(training_data_path)
|
62
|
-
data = []
|
63
62
|
files = Dir.glob(training_data_path)
|
64
63
|
raise_error "No files found at #{training_data_path}" if files.empty?
|
65
64
|
|
66
|
-
files.
|
67
|
-
|
65
|
+
data = files.map do |file|
|
66
|
+
File.read(file)
|
68
67
|
end
|
69
68
|
puts "Added #{files.length} files to data. Splitting text into chunks..."
|
70
69
|
data
|
data/lib/boxcars/version.rb
CHANGED
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: boxcars
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.6.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Francis Sullivan
|
@@ -9,7 +9,7 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: exe
|
11
11
|
cert_chain: []
|
12
|
-
date: 2024-
|
12
|
+
date: 2024-07-19 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: anthropic
|
@@ -104,7 +104,7 @@ dependencies:
|
|
104
104
|
version: '4.2'
|
105
105
|
- - "<"
|
106
106
|
- !ruby/object:Gem::Version
|
107
|
-
version: '
|
107
|
+
version: '8.0'
|
108
108
|
type: :runtime
|
109
109
|
prerelease: false
|
110
110
|
version_requirements: !ruby/object:Gem::Requirement
|
@@ -114,7 +114,7 @@ dependencies:
|
|
114
114
|
version: '4.2'
|
115
115
|
- - "<"
|
116
116
|
- !ruby/object:Gem::Version
|
117
|
-
version: '
|
117
|
+
version: '8.0'
|
118
118
|
description: You simply set an OpenAI key, give a number of Boxcars to a Train, and
|
119
119
|
magic ensues when you run it.
|
120
120
|
email:
|