rubyllm-observ 0.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (209) hide show
  1. checksums.yaml +7 -0
  2. data/README.md +778 -0
  3. data/Rakefile +49 -0
  4. data/app/assets/javascripts/observ/application.js +12 -0
  5. data/app/assets/javascripts/observ/controllers/autoscroll_controller.js +33 -0
  6. data/app/assets/javascripts/observ/controllers/chat_form_controller.js +93 -0
  7. data/app/assets/javascripts/observ/controllers/copy_controller.js +43 -0
  8. data/app/assets/javascripts/observ/controllers/dashboard_controller.js +58 -0
  9. data/app/assets/javascripts/observ/controllers/drawer_controller.js +58 -0
  10. data/app/assets/javascripts/observ/controllers/expandable_controller.js +33 -0
  11. data/app/assets/javascripts/observ/controllers/filter_controller.js +36 -0
  12. data/app/assets/javascripts/observ/controllers/index.js +52 -0
  13. data/app/assets/javascripts/observ/controllers/json_viewer_controller.js +260 -0
  14. data/app/assets/javascripts/observ/controllers/message_form_controller.js +58 -0
  15. data/app/assets/javascripts/observ/controllers/prompt_variables_controller.js +64 -0
  16. data/app/assets/javascripts/observ/controllers/text_select_controller.js +14 -0
  17. data/app/assets/stylesheets/observ/_annotations.scss +127 -0
  18. data/app/assets/stylesheets/observ/_card.scss +52 -0
  19. data/app/assets/stylesheets/observ/_chat.scss +156 -0
  20. data/app/assets/stylesheets/observ/_components.scss +460 -0
  21. data/app/assets/stylesheets/observ/_dashboard.scss +40 -0
  22. data/app/assets/stylesheets/observ/_datasets.scss +697 -0
  23. data/app/assets/stylesheets/observ/_drawer.scss +273 -0
  24. data/app/assets/stylesheets/observ/_json_viewer.scss +120 -0
  25. data/app/assets/stylesheets/observ/_layout.scss +256 -0
  26. data/app/assets/stylesheets/observ/_metrics.scss +99 -0
  27. data/app/assets/stylesheets/observ/_observations.scss +160 -0
  28. data/app/assets/stylesheets/observ/_pagination.scss +143 -0
  29. data/app/assets/stylesheets/observ/_prompts.scss +365 -0
  30. data/app/assets/stylesheets/observ/_table.scss +53 -0
  31. data/app/assets/stylesheets/observ/_variables.scss +53 -0
  32. data/app/assets/stylesheets/observ/application.scss +15 -0
  33. data/app/controllers/observ/annotations_controller.rb +144 -0
  34. data/app/controllers/observ/application_controller.rb +8 -0
  35. data/app/controllers/observ/chats_controller.rb +58 -0
  36. data/app/controllers/observ/dashboard_controller.rb +159 -0
  37. data/app/controllers/observ/dataset_items_controller.rb +85 -0
  38. data/app/controllers/observ/dataset_run_items_controller.rb +84 -0
  39. data/app/controllers/observ/dataset_runs_controller.rb +110 -0
  40. data/app/controllers/observ/datasets_controller.rb +74 -0
  41. data/app/controllers/observ/messages_controller.rb +26 -0
  42. data/app/controllers/observ/observations_controller.rb +59 -0
  43. data/app/controllers/observ/prompt_versions_controller.rb +148 -0
  44. data/app/controllers/observ/prompts_controller.rb +205 -0
  45. data/app/controllers/observ/sessions_controller.rb +45 -0
  46. data/app/controllers/observ/traces_controller.rb +86 -0
  47. data/app/forms/observ/prompt_form.rb +96 -0
  48. data/app/helpers/observ/application_helper.rb +9 -0
  49. data/app/helpers/observ/chats_helper.rb +47 -0
  50. data/app/helpers/observ/dashboard_helper.rb +154 -0
  51. data/app/helpers/observ/datasets_helper.rb +62 -0
  52. data/app/helpers/observ/pagination_helper.rb +38 -0
  53. data/app/jobs/observ/application_job.rb +4 -0
  54. data/app/jobs/observ/dataset_runner_job.rb +49 -0
  55. data/app/mailers/observ/application_mailer.rb +6 -0
  56. data/app/models/concerns/observ/agent_phaseable.rb +124 -0
  57. data/app/models/concerns/observ/agent_selectable.rb +50 -0
  58. data/app/models/concerns/observ/chat_enhancements.rb +109 -0
  59. data/app/models/concerns/observ/message_enhancements.rb +31 -0
  60. data/app/models/concerns/observ/observability_instrumentation.rb +124 -0
  61. data/app/models/concerns/observ/prompt_management.rb +320 -0
  62. data/app/models/concerns/observ/trace_association.rb +9 -0
  63. data/app/models/observ/annotation.rb +23 -0
  64. data/app/models/observ/application_record.rb +5 -0
  65. data/app/models/observ/dataset.rb +51 -0
  66. data/app/models/observ/dataset_item.rb +41 -0
  67. data/app/models/observ/dataset_run.rb +104 -0
  68. data/app/models/observ/dataset_run_item.rb +111 -0
  69. data/app/models/observ/generation.rb +56 -0
  70. data/app/models/observ/null_prompt.rb +59 -0
  71. data/app/models/observ/observation.rb +38 -0
  72. data/app/models/observ/prompt.rb +315 -0
  73. data/app/models/observ/score.rb +51 -0
  74. data/app/models/observ/session.rb +131 -0
  75. data/app/models/observ/span.rb +13 -0
  76. data/app/models/observ/trace.rb +135 -0
  77. data/app/presenters/observ/agent_select_presenter.rb +59 -0
  78. data/app/services/observ/agent_executor_service.rb +174 -0
  79. data/app/services/observ/agent_provider.rb +60 -0
  80. data/app/services/observ/agent_selection_service.rb +53 -0
  81. data/app/services/observ/chat_instrumenter.rb +523 -0
  82. data/app/services/observ/dataset_runner_service.rb +153 -0
  83. data/app/services/observ/evaluator_runner_service.rb +58 -0
  84. data/app/services/observ/evaluators/base_evaluator.rb +51 -0
  85. data/app/services/observ/evaluators/contains_evaluator.rb +53 -0
  86. data/app/services/observ/evaluators/exact_match_evaluator.rb +23 -0
  87. data/app/services/observ/evaluators/json_structure_evaluator.rb +44 -0
  88. data/app/services/observ/prompt_manager/cache_statistics.rb +82 -0
  89. data/app/services/observ/prompt_manager/caching.rb +167 -0
  90. data/app/services/observ/prompt_manager/comparison.rb +49 -0
  91. data/app/services/observ/prompt_manager/version_management.rb +96 -0
  92. data/app/services/observ/prompt_manager.rb +40 -0
  93. data/app/services/observ/trace_text_formatter.rb +349 -0
  94. data/app/validators/observ/prompt_config_validator.rb +187 -0
  95. data/app/views/kaminari/_first_page.html.erb +11 -0
  96. data/app/views/kaminari/_gap.html.erb +8 -0
  97. data/app/views/kaminari/_last_page.html.erb +11 -0
  98. data/app/views/kaminari/_next_page.html.erb +11 -0
  99. data/app/views/kaminari/_page.html.erb +12 -0
  100. data/app/views/kaminari/_paginator.html.erb +25 -0
  101. data/app/views/kaminari/_prev_page.html.erb +11 -0
  102. data/app/views/kaminari/observ/_first_page.html.erb +11 -0
  103. data/app/views/kaminari/observ/_gap.html.erb +8 -0
  104. data/app/views/kaminari/observ/_last_page.html.erb +11 -0
  105. data/app/views/kaminari/observ/_next_page.html.erb +11 -0
  106. data/app/views/kaminari/observ/_page.html.erb +12 -0
  107. data/app/views/kaminari/observ/_paginator.html.erb +25 -0
  108. data/app/views/kaminari/observ/_prev_page.html.erb +11 -0
  109. data/app/views/layouts/observ/application.html.erb +88 -0
  110. data/app/views/observ/annotations/_annotation.html.erb +13 -0
  111. data/app/views/observ/annotations/_form.html.erb +28 -0
  112. data/app/views/observ/annotations/index.html.erb +28 -0
  113. data/app/views/observ/annotations/sessions_index.html.erb +48 -0
  114. data/app/views/observ/annotations/traces_index.html.erb +48 -0
  115. data/app/views/observ/chats/_form.html.erb +45 -0
  116. data/app/views/observ/chats/index.html.erb +67 -0
  117. data/app/views/observ/chats/new.html.erb +17 -0
  118. data/app/views/observ/chats/show.html.erb +34 -0
  119. data/app/views/observ/dashboard/index.html.erb +236 -0
  120. data/app/views/observ/dataset_items/_form.html.erb +49 -0
  121. data/app/views/observ/dataset_items/edit.html.erb +18 -0
  122. data/app/views/observ/dataset_items/index.html.erb +95 -0
  123. data/app/views/observ/dataset_items/new.html.erb +18 -0
  124. data/app/views/observ/dataset_run_items/_score_close_drawer.html.erb +4 -0
  125. data/app/views/observ/dataset_run_items/_score_drawer.html.erb +75 -0
  126. data/app/views/observ/dataset_run_items/_score_success.html.erb +29 -0
  127. data/app/views/observ/dataset_run_items/_scores_cell.html.erb +19 -0
  128. data/app/views/observ/dataset_run_items/details_drawer.turbo_stream.erb +80 -0
  129. data/app/views/observ/dataset_run_items/score_drawer.turbo_stream.erb +7 -0
  130. data/app/views/observ/dataset_runs/index.html.erb +108 -0
  131. data/app/views/observ/dataset_runs/new.html.erb +57 -0
  132. data/app/views/observ/dataset_runs/review.html.erb +155 -0
  133. data/app/views/observ/dataset_runs/show.html.erb +166 -0
  134. data/app/views/observ/datasets/_form.html.erb +62 -0
  135. data/app/views/observ/datasets/_items_tab.html.erb +66 -0
  136. data/app/views/observ/datasets/_runs_tab.html.erb +82 -0
  137. data/app/views/observ/datasets/edit.html.erb +32 -0
  138. data/app/views/observ/datasets/index.html.erb +105 -0
  139. data/app/views/observ/datasets/new.html.erb +18 -0
  140. data/app/views/observ/datasets/show.html.erb +67 -0
  141. data/app/views/observ/messages/_content.html.erb +1 -0
  142. data/app/views/observ/messages/_form.html.erb +33 -0
  143. data/app/views/observ/messages/_message.html.erb +14 -0
  144. data/app/views/observ/messages/_tool_calls.html.erb +10 -0
  145. data/app/views/observ/messages/create.turbo_stream.erb +9 -0
  146. data/app/views/observ/observations/index.html.erb +97 -0
  147. data/app/views/observ/observations/show_generation.html.erb +195 -0
  148. data/app/views/observ/observations/show_span.html.erb +93 -0
  149. data/app/views/observ/prompts/_diff_content.html.erb +16 -0
  150. data/app/views/observ/prompts/_form.html.erb +111 -0
  151. data/app/views/observ/prompts/_new_form.html.erb +102 -0
  152. data/app/views/observ/prompts/_prompt_actions.html.erb +4 -0
  153. data/app/views/observ/prompts/_prompt_content_highlighted.html.erb +4 -0
  154. data/app/views/observ/prompts/_version_actions.html.erb +40 -0
  155. data/app/views/observ/prompts/compare.html.erb +155 -0
  156. data/app/views/observ/prompts/edit.html.erb +17 -0
  157. data/app/views/observ/prompts/index.html.erb +108 -0
  158. data/app/views/observ/prompts/new.html.erb +17 -0
  159. data/app/views/observ/prompts/show.html.erb +138 -0
  160. data/app/views/observ/prompts/versions.html.erb +87 -0
  161. data/app/views/observ/sessions/annotations_drawer.turbo_stream.erb +25 -0
  162. data/app/views/observ/sessions/drawer_test.turbo_stream.erb +49 -0
  163. data/app/views/observ/sessions/index.html.erb +91 -0
  164. data/app/views/observ/sessions/show.html.erb +251 -0
  165. data/app/views/observ/traces/add_to_dataset_drawer.turbo_stream.erb +48 -0
  166. data/app/views/observ/traces/annotations_drawer.turbo_stream.erb +25 -0
  167. data/app/views/observ/traces/index.html.erb +87 -0
  168. data/app/views/observ/traces/show.html.erb +285 -0
  169. data/app/views/observ/traces/text_output_drawer.turbo_stream.erb +48 -0
  170. data/app/views/shared/_drawer.html.erb +26 -0
  171. data/config/routes.rb +80 -0
  172. data/db/migrate/001_create_observ_sessions.rb +21 -0
  173. data/db/migrate/002_create_observ_traces.rb +25 -0
  174. data/db/migrate/003_create_observ_observations.rb +42 -0
  175. data/db/migrate/004_add_message_id_to_observ_traces.rb +7 -0
  176. data/db/migrate/005_create_observ_prompts.rb +21 -0
  177. data/db/migrate/006_fix_prompt_config_strings.rb +23 -0
  178. data/db/migrate/007_create_observ_annotations.rb +12 -0
  179. data/db/migrate/009_add_prompt_fields_to_observ_chats.rb +11 -0
  180. data/db/migrate/010_create_observ_datasets.rb +15 -0
  181. data/db/migrate/011_create_observ_dataset_items.rb +17 -0
  182. data/db/migrate/012_create_observ_dataset_runs.rb +22 -0
  183. data/db/migrate/013_create_observ_dataset_run_items.rb +16 -0
  184. data/db/migrate/014_create_observ_scores.rb +26 -0
  185. data/lib/generators/observ/add_phase_tracking/add_phase_tracking_generator.rb +150 -0
  186. data/lib/generators/observ/add_phase_tracking/templates/migration.rb.tt +6 -0
  187. data/lib/generators/observ/install/USAGE +27 -0
  188. data/lib/generators/observ/install/install_generator.rb +270 -0
  189. data/lib/generators/observ/install_chat/install_chat_generator.rb +313 -0
  190. data/lib/generators/observ/install_chat/templates/agents/base_agent.rb.tt +147 -0
  191. data/lib/generators/observ/install_chat/templates/agents/simple_agent.rb.tt +55 -0
  192. data/lib/generators/observ/install_chat/templates/concerns/observ_chat_enhancements.rb.tt +34 -0
  193. data/lib/generators/observ/install_chat/templates/concerns/observ_message_enhancements.rb.tt +18 -0
  194. data/lib/generators/observ/install_chat/templates/initializers/observability.rb.tt +20 -0
  195. data/lib/generators/observ/install_chat/templates/jobs/chat_response_job.rb.tt +56 -0
  196. data/lib/generators/observ/install_chat/templates/migrations/add_agent_class_name.rb.tt +6 -0
  197. data/lib/generators/observ/install_chat/templates/migrations/add_observability_session_id.rb.tt +6 -0
  198. data/lib/generators/observ/install_chat/templates/tools/think_tool.rb.tt +29 -0
  199. data/lib/generators/observ/install_chat/templates/views/messages/_content.html.erb.tt +1 -0
  200. data/lib/observ/asset_installer.rb +130 -0
  201. data/lib/observ/asset_syncer.rb +104 -0
  202. data/lib/observ/configuration.rb +108 -0
  203. data/lib/observ/engine.rb +50 -0
  204. data/lib/observ/index_file_generator.rb +142 -0
  205. data/lib/observ/instrumenter/ruby_llm.rb +6 -0
  206. data/lib/observ/version.rb +3 -0
  207. data/lib/observ.rb +29 -0
  208. data/lib/tasks/observ_tasks.rake +75 -0
  209. metadata +453 -0
metadata ADDED
@@ -0,0 +1,453 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: rubyllm-observ
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.5.0
5
+ platform: ruby
6
+ authors:
7
+ - Franck D'agostini
8
+ bindir: bin
9
+ cert_chain: []
10
+ date: 1980-01-02 00:00:00.000000000 Z
11
+ dependencies:
12
+ - !ruby/object:Gem::Dependency
13
+ name: rails
14
+ requirement: !ruby/object:Gem::Requirement
15
+ requirements:
16
+ - - ">="
17
+ - !ruby/object:Gem::Version
18
+ version: '7.0'
19
+ - - "<"
20
+ - !ruby/object:Gem::Version
21
+ version: '9.0'
22
+ type: :runtime
23
+ prerelease: false
24
+ version_requirements: !ruby/object:Gem::Requirement
25
+ requirements:
26
+ - - ">="
27
+ - !ruby/object:Gem::Version
28
+ version: '7.0'
29
+ - - "<"
30
+ - !ruby/object:Gem::Version
31
+ version: '9.0'
32
+ - !ruby/object:Gem::Dependency
33
+ name: kaminari
34
+ requirement: !ruby/object:Gem::Requirement
35
+ requirements:
36
+ - - "~>"
37
+ - !ruby/object:Gem::Version
38
+ version: '1.2'
39
+ type: :runtime
40
+ prerelease: false
41
+ version_requirements: !ruby/object:Gem::Requirement
42
+ requirements:
43
+ - - "~>"
44
+ - !ruby/object:Gem::Version
45
+ version: '1.2'
46
+ - !ruby/object:Gem::Dependency
47
+ name: aasm
48
+ requirement: !ruby/object:Gem::Requirement
49
+ requirements:
50
+ - - "~>"
51
+ - !ruby/object:Gem::Version
52
+ version: '5.5'
53
+ type: :runtime
54
+ prerelease: false
55
+ version_requirements: !ruby/object:Gem::Requirement
56
+ requirements:
57
+ - - "~>"
58
+ - !ruby/object:Gem::Version
59
+ version: '5.5'
60
+ - !ruby/object:Gem::Dependency
61
+ name: ruby_llm
62
+ requirement: !ruby/object:Gem::Requirement
63
+ requirements:
64
+ - - ">="
65
+ - !ruby/object:Gem::Version
66
+ version: '1.0'
67
+ type: :runtime
68
+ prerelease: false
69
+ version_requirements: !ruby/object:Gem::Requirement
70
+ requirements:
71
+ - - ">="
72
+ - !ruby/object:Gem::Version
73
+ version: '1.0'
74
+ - !ruby/object:Gem::Dependency
75
+ name: ruby_llm-schema
76
+ requirement: !ruby/object:Gem::Requirement
77
+ requirements:
78
+ - - ">="
79
+ - !ruby/object:Gem::Version
80
+ version: '0.2'
81
+ type: :runtime
82
+ prerelease: false
83
+ version_requirements: !ruby/object:Gem::Requirement
84
+ requirements:
85
+ - - ">="
86
+ - !ruby/object:Gem::Version
87
+ version: '0.2'
88
+ - !ruby/object:Gem::Dependency
89
+ name: csv
90
+ requirement: !ruby/object:Gem::Requirement
91
+ requirements:
92
+ - - "~>"
93
+ - !ruby/object:Gem::Version
94
+ version: '3.0'
95
+ type: :runtime
96
+ prerelease: false
97
+ version_requirements: !ruby/object:Gem::Requirement
98
+ requirements:
99
+ - - "~>"
100
+ - !ruby/object:Gem::Version
101
+ version: '3.0'
102
+ - !ruby/object:Gem::Dependency
103
+ name: mustache
104
+ requirement: !ruby/object:Gem::Requirement
105
+ requirements:
106
+ - - "~>"
107
+ - !ruby/object:Gem::Version
108
+ version: '1.1'
109
+ type: :runtime
110
+ prerelease: false
111
+ version_requirements: !ruby/object:Gem::Requirement
112
+ requirements:
113
+ - - "~>"
114
+ - !ruby/object:Gem::Version
115
+ version: '1.1'
116
+ - !ruby/object:Gem::Dependency
117
+ name: rspec-rails
118
+ requirement: !ruby/object:Gem::Requirement
119
+ requirements:
120
+ - - "~>"
121
+ - !ruby/object:Gem::Version
122
+ version: '7.0'
123
+ type: :development
124
+ prerelease: false
125
+ version_requirements: !ruby/object:Gem::Requirement
126
+ requirements:
127
+ - - "~>"
128
+ - !ruby/object:Gem::Version
129
+ version: '7.0'
130
+ - !ruby/object:Gem::Dependency
131
+ name: factory_bot_rails
132
+ requirement: !ruby/object:Gem::Requirement
133
+ requirements:
134
+ - - "~>"
135
+ - !ruby/object:Gem::Version
136
+ version: '6.0'
137
+ type: :development
138
+ prerelease: false
139
+ version_requirements: !ruby/object:Gem::Requirement
140
+ requirements:
141
+ - - "~>"
142
+ - !ruby/object:Gem::Version
143
+ version: '6.0'
144
+ - !ruby/object:Gem::Dependency
145
+ name: shoulda-matchers
146
+ requirement: !ruby/object:Gem::Requirement
147
+ requirements:
148
+ - - "~>"
149
+ - !ruby/object:Gem::Version
150
+ version: '6.0'
151
+ type: :development
152
+ prerelease: false
153
+ version_requirements: !ruby/object:Gem::Requirement
154
+ requirements:
155
+ - - "~>"
156
+ - !ruby/object:Gem::Version
157
+ version: '6.0'
158
+ - !ruby/object:Gem::Dependency
159
+ name: faker
160
+ requirement: !ruby/object:Gem::Requirement
161
+ requirements:
162
+ - - "~>"
163
+ - !ruby/object:Gem::Version
164
+ version: '3.0'
165
+ type: :development
166
+ prerelease: false
167
+ version_requirements: !ruby/object:Gem::Requirement
168
+ requirements:
169
+ - - "~>"
170
+ - !ruby/object:Gem::Version
171
+ version: '3.0'
172
+ - !ruby/object:Gem::Dependency
173
+ name: capybara
174
+ requirement: !ruby/object:Gem::Requirement
175
+ requirements:
176
+ - - "~>"
177
+ - !ruby/object:Gem::Version
178
+ version: '3.0'
179
+ type: :development
180
+ prerelease: false
181
+ version_requirements: !ruby/object:Gem::Requirement
182
+ requirements:
183
+ - - "~>"
184
+ - !ruby/object:Gem::Version
185
+ version: '3.0'
186
+ - !ruby/object:Gem::Dependency
187
+ name: sqlite3
188
+ requirement: !ruby/object:Gem::Requirement
189
+ requirements:
190
+ - - "~>"
191
+ - !ruby/object:Gem::Version
192
+ version: '1.4'
193
+ type: :development
194
+ prerelease: false
195
+ version_requirements: !ruby/object:Gem::Requirement
196
+ requirements:
197
+ - - "~>"
198
+ - !ruby/object:Gem::Version
199
+ version: '1.4'
200
+ - !ruby/object:Gem::Dependency
201
+ name: turbo-rails
202
+ requirement: !ruby/object:Gem::Requirement
203
+ requirements:
204
+ - - "~>"
205
+ - !ruby/object:Gem::Version
206
+ version: '2.0'
207
+ type: :development
208
+ prerelease: false
209
+ version_requirements: !ruby/object:Gem::Requirement
210
+ requirements:
211
+ - - "~>"
212
+ - !ruby/object:Gem::Version
213
+ version: '2.0'
214
+ description: A Rails engine providing comprehensive observability for LLM-powered
215
+ applications. Features include session tracking, trace analysis, prompt management,
216
+ cost monitoring, and optional chat/agent testing UI (with RubyLLM integration).
217
+ email:
218
+ - franck.dagostini@gmail.com
219
+ executables: []
220
+ extensions: []
221
+ extra_rdoc_files: []
222
+ files:
223
+ - README.md
224
+ - Rakefile
225
+ - app/assets/javascripts/observ/application.js
226
+ - app/assets/javascripts/observ/controllers/autoscroll_controller.js
227
+ - app/assets/javascripts/observ/controllers/chat_form_controller.js
228
+ - app/assets/javascripts/observ/controllers/copy_controller.js
229
+ - app/assets/javascripts/observ/controllers/dashboard_controller.js
230
+ - app/assets/javascripts/observ/controllers/drawer_controller.js
231
+ - app/assets/javascripts/observ/controllers/expandable_controller.js
232
+ - app/assets/javascripts/observ/controllers/filter_controller.js
233
+ - app/assets/javascripts/observ/controllers/index.js
234
+ - app/assets/javascripts/observ/controllers/json_viewer_controller.js
235
+ - app/assets/javascripts/observ/controllers/message_form_controller.js
236
+ - app/assets/javascripts/observ/controllers/prompt_variables_controller.js
237
+ - app/assets/javascripts/observ/controllers/text_select_controller.js
238
+ - app/assets/stylesheets/observ/_annotations.scss
239
+ - app/assets/stylesheets/observ/_card.scss
240
+ - app/assets/stylesheets/observ/_chat.scss
241
+ - app/assets/stylesheets/observ/_components.scss
242
+ - app/assets/stylesheets/observ/_dashboard.scss
243
+ - app/assets/stylesheets/observ/_datasets.scss
244
+ - app/assets/stylesheets/observ/_drawer.scss
245
+ - app/assets/stylesheets/observ/_json_viewer.scss
246
+ - app/assets/stylesheets/observ/_layout.scss
247
+ - app/assets/stylesheets/observ/_metrics.scss
248
+ - app/assets/stylesheets/observ/_observations.scss
249
+ - app/assets/stylesheets/observ/_pagination.scss
250
+ - app/assets/stylesheets/observ/_prompts.scss
251
+ - app/assets/stylesheets/observ/_table.scss
252
+ - app/assets/stylesheets/observ/_variables.scss
253
+ - app/assets/stylesheets/observ/application.scss
254
+ - app/controllers/observ/annotations_controller.rb
255
+ - app/controllers/observ/application_controller.rb
256
+ - app/controllers/observ/chats_controller.rb
257
+ - app/controllers/observ/dashboard_controller.rb
258
+ - app/controllers/observ/dataset_items_controller.rb
259
+ - app/controllers/observ/dataset_run_items_controller.rb
260
+ - app/controllers/observ/dataset_runs_controller.rb
261
+ - app/controllers/observ/datasets_controller.rb
262
+ - app/controllers/observ/messages_controller.rb
263
+ - app/controllers/observ/observations_controller.rb
264
+ - app/controllers/observ/prompt_versions_controller.rb
265
+ - app/controllers/observ/prompts_controller.rb
266
+ - app/controllers/observ/sessions_controller.rb
267
+ - app/controllers/observ/traces_controller.rb
268
+ - app/forms/observ/prompt_form.rb
269
+ - app/helpers/observ/application_helper.rb
270
+ - app/helpers/observ/chats_helper.rb
271
+ - app/helpers/observ/dashboard_helper.rb
272
+ - app/helpers/observ/datasets_helper.rb
273
+ - app/helpers/observ/pagination_helper.rb
274
+ - app/jobs/observ/application_job.rb
275
+ - app/jobs/observ/dataset_runner_job.rb
276
+ - app/mailers/observ/application_mailer.rb
277
+ - app/models/concerns/observ/agent_phaseable.rb
278
+ - app/models/concerns/observ/agent_selectable.rb
279
+ - app/models/concerns/observ/chat_enhancements.rb
280
+ - app/models/concerns/observ/message_enhancements.rb
281
+ - app/models/concerns/observ/observability_instrumentation.rb
282
+ - app/models/concerns/observ/prompt_management.rb
283
+ - app/models/concerns/observ/trace_association.rb
284
+ - app/models/observ/annotation.rb
285
+ - app/models/observ/application_record.rb
286
+ - app/models/observ/dataset.rb
287
+ - app/models/observ/dataset_item.rb
288
+ - app/models/observ/dataset_run.rb
289
+ - app/models/observ/dataset_run_item.rb
290
+ - app/models/observ/generation.rb
291
+ - app/models/observ/null_prompt.rb
292
+ - app/models/observ/observation.rb
293
+ - app/models/observ/prompt.rb
294
+ - app/models/observ/score.rb
295
+ - app/models/observ/session.rb
296
+ - app/models/observ/span.rb
297
+ - app/models/observ/trace.rb
298
+ - app/presenters/observ/agent_select_presenter.rb
299
+ - app/services/observ/agent_executor_service.rb
300
+ - app/services/observ/agent_provider.rb
301
+ - app/services/observ/agent_selection_service.rb
302
+ - app/services/observ/chat_instrumenter.rb
303
+ - app/services/observ/dataset_runner_service.rb
304
+ - app/services/observ/evaluator_runner_service.rb
305
+ - app/services/observ/evaluators/base_evaluator.rb
306
+ - app/services/observ/evaluators/contains_evaluator.rb
307
+ - app/services/observ/evaluators/exact_match_evaluator.rb
308
+ - app/services/observ/evaluators/json_structure_evaluator.rb
309
+ - app/services/observ/prompt_manager.rb
310
+ - app/services/observ/prompt_manager/cache_statistics.rb
311
+ - app/services/observ/prompt_manager/caching.rb
312
+ - app/services/observ/prompt_manager/comparison.rb
313
+ - app/services/observ/prompt_manager/version_management.rb
314
+ - app/services/observ/trace_text_formatter.rb
315
+ - app/validators/observ/prompt_config_validator.rb
316
+ - app/views/kaminari/_first_page.html.erb
317
+ - app/views/kaminari/_gap.html.erb
318
+ - app/views/kaminari/_last_page.html.erb
319
+ - app/views/kaminari/_next_page.html.erb
320
+ - app/views/kaminari/_page.html.erb
321
+ - app/views/kaminari/_paginator.html.erb
322
+ - app/views/kaminari/_prev_page.html.erb
323
+ - app/views/kaminari/observ/_first_page.html.erb
324
+ - app/views/kaminari/observ/_gap.html.erb
325
+ - app/views/kaminari/observ/_last_page.html.erb
326
+ - app/views/kaminari/observ/_next_page.html.erb
327
+ - app/views/kaminari/observ/_page.html.erb
328
+ - app/views/kaminari/observ/_paginator.html.erb
329
+ - app/views/kaminari/observ/_prev_page.html.erb
330
+ - app/views/layouts/observ/application.html.erb
331
+ - app/views/observ/annotations/_annotation.html.erb
332
+ - app/views/observ/annotations/_form.html.erb
333
+ - app/views/observ/annotations/index.html.erb
334
+ - app/views/observ/annotations/sessions_index.html.erb
335
+ - app/views/observ/annotations/traces_index.html.erb
336
+ - app/views/observ/chats/_form.html.erb
337
+ - app/views/observ/chats/index.html.erb
338
+ - app/views/observ/chats/new.html.erb
339
+ - app/views/observ/chats/show.html.erb
340
+ - app/views/observ/dashboard/index.html.erb
341
+ - app/views/observ/dataset_items/_form.html.erb
342
+ - app/views/observ/dataset_items/edit.html.erb
343
+ - app/views/observ/dataset_items/index.html.erb
344
+ - app/views/observ/dataset_items/new.html.erb
345
+ - app/views/observ/dataset_run_items/_score_close_drawer.html.erb
346
+ - app/views/observ/dataset_run_items/_score_drawer.html.erb
347
+ - app/views/observ/dataset_run_items/_score_success.html.erb
348
+ - app/views/observ/dataset_run_items/_scores_cell.html.erb
349
+ - app/views/observ/dataset_run_items/details_drawer.turbo_stream.erb
350
+ - app/views/observ/dataset_run_items/score_drawer.turbo_stream.erb
351
+ - app/views/observ/dataset_runs/index.html.erb
352
+ - app/views/observ/dataset_runs/new.html.erb
353
+ - app/views/observ/dataset_runs/review.html.erb
354
+ - app/views/observ/dataset_runs/show.html.erb
355
+ - app/views/observ/datasets/_form.html.erb
356
+ - app/views/observ/datasets/_items_tab.html.erb
357
+ - app/views/observ/datasets/_runs_tab.html.erb
358
+ - app/views/observ/datasets/edit.html.erb
359
+ - app/views/observ/datasets/index.html.erb
360
+ - app/views/observ/datasets/new.html.erb
361
+ - app/views/observ/datasets/show.html.erb
362
+ - app/views/observ/messages/_content.html.erb
363
+ - app/views/observ/messages/_form.html.erb
364
+ - app/views/observ/messages/_message.html.erb
365
+ - app/views/observ/messages/_tool_calls.html.erb
366
+ - app/views/observ/messages/create.turbo_stream.erb
367
+ - app/views/observ/observations/index.html.erb
368
+ - app/views/observ/observations/show_generation.html.erb
369
+ - app/views/observ/observations/show_span.html.erb
370
+ - app/views/observ/prompts/_diff_content.html.erb
371
+ - app/views/observ/prompts/_form.html.erb
372
+ - app/views/observ/prompts/_new_form.html.erb
373
+ - app/views/observ/prompts/_prompt_actions.html.erb
374
+ - app/views/observ/prompts/_prompt_content_highlighted.html.erb
375
+ - app/views/observ/prompts/_version_actions.html.erb
376
+ - app/views/observ/prompts/compare.html.erb
377
+ - app/views/observ/prompts/edit.html.erb
378
+ - app/views/observ/prompts/index.html.erb
379
+ - app/views/observ/prompts/new.html.erb
380
+ - app/views/observ/prompts/show.html.erb
381
+ - app/views/observ/prompts/versions.html.erb
382
+ - app/views/observ/sessions/annotations_drawer.turbo_stream.erb
383
+ - app/views/observ/sessions/drawer_test.turbo_stream.erb
384
+ - app/views/observ/sessions/index.html.erb
385
+ - app/views/observ/sessions/show.html.erb
386
+ - app/views/observ/traces/add_to_dataset_drawer.turbo_stream.erb
387
+ - app/views/observ/traces/annotations_drawer.turbo_stream.erb
388
+ - app/views/observ/traces/index.html.erb
389
+ - app/views/observ/traces/show.html.erb
390
+ - app/views/observ/traces/text_output_drawer.turbo_stream.erb
391
+ - app/views/shared/_drawer.html.erb
392
+ - config/routes.rb
393
+ - db/migrate/001_create_observ_sessions.rb
394
+ - db/migrate/002_create_observ_traces.rb
395
+ - db/migrate/003_create_observ_observations.rb
396
+ - db/migrate/004_add_message_id_to_observ_traces.rb
397
+ - db/migrate/005_create_observ_prompts.rb
398
+ - db/migrate/006_fix_prompt_config_strings.rb
399
+ - db/migrate/007_create_observ_annotations.rb
400
+ - db/migrate/009_add_prompt_fields_to_observ_chats.rb
401
+ - db/migrate/010_create_observ_datasets.rb
402
+ - db/migrate/011_create_observ_dataset_items.rb
403
+ - db/migrate/012_create_observ_dataset_runs.rb
404
+ - db/migrate/013_create_observ_dataset_run_items.rb
405
+ - db/migrate/014_create_observ_scores.rb
406
+ - lib/generators/observ/add_phase_tracking/add_phase_tracking_generator.rb
407
+ - lib/generators/observ/add_phase_tracking/templates/migration.rb.tt
408
+ - lib/generators/observ/install/USAGE
409
+ - lib/generators/observ/install/install_generator.rb
410
+ - lib/generators/observ/install_chat/install_chat_generator.rb
411
+ - lib/generators/observ/install_chat/templates/agents/base_agent.rb.tt
412
+ - lib/generators/observ/install_chat/templates/agents/simple_agent.rb.tt
413
+ - lib/generators/observ/install_chat/templates/concerns/observ_chat_enhancements.rb.tt
414
+ - lib/generators/observ/install_chat/templates/concerns/observ_message_enhancements.rb.tt
415
+ - lib/generators/observ/install_chat/templates/initializers/observability.rb.tt
416
+ - lib/generators/observ/install_chat/templates/jobs/chat_response_job.rb.tt
417
+ - lib/generators/observ/install_chat/templates/migrations/add_agent_class_name.rb.tt
418
+ - lib/generators/observ/install_chat/templates/migrations/add_observability_session_id.rb.tt
419
+ - lib/generators/observ/install_chat/templates/tools/think_tool.rb.tt
420
+ - lib/generators/observ/install_chat/templates/views/messages/_content.html.erb.tt
421
+ - lib/observ.rb
422
+ - lib/observ/asset_installer.rb
423
+ - lib/observ/asset_syncer.rb
424
+ - lib/observ/configuration.rb
425
+ - lib/observ/engine.rb
426
+ - lib/observ/index_file_generator.rb
427
+ - lib/observ/instrumenter/ruby_llm.rb
428
+ - lib/observ/version.rb
429
+ - lib/tasks/observ_tasks.rake
430
+ homepage: https://github.com/franck/observ
431
+ licenses:
432
+ - MIT
433
+ metadata:
434
+ source_code_uri: https://github.com/franck/observ
435
+ changelog_uri: https://github.com/franck/observ/blob/main/CHANGELOG.md
436
+ rdoc_options: []
437
+ require_paths:
438
+ - lib
439
+ required_ruby_version: !ruby/object:Gem::Requirement
440
+ requirements:
441
+ - - ">="
442
+ - !ruby/object:Gem::Version
443
+ version: '3.0'
444
+ required_rubygems_version: !ruby/object:Gem::Requirement
445
+ requirements:
446
+ - - ">="
447
+ - !ruby/object:Gem::Version
448
+ version: '0'
449
+ requirements: []
450
+ rubygems_version: 3.6.9
451
+ specification_version: 4
452
+ summary: Rails observability engine for LLM applications
453
+ test_files: []