mirror of
https://github.com/PostHog/posthog.git
synced 2024-11-28 09:16:49 +01:00
784c7d3b08
* Resolve weird SQL formatting issue * Use a discriminated union for ActorType * Use standard response types for related groups * Update typing * Always filter related actors by group type index * Update snapshots & typing
29 lines
1.2 KiB
Python
29 lines
1.2 KiB
Python
from typing import List, Optional, cast
|
|
|
|
from ee.clickhouse.queries.actor_base_query import ActorBaseQuery
|
|
from ee.clickhouse.queries.funnels.funnel_unordered import ClickhouseFunnelUnordered
|
|
from ee.clickhouse.sql.funnels.funnel import FUNNEL_PERSONS_BY_STEP_SQL
|
|
from posthog.models.filters.filter import Filter
|
|
from posthog.models.filters.mixins.utils import cached_property
|
|
|
|
|
|
class ClickhouseFunnelUnorderedActors(ClickhouseFunnelUnordered, ActorBaseQuery):
|
|
_filter: Filter
|
|
|
|
@cached_property
|
|
def aggregation_group_type_index(self):
|
|
return self._filter.aggregation_group_type_index
|
|
|
|
def actor_query(self, limit_actors: Optional[bool] = True, extra_fields: Optional[List[str]] = None):
|
|
extra_fields_string = ", ".join([self._get_timestamp_outer_select()] + (extra_fields or []))
|
|
return (
|
|
FUNNEL_PERSONS_BY_STEP_SQL.format(
|
|
steps_per_person_query=self.get_step_counts_query(),
|
|
persons_steps=self._get_funnel_person_step_condition(),
|
|
extra_fields=extra_fields_string,
|
|
limit="LIMIT %(limit)s" if limit_actors else "",
|
|
offset="OFFSET %(offset)s" if limit_actors else "",
|
|
),
|
|
self.params,
|
|
)
|