Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 12 additions & 0 deletions src/adcp/decisioning/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,13 @@ def create_media_buy(
DecisioningPlatform,
)
from adcp.decisioning.platform_router import PlatformRouter
from adcp.decisioning.property_list import (
PropertyListFetcher,
filter_products_by_property_list,
property_list_capability_enabled,
resolve_property_list,
validate_property_list_config,
)
from adcp.decisioning.registry import (
ApiKeyCredential,
BillingMode,
Expand Down Expand Up @@ -298,9 +305,14 @@ def __init__(self, *args: object, **kwargs: object) -> None:
"PostgresTaskRegistry",
"Proposal",
"PropertyList",
"PropertyListFetcher",
"PropertyListReference",
"ProductConfigStore",
"property_list_capability_enabled",
"PropertyListsPlatform",
"filter_products_by_property_list",
"resolve_property_list",
"validate_property_list_config",
"RateLimitedBuyerAgentRegistry",
"RateLimitedError",
"RequestContext",
Expand Down
17 changes: 17 additions & 0 deletions src/adcp/decisioning/handler.py
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,10 @@
)
from adcp.decisioning.implementation_config import ProductConfigStore
from adcp.decisioning.pagination import _query_hash, apply_framework_pagination
from adcp.decisioning.property_list import (
maybe_apply_property_list_filter,
property_list_capability_enabled,
)
from adcp.decisioning.webhook_emit import maybe_emit_sync_completion
from adcp.server.base import ADCPHandler, ToolContext

Expand Down Expand Up @@ -151,6 +155,7 @@
from concurrent.futures import ThreadPoolExecutor

from adcp.decisioning.platform import DecisioningPlatform
from adcp.decisioning.property_list import PropertyListFetcher
from adcp.decisioning.registry import BuyerAgent, BuyerAgentRegistry
from adcp.decisioning.resolve import ResourceResolver
from adcp.decisioning.state import StateReader
Expand Down Expand Up @@ -696,6 +701,7 @@ def __init__(
auto_emit_completion_webhooks: bool = True,
buyer_agent_registry: BuyerAgentRegistry | None = None,
config_store: ProductConfigStore | None = None,
property_list_fetcher: PropertyListFetcher | None = None,
) -> None:
super().__init__()
self._platform = platform
Expand All @@ -708,6 +714,7 @@ def __init__(
self._auto_emit_completion_webhooks = auto_emit_completion_webhooks
self._buyer_agent_registry = buyer_agent_registry
self._config_store = config_store
self._property_list_fetcher = property_list_fetcher

# Cache whether the platform's create_media_buy accepts 'configs'
# so we only pay the inspect.signature cost at construction time.
Expand Down Expand Up @@ -1076,6 +1083,16 @@ async def get_products( # type: ignore[override]
registry=self._registry,
),
)
# Post-adapter: capability-gated property-list filter.
response = cast(
"GetProductsResponse",
await maybe_apply_property_list_filter(
params=params,
response=response,
fetcher=self._property_list_fetcher,
capability_enabled=property_list_capability_enabled(self._platform),
),
)
if self._platform.capabilities.auto_paginate and params.pagination is not None:
response = cast(
"GetProductsResponse",
Expand Down
Loading
Loading