deeprails 0.8.0 → 0.9.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.
@@ -7,7 +7,7 @@ module Deeprails
7
7
  name: String,
8
8
  created_at: Time,
9
9
  description: String,
10
- evaluations: ::Array[Deeprails::Evaluation],
10
+ evaluations: ::Array[Deeprails::MonitorDetailResponse::Evaluation],
11
11
  stats: Deeprails::MonitorDetailResponse::Stats,
12
12
  updated_at: Time,
13
13
  user_id: String
@@ -28,11 +28,11 @@ module Deeprails
28
28
 
29
29
  def description=: (String) -> String
30
30
 
31
- attr_reader evaluations: ::Array[Deeprails::Evaluation]?
31
+ attr_reader evaluations: ::Array[Deeprails::MonitorDetailResponse::Evaluation]?
32
32
 
33
33
  def evaluations=: (
34
- ::Array[Deeprails::Evaluation]
35
- ) -> ::Array[Deeprails::Evaluation]
34
+ ::Array[Deeprails::MonitorDetailResponse::Evaluation]
35
+ ) -> ::Array[Deeprails::MonitorDetailResponse::Evaluation]
36
36
 
37
37
  attr_reader stats: Deeprails::MonitorDetailResponse::Stats?
38
38
 
@@ -54,7 +54,7 @@ module Deeprails
54
54
  name: String,
55
55
  ?created_at: Time,
56
56
  ?description: String,
57
- ?evaluations: ::Array[Deeprails::Evaluation],
57
+ ?evaluations: ::Array[Deeprails::MonitorDetailResponse::Evaluation],
58
58
  ?stats: Deeprails::MonitorDetailResponse::Stats,
59
59
  ?updated_at: Time,
60
60
  ?user_id: String
@@ -66,7 +66,7 @@ module Deeprails
66
66
  name: String,
67
67
  created_at: Time,
68
68
  description: String,
69
- evaluations: ::Array[Deeprails::Evaluation],
69
+ evaluations: ::Array[Deeprails::MonitorDetailResponse::Evaluation],
70
70
  stats: Deeprails::MonitorDetailResponse::Stats,
71
71
  updated_at: Time,
72
72
  user_id: String
@@ -83,6 +83,207 @@ module Deeprails
83
83
  def self?.values: -> ::Array[Deeprails::Models::MonitorDetailResponse::monitor_status]
84
84
  end
85
85
 
86
+ type evaluation =
87
+ {
88
+ eval_id: String,
89
+ evaluation_status: Deeprails::Models::MonitorDetailResponse::Evaluation::evaluation_status,
90
+ model_input: Deeprails::MonitorDetailResponse::Evaluation::ModelInput,
91
+ model_output: String,
92
+ run_mode: Deeprails::Models::MonitorDetailResponse::Evaluation::run_mode,
93
+ created_at: Time,
94
+ end_timestamp: Time,
95
+ error_message: String,
96
+ error_timestamp: Time,
97
+ evaluation_result: ::Hash[Symbol, top],
98
+ evaluation_total_cost: Float,
99
+ guardrail_metrics: ::Array[Deeprails::Models::MonitorDetailResponse::Evaluation::guardrail_metric],
100
+ model_used: String,
101
+ modified_at: Time,
102
+ nametag: String,
103
+ progress: Integer,
104
+ start_timestamp: Time
105
+ }
106
+
107
+ class Evaluation < Deeprails::Internal::Type::BaseModel
108
+ attr_accessor eval_id: String
109
+
110
+ attr_accessor evaluation_status: Deeprails::Models::MonitorDetailResponse::Evaluation::evaluation_status
111
+
112
+ attr_accessor model_input: Deeprails::MonitorDetailResponse::Evaluation::ModelInput
113
+
114
+ attr_accessor model_output: String
115
+
116
+ attr_accessor run_mode: Deeprails::Models::MonitorDetailResponse::Evaluation::run_mode
117
+
118
+ attr_reader created_at: Time?
119
+
120
+ def created_at=: (Time) -> Time
121
+
122
+ attr_reader end_timestamp: Time?
123
+
124
+ def end_timestamp=: (Time) -> Time
125
+
126
+ attr_reader error_message: String?
127
+
128
+ def error_message=: (String) -> String
129
+
130
+ attr_reader error_timestamp: Time?
131
+
132
+ def error_timestamp=: (Time) -> Time
133
+
134
+ attr_reader evaluation_result: ::Hash[Symbol, top]?
135
+
136
+ def evaluation_result=: (::Hash[Symbol, top]) -> ::Hash[Symbol, top]
137
+
138
+ attr_reader evaluation_total_cost: Float?
139
+
140
+ def evaluation_total_cost=: (Float) -> Float
141
+
142
+ attr_reader guardrail_metrics: ::Array[Deeprails::Models::MonitorDetailResponse::Evaluation::guardrail_metric]?
143
+
144
+ def guardrail_metrics=: (
145
+ ::Array[Deeprails::Models::MonitorDetailResponse::Evaluation::guardrail_metric]
146
+ ) -> ::Array[Deeprails::Models::MonitorDetailResponse::Evaluation::guardrail_metric]
147
+
148
+ attr_reader model_used: String?
149
+
150
+ def model_used=: (String) -> String
151
+
152
+ attr_reader modified_at: Time?
153
+
154
+ def modified_at=: (Time) -> Time
155
+
156
+ attr_reader nametag: String?
157
+
158
+ def nametag=: (String) -> String
159
+
160
+ attr_reader progress: Integer?
161
+
162
+ def progress=: (Integer) -> Integer
163
+
164
+ attr_reader start_timestamp: Time?
165
+
166
+ def start_timestamp=: (Time) -> Time
167
+
168
+ def initialize: (
169
+ eval_id: String,
170
+ evaluation_status: Deeprails::Models::MonitorDetailResponse::Evaluation::evaluation_status,
171
+ model_input: Deeprails::MonitorDetailResponse::Evaluation::ModelInput,
172
+ model_output: String,
173
+ run_mode: Deeprails::Models::MonitorDetailResponse::Evaluation::run_mode,
174
+ ?created_at: Time,
175
+ ?end_timestamp: Time,
176
+ ?error_message: String,
177
+ ?error_timestamp: Time,
178
+ ?evaluation_result: ::Hash[Symbol, top],
179
+ ?evaluation_total_cost: Float,
180
+ ?guardrail_metrics: ::Array[Deeprails::Models::MonitorDetailResponse::Evaluation::guardrail_metric],
181
+ ?model_used: String,
182
+ ?modified_at: Time,
183
+ ?nametag: String,
184
+ ?progress: Integer,
185
+ ?start_timestamp: Time
186
+ ) -> void
187
+
188
+ def to_hash: -> {
189
+ eval_id: String,
190
+ evaluation_status: Deeprails::Models::MonitorDetailResponse::Evaluation::evaluation_status,
191
+ model_input: Deeprails::MonitorDetailResponse::Evaluation::ModelInput,
192
+ model_output: String,
193
+ run_mode: Deeprails::Models::MonitorDetailResponse::Evaluation::run_mode,
194
+ created_at: Time,
195
+ end_timestamp: Time,
196
+ error_message: String,
197
+ error_timestamp: Time,
198
+ evaluation_result: ::Hash[Symbol, top],
199
+ evaluation_total_cost: Float,
200
+ guardrail_metrics: ::Array[Deeprails::Models::MonitorDetailResponse::Evaluation::guardrail_metric],
201
+ model_used: String,
202
+ modified_at: Time,
203
+ nametag: String,
204
+ progress: Integer,
205
+ start_timestamp: Time
206
+ }
207
+
208
+ type evaluation_status =
209
+ :in_progress | :completed | :canceled | :queued | :failed
210
+
211
+ module EvaluationStatus
212
+ extend Deeprails::Internal::Type::Enum
213
+
214
+ IN_PROGRESS: :in_progress
215
+ COMPLETED: :completed
216
+ CANCELED: :canceled
217
+ QUEUED: :queued
218
+ FAILED: :failed
219
+
220
+ def self?.values: -> ::Array[Deeprails::Models::MonitorDetailResponse::Evaluation::evaluation_status]
221
+ end
222
+
223
+ type model_input =
224
+ { ground_truth: String, system_prompt: String, user_prompt: String }
225
+
226
+ class ModelInput < Deeprails::Internal::Type::BaseModel
227
+ attr_reader ground_truth: String?
228
+
229
+ def ground_truth=: (String) -> String
230
+
231
+ attr_reader system_prompt: String?
232
+
233
+ def system_prompt=: (String) -> String
234
+
235
+ attr_reader user_prompt: String?
236
+
237
+ def user_prompt=: (String) -> String
238
+
239
+ def initialize: (
240
+ ?ground_truth: String,
241
+ ?system_prompt: String,
242
+ ?user_prompt: String
243
+ ) -> void
244
+
245
+ def to_hash: -> {
246
+ ground_truth: String,
247
+ system_prompt: String,
248
+ user_prompt: String
249
+ }
250
+ end
251
+
252
+ type run_mode = :precision_plus | :precision | :smart | :economy
253
+
254
+ module RunMode
255
+ extend Deeprails::Internal::Type::Enum
256
+
257
+ PRECISION_PLUS: :precision_plus
258
+ PRECISION: :precision
259
+ SMART: :smart
260
+ ECONOMY: :economy
261
+
262
+ def self?.values: -> ::Array[Deeprails::Models::MonitorDetailResponse::Evaluation::run_mode]
263
+ end
264
+
265
+ type guardrail_metric =
266
+ :correctness
267
+ | :completeness
268
+ | :instruction_adherence
269
+ | :context_adherence
270
+ | :ground_truth_adherence
271
+ | :comprehensive_safety
272
+
273
+ module GuardrailMetric
274
+ extend Deeprails::Internal::Type::Enum
275
+
276
+ CORRECTNESS: :correctness
277
+ COMPLETENESS: :completeness
278
+ INSTRUCTION_ADHERENCE: :instruction_adherence
279
+ CONTEXT_ADHERENCE: :context_adherence
280
+ GROUND_TRUTH_ADHERENCE: :ground_truth_adherence
281
+ COMPREHENSIVE_SAFETY: :comprehensive_safety
282
+
283
+ def self?.values: -> ::Array[Deeprails::Models::MonitorDetailResponse::Evaluation::guardrail_metric]
284
+ end
285
+ end
286
+
86
287
  type stats =
87
288
  {
88
289
  completed_evaluations: Integer,
@@ -11,12 +11,6 @@ module Deeprails
11
11
 
12
12
  class DefendUpdateWorkflowParams = Deeprails::Models::DefendUpdateWorkflowParams
13
13
 
14
- class EvaluateCreateParams = Deeprails::Models::EvaluateCreateParams
15
-
16
- class EvaluateRetrieveParams = Deeprails::Models::EvaluateRetrieveParams
17
-
18
- class Evaluation = Deeprails::Models::Evaluation
19
-
20
14
  class MonitorCreateParams = Deeprails::Models::MonitorCreateParams
21
15
 
22
16
  class MonitorDetailResponse = Deeprails::Models::MonitorDetailResponse
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: deeprails
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.8.0
4
+ version: 0.9.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Deeprails
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2025-10-24 00:00:00.000000000 Z
11
+ date: 2025-10-29 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: connection_pool
@@ -61,9 +61,6 @@ files:
61
61
  - lib/deeprails/models/defend_retrieve_workflow_params.rb
62
62
  - lib/deeprails/models/defend_submit_event_params.rb
63
63
  - lib/deeprails/models/defend_update_workflow_params.rb
64
- - lib/deeprails/models/evaluate_create_params.rb
65
- - lib/deeprails/models/evaluate_retrieve_params.rb
66
- - lib/deeprails/models/evaluation.rb
67
64
  - lib/deeprails/models/monitor_create_params.rb
68
65
  - lib/deeprails/models/monitor_detail_response.rb
69
66
  - lib/deeprails/models/monitor_event_response.rb
@@ -74,7 +71,6 @@ files:
74
71
  - lib/deeprails/models/workflow_event_response.rb
75
72
  - lib/deeprails/request_options.rb
76
73
  - lib/deeprails/resources/defend.rb
77
- - lib/deeprails/resources/evaluate.rb
78
74
  - lib/deeprails/resources/monitor.rb
79
75
  - lib/deeprails/version.rb
80
76
  - manifest.yaml
@@ -103,9 +99,6 @@ files:
103
99
  - rbi/deeprails/models/defend_retrieve_workflow_params.rbi
104
100
  - rbi/deeprails/models/defend_submit_event_params.rbi
105
101
  - rbi/deeprails/models/defend_update_workflow_params.rbi
106
- - rbi/deeprails/models/evaluate_create_params.rbi
107
- - rbi/deeprails/models/evaluate_retrieve_params.rbi
108
- - rbi/deeprails/models/evaluation.rbi
109
102
  - rbi/deeprails/models/monitor_create_params.rbi
110
103
  - rbi/deeprails/models/monitor_detail_response.rbi
111
104
  - rbi/deeprails/models/monitor_event_response.rbi
@@ -116,7 +109,6 @@ files:
116
109
  - rbi/deeprails/models/workflow_event_response.rbi
117
110
  - rbi/deeprails/request_options.rbi
118
111
  - rbi/deeprails/resources/defend.rbi
119
- - rbi/deeprails/resources/evaluate.rbi
120
112
  - rbi/deeprails/resources/monitor.rbi
121
113
  - rbi/deeprails/version.rbi
122
114
  - sig/deeprails/client.rbs
@@ -144,9 +136,6 @@ files:
144
136
  - sig/deeprails/models/defend_retrieve_workflow_params.rbs
145
137
  - sig/deeprails/models/defend_submit_event_params.rbs
146
138
  - sig/deeprails/models/defend_update_workflow_params.rbs
147
- - sig/deeprails/models/evaluate_create_params.rbs
148
- - sig/deeprails/models/evaluate_retrieve_params.rbs
149
- - sig/deeprails/models/evaluation.rbs
150
139
  - sig/deeprails/models/monitor_create_params.rbs
151
140
  - sig/deeprails/models/monitor_detail_response.rbs
152
141
  - sig/deeprails/models/monitor_event_response.rbs
@@ -157,7 +146,6 @@ files:
157
146
  - sig/deeprails/models/workflow_event_response.rbs
158
147
  - sig/deeprails/request_options.rbs
159
148
  - sig/deeprails/resources/defend.rbs
160
- - sig/deeprails/resources/evaluate.rbs
161
149
  - sig/deeprails/resources/monitor.rbs
162
150
  - sig/deeprails/version.rbs
163
151
  homepage: https://gemdocs.org/gems/deeprails
@@ -1,134 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Deeprails
4
- module Models
5
- # @see Deeprails::Resources::Evaluate#create
6
- class EvaluateCreateParams < Deeprails::Internal::Type::BaseModel
7
- extend Deeprails::Internal::Type::RequestParameters::Converter
8
- include Deeprails::Internal::Type::RequestParameters
9
-
10
- # @!attribute model_input
11
- # A dictionary of inputs sent to the LLM to generate output. The dictionary must
12
- # contain at least a `user_prompt` field or a `system_prompt` field. For
13
- # ground_truth_adherence guardrail metric, `ground_truth` should be provided.
14
- #
15
- # @return [Deeprails::Models::EvaluateCreateParams::ModelInput]
16
- required :model_input, -> { Deeprails::EvaluateCreateParams::ModelInput }
17
-
18
- # @!attribute model_output
19
- # Output generated by the LLM to be evaluated.
20
- #
21
- # @return [String]
22
- required :model_output, String
23
-
24
- # @!attribute run_mode
25
- # Run mode for the evaluation. The run mode allows the user to optimize for speed,
26
- # accuracy, and cost by determining which models are used to evaluate the event.
27
- # Available run modes include `precision_plus`, `precision`, `smart`, and
28
- # `economy`. Defaults to `smart`.
29
- #
30
- # @return [Symbol, Deeprails::Models::EvaluateCreateParams::RunMode]
31
- required :run_mode, enum: -> { Deeprails::EvaluateCreateParams::RunMode }
32
-
33
- # @!attribute guardrail_metrics
34
- # An array of guardrail metrics that the model input and output pair will be
35
- # evaluated on. For non-enterprise users, these will be limited to the allowed
36
- # guardrail metrics.
37
- #
38
- # @return [Array<Symbol, Deeprails::Models::EvaluateCreateParams::GuardrailMetric>, nil]
39
- optional :guardrail_metrics,
40
- -> { Deeprails::Internal::Type::ArrayOf[enum: Deeprails::EvaluateCreateParams::GuardrailMetric] }
41
-
42
- # @!attribute model_used
43
- # Model ID used to generate the output, like `gpt-4o` or `o3`.
44
- #
45
- # @return [String, nil]
46
- optional :model_used, String
47
-
48
- # @!attribute nametag
49
- # An optional, user-defined tag for the evaluation.
50
- #
51
- # @return [String, nil]
52
- optional :nametag, String
53
-
54
- # @!method initialize(model_input:, model_output:, run_mode:, guardrail_metrics: nil, model_used: nil, nametag: nil, request_options: {})
55
- # Some parameter documentations has been truncated, see
56
- # {Deeprails::Models::EvaluateCreateParams} for more details.
57
- #
58
- # @param model_input [Deeprails::Models::EvaluateCreateParams::ModelInput] A dictionary of inputs sent to the LLM to generate output. The dictionary must c
59
- #
60
- # @param model_output [String] Output generated by the LLM to be evaluated.
61
- #
62
- # @param run_mode [Symbol, Deeprails::Models::EvaluateCreateParams::RunMode] Run mode for the evaluation. The run mode allows the user to optimize for speed
63
- #
64
- # @param guardrail_metrics [Array<Symbol, Deeprails::Models::EvaluateCreateParams::GuardrailMetric>] An array of guardrail metrics that the model input and output pair will be evalu
65
- #
66
- # @param model_used [String] Model ID used to generate the output, like `gpt-4o` or `o3`.
67
- #
68
- # @param nametag [String] An optional, user-defined tag for the evaluation.
69
- #
70
- # @param request_options [Deeprails::RequestOptions, Hash{Symbol=>Object}]
71
-
72
- class ModelInput < Deeprails::Internal::Type::BaseModel
73
- # @!attribute ground_truth
74
- # The ground truth for evaluating Ground Truth Adherence guardrail.
75
- #
76
- # @return [String, nil]
77
- optional :ground_truth, String
78
-
79
- # @!attribute system_prompt
80
- # The system prompt used to generate the output.
81
- #
82
- # @return [String, nil]
83
- optional :system_prompt, String
84
-
85
- # @!attribute user_prompt
86
- # The user prompt used to generate the output.
87
- #
88
- # @return [String, nil]
89
- optional :user_prompt, String
90
-
91
- # @!method initialize(ground_truth: nil, system_prompt: nil, user_prompt: nil)
92
- # A dictionary of inputs sent to the LLM to generate output. The dictionary must
93
- # contain at least a `user_prompt` field or a `system_prompt` field. For
94
- # ground_truth_adherence guardrail metric, `ground_truth` should be provided.
95
- #
96
- # @param ground_truth [String] The ground truth for evaluating Ground Truth Adherence guardrail.
97
- #
98
- # @param system_prompt [String] The system prompt used to generate the output.
99
- #
100
- # @param user_prompt [String] The user prompt used to generate the output.
101
- end
102
-
103
- # Run mode for the evaluation. The run mode allows the user to optimize for speed,
104
- # accuracy, and cost by determining which models are used to evaluate the event.
105
- # Available run modes include `precision_plus`, `precision`, `smart`, and
106
- # `economy`. Defaults to `smart`.
107
- module RunMode
108
- extend Deeprails::Internal::Type::Enum
109
-
110
- PRECISION_PLUS = :precision_plus
111
- PRECISION = :precision
112
- SMART = :smart
113
- ECONOMY = :economy
114
-
115
- # @!method self.values
116
- # @return [Array<Symbol>]
117
- end
118
-
119
- module GuardrailMetric
120
- extend Deeprails::Internal::Type::Enum
121
-
122
- CORRECTNESS = :correctness
123
- COMPLETENESS = :completeness
124
- INSTRUCTION_ADHERENCE = :instruction_adherence
125
- CONTEXT_ADHERENCE = :context_adherence
126
- GROUND_TRUTH_ADHERENCE = :ground_truth_adherence
127
- COMPREHENSIVE_SAFETY = :comprehensive_safety
128
-
129
- # @!method self.values
130
- # @return [Array<Symbol>]
131
- end
132
- end
133
- end
134
- end
@@ -1,14 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Deeprails
4
- module Models
5
- # @see Deeprails::Resources::Evaluate#retrieve
6
- class EvaluateRetrieveParams < Deeprails::Internal::Type::BaseModel
7
- extend Deeprails::Internal::Type::RequestParameters::Converter
8
- include Deeprails::Internal::Type::RequestParameters
9
-
10
- # @!method initialize(request_options: {})
11
- # @param request_options [Deeprails::RequestOptions, Hash{Symbol=>Object}]
12
- end
13
- end
14
- end