arize-phoenix 4.14.1__py3-none-any.whl → 4.16.0__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.
Potentially problematic release.
This version of arize-phoenix might be problematic. Click here for more details.
- {arize_phoenix-4.14.1.dist-info → arize_phoenix-4.16.0.dist-info}/METADATA +5 -3
- {arize_phoenix-4.14.1.dist-info → arize_phoenix-4.16.0.dist-info}/RECORD +81 -71
- phoenix/db/bulk_inserter.py +131 -5
- phoenix/db/engines.py +2 -1
- phoenix/db/helpers.py +23 -1
- phoenix/db/insertion/constants.py +2 -0
- phoenix/db/insertion/document_annotation.py +157 -0
- phoenix/db/insertion/helpers.py +13 -0
- phoenix/db/insertion/span_annotation.py +144 -0
- phoenix/db/insertion/trace_annotation.py +144 -0
- phoenix/db/insertion/types.py +261 -0
- phoenix/experiments/functions.py +3 -2
- phoenix/experiments/types.py +3 -3
- phoenix/server/api/context.py +7 -9
- phoenix/server/api/dataloaders/__init__.py +2 -0
- phoenix/server/api/dataloaders/average_experiment_run_latency.py +3 -3
- phoenix/server/api/dataloaders/dataset_example_revisions.py +2 -4
- phoenix/server/api/dataloaders/dataset_example_spans.py +2 -4
- phoenix/server/api/dataloaders/document_evaluation_summaries.py +2 -4
- phoenix/server/api/dataloaders/document_evaluations.py +2 -4
- phoenix/server/api/dataloaders/document_retrieval_metrics.py +2 -4
- phoenix/server/api/dataloaders/evaluation_summaries.py +2 -4
- phoenix/server/api/dataloaders/experiment_annotation_summaries.py +2 -4
- phoenix/server/api/dataloaders/experiment_error_rates.py +2 -4
- phoenix/server/api/dataloaders/experiment_run_counts.py +2 -4
- phoenix/server/api/dataloaders/experiment_sequence_number.py +2 -4
- phoenix/server/api/dataloaders/latency_ms_quantile.py +2 -3
- phoenix/server/api/dataloaders/min_start_or_max_end_times.py +2 -4
- phoenix/server/api/dataloaders/project_by_name.py +3 -3
- phoenix/server/api/dataloaders/record_counts.py +2 -4
- phoenix/server/api/dataloaders/span_annotations.py +2 -4
- phoenix/server/api/dataloaders/span_dataset_examples.py +36 -0
- phoenix/server/api/dataloaders/span_descendants.py +2 -4
- phoenix/server/api/dataloaders/span_evaluations.py +2 -4
- phoenix/server/api/dataloaders/span_projects.py +3 -3
- phoenix/server/api/dataloaders/token_counts.py +2 -4
- phoenix/server/api/dataloaders/trace_evaluations.py +2 -4
- phoenix/server/api/dataloaders/trace_row_ids.py +2 -4
- phoenix/server/api/input_types/SpanAnnotationSort.py +17 -0
- phoenix/server/api/input_types/TraceAnnotationSort.py +17 -0
- phoenix/server/api/mutations/span_annotations_mutations.py +8 -3
- phoenix/server/api/mutations/trace_annotations_mutations.py +8 -3
- phoenix/server/api/openapi/main.py +18 -2
- phoenix/server/api/openapi/schema.py +12 -12
- phoenix/server/api/routers/v1/__init__.py +36 -83
- phoenix/server/api/routers/v1/datasets.py +515 -509
- phoenix/server/api/routers/v1/evaluations.py +164 -73
- phoenix/server/api/routers/v1/experiment_evaluations.py +68 -91
- phoenix/server/api/routers/v1/experiment_runs.py +98 -155
- phoenix/server/api/routers/v1/experiments.py +132 -181
- phoenix/server/api/routers/v1/pydantic_compat.py +78 -0
- phoenix/server/api/routers/v1/spans.py +164 -203
- phoenix/server/api/routers/v1/traces.py +134 -159
- phoenix/server/api/routers/v1/utils.py +95 -0
- phoenix/server/api/types/Span.py +27 -3
- phoenix/server/api/types/Trace.py +21 -4
- phoenix/server/api/utils.py +4 -4
- phoenix/server/app.py +172 -192
- phoenix/server/grpc_server.py +2 -2
- phoenix/server/main.py +5 -9
- phoenix/server/static/.vite/manifest.json +31 -31
- phoenix/server/static/assets/components-Ci5kMOk5.js +1175 -0
- phoenix/server/static/assets/{index-CQgXRwU0.js → index-BQG5WVX7.js} +2 -2
- phoenix/server/static/assets/{pages-hdjlFZhO.js → pages-BrevprVW.js} +451 -275
- phoenix/server/static/assets/{vendor-DPvSDRn3.js → vendor-CP0b0YG0.js} +2 -2
- phoenix/server/static/assets/{vendor-arizeai-CkvPT67c.js → vendor-arizeai-DTbiPGp6.js} +27 -27
- phoenix/server/static/assets/vendor-codemirror-DtdPDzrv.js +15 -0
- phoenix/server/static/assets/{vendor-recharts-5jlNaZuF.js → vendor-recharts-A0DA1O99.js} +1 -1
- phoenix/server/thread_server.py +2 -2
- phoenix/server/types.py +18 -0
- phoenix/session/client.py +5 -3
- phoenix/session/session.py +2 -2
- phoenix/trace/dsl/filter.py +2 -6
- phoenix/trace/fixtures.py +17 -23
- phoenix/trace/utils.py +23 -0
- phoenix/utilities/client.py +116 -0
- phoenix/utilities/project.py +1 -1
- phoenix/version.py +1 -1
- phoenix/server/api/routers/v1/dataset_examples.py +0 -178
- phoenix/server/openapi/docs.py +0 -221
- phoenix/server/static/assets/components-DeS0YEmv.js +0 -1142
- phoenix/server/static/assets/vendor-codemirror-Cqwpwlua.js +0 -12
- {arize_phoenix-4.14.1.dist-info → arize_phoenix-4.16.0.dist-info}/WHEEL +0 -0
- {arize_phoenix-4.14.1.dist-info → arize_phoenix-4.16.0.dist-info}/licenses/IP_NOTICE +0 -0
- {arize_phoenix-4.14.1.dist-info → arize_phoenix-4.16.0.dist-info}/licenses/LICENSE +0 -0
|
@@ -1,89 +1,42 @@
|
|
|
1
|
-
from
|
|
2
|
-
|
|
3
|
-
import wrapt
|
|
4
|
-
from starlette import routing
|
|
5
|
-
from starlette.requests import Request
|
|
6
|
-
from starlette.responses import Response
|
|
1
|
+
from fastapi import APIRouter, Depends, HTTPException, Request
|
|
7
2
|
from starlette.status import HTTP_403_FORBIDDEN
|
|
8
3
|
|
|
9
|
-
from . import
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
)
|
|
18
|
-
from .dataset_examples import list_dataset_examples
|
|
19
|
-
|
|
4
|
+
from .datasets import router as datasets_router
|
|
5
|
+
from .evaluations import router as evaluations_router
|
|
6
|
+
from .experiment_evaluations import router as experiment_evaluations_router
|
|
7
|
+
from .experiment_runs import router as experiment_runs_router
|
|
8
|
+
from .experiments import router as experiments_router
|
|
9
|
+
from .spans import router as spans_router
|
|
10
|
+
from .traces import router as traces_router
|
|
11
|
+
from .utils import add_errors_to_responses
|
|
20
12
|
|
|
21
|
-
|
|
22
|
-
async def forbid_if_readonly(
|
|
23
|
-
wrapped: Callable[[Request], Awaitable[Response]],
|
|
24
|
-
_: Any,
|
|
25
|
-
args: Tuple[Request],
|
|
26
|
-
kwargs: Mapping[str, Any],
|
|
27
|
-
) -> Response:
|
|
28
|
-
request, *_ = args
|
|
29
|
-
if request.app.state.read_only:
|
|
30
|
-
return Response(status_code=HTTP_403_FORBIDDEN)
|
|
31
|
-
return await wrapped(*args, **kwargs)
|
|
13
|
+
REST_API_VERSION = "1.0"
|
|
32
14
|
|
|
33
15
|
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
Route(
|
|
53
|
-
"/v1/datasets/{id:str}/jsonl/openai_ft",
|
|
54
|
-
datasets.get_dataset_jsonl_openai_ft,
|
|
55
|
-
methods=["GET"],
|
|
56
|
-
),
|
|
57
|
-
Route(
|
|
58
|
-
"/v1/datasets/{id:str}/jsonl/openai_evals",
|
|
59
|
-
datasets.get_dataset_jsonl_openai_evals,
|
|
60
|
-
methods=["GET"],
|
|
61
|
-
),
|
|
62
|
-
Route("/v1/datasets/{id:str}/examples", list_dataset_examples, methods=["GET"]),
|
|
63
|
-
Route("/v1/datasets/{id:str}/versions", datasets.get_dataset_versions, methods=["GET"]),
|
|
64
|
-
Route(
|
|
65
|
-
"/v1/datasets/{dataset_id:str}/experiments",
|
|
66
|
-
experiments.create_experiment,
|
|
67
|
-
methods=["POST"],
|
|
68
|
-
),
|
|
69
|
-
Route(
|
|
70
|
-
"/v1/experiments/{experiment_id:str}",
|
|
71
|
-
experiments.read_experiment,
|
|
72
|
-
methods=["GET"],
|
|
73
|
-
),
|
|
74
|
-
Route(
|
|
75
|
-
"/v1/experiments/{experiment_id:str}/runs",
|
|
76
|
-
experiment_runs.create_experiment_run,
|
|
77
|
-
methods=["POST"],
|
|
78
|
-
),
|
|
79
|
-
Route(
|
|
80
|
-
"/v1/experiments/{experiment_id:str}/runs",
|
|
81
|
-
experiment_runs.list_experiment_runs,
|
|
82
|
-
methods=["GET"],
|
|
83
|
-
),
|
|
84
|
-
Route(
|
|
85
|
-
"/v1/experiment_evaluations",
|
|
86
|
-
experiment_evaluations.upsert_experiment_evaluation,
|
|
87
|
-
methods=["POST"],
|
|
16
|
+
async def prevent_access_in_read_only_mode(request: Request) -> None:
|
|
17
|
+
"""
|
|
18
|
+
Prevents access to the REST API in read-only mode.
|
|
19
|
+
"""
|
|
20
|
+
if request.app.state.read_only:
|
|
21
|
+
raise HTTPException(
|
|
22
|
+
detail="The Phoenix REST API is disabled in read-only mode.",
|
|
23
|
+
status_code=HTTP_403_FORBIDDEN,
|
|
24
|
+
)
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
router = APIRouter(
|
|
28
|
+
prefix="/v1",
|
|
29
|
+
dependencies=[Depends(prevent_access_in_read_only_mode)],
|
|
30
|
+
responses=add_errors_to_responses(
|
|
31
|
+
[
|
|
32
|
+
HTTP_403_FORBIDDEN # adds a 403 response to each route in the generated OpenAPI schema
|
|
33
|
+
]
|
|
88
34
|
),
|
|
89
|
-
|
|
35
|
+
)
|
|
36
|
+
router.include_router(datasets_router)
|
|
37
|
+
router.include_router(experiments_router)
|
|
38
|
+
router.include_router(experiment_runs_router)
|
|
39
|
+
router.include_router(experiment_evaluations_router)
|
|
40
|
+
router.include_router(traces_router)
|
|
41
|
+
router.include_router(spans_router)
|
|
42
|
+
router.include_router(evaluations_router)
|