arize-phoenix 11.23.1__py3-none-any.whl → 12.28.1__py3-none-any.whl

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 (221) hide show
  1. {arize_phoenix-11.23.1.dist-info → arize_phoenix-12.28.1.dist-info}/METADATA +61 -36
  2. {arize_phoenix-11.23.1.dist-info → arize_phoenix-12.28.1.dist-info}/RECORD +212 -162
  3. {arize_phoenix-11.23.1.dist-info → arize_phoenix-12.28.1.dist-info}/WHEEL +1 -1
  4. {arize_phoenix-11.23.1.dist-info → arize_phoenix-12.28.1.dist-info}/licenses/IP_NOTICE +1 -1
  5. phoenix/__generated__/__init__.py +0 -0
  6. phoenix/__generated__/classification_evaluator_configs/__init__.py +20 -0
  7. phoenix/__generated__/classification_evaluator_configs/_document_relevance_classification_evaluator_config.py +17 -0
  8. phoenix/__generated__/classification_evaluator_configs/_hallucination_classification_evaluator_config.py +17 -0
  9. phoenix/__generated__/classification_evaluator_configs/_models.py +18 -0
  10. phoenix/__generated__/classification_evaluator_configs/_tool_selection_classification_evaluator_config.py +17 -0
  11. phoenix/__init__.py +2 -1
  12. phoenix/auth.py +27 -2
  13. phoenix/config.py +1594 -81
  14. phoenix/db/README.md +546 -28
  15. phoenix/db/bulk_inserter.py +119 -116
  16. phoenix/db/engines.py +140 -33
  17. phoenix/db/facilitator.py +22 -1
  18. phoenix/db/helpers.py +818 -65
  19. phoenix/db/iam_auth.py +64 -0
  20. phoenix/db/insertion/dataset.py +133 -1
  21. phoenix/db/insertion/document_annotation.py +9 -6
  22. phoenix/db/insertion/evaluation.py +2 -3
  23. phoenix/db/insertion/helpers.py +2 -2
  24. phoenix/db/insertion/session_annotation.py +176 -0
  25. phoenix/db/insertion/span_annotation.py +3 -4
  26. phoenix/db/insertion/trace_annotation.py +3 -4
  27. phoenix/db/insertion/types.py +41 -18
  28. phoenix/db/migrations/versions/01a8342c9cdf_add_user_id_on_datasets.py +40 -0
  29. phoenix/db/migrations/versions/0df286449799_add_session_annotations_table.py +105 -0
  30. phoenix/db/migrations/versions/272b66ff50f8_drop_single_indices.py +119 -0
  31. phoenix/db/migrations/versions/58228d933c91_dataset_labels.py +67 -0
  32. phoenix/db/migrations/versions/699f655af132_experiment_tags.py +57 -0
  33. phoenix/db/migrations/versions/735d3d93c33e_add_composite_indices.py +41 -0
  34. phoenix/db/migrations/versions/ab513d89518b_add_user_id_on_dataset_versions.py +40 -0
  35. phoenix/db/migrations/versions/d0690a79ea51_users_on_experiments.py +40 -0
  36. phoenix/db/migrations/versions/deb2c81c0bb2_dataset_splits.py +139 -0
  37. phoenix/db/migrations/versions/e76cbd66ffc3_add_experiments_dataset_examples.py +87 -0
  38. phoenix/db/models.py +364 -56
  39. phoenix/db/pg_config.py +10 -0
  40. phoenix/db/types/trace_retention.py +7 -6
  41. phoenix/experiments/functions.py +69 -19
  42. phoenix/inferences/inferences.py +1 -2
  43. phoenix/server/api/auth.py +9 -0
  44. phoenix/server/api/auth_messages.py +46 -0
  45. phoenix/server/api/context.py +60 -0
  46. phoenix/server/api/dataloaders/__init__.py +36 -0
  47. phoenix/server/api/dataloaders/annotation_summaries.py +60 -8
  48. phoenix/server/api/dataloaders/average_experiment_repeated_run_group_latency.py +50 -0
  49. phoenix/server/api/dataloaders/average_experiment_run_latency.py +17 -24
  50. phoenix/server/api/dataloaders/cache/two_tier_cache.py +1 -2
  51. phoenix/server/api/dataloaders/dataset_dataset_splits.py +52 -0
  52. phoenix/server/api/dataloaders/dataset_example_revisions.py +0 -1
  53. phoenix/server/api/dataloaders/dataset_example_splits.py +40 -0
  54. phoenix/server/api/dataloaders/dataset_examples_and_versions_by_experiment_run.py +47 -0
  55. phoenix/server/api/dataloaders/dataset_labels.py +36 -0
  56. phoenix/server/api/dataloaders/document_evaluation_summaries.py +2 -2
  57. phoenix/server/api/dataloaders/document_evaluations.py +6 -9
  58. phoenix/server/api/dataloaders/experiment_annotation_summaries.py +88 -34
  59. phoenix/server/api/dataloaders/experiment_dataset_splits.py +43 -0
  60. phoenix/server/api/dataloaders/experiment_error_rates.py +21 -28
  61. phoenix/server/api/dataloaders/experiment_repeated_run_group_annotation_summaries.py +77 -0
  62. phoenix/server/api/dataloaders/experiment_repeated_run_groups.py +57 -0
  63. phoenix/server/api/dataloaders/experiment_runs_by_experiment_and_example.py +44 -0
  64. phoenix/server/api/dataloaders/latency_ms_quantile.py +40 -8
  65. phoenix/server/api/dataloaders/record_counts.py +37 -10
  66. phoenix/server/api/dataloaders/session_annotations_by_session.py +29 -0
  67. phoenix/server/api/dataloaders/span_cost_summary_by_experiment_repeated_run_group.py +64 -0
  68. phoenix/server/api/dataloaders/span_cost_summary_by_project.py +28 -14
  69. phoenix/server/api/dataloaders/span_costs.py +3 -9
  70. phoenix/server/api/dataloaders/table_fields.py +2 -2
  71. phoenix/server/api/dataloaders/token_prices_by_model.py +30 -0
  72. phoenix/server/api/dataloaders/trace_annotations_by_trace.py +27 -0
  73. phoenix/server/api/exceptions.py +5 -1
  74. phoenix/server/api/helpers/playground_clients.py +263 -83
  75. phoenix/server/api/helpers/playground_spans.py +2 -1
  76. phoenix/server/api/helpers/playground_users.py +26 -0
  77. phoenix/server/api/helpers/prompts/conversions/google.py +103 -0
  78. phoenix/server/api/helpers/prompts/models.py +61 -19
  79. phoenix/server/api/input_types/{SpanAnnotationFilter.py → AnnotationFilter.py} +22 -14
  80. phoenix/server/api/input_types/ChatCompletionInput.py +3 -0
  81. phoenix/server/api/input_types/CreateProjectSessionAnnotationInput.py +37 -0
  82. phoenix/server/api/input_types/DatasetFilter.py +5 -2
  83. phoenix/server/api/input_types/ExperimentRunSort.py +237 -0
  84. phoenix/server/api/input_types/GenerativeModelInput.py +3 -0
  85. phoenix/server/api/input_types/ProjectSessionSort.py +158 -1
  86. phoenix/server/api/input_types/PromptVersionInput.py +47 -1
  87. phoenix/server/api/input_types/SpanSort.py +3 -2
  88. phoenix/server/api/input_types/UpdateAnnotationInput.py +34 -0
  89. phoenix/server/api/input_types/UserRoleInput.py +1 -0
  90. phoenix/server/api/mutations/__init__.py +8 -0
  91. phoenix/server/api/mutations/annotation_config_mutations.py +8 -8
  92. phoenix/server/api/mutations/api_key_mutations.py +15 -20
  93. phoenix/server/api/mutations/chat_mutations.py +106 -37
  94. phoenix/server/api/mutations/dataset_label_mutations.py +243 -0
  95. phoenix/server/api/mutations/dataset_mutations.py +21 -16
  96. phoenix/server/api/mutations/dataset_split_mutations.py +351 -0
  97. phoenix/server/api/mutations/experiment_mutations.py +2 -2
  98. phoenix/server/api/mutations/export_events_mutations.py +3 -3
  99. phoenix/server/api/mutations/model_mutations.py +11 -9
  100. phoenix/server/api/mutations/project_mutations.py +4 -4
  101. phoenix/server/api/mutations/project_session_annotations_mutations.py +158 -0
  102. phoenix/server/api/mutations/project_trace_retention_policy_mutations.py +8 -4
  103. phoenix/server/api/mutations/prompt_label_mutations.py +74 -65
  104. phoenix/server/api/mutations/prompt_mutations.py +65 -129
  105. phoenix/server/api/mutations/prompt_version_tag_mutations.py +11 -8
  106. phoenix/server/api/mutations/span_annotations_mutations.py +15 -10
  107. phoenix/server/api/mutations/trace_annotations_mutations.py +13 -8
  108. phoenix/server/api/mutations/trace_mutations.py +3 -3
  109. phoenix/server/api/mutations/user_mutations.py +55 -26
  110. phoenix/server/api/queries.py +501 -617
  111. phoenix/server/api/routers/__init__.py +2 -2
  112. phoenix/server/api/routers/auth.py +141 -87
  113. phoenix/server/api/routers/ldap.py +229 -0
  114. phoenix/server/api/routers/oauth2.py +349 -101
  115. phoenix/server/api/routers/v1/__init__.py +22 -4
  116. phoenix/server/api/routers/v1/annotation_configs.py +19 -30
  117. phoenix/server/api/routers/v1/annotations.py +455 -13
  118. phoenix/server/api/routers/v1/datasets.py +355 -68
  119. phoenix/server/api/routers/v1/documents.py +142 -0
  120. phoenix/server/api/routers/v1/evaluations.py +20 -28
  121. phoenix/server/api/routers/v1/experiment_evaluations.py +16 -6
  122. phoenix/server/api/routers/v1/experiment_runs.py +335 -59
  123. phoenix/server/api/routers/v1/experiments.py +475 -47
  124. phoenix/server/api/routers/v1/projects.py +16 -50
  125. phoenix/server/api/routers/v1/prompts.py +50 -39
  126. phoenix/server/api/routers/v1/sessions.py +108 -0
  127. phoenix/server/api/routers/v1/spans.py +156 -96
  128. phoenix/server/api/routers/v1/traces.py +51 -77
  129. phoenix/server/api/routers/v1/users.py +64 -24
  130. phoenix/server/api/routers/v1/utils.py +3 -7
  131. phoenix/server/api/subscriptions.py +257 -93
  132. phoenix/server/api/types/Annotation.py +90 -23
  133. phoenix/server/api/types/ApiKey.py +13 -17
  134. phoenix/server/api/types/AuthMethod.py +1 -0
  135. phoenix/server/api/types/ChatCompletionSubscriptionPayload.py +1 -0
  136. phoenix/server/api/types/Dataset.py +199 -72
  137. phoenix/server/api/types/DatasetExample.py +88 -18
  138. phoenix/server/api/types/DatasetExperimentAnnotationSummary.py +10 -0
  139. phoenix/server/api/types/DatasetLabel.py +57 -0
  140. phoenix/server/api/types/DatasetSplit.py +98 -0
  141. phoenix/server/api/types/DatasetVersion.py +49 -4
  142. phoenix/server/api/types/DocumentAnnotation.py +212 -0
  143. phoenix/server/api/types/Experiment.py +215 -68
  144. phoenix/server/api/types/ExperimentComparison.py +3 -9
  145. phoenix/server/api/types/ExperimentRepeatedRunGroup.py +155 -0
  146. phoenix/server/api/types/ExperimentRepeatedRunGroupAnnotationSummary.py +9 -0
  147. phoenix/server/api/types/ExperimentRun.py +120 -70
  148. phoenix/server/api/types/ExperimentRunAnnotation.py +158 -39
  149. phoenix/server/api/types/GenerativeModel.py +95 -42
  150. phoenix/server/api/types/GenerativeProvider.py +1 -1
  151. phoenix/server/api/types/ModelInterface.py +7 -2
  152. phoenix/server/api/types/PlaygroundModel.py +12 -2
  153. phoenix/server/api/types/Project.py +218 -185
  154. phoenix/server/api/types/ProjectSession.py +146 -29
  155. phoenix/server/api/types/ProjectSessionAnnotation.py +187 -0
  156. phoenix/server/api/types/ProjectTraceRetentionPolicy.py +1 -1
  157. phoenix/server/api/types/Prompt.py +119 -39
  158. phoenix/server/api/types/PromptLabel.py +42 -25
  159. phoenix/server/api/types/PromptVersion.py +11 -8
  160. phoenix/server/api/types/PromptVersionTag.py +65 -25
  161. phoenix/server/api/types/Span.py +130 -123
  162. phoenix/server/api/types/SpanAnnotation.py +189 -42
  163. phoenix/server/api/types/SystemApiKey.py +65 -1
  164. phoenix/server/api/types/Trace.py +184 -53
  165. phoenix/server/api/types/TraceAnnotation.py +149 -50
  166. phoenix/server/api/types/User.py +128 -33
  167. phoenix/server/api/types/UserApiKey.py +73 -26
  168. phoenix/server/api/types/node.py +10 -0
  169. phoenix/server/api/types/pagination.py +11 -2
  170. phoenix/server/app.py +154 -36
  171. phoenix/server/authorization.py +5 -4
  172. phoenix/server/bearer_auth.py +13 -5
  173. phoenix/server/cost_tracking/cost_model_lookup.py +42 -14
  174. phoenix/server/cost_tracking/model_cost_manifest.json +1085 -194
  175. phoenix/server/daemons/generative_model_store.py +61 -9
  176. phoenix/server/daemons/span_cost_calculator.py +10 -8
  177. phoenix/server/dml_event.py +13 -0
  178. phoenix/server/email/sender.py +29 -2
  179. phoenix/server/grpc_server.py +9 -9
  180. phoenix/server/jwt_store.py +8 -6
  181. phoenix/server/ldap.py +1449 -0
  182. phoenix/server/main.py +9 -3
  183. phoenix/server/oauth2.py +330 -12
  184. phoenix/server/prometheus.py +43 -6
  185. phoenix/server/rate_limiters.py +4 -9
  186. phoenix/server/retention.py +33 -20
  187. phoenix/server/session_filters.py +49 -0
  188. phoenix/server/static/.vite/manifest.json +51 -53
  189. phoenix/server/static/assets/components-BreFUQQa.js +6702 -0
  190. phoenix/server/static/assets/{index-BPCwGQr8.js → index-CTQoemZv.js} +42 -35
  191. phoenix/server/static/assets/pages-DBE5iYM3.js +9524 -0
  192. phoenix/server/static/assets/vendor-BGzfc4EU.css +1 -0
  193. phoenix/server/static/assets/vendor-DCE4v-Ot.js +920 -0
  194. phoenix/server/static/assets/vendor-codemirror-D5f205eT.js +25 -0
  195. phoenix/server/static/assets/{vendor-recharts-Bw30oz1A.js → vendor-recharts-V9cwpXsm.js} +7 -7
  196. phoenix/server/static/assets/{vendor-shiki-DZajAPeq.js → vendor-shiki-Do--csgv.js} +1 -1
  197. phoenix/server/static/assets/vendor-three-CmB8bl_y.js +3840 -0
  198. phoenix/server/templates/index.html +7 -1
  199. phoenix/server/thread_server.py +1 -2
  200. phoenix/server/utils.py +74 -0
  201. phoenix/session/client.py +55 -1
  202. phoenix/session/data_extractor.py +5 -0
  203. phoenix/session/evaluation.py +8 -4
  204. phoenix/session/session.py +44 -8
  205. phoenix/settings.py +2 -0
  206. phoenix/trace/attributes.py +80 -13
  207. phoenix/trace/dsl/query.py +2 -0
  208. phoenix/trace/projects.py +5 -0
  209. phoenix/utilities/template_formatters.py +1 -1
  210. phoenix/version.py +1 -1
  211. phoenix/server/api/types/Evaluation.py +0 -39
  212. phoenix/server/static/assets/components-D0DWAf0l.js +0 -5650
  213. phoenix/server/static/assets/pages-Creyamao.js +0 -8612
  214. phoenix/server/static/assets/vendor-CU36oj8y.js +0 -905
  215. phoenix/server/static/assets/vendor-CqDb5u4o.css +0 -1
  216. phoenix/server/static/assets/vendor-arizeai-Ctgw0e1G.js +0 -168
  217. phoenix/server/static/assets/vendor-codemirror-Cojjzqb9.js +0 -25
  218. phoenix/server/static/assets/vendor-three-BLWp5bic.js +0 -2998
  219. phoenix/utilities/deprecation.py +0 -31
  220. {arize_phoenix-11.23.1.dist-info → arize_phoenix-12.28.1.dist-info}/entry_points.txt +0 -0
  221. {arize_phoenix-11.23.1.dist-info → arize_phoenix-12.28.1.dist-info}/licenses/LICENSE +0 -0
@@ -1,18 +1,63 @@
1
1
  """
2
+ OpenTelemetry Span Attribute Flattening/Unflattening for Phoenix
3
+
4
+ This module handles the conversion between flattened dot-separated key-value pairs
5
+ (as received from OpenTelemetry protobuf) and nested dictionary structures (as used
6
+ internally by Phoenix).
7
+
8
+ Basic Behavior
9
+ --------------
2
10
  Span attribute keys have a special relationship with the `.` separator. When
3
11
  a span attribute is ingested from protobuf, it's in the form of a key value
4
- pair such as `("llm.token_count.completion", 123)`. What we need to do is to split
5
- the key by the `.` separator and turn it into part of a nested dictionary such
6
- as {"llm": {"token_count": {"completion": 123}}}. We also need to reverse this
7
- process, which is to flatten the nested dictionary into a list of key value
8
- pairs. This module provides functions to do both of these operations.
9
-
10
- Note that digit keys are treated as indices of a nested array. For example,
11
- the digits inside `("retrieval.documents.0.document.content", 'A')` and
12
- `("retrieval.documents.1.document.content": 'B')` turn the sub-keys following
13
- them into a nested list of dictionaries i.e.
14
- {`retrieval: {"documents": [{"document": {"content": "A"}}, {"document":
15
- {"content": "B"}}]}`.
12
+ pair such as `("llm.token_count.completion", 123)`. We split the key by the `.`
13
+ separator and turn it into a nested dictionary:
14
+ {"llm": {"token_count": {"completion": 123}}}
15
+
16
+ Array Creation Rule
17
+ -------------------
18
+ Numeric keys are treated specially to support array-like structures in OpenTelemetry
19
+ semantic conventions. A numeric key becomes an array index ONLY when:
20
+ 1. The numeric key has additional segments after it (e.g., "documents.0.content")
21
+ 2. Those segments lead to mappings (dictionaries), not scalar values
22
+
23
+ Examples:
24
+ ("documents.0.content", "A"), ("documents.1.content", "B")
25
+ → {"documents": [{"content": "A"}, {"content": "B"}]} # Array created
26
+
27
+ ("tags.0", "python"), ("tags.1", "ai")
28
+ → {"tags": {"0": "python", "1": "ai"}} # Dict with string keys, NOT array
29
+
30
+ Rationale: In OpenTelemetry semantic conventions, arrays typically contain structured
31
+ objects (like documents or events), not primitive values. This rule ensures that only
32
+ semantically meaningful arrays are created, avoiding ambiguity with numeric string keys.
33
+
34
+ Terminal Value Node Behavior
35
+ ----------------------------
36
+ When a path receives an explicit value (typically from pre-nested input), that node
37
+ becomes "terminal" and cannot have children added via flattened keys. Instead,
38
+ attempted extensions become separate dotted keys:
39
+
40
+ ("a", {"b": 1}), ("a.c", 2)
41
+ → {"a": {"b": 1}, "a.c": 2} # "a.c" becomes dotted key, not nested
42
+
43
+ This preserves all data during OpenTelemetry ingestion where:
44
+ - Pre-nested values (dicts/arrays) come from the OTEL data model
45
+ - Flattened keys come from custom instrumentation
46
+ - Both must be preserved to avoid data loss
47
+
48
+ Edge Cases
49
+ ----------
50
+ - None values: Skipped entirely during processing
51
+ - Leading zeros: Normalized ("00" → "0", treated as same key)
52
+ - Negative numbers: Treated as string keys, not array indices
53
+ - Empty key segments: Ignored ("a..b" → "a.b")
54
+ - Alphanumeric keys: "0a", "1x" are string keys, not array indices
55
+ - Whitespace: Stripped from key segments (" key " → "key")
56
+ - Empty string key: Valid key, preserved as-is
57
+ - Duplicate keys: Last write wins
58
+
59
+ These edge cases are handled consistently to ensure reliable round-tripping
60
+ between flattened and nested representations.
16
61
  """
17
62
 
18
63
  import inspect
@@ -107,6 +152,13 @@ def has_mapping(sequence: Iterable[Any]) -> bool:
107
152
  only contain primitive types, such as strings, integers, etc. Conversely,
108
153
  we'll only un-flatten digit sub-keys if it can be interpreted the index of
109
154
  an array of dictionaries.
155
+
156
+ This is the key function that implements the "arrays only for mappings" rule.
157
+ In OpenTelemetry semantic conventions, arrays typically contain structured
158
+ objects (e.g., retrieval.documents[0], llm.messages[1]) not primitive arrays
159
+ like ["tag1", "tag2"]. This check ensures semantic correctness during round-
160
+ trip conversions: primitive arrays stay as-is, only structured arrays are
161
+ flattened/unflattened with numeric indices.
110
162
  """
111
163
  for item in sequence:
112
164
  if isinstance(item, Mapping):
@@ -189,7 +241,9 @@ class _Trie(defaultdict[Union[str, int], "_Trie"]):
189
241
 
190
242
  def set_value(self, value: Any) -> None:
191
243
  self.value = value
192
- # value and indices must not coexist
244
+ # value and indices must not coexist - convert indices to branches
245
+ # This handles the case where a numeric key ends a path (scalar value)
246
+ # vs. continues a path (array index). Example: "a.0" vs "a.0.b"
193
247
  self.branches.update(self.indices)
194
248
  self.indices.clear()
195
249
 
@@ -230,8 +284,14 @@ def _build_trie(
230
284
  separator,
231
285
  prefix_exclusions,
232
286
  )
287
+ # Strip whitespace from key segments for cleaner attribute keys
288
+ prefix = prefix.strip()
233
289
  if prefix.isdigit():
234
290
  index = int(prefix)
291
+ # Key decision: numeric key with suffix → array index (add_index)
292
+ # numeric key without suffix → dict key (add_branch)
293
+ # This ensures arrays only contain mappings, not scalar values,
294
+ # matching OpenTelemetry semantic conventions.
235
295
  t = t.add_index(index) if suffix else t.add_branch(index)
236
296
  else:
237
297
  t = t.add_branch(prefix)
@@ -253,8 +313,15 @@ def _walk(
253
313
  yield the prefix and the value. If the Trie node has indices, then yield the
254
314
  prefix and a list of dictionaries. If the Trie node has branches, then yield
255
315
  the prefix and a dictionary.
316
+
317
+ Conflict Resolution: When a node has both a value and child nodes, both are
318
+ yielded. The value is yielded with its current prefix, and children create
319
+ additional dotted keys. This preserves all data from mixed flattened/nested
320
+ input, avoiding data loss during OpenTelemetry span ingestion.
256
321
  """
257
322
  if trie.value is not None:
323
+ # Yield the value first - if there are also branches, those will become
324
+ # separate dotted keys (e.g., "a" and "a.b" coexist)
258
325
  yield prefix, trie.value
259
326
  elif prefix and trie.indices:
260
327
  yield (
@@ -807,6 +807,8 @@ def _get_spans_dataframe(
807
807
  stmt = stmt.where(start_time <= models.Span.start_time)
808
808
  if end_time:
809
809
  stmt = stmt.where(models.Span.start_time < end_time)
810
+ # Default newest-first ordering by start_time, with id as a stable tiebreaker
811
+ stmt = stmt.order_by(models.Span.start_time.desc(), models.Span.id.desc())
810
812
  if root_spans_only:
811
813
  # A root span is either a span with no parent_id or an orphan span
812
814
  # (a span whose parent_id references a span that doesn't exist in the database)
phoenix/trace/projects.py CHANGED
@@ -5,6 +5,7 @@ from typing import Any, Optional
5
5
  from openinference.semconv.resource import ResourceAttributes
6
6
  from opentelemetry.sdk import trace
7
7
  from opentelemetry.sdk.resources import Resource
8
+ from typing_extensions import deprecated
8
9
  from wrapt import wrap_function_wrapper
9
10
 
10
11
 
@@ -27,6 +28,10 @@ def project_override_wrapper(project_name: str) -> Callable[..., None]:
27
28
  return wrapper
28
29
 
29
30
 
31
+ @deprecated(
32
+ "This decorator has been moved to openinference-instrumentation via dangerously_using_project"
33
+ " in version 0.1.38 and will be removed in an upcoming major release"
34
+ )
30
35
  class using_project:
31
36
  """
32
37
  A context manager that switches the project for all spans created within the context.
@@ -85,7 +85,7 @@ class MustacheTemplateFormatter(TemplateFormatter):
85
85
  for variable_name in variable_names:
86
86
  template = re.sub(
87
87
  pattern=rf"(?<!\\){{{{\s*{variable_name}\s*}}}}",
88
- repl=variables[variable_name],
88
+ repl=str(variables[variable_name]),
89
89
  string=template,
90
90
  )
91
91
  return template
phoenix/version.py CHANGED
@@ -1 +1 @@
1
- __version__ = "11.23.1"
1
+ __version__ = "12.28.1"
@@ -1,39 +0,0 @@
1
- import strawberry
2
-
3
- from phoenix.db.models import DocumentAnnotation, TraceAnnotation
4
-
5
- from .Annotation import Annotation
6
-
7
-
8
- @strawberry.type
9
- class TraceEvaluation(Annotation):
10
- @staticmethod
11
- def from_sql_trace_annotation(annotation: TraceAnnotation) -> "TraceEvaluation":
12
- return TraceEvaluation(
13
- name=annotation.name,
14
- score=annotation.score,
15
- label=annotation.label,
16
- explanation=annotation.explanation,
17
- created_at=annotation.created_at,
18
- updated_at=annotation.updated_at,
19
- )
20
-
21
-
22
- @strawberry.type
23
- class DocumentEvaluation(Annotation):
24
- document_position: int = strawberry.field(
25
- description="The zero-based index among retrieved documents, which "
26
- "is collected as a list (even when ordering is not inherently meaningful)."
27
- )
28
-
29
- @staticmethod
30
- def from_sql_document_annotation(annotation: DocumentAnnotation) -> "DocumentEvaluation":
31
- return DocumentEvaluation(
32
- name=annotation.name,
33
- score=annotation.score,
34
- label=annotation.label,
35
- explanation=annotation.explanation,
36
- document_position=annotation.document_position,
37
- created_at=annotation.created_at,
38
- updated_at=annotation.updated_at,
39
- )