arize-phoenix 10.0.4__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 (276) hide show
  1. {arize_phoenix-10.0.4.dist-info → arize_phoenix-12.28.1.dist-info}/METADATA +124 -72
  2. arize_phoenix-12.28.1.dist-info/RECORD +499 -0
  3. {arize_phoenix-10.0.4.dist-info → arize_phoenix-12.28.1.dist-info}/WHEEL +1 -1
  4. {arize_phoenix-10.0.4.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 +5 -4
  12. phoenix/auth.py +39 -2
  13. phoenix/config.py +1763 -91
  14. phoenix/datetime_utils.py +120 -2
  15. phoenix/db/README.md +595 -25
  16. phoenix/db/bulk_inserter.py +145 -103
  17. phoenix/db/engines.py +140 -33
  18. phoenix/db/enums.py +3 -12
  19. phoenix/db/facilitator.py +302 -35
  20. phoenix/db/helpers.py +1000 -65
  21. phoenix/db/iam_auth.py +64 -0
  22. phoenix/db/insertion/dataset.py +135 -2
  23. phoenix/db/insertion/document_annotation.py +9 -6
  24. phoenix/db/insertion/evaluation.py +2 -3
  25. phoenix/db/insertion/helpers.py +17 -2
  26. phoenix/db/insertion/session_annotation.py +176 -0
  27. phoenix/db/insertion/span.py +15 -11
  28. phoenix/db/insertion/span_annotation.py +3 -4
  29. phoenix/db/insertion/trace_annotation.py +3 -4
  30. phoenix/db/insertion/types.py +50 -20
  31. phoenix/db/migrations/versions/01a8342c9cdf_add_user_id_on_datasets.py +40 -0
  32. phoenix/db/migrations/versions/0df286449799_add_session_annotations_table.py +105 -0
  33. phoenix/db/migrations/versions/272b66ff50f8_drop_single_indices.py +119 -0
  34. phoenix/db/migrations/versions/58228d933c91_dataset_labels.py +67 -0
  35. phoenix/db/migrations/versions/699f655af132_experiment_tags.py +57 -0
  36. phoenix/db/migrations/versions/735d3d93c33e_add_composite_indices.py +41 -0
  37. phoenix/db/migrations/versions/a20694b15f82_cost.py +196 -0
  38. phoenix/db/migrations/versions/ab513d89518b_add_user_id_on_dataset_versions.py +40 -0
  39. phoenix/db/migrations/versions/d0690a79ea51_users_on_experiments.py +40 -0
  40. phoenix/db/migrations/versions/deb2c81c0bb2_dataset_splits.py +139 -0
  41. phoenix/db/migrations/versions/e76cbd66ffc3_add_experiments_dataset_examples.py +87 -0
  42. phoenix/db/models.py +669 -56
  43. phoenix/db/pg_config.py +10 -0
  44. phoenix/db/types/model_provider.py +4 -0
  45. phoenix/db/types/token_price_customization.py +29 -0
  46. phoenix/db/types/trace_retention.py +23 -15
  47. phoenix/experiments/evaluators/utils.py +3 -3
  48. phoenix/experiments/functions.py +160 -52
  49. phoenix/experiments/tracing.py +2 -2
  50. phoenix/experiments/types.py +1 -1
  51. phoenix/inferences/inferences.py +1 -2
  52. phoenix/server/api/auth.py +38 -7
  53. phoenix/server/api/auth_messages.py +46 -0
  54. phoenix/server/api/context.py +100 -4
  55. phoenix/server/api/dataloaders/__init__.py +79 -5
  56. phoenix/server/api/dataloaders/annotation_configs_by_project.py +31 -0
  57. phoenix/server/api/dataloaders/annotation_summaries.py +60 -8
  58. phoenix/server/api/dataloaders/average_experiment_repeated_run_group_latency.py +50 -0
  59. phoenix/server/api/dataloaders/average_experiment_run_latency.py +17 -24
  60. phoenix/server/api/dataloaders/cache/two_tier_cache.py +1 -2
  61. phoenix/server/api/dataloaders/dataset_dataset_splits.py +52 -0
  62. phoenix/server/api/dataloaders/dataset_example_revisions.py +0 -1
  63. phoenix/server/api/dataloaders/dataset_example_splits.py +40 -0
  64. phoenix/server/api/dataloaders/dataset_examples_and_versions_by_experiment_run.py +47 -0
  65. phoenix/server/api/dataloaders/dataset_labels.py +36 -0
  66. phoenix/server/api/dataloaders/document_evaluation_summaries.py +2 -2
  67. phoenix/server/api/dataloaders/document_evaluations.py +6 -9
  68. phoenix/server/api/dataloaders/experiment_annotation_summaries.py +88 -34
  69. phoenix/server/api/dataloaders/experiment_dataset_splits.py +43 -0
  70. phoenix/server/api/dataloaders/experiment_error_rates.py +21 -28
  71. phoenix/server/api/dataloaders/experiment_repeated_run_group_annotation_summaries.py +77 -0
  72. phoenix/server/api/dataloaders/experiment_repeated_run_groups.py +57 -0
  73. phoenix/server/api/dataloaders/experiment_runs_by_experiment_and_example.py +44 -0
  74. phoenix/server/api/dataloaders/last_used_times_by_generative_model_id.py +35 -0
  75. phoenix/server/api/dataloaders/latency_ms_quantile.py +40 -8
  76. phoenix/server/api/dataloaders/record_counts.py +37 -10
  77. phoenix/server/api/dataloaders/session_annotations_by_session.py +29 -0
  78. phoenix/server/api/dataloaders/span_cost_by_span.py +24 -0
  79. phoenix/server/api/dataloaders/span_cost_detail_summary_entries_by_generative_model.py +56 -0
  80. phoenix/server/api/dataloaders/span_cost_detail_summary_entries_by_project_session.py +57 -0
  81. phoenix/server/api/dataloaders/span_cost_detail_summary_entries_by_span.py +43 -0
  82. phoenix/server/api/dataloaders/span_cost_detail_summary_entries_by_trace.py +56 -0
  83. phoenix/server/api/dataloaders/span_cost_details_by_span_cost.py +27 -0
  84. phoenix/server/api/dataloaders/span_cost_summary_by_experiment.py +57 -0
  85. phoenix/server/api/dataloaders/span_cost_summary_by_experiment_repeated_run_group.py +64 -0
  86. phoenix/server/api/dataloaders/span_cost_summary_by_experiment_run.py +58 -0
  87. phoenix/server/api/dataloaders/span_cost_summary_by_generative_model.py +55 -0
  88. phoenix/server/api/dataloaders/span_cost_summary_by_project.py +152 -0
  89. phoenix/server/api/dataloaders/span_cost_summary_by_project_session.py +56 -0
  90. phoenix/server/api/dataloaders/span_cost_summary_by_trace.py +55 -0
  91. phoenix/server/api/dataloaders/span_costs.py +29 -0
  92. phoenix/server/api/dataloaders/table_fields.py +2 -2
  93. phoenix/server/api/dataloaders/token_prices_by_model.py +30 -0
  94. phoenix/server/api/dataloaders/trace_annotations_by_trace.py +27 -0
  95. phoenix/server/api/dataloaders/types.py +29 -0
  96. phoenix/server/api/exceptions.py +11 -1
  97. phoenix/server/api/helpers/dataset_helpers.py +5 -1
  98. phoenix/server/api/helpers/playground_clients.py +1243 -292
  99. phoenix/server/api/helpers/playground_registry.py +2 -2
  100. phoenix/server/api/helpers/playground_spans.py +8 -4
  101. phoenix/server/api/helpers/playground_users.py +26 -0
  102. phoenix/server/api/helpers/prompts/conversions/aws.py +83 -0
  103. phoenix/server/api/helpers/prompts/conversions/google.py +103 -0
  104. phoenix/server/api/helpers/prompts/models.py +205 -22
  105. phoenix/server/api/input_types/{SpanAnnotationFilter.py → AnnotationFilter.py} +22 -14
  106. phoenix/server/api/input_types/ChatCompletionInput.py +6 -2
  107. phoenix/server/api/input_types/CreateProjectInput.py +27 -0
  108. phoenix/server/api/input_types/CreateProjectSessionAnnotationInput.py +37 -0
  109. phoenix/server/api/input_types/DatasetFilter.py +17 -0
  110. phoenix/server/api/input_types/ExperimentRunSort.py +237 -0
  111. phoenix/server/api/input_types/GenerativeCredentialInput.py +9 -0
  112. phoenix/server/api/input_types/GenerativeModelInput.py +5 -0
  113. phoenix/server/api/input_types/ProjectSessionSort.py +161 -1
  114. phoenix/server/api/input_types/PromptFilter.py +14 -0
  115. phoenix/server/api/input_types/PromptVersionInput.py +52 -1
  116. phoenix/server/api/input_types/SpanSort.py +44 -7
  117. phoenix/server/api/input_types/TimeBinConfig.py +23 -0
  118. phoenix/server/api/input_types/UpdateAnnotationInput.py +34 -0
  119. phoenix/server/api/input_types/UserRoleInput.py +1 -0
  120. phoenix/server/api/mutations/__init__.py +10 -0
  121. phoenix/server/api/mutations/annotation_config_mutations.py +8 -8
  122. phoenix/server/api/mutations/api_key_mutations.py +19 -23
  123. phoenix/server/api/mutations/chat_mutations.py +154 -47
  124. phoenix/server/api/mutations/dataset_label_mutations.py +243 -0
  125. phoenix/server/api/mutations/dataset_mutations.py +21 -16
  126. phoenix/server/api/mutations/dataset_split_mutations.py +351 -0
  127. phoenix/server/api/mutations/experiment_mutations.py +2 -2
  128. phoenix/server/api/mutations/export_events_mutations.py +3 -3
  129. phoenix/server/api/mutations/model_mutations.py +210 -0
  130. phoenix/server/api/mutations/project_mutations.py +49 -10
  131. phoenix/server/api/mutations/project_session_annotations_mutations.py +158 -0
  132. phoenix/server/api/mutations/project_trace_retention_policy_mutations.py +8 -4
  133. phoenix/server/api/mutations/prompt_label_mutations.py +74 -65
  134. phoenix/server/api/mutations/prompt_mutations.py +65 -129
  135. phoenix/server/api/mutations/prompt_version_tag_mutations.py +11 -8
  136. phoenix/server/api/mutations/span_annotations_mutations.py +15 -10
  137. phoenix/server/api/mutations/trace_annotations_mutations.py +14 -10
  138. phoenix/server/api/mutations/trace_mutations.py +47 -3
  139. phoenix/server/api/mutations/user_mutations.py +66 -41
  140. phoenix/server/api/queries.py +768 -293
  141. phoenix/server/api/routers/__init__.py +2 -2
  142. phoenix/server/api/routers/auth.py +154 -88
  143. phoenix/server/api/routers/ldap.py +229 -0
  144. phoenix/server/api/routers/oauth2.py +369 -106
  145. phoenix/server/api/routers/v1/__init__.py +24 -4
  146. phoenix/server/api/routers/v1/annotation_configs.py +23 -31
  147. phoenix/server/api/routers/v1/annotations.py +481 -17
  148. phoenix/server/api/routers/v1/datasets.py +395 -81
  149. phoenix/server/api/routers/v1/documents.py +142 -0
  150. phoenix/server/api/routers/v1/evaluations.py +24 -31
  151. phoenix/server/api/routers/v1/experiment_evaluations.py +19 -8
  152. phoenix/server/api/routers/v1/experiment_runs.py +337 -59
  153. phoenix/server/api/routers/v1/experiments.py +479 -48
  154. phoenix/server/api/routers/v1/models.py +7 -0
  155. phoenix/server/api/routers/v1/projects.py +18 -49
  156. phoenix/server/api/routers/v1/prompts.py +54 -40
  157. phoenix/server/api/routers/v1/sessions.py +108 -0
  158. phoenix/server/api/routers/v1/spans.py +1091 -81
  159. phoenix/server/api/routers/v1/traces.py +132 -78
  160. phoenix/server/api/routers/v1/users.py +389 -0
  161. phoenix/server/api/routers/v1/utils.py +3 -7
  162. phoenix/server/api/subscriptions.py +305 -88
  163. phoenix/server/api/types/Annotation.py +90 -23
  164. phoenix/server/api/types/ApiKey.py +13 -17
  165. phoenix/server/api/types/AuthMethod.py +1 -0
  166. phoenix/server/api/types/ChatCompletionSubscriptionPayload.py +1 -0
  167. phoenix/server/api/types/CostBreakdown.py +12 -0
  168. phoenix/server/api/types/Dataset.py +226 -72
  169. phoenix/server/api/types/DatasetExample.py +88 -18
  170. phoenix/server/api/types/DatasetExperimentAnnotationSummary.py +10 -0
  171. phoenix/server/api/types/DatasetLabel.py +57 -0
  172. phoenix/server/api/types/DatasetSplit.py +98 -0
  173. phoenix/server/api/types/DatasetVersion.py +49 -4
  174. phoenix/server/api/types/DocumentAnnotation.py +212 -0
  175. phoenix/server/api/types/Experiment.py +264 -59
  176. phoenix/server/api/types/ExperimentComparison.py +5 -10
  177. phoenix/server/api/types/ExperimentRepeatedRunGroup.py +155 -0
  178. phoenix/server/api/types/ExperimentRepeatedRunGroupAnnotationSummary.py +9 -0
  179. phoenix/server/api/types/ExperimentRun.py +169 -65
  180. phoenix/server/api/types/ExperimentRunAnnotation.py +158 -39
  181. phoenix/server/api/types/GenerativeModel.py +245 -3
  182. phoenix/server/api/types/GenerativeProvider.py +70 -11
  183. phoenix/server/api/types/{Model.py → InferenceModel.py} +1 -1
  184. phoenix/server/api/types/ModelInterface.py +16 -0
  185. phoenix/server/api/types/PlaygroundModel.py +20 -0
  186. phoenix/server/api/types/Project.py +1278 -216
  187. phoenix/server/api/types/ProjectSession.py +188 -28
  188. phoenix/server/api/types/ProjectSessionAnnotation.py +187 -0
  189. phoenix/server/api/types/ProjectTraceRetentionPolicy.py +1 -1
  190. phoenix/server/api/types/Prompt.py +119 -39
  191. phoenix/server/api/types/PromptLabel.py +42 -25
  192. phoenix/server/api/types/PromptVersion.py +11 -8
  193. phoenix/server/api/types/PromptVersionTag.py +65 -25
  194. phoenix/server/api/types/ServerStatus.py +6 -0
  195. phoenix/server/api/types/Span.py +167 -123
  196. phoenix/server/api/types/SpanAnnotation.py +189 -42
  197. phoenix/server/api/types/SpanCostDetailSummaryEntry.py +10 -0
  198. phoenix/server/api/types/SpanCostSummary.py +10 -0
  199. phoenix/server/api/types/SystemApiKey.py +65 -1
  200. phoenix/server/api/types/TokenPrice.py +16 -0
  201. phoenix/server/api/types/TokenUsage.py +3 -3
  202. phoenix/server/api/types/Trace.py +223 -51
  203. phoenix/server/api/types/TraceAnnotation.py +149 -50
  204. phoenix/server/api/types/User.py +137 -32
  205. phoenix/server/api/types/UserApiKey.py +73 -26
  206. phoenix/server/api/types/node.py +10 -0
  207. phoenix/server/api/types/pagination.py +11 -2
  208. phoenix/server/app.py +290 -45
  209. phoenix/server/authorization.py +38 -3
  210. phoenix/server/bearer_auth.py +34 -24
  211. phoenix/server/cost_tracking/cost_details_calculator.py +196 -0
  212. phoenix/server/cost_tracking/cost_model_lookup.py +179 -0
  213. phoenix/server/cost_tracking/helpers.py +68 -0
  214. phoenix/server/cost_tracking/model_cost_manifest.json +3657 -830
  215. phoenix/server/cost_tracking/regex_specificity.py +397 -0
  216. phoenix/server/cost_tracking/token_cost_calculator.py +57 -0
  217. phoenix/server/daemons/__init__.py +0 -0
  218. phoenix/server/daemons/db_disk_usage_monitor.py +214 -0
  219. phoenix/server/daemons/generative_model_store.py +103 -0
  220. phoenix/server/daemons/span_cost_calculator.py +99 -0
  221. phoenix/server/dml_event.py +17 -0
  222. phoenix/server/dml_event_handler.py +5 -0
  223. phoenix/server/email/sender.py +56 -3
  224. phoenix/server/email/templates/db_disk_usage_notification.html +19 -0
  225. phoenix/server/email/types.py +11 -0
  226. phoenix/server/experiments/__init__.py +0 -0
  227. phoenix/server/experiments/utils.py +14 -0
  228. phoenix/server/grpc_server.py +11 -11
  229. phoenix/server/jwt_store.py +17 -15
  230. phoenix/server/ldap.py +1449 -0
  231. phoenix/server/main.py +26 -10
  232. phoenix/server/oauth2.py +330 -12
  233. phoenix/server/prometheus.py +66 -6
  234. phoenix/server/rate_limiters.py +4 -9
  235. phoenix/server/retention.py +33 -20
  236. phoenix/server/session_filters.py +49 -0
  237. phoenix/server/static/.vite/manifest.json +55 -51
  238. phoenix/server/static/assets/components-BreFUQQa.js +6702 -0
  239. phoenix/server/static/assets/{index-E0M82BdE.js → index-CTQoemZv.js} +140 -56
  240. phoenix/server/static/assets/pages-DBE5iYM3.js +9524 -0
  241. phoenix/server/static/assets/vendor-BGzfc4EU.css +1 -0
  242. phoenix/server/static/assets/vendor-DCE4v-Ot.js +920 -0
  243. phoenix/server/static/assets/vendor-codemirror-D5f205eT.js +25 -0
  244. phoenix/server/static/assets/vendor-recharts-V9cwpXsm.js +37 -0
  245. phoenix/server/static/assets/vendor-shiki-Do--csgv.js +5 -0
  246. phoenix/server/static/assets/vendor-three-CmB8bl_y.js +3840 -0
  247. phoenix/server/templates/index.html +40 -6
  248. phoenix/server/thread_server.py +1 -2
  249. phoenix/server/types.py +14 -4
  250. phoenix/server/utils.py +74 -0
  251. phoenix/session/client.py +56 -3
  252. phoenix/session/data_extractor.py +5 -0
  253. phoenix/session/evaluation.py +14 -5
  254. phoenix/session/session.py +45 -9
  255. phoenix/settings.py +5 -0
  256. phoenix/trace/attributes.py +80 -13
  257. phoenix/trace/dsl/helpers.py +90 -1
  258. phoenix/trace/dsl/query.py +8 -6
  259. phoenix/trace/projects.py +5 -0
  260. phoenix/utilities/template_formatters.py +1 -1
  261. phoenix/version.py +1 -1
  262. arize_phoenix-10.0.4.dist-info/RECORD +0 -405
  263. phoenix/server/api/types/Evaluation.py +0 -39
  264. phoenix/server/cost_tracking/cost_lookup.py +0 -255
  265. phoenix/server/static/assets/components-DULKeDfL.js +0 -4365
  266. phoenix/server/static/assets/pages-Cl0A-0U2.js +0 -7430
  267. phoenix/server/static/assets/vendor-WIZid84E.css +0 -1
  268. phoenix/server/static/assets/vendor-arizeai-Dy-0mSNw.js +0 -649
  269. phoenix/server/static/assets/vendor-codemirror-DBtifKNr.js +0 -33
  270. phoenix/server/static/assets/vendor-oB4u9zuV.js +0 -905
  271. phoenix/server/static/assets/vendor-recharts-D-T4KPz2.js +0 -59
  272. phoenix/server/static/assets/vendor-shiki-BMn4O_9F.js +0 -5
  273. phoenix/server/static/assets/vendor-three-C5WAXd5r.js +0 -2998
  274. phoenix/utilities/deprecation.py +0 -31
  275. {arize_phoenix-10.0.4.dist-info → arize_phoenix-12.28.1.dist-info}/entry_points.txt +0 -0
  276. {arize_phoenix-10.0.4.dist-info → arize_phoenix-12.28.1.dist-info}/licenses/LICENSE +0 -0
@@ -1,7 +1,9 @@
1
1
  from __future__ import annotations
2
2
 
3
+ import logging
3
4
  from asyncio import create_task, gather, sleep
4
5
  from datetime import datetime, timedelta, timezone
6
+ from time import time
5
7
 
6
8
  import sqlalchemy as sa
7
9
  from sqlalchemy.orm import selectinload
@@ -10,9 +12,15 @@ from phoenix.db.constants import DEFAULT_PROJECT_TRACE_RETENTION_POLICY_ID
10
12
  from phoenix.db.models import Project, ProjectTraceRetentionPolicy
11
13
  from phoenix.server.dml_event import SpanDeleteEvent
12
14
  from phoenix.server.dml_event_handler import DmlEventHandler
15
+ from phoenix.server.prometheus import (
16
+ RETENTION_POLICY_EXECUTIONS,
17
+ RETENTION_SWEEPER_LAST_RUN,
18
+ )
13
19
  from phoenix.server.types import DaemonTask, DbSessionFactory
14
20
  from phoenix.utilities import hour_of_week
15
21
 
22
+ logger = logging.getLogger(__name__)
23
+
16
24
 
17
25
  class TraceDataSweeper(DaemonTask):
18
26
  def __init__(self, db: DbSessionFactory, dml_event_handler: DmlEventHandler):
@@ -24,15 +32,19 @@ class TraceDataSweeper(DaemonTask):
24
32
  """Check hourly and apply policies."""
25
33
  while self._running:
26
34
  await self._sleep_until_next_hour()
27
- if not (policies := await self._get_policies()):
28
- continue
29
- current_hour = self._current_hour()
30
- if tasks := [
31
- create_task(self._apply(policy))
32
- for policy in policies
33
- if self._should_apply(policy, current_hour)
34
- ]:
35
- await gather(*tasks, return_exceptions=True)
35
+ RETENTION_SWEEPER_LAST_RUN.set(time())
36
+ try:
37
+ if not (policies := await self._get_policies()):
38
+ continue
39
+ current_hour = self._current_hour()
40
+ if tasks := [
41
+ create_task(self._apply(policy))
42
+ for policy in policies
43
+ if self._should_apply(policy, current_hour)
44
+ ]:
45
+ await gather(*tasks, return_exceptions=True)
46
+ except Exception:
47
+ logger.exception("Unexpected error in retention sweeper main loop")
36
48
 
37
49
  async def _get_policies(self) -> list[ProjectTraceRetentionPolicy]:
38
50
  stmt = sa.select(ProjectTraceRetentionPolicy).options(
@@ -58,18 +70,19 @@ class TraceDataSweeper(DaemonTask):
58
70
  return True
59
71
 
60
72
  async def _apply(self, policy: ProjectTraceRetentionPolicy) -> None:
61
- project_rowids = (
62
- (
63
- sa.select(Project.id)
64
- .where(Project.trace_retention_policy_id.is_(None))
65
- .scalar_subquery()
73
+ try:
74
+ project_rowids = (
75
+ (sa.select(Project.id).where(Project.trace_retention_policy_id.is_(None)))
76
+ if policy.id == DEFAULT_PROJECT_TRACE_RETENTION_POLICY_ID
77
+ else [p.id for p in policy.projects]
66
78
  )
67
- if policy.id == DEFAULT_PROJECT_TRACE_RETENTION_POLICY_ID
68
- else [p.id for p in policy.projects]
69
- )
70
- async with self._db() as session:
71
- result = await policy.rule.delete_traces(session, project_rowids)
72
- self._dml_event_handler.put(SpanDeleteEvent(tuple(result)))
79
+ async with self._db() as session:
80
+ result = await policy.rule.delete_traces(session, project_rowids)
81
+ self._dml_event_handler.put(SpanDeleteEvent(tuple(result)))
82
+ RETENTION_POLICY_EXECUTIONS.labels(status="success").inc()
83
+ except Exception:
84
+ logger.exception(f"Failed to apply retention policy '{policy.name}' (id={policy.id})")
85
+ RETENTION_POLICY_EXECUTIONS.labels(status="error").inc()
73
86
 
74
87
  async def _sleep_until_next_hour(self) -> None:
75
88
  next_hour = self._now().replace(minute=0, second=0, microsecond=0) + timedelta(hours=1)
@@ -0,0 +1,49 @@
1
+ from datetime import datetime
2
+ from typing import Optional, Sequence
3
+
4
+ from openinference.semconv.trace import SpanAttributes
5
+ from sqlalchemy import distinct, or_, select
6
+ from sqlalchemy.sql.selectable import ScalarSelect
7
+
8
+ from phoenix.db import models
9
+
10
+
11
+ def get_filtered_session_rowids_subquery(
12
+ session_filter_condition: str,
13
+ project_rowids: Sequence[int],
14
+ start_time: Optional[datetime] = None,
15
+ end_time: Optional[datetime] = None,
16
+ ) -> ScalarSelect[int]:
17
+ """
18
+ Returns a subquery that contains the project session rowids that match the session filter.
19
+ """
20
+
21
+ filtered_session_rowids = (
22
+ select(distinct(models.Trace.project_session_rowid).label("id"))
23
+ .join_from(models.Trace, models.Span)
24
+ .where(models.Trace.project_rowid.in_(project_rowids))
25
+ .where(models.Span.parent_id.is_(None))
26
+ .where(
27
+ or_(
28
+ models.CaseInsensitiveContains(
29
+ models.Span.attributes[INPUT_VALUE].as_string(),
30
+ session_filter_condition,
31
+ ),
32
+ models.CaseInsensitiveContains(
33
+ models.Span.attributes[OUTPUT_VALUE].as_string(),
34
+ session_filter_condition,
35
+ ),
36
+ )
37
+ )
38
+ )
39
+ if start_time:
40
+ filtered_session_rowids = filtered_session_rowids.where(
41
+ start_time <= models.Trace.start_time
42
+ )
43
+ if end_time:
44
+ filtered_session_rowids = filtered_session_rowids.where(models.Trace.start_time < end_time)
45
+ return filtered_session_rowids.scalar_subquery()
46
+
47
+
48
+ INPUT_VALUE = SpanAttributes.INPUT_VALUE.split(".")
49
+ OUTPUT_VALUE = SpanAttributes.OUTPUT_VALUE.split(".")
@@ -1,87 +1,91 @@
1
1
  {
2
- "_components-DULKeDfL.js": {
3
- "file": "assets/components-DULKeDfL.js",
2
+ "_components-BreFUQQa.js": {
3
+ "file": "assets/components-BreFUQQa.js",
4
4
  "name": "components",
5
5
  "imports": [
6
- "_vendor-oB4u9zuV.js",
7
- "_pages-Cl0A-0U2.js",
8
- "_vendor-arizeai-Dy-0mSNw.js",
9
- "_vendor-codemirror-DBtifKNr.js",
10
- "_vendor-three-C5WAXd5r.js"
6
+ "_vendor-DCE4v-Ot.js",
7
+ "_vendor-codemirror-D5f205eT.js",
8
+ "_pages-DBE5iYM3.js",
9
+ "_vendor-three-CmB8bl_y.js"
11
10
  ]
12
11
  },
13
- "_pages-Cl0A-0U2.js": {
14
- "file": "assets/pages-Cl0A-0U2.js",
12
+ "_pages-DBE5iYM3.js": {
13
+ "file": "assets/pages-DBE5iYM3.js",
15
14
  "name": "pages",
15
+ "isDynamicEntry": true,
16
16
  "imports": [
17
- "_vendor-oB4u9zuV.js",
18
- "_vendor-arizeai-Dy-0mSNw.js",
19
- "_components-DULKeDfL.js",
20
- "_vendor-codemirror-DBtifKNr.js",
21
- "_vendor-recharts-D-T4KPz2.js"
17
+ "_components-BreFUQQa.js",
18
+ "_vendor-DCE4v-Ot.js",
19
+ "_vendor-codemirror-D5f205eT.js",
20
+ "_vendor-recharts-V9cwpXsm.js"
22
21
  ]
23
22
  },
24
- "_vendor-WIZid84E.css": {
25
- "file": "assets/vendor-WIZid84E.css",
26
- "src": "_vendor-WIZid84E.css"
23
+ "_vendor-BGzfc4EU.css": {
24
+ "file": "assets/vendor-BGzfc4EU.css",
25
+ "src": "_vendor-BGzfc4EU.css"
27
26
  },
28
- "_vendor-arizeai-Dy-0mSNw.js": {
29
- "file": "assets/vendor-arizeai-Dy-0mSNw.js",
30
- "name": "vendor-arizeai",
27
+ "_vendor-DCE4v-Ot.js": {
28
+ "file": "assets/vendor-DCE4v-Ot.js",
29
+ "name": "vendor",
31
30
  "imports": [
32
- "_vendor-oB4u9zuV.js"
31
+ "_vendor-three-CmB8bl_y.js"
32
+ ],
33
+ "css": [
34
+ "assets/vendor-BGzfc4EU.css"
33
35
  ]
34
36
  },
35
- "_vendor-codemirror-DBtifKNr.js": {
36
- "file": "assets/vendor-codemirror-DBtifKNr.js",
37
+ "_vendor-codemirror-D5f205eT.js": {
38
+ "file": "assets/vendor-codemirror-D5f205eT.js",
37
39
  "name": "vendor-codemirror",
38
40
  "imports": [
39
- "_vendor-oB4u9zuV.js",
40
- "_vendor-shiki-BMn4O_9F.js"
41
- ]
42
- },
43
- "_vendor-oB4u9zuV.js": {
44
- "file": "assets/vendor-oB4u9zuV.js",
45
- "name": "vendor",
46
- "imports": [
47
- "_vendor-three-C5WAXd5r.js"
41
+ "_vendor-DCE4v-Ot.js",
42
+ "_vendor-shiki-Do--csgv.js"
48
43
  ],
49
- "css": [
50
- "assets/vendor-WIZid84E.css"
44
+ "dynamicImports": [
45
+ "_vendor-shiki-Do--csgv.js",
46
+ "_vendor-shiki-Do--csgv.js",
47
+ "_vendor-shiki-Do--csgv.js"
51
48
  ]
52
49
  },
53
- "_vendor-recharts-D-T4KPz2.js": {
54
- "file": "assets/vendor-recharts-D-T4KPz2.js",
50
+ "_vendor-recharts-V9cwpXsm.js": {
51
+ "file": "assets/vendor-recharts-V9cwpXsm.js",
55
52
  "name": "vendor-recharts",
56
53
  "imports": [
57
- "_vendor-oB4u9zuV.js"
54
+ "_vendor-DCE4v-Ot.js"
58
55
  ]
59
56
  },
60
- "_vendor-shiki-BMn4O_9F.js": {
61
- "file": "assets/vendor-shiki-BMn4O_9F.js",
57
+ "_vendor-shiki-Do--csgv.js": {
58
+ "file": "assets/vendor-shiki-Do--csgv.js",
62
59
  "name": "vendor-shiki",
60
+ "isDynamicEntry": true,
63
61
  "imports": [
64
- "_vendor-oB4u9zuV.js"
62
+ "_vendor-DCE4v-Ot.js"
65
63
  ]
66
64
  },
67
- "_vendor-three-C5WAXd5r.js": {
68
- "file": "assets/vendor-three-C5WAXd5r.js",
65
+ "_vendor-three-CmB8bl_y.js": {
66
+ "file": "assets/vendor-three-CmB8bl_y.js",
69
67
  "name": "vendor-three"
70
68
  },
71
69
  "index.tsx": {
72
- "file": "assets/index-E0M82BdE.js",
70
+ "file": "assets/index-CTQoemZv.js",
73
71
  "name": "index",
74
72
  "src": "index.tsx",
75
73
  "isEntry": true,
76
74
  "imports": [
77
- "_vendor-oB4u9zuV.js",
78
- "_vendor-arizeai-Dy-0mSNw.js",
79
- "_pages-Cl0A-0U2.js",
80
- "_components-DULKeDfL.js",
81
- "_vendor-three-C5WAXd5r.js",
82
- "_vendor-codemirror-DBtifKNr.js",
83
- "_vendor-shiki-BMn4O_9F.js",
84
- "_vendor-recharts-D-T4KPz2.js"
75
+ "_vendor-DCE4v-Ot.js",
76
+ "_pages-DBE5iYM3.js",
77
+ "_components-BreFUQQa.js",
78
+ "_vendor-three-CmB8bl_y.js",
79
+ "_vendor-codemirror-D5f205eT.js",
80
+ "_vendor-shiki-Do--csgv.js",
81
+ "_vendor-recharts-V9cwpXsm.js"
82
+ ],
83
+ "dynamicImports": [
84
+ "_pages-DBE5iYM3.js",
85
+ "_pages-DBE5iYM3.js",
86
+ "_pages-DBE5iYM3.js",
87
+ "_pages-DBE5iYM3.js",
88
+ "_pages-DBE5iYM3.js"
85
89
  ]
86
90
  }
87
91
  }