Skip to content

Commit

Permalink
Merge branch 'master' into editor-3001-modeling-load-states
Browse files Browse the repository at this point in the history
  • Loading branch information
EDsCODE authored Jan 2, 2025
2 parents 632f09e + fee8dd4 commit 7591eec
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 2 deletions.
8 changes: 8 additions & 0 deletions posthog/rbac/user_access_control.py
Original file line number Diff line number Diff line change
Expand Up @@ -180,6 +180,14 @@ def _access_controls_filters_for_object(self, resource: APIScopeObject, resource
"""
Used when checking an individual object - gets all access controls for the object and its type
"""
# Plugins are a special case because they don't belong to a team, instead they belong to an organization
if resource == "plugin":
return {
"team__organization_id": str(self._organization_id),
"resource": resource,
"resource_id": resource_id,
}

return {"team_id": self._team.id, "resource": resource, "resource_id": resource_id} # type: ignore

def _access_controls_filters_for_resource(self, resource: APIScopeObject) -> dict:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,10 @@
from dlt.common.normalizers.naming.snake_case import NamingConvention
import deltalake as deltalake
from django.conf import settings
from sentry_sdk import capture_exception
from posthog.settings.base_variables import TEST
from posthog.warehouse.models import ExternalDataJob
from posthog.warehouse.s3 import get_s3_client


class DeltaTableHelper:
Expand Down Expand Up @@ -66,7 +68,15 @@ def get_delta_table(self) -> deltalake.DeltaTable | None:
storage_options = self._get_credentials()

if deltalake.DeltaTable.is_deltatable(table_uri=delta_uri, storage_options=storage_options):
return deltalake.DeltaTable(table_uri=delta_uri, storage_options=storage_options)
try:
return deltalake.DeltaTable(table_uri=delta_uri, storage_options=storage_options)
except Exception as e:
# Temp fix for bugged tables
capture_exception(e)
if "parse decimal overflow" in "".join(e.args):
s3 = get_s3_client()
s3.delete(delta_uri, recursive=True)
return None

return None

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -164,7 +164,11 @@ def import_data_activity_sync(inputs: ImportDataActivityInputs):
ExternalDataSource.Type.MYSQL,
ExternalDataSource.Type.MSSQL,
]:
if is_posthog_team(inputs.team_id) or is_enabled_for_team(inputs.team_id):
if (
is_posthog_team(inputs.team_id)
or is_enabled_for_team(inputs.team_id)
or settings.TEMPORAL_TASK_QUEUE == DATA_WAREHOUSE_TASK_QUEUE_V2
):
from posthog.temporal.data_imports.pipelines.sql_database_v2 import sql_source_for_type
else:
from posthog.temporal.data_imports.pipelines.sql_database import sql_source_for_type
Expand Down

0 comments on commit 7591eec

Please sign in to comment.