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.
- {arize_phoenix-11.23.1.dist-info → arize_phoenix-12.28.1.dist-info}/METADATA +61 -36
- {arize_phoenix-11.23.1.dist-info → arize_phoenix-12.28.1.dist-info}/RECORD +212 -162
- {arize_phoenix-11.23.1.dist-info → arize_phoenix-12.28.1.dist-info}/WHEEL +1 -1
- {arize_phoenix-11.23.1.dist-info → arize_phoenix-12.28.1.dist-info}/licenses/IP_NOTICE +1 -1
- phoenix/__generated__/__init__.py +0 -0
- phoenix/__generated__/classification_evaluator_configs/__init__.py +20 -0
- phoenix/__generated__/classification_evaluator_configs/_document_relevance_classification_evaluator_config.py +17 -0
- phoenix/__generated__/classification_evaluator_configs/_hallucination_classification_evaluator_config.py +17 -0
- phoenix/__generated__/classification_evaluator_configs/_models.py +18 -0
- phoenix/__generated__/classification_evaluator_configs/_tool_selection_classification_evaluator_config.py +17 -0
- phoenix/__init__.py +2 -1
- phoenix/auth.py +27 -2
- phoenix/config.py +1594 -81
- phoenix/db/README.md +546 -28
- phoenix/db/bulk_inserter.py +119 -116
- phoenix/db/engines.py +140 -33
- phoenix/db/facilitator.py +22 -1
- phoenix/db/helpers.py +818 -65
- phoenix/db/iam_auth.py +64 -0
- phoenix/db/insertion/dataset.py +133 -1
- phoenix/db/insertion/document_annotation.py +9 -6
- phoenix/db/insertion/evaluation.py +2 -3
- phoenix/db/insertion/helpers.py +2 -2
- phoenix/db/insertion/session_annotation.py +176 -0
- phoenix/db/insertion/span_annotation.py +3 -4
- phoenix/db/insertion/trace_annotation.py +3 -4
- phoenix/db/insertion/types.py +41 -18
- phoenix/db/migrations/versions/01a8342c9cdf_add_user_id_on_datasets.py +40 -0
- phoenix/db/migrations/versions/0df286449799_add_session_annotations_table.py +105 -0
- phoenix/db/migrations/versions/272b66ff50f8_drop_single_indices.py +119 -0
- phoenix/db/migrations/versions/58228d933c91_dataset_labels.py +67 -0
- phoenix/db/migrations/versions/699f655af132_experiment_tags.py +57 -0
- phoenix/db/migrations/versions/735d3d93c33e_add_composite_indices.py +41 -0
- phoenix/db/migrations/versions/ab513d89518b_add_user_id_on_dataset_versions.py +40 -0
- phoenix/db/migrations/versions/d0690a79ea51_users_on_experiments.py +40 -0
- phoenix/db/migrations/versions/deb2c81c0bb2_dataset_splits.py +139 -0
- phoenix/db/migrations/versions/e76cbd66ffc3_add_experiments_dataset_examples.py +87 -0
- phoenix/db/models.py +364 -56
- phoenix/db/pg_config.py +10 -0
- phoenix/db/types/trace_retention.py +7 -6
- phoenix/experiments/functions.py +69 -19
- phoenix/inferences/inferences.py +1 -2
- phoenix/server/api/auth.py +9 -0
- phoenix/server/api/auth_messages.py +46 -0
- phoenix/server/api/context.py +60 -0
- phoenix/server/api/dataloaders/__init__.py +36 -0
- phoenix/server/api/dataloaders/annotation_summaries.py +60 -8
- phoenix/server/api/dataloaders/average_experiment_repeated_run_group_latency.py +50 -0
- phoenix/server/api/dataloaders/average_experiment_run_latency.py +17 -24
- phoenix/server/api/dataloaders/cache/two_tier_cache.py +1 -2
- phoenix/server/api/dataloaders/dataset_dataset_splits.py +52 -0
- phoenix/server/api/dataloaders/dataset_example_revisions.py +0 -1
- phoenix/server/api/dataloaders/dataset_example_splits.py +40 -0
- phoenix/server/api/dataloaders/dataset_examples_and_versions_by_experiment_run.py +47 -0
- phoenix/server/api/dataloaders/dataset_labels.py +36 -0
- phoenix/server/api/dataloaders/document_evaluation_summaries.py +2 -2
- phoenix/server/api/dataloaders/document_evaluations.py +6 -9
- phoenix/server/api/dataloaders/experiment_annotation_summaries.py +88 -34
- phoenix/server/api/dataloaders/experiment_dataset_splits.py +43 -0
- phoenix/server/api/dataloaders/experiment_error_rates.py +21 -28
- phoenix/server/api/dataloaders/experiment_repeated_run_group_annotation_summaries.py +77 -0
- phoenix/server/api/dataloaders/experiment_repeated_run_groups.py +57 -0
- phoenix/server/api/dataloaders/experiment_runs_by_experiment_and_example.py +44 -0
- phoenix/server/api/dataloaders/latency_ms_quantile.py +40 -8
- phoenix/server/api/dataloaders/record_counts.py +37 -10
- phoenix/server/api/dataloaders/session_annotations_by_session.py +29 -0
- phoenix/server/api/dataloaders/span_cost_summary_by_experiment_repeated_run_group.py +64 -0
- phoenix/server/api/dataloaders/span_cost_summary_by_project.py +28 -14
- phoenix/server/api/dataloaders/span_costs.py +3 -9
- phoenix/server/api/dataloaders/table_fields.py +2 -2
- phoenix/server/api/dataloaders/token_prices_by_model.py +30 -0
- phoenix/server/api/dataloaders/trace_annotations_by_trace.py +27 -0
- phoenix/server/api/exceptions.py +5 -1
- phoenix/server/api/helpers/playground_clients.py +263 -83
- phoenix/server/api/helpers/playground_spans.py +2 -1
- phoenix/server/api/helpers/playground_users.py +26 -0
- phoenix/server/api/helpers/prompts/conversions/google.py +103 -0
- phoenix/server/api/helpers/prompts/models.py +61 -19
- phoenix/server/api/input_types/{SpanAnnotationFilter.py → AnnotationFilter.py} +22 -14
- phoenix/server/api/input_types/ChatCompletionInput.py +3 -0
- phoenix/server/api/input_types/CreateProjectSessionAnnotationInput.py +37 -0
- phoenix/server/api/input_types/DatasetFilter.py +5 -2
- phoenix/server/api/input_types/ExperimentRunSort.py +237 -0
- phoenix/server/api/input_types/GenerativeModelInput.py +3 -0
- phoenix/server/api/input_types/ProjectSessionSort.py +158 -1
- phoenix/server/api/input_types/PromptVersionInput.py +47 -1
- phoenix/server/api/input_types/SpanSort.py +3 -2
- phoenix/server/api/input_types/UpdateAnnotationInput.py +34 -0
- phoenix/server/api/input_types/UserRoleInput.py +1 -0
- phoenix/server/api/mutations/__init__.py +8 -0
- phoenix/server/api/mutations/annotation_config_mutations.py +8 -8
- phoenix/server/api/mutations/api_key_mutations.py +15 -20
- phoenix/server/api/mutations/chat_mutations.py +106 -37
- phoenix/server/api/mutations/dataset_label_mutations.py +243 -0
- phoenix/server/api/mutations/dataset_mutations.py +21 -16
- phoenix/server/api/mutations/dataset_split_mutations.py +351 -0
- phoenix/server/api/mutations/experiment_mutations.py +2 -2
- phoenix/server/api/mutations/export_events_mutations.py +3 -3
- phoenix/server/api/mutations/model_mutations.py +11 -9
- phoenix/server/api/mutations/project_mutations.py +4 -4
- phoenix/server/api/mutations/project_session_annotations_mutations.py +158 -0
- phoenix/server/api/mutations/project_trace_retention_policy_mutations.py +8 -4
- phoenix/server/api/mutations/prompt_label_mutations.py +74 -65
- phoenix/server/api/mutations/prompt_mutations.py +65 -129
- phoenix/server/api/mutations/prompt_version_tag_mutations.py +11 -8
- phoenix/server/api/mutations/span_annotations_mutations.py +15 -10
- phoenix/server/api/mutations/trace_annotations_mutations.py +13 -8
- phoenix/server/api/mutations/trace_mutations.py +3 -3
- phoenix/server/api/mutations/user_mutations.py +55 -26
- phoenix/server/api/queries.py +501 -617
- phoenix/server/api/routers/__init__.py +2 -2
- phoenix/server/api/routers/auth.py +141 -87
- phoenix/server/api/routers/ldap.py +229 -0
- phoenix/server/api/routers/oauth2.py +349 -101
- phoenix/server/api/routers/v1/__init__.py +22 -4
- phoenix/server/api/routers/v1/annotation_configs.py +19 -30
- phoenix/server/api/routers/v1/annotations.py +455 -13
- phoenix/server/api/routers/v1/datasets.py +355 -68
- phoenix/server/api/routers/v1/documents.py +142 -0
- phoenix/server/api/routers/v1/evaluations.py +20 -28
- phoenix/server/api/routers/v1/experiment_evaluations.py +16 -6
- phoenix/server/api/routers/v1/experiment_runs.py +335 -59
- phoenix/server/api/routers/v1/experiments.py +475 -47
- phoenix/server/api/routers/v1/projects.py +16 -50
- phoenix/server/api/routers/v1/prompts.py +50 -39
- phoenix/server/api/routers/v1/sessions.py +108 -0
- phoenix/server/api/routers/v1/spans.py +156 -96
- phoenix/server/api/routers/v1/traces.py +51 -77
- phoenix/server/api/routers/v1/users.py +64 -24
- phoenix/server/api/routers/v1/utils.py +3 -7
- phoenix/server/api/subscriptions.py +257 -93
- phoenix/server/api/types/Annotation.py +90 -23
- phoenix/server/api/types/ApiKey.py +13 -17
- phoenix/server/api/types/AuthMethod.py +1 -0
- phoenix/server/api/types/ChatCompletionSubscriptionPayload.py +1 -0
- phoenix/server/api/types/Dataset.py +199 -72
- phoenix/server/api/types/DatasetExample.py +88 -18
- phoenix/server/api/types/DatasetExperimentAnnotationSummary.py +10 -0
- phoenix/server/api/types/DatasetLabel.py +57 -0
- phoenix/server/api/types/DatasetSplit.py +98 -0
- phoenix/server/api/types/DatasetVersion.py +49 -4
- phoenix/server/api/types/DocumentAnnotation.py +212 -0
- phoenix/server/api/types/Experiment.py +215 -68
- phoenix/server/api/types/ExperimentComparison.py +3 -9
- phoenix/server/api/types/ExperimentRepeatedRunGroup.py +155 -0
- phoenix/server/api/types/ExperimentRepeatedRunGroupAnnotationSummary.py +9 -0
- phoenix/server/api/types/ExperimentRun.py +120 -70
- phoenix/server/api/types/ExperimentRunAnnotation.py +158 -39
- phoenix/server/api/types/GenerativeModel.py +95 -42
- phoenix/server/api/types/GenerativeProvider.py +1 -1
- phoenix/server/api/types/ModelInterface.py +7 -2
- phoenix/server/api/types/PlaygroundModel.py +12 -2
- phoenix/server/api/types/Project.py +218 -185
- phoenix/server/api/types/ProjectSession.py +146 -29
- phoenix/server/api/types/ProjectSessionAnnotation.py +187 -0
- phoenix/server/api/types/ProjectTraceRetentionPolicy.py +1 -1
- phoenix/server/api/types/Prompt.py +119 -39
- phoenix/server/api/types/PromptLabel.py +42 -25
- phoenix/server/api/types/PromptVersion.py +11 -8
- phoenix/server/api/types/PromptVersionTag.py +65 -25
- phoenix/server/api/types/Span.py +130 -123
- phoenix/server/api/types/SpanAnnotation.py +189 -42
- phoenix/server/api/types/SystemApiKey.py +65 -1
- phoenix/server/api/types/Trace.py +184 -53
- phoenix/server/api/types/TraceAnnotation.py +149 -50
- phoenix/server/api/types/User.py +128 -33
- phoenix/server/api/types/UserApiKey.py +73 -26
- phoenix/server/api/types/node.py +10 -0
- phoenix/server/api/types/pagination.py +11 -2
- phoenix/server/app.py +154 -36
- phoenix/server/authorization.py +5 -4
- phoenix/server/bearer_auth.py +13 -5
- phoenix/server/cost_tracking/cost_model_lookup.py +42 -14
- phoenix/server/cost_tracking/model_cost_manifest.json +1085 -194
- phoenix/server/daemons/generative_model_store.py +61 -9
- phoenix/server/daemons/span_cost_calculator.py +10 -8
- phoenix/server/dml_event.py +13 -0
- phoenix/server/email/sender.py +29 -2
- phoenix/server/grpc_server.py +9 -9
- phoenix/server/jwt_store.py +8 -6
- phoenix/server/ldap.py +1449 -0
- phoenix/server/main.py +9 -3
- phoenix/server/oauth2.py +330 -12
- phoenix/server/prometheus.py +43 -6
- phoenix/server/rate_limiters.py +4 -9
- phoenix/server/retention.py +33 -20
- phoenix/server/session_filters.py +49 -0
- phoenix/server/static/.vite/manifest.json +51 -53
- phoenix/server/static/assets/components-BreFUQQa.js +6702 -0
- phoenix/server/static/assets/{index-BPCwGQr8.js → index-CTQoemZv.js} +42 -35
- phoenix/server/static/assets/pages-DBE5iYM3.js +9524 -0
- phoenix/server/static/assets/vendor-BGzfc4EU.css +1 -0
- phoenix/server/static/assets/vendor-DCE4v-Ot.js +920 -0
- phoenix/server/static/assets/vendor-codemirror-D5f205eT.js +25 -0
- phoenix/server/static/assets/{vendor-recharts-Bw30oz1A.js → vendor-recharts-V9cwpXsm.js} +7 -7
- phoenix/server/static/assets/{vendor-shiki-DZajAPeq.js → vendor-shiki-Do--csgv.js} +1 -1
- phoenix/server/static/assets/vendor-three-CmB8bl_y.js +3840 -0
- phoenix/server/templates/index.html +7 -1
- phoenix/server/thread_server.py +1 -2
- phoenix/server/utils.py +74 -0
- phoenix/session/client.py +55 -1
- phoenix/session/data_extractor.py +5 -0
- phoenix/session/evaluation.py +8 -4
- phoenix/session/session.py +44 -8
- phoenix/settings.py +2 -0
- phoenix/trace/attributes.py +80 -13
- phoenix/trace/dsl/query.py +2 -0
- phoenix/trace/projects.py +5 -0
- phoenix/utilities/template_formatters.py +1 -1
- phoenix/version.py +1 -1
- phoenix/server/api/types/Evaluation.py +0 -39
- phoenix/server/static/assets/components-D0DWAf0l.js +0 -5650
- phoenix/server/static/assets/pages-Creyamao.js +0 -8612
- phoenix/server/static/assets/vendor-CU36oj8y.js +0 -905
- phoenix/server/static/assets/vendor-CqDb5u4o.css +0 -1
- phoenix/server/static/assets/vendor-arizeai-Ctgw0e1G.js +0 -168
- phoenix/server/static/assets/vendor-codemirror-Cojjzqb9.js +0 -25
- phoenix/server/static/assets/vendor-three-BLWp5bic.js +0 -2998
- phoenix/utilities/deprecation.py +0 -31
- {arize_phoenix-11.23.1.dist-info → arize_phoenix-12.28.1.dist-info}/entry_points.txt +0 -0
- {arize_phoenix-11.23.1.dist-info → arize_phoenix-12.28.1.dist-info}/licenses/LICENSE +0 -0
phoenix/trace/attributes.py
CHANGED
|
@@ -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)`.
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
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 (
|
phoenix/trace/dsl/query.py
CHANGED
|
@@ -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__ = "
|
|
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
|
-
)
|