omnata-plugin-runtime 0.7.0a182__tar.gz → 0.7.0a184__tar.gz
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.
- {omnata_plugin_runtime-0.7.0a182 → omnata_plugin_runtime-0.7.0a184}/PKG-INFO +1 -1
- {omnata_plugin_runtime-0.7.0a182 → omnata_plugin_runtime-0.7.0a184}/pyproject.toml +1 -1
- {omnata_plugin_runtime-0.7.0a182 → omnata_plugin_runtime-0.7.0a184}/src/omnata_plugin_runtime/api.py +3 -0
- {omnata_plugin_runtime-0.7.0a182 → omnata_plugin_runtime-0.7.0a184}/src/omnata_plugin_runtime/configuration.py +4 -5
- {omnata_plugin_runtime-0.7.0a182 → omnata_plugin_runtime-0.7.0a184}/src/omnata_plugin_runtime/plugin_entrypoints.py +21 -24
- {omnata_plugin_runtime-0.7.0a182 → omnata_plugin_runtime-0.7.0a184}/LICENSE +0 -0
- {omnata_plugin_runtime-0.7.0a182 → omnata_plugin_runtime-0.7.0a184}/README.md +0 -0
- {omnata_plugin_runtime-0.7.0a182 → omnata_plugin_runtime-0.7.0a184}/src/omnata_plugin_runtime/__init__.py +0 -0
- {omnata_plugin_runtime-0.7.0a182 → omnata_plugin_runtime-0.7.0a184}/src/omnata_plugin_runtime/forms.py +0 -0
- {omnata_plugin_runtime-0.7.0a182 → omnata_plugin_runtime-0.7.0a184}/src/omnata_plugin_runtime/logging.py +0 -0
- {omnata_plugin_runtime-0.7.0a182 → omnata_plugin_runtime-0.7.0a184}/src/omnata_plugin_runtime/omnata_plugin.py +0 -0
- {omnata_plugin_runtime-0.7.0a182 → omnata_plugin_runtime-0.7.0a184}/src/omnata_plugin_runtime/rate_limiting.py +0 -0
| @@ -1,6 +1,6 @@ | |
| 1 1 | 
             
            [tool.poetry]
         | 
| 2 2 | 
             
            name = "omnata-plugin-runtime"
         | 
| 3 | 
            -
            version = "0.7.0- | 
| 3 | 
            +
            version = "0.7.0-a184"
         | 
| 4 4 | 
             
            description = "Classes and common runtime components for building and running Omnata Plugins"
         | 
| 5 5 | 
             
            authors = ["James Weakley <james.weakley@omnata.com>"]
         | 
| 6 6 | 
             
            readme = "README.md"
         | 
    
        {omnata_plugin_runtime-0.7.0a182 → omnata_plugin_runtime-0.7.0a184}/src/omnata_plugin_runtime/api.py
    RENAMED
    
    | @@ -22,6 +22,7 @@ from .configuration import ( | |
| 22 22 | 
             
                OutboundSyncStrategy,
         | 
| 23 23 | 
             
                StoredConfigurationValue,
         | 
| 24 24 | 
             
                StoredMappingValue,
         | 
| 25 | 
            +
                ConnectivityOption
         | 
| 25 26 | 
             
            )
         | 
| 26 27 | 
             
            from .rate_limiting import ApiLimits, RateLimitState
         | 
| 27 28 |  | 
| @@ -119,6 +120,7 @@ class OutboundSyncRequestPayload(BaseModel): | |
| 119 120 | 
             
                results_table_name: str  # used to stage results back to the engine, resides in the main Omnata app database
         | 
| 120 121 | 
             
                logging_level: str
         | 
| 121 122 | 
             
                connection_method: str
         | 
| 123 | 
            +
                connectivity_option: ConnectivityOption = Field(default=ConnectivityOption.DIRECT)
         | 
| 122 124 | 
             
                connection_parameters: Dict[str, StoredConfigurationValue]
         | 
| 123 125 | 
             
                oauth_secret_name: Optional[str] = None
         | 
| 124 126 | 
             
                other_secrets_name: Optional[str] = None
         | 
| @@ -146,6 +148,7 @@ class InboundSyncRequestPayload(BaseModel): | |
| 146 148 | 
             
                results_table_name: str  # used to stage results back to the engine, resides in the main Omnata app database
         | 
| 147 149 | 
             
                logging_level: str
         | 
| 148 150 | 
             
                connection_method: str
         | 
| 151 | 
            +
                connectivity_option: ConnectivityOption = Field(default=ConnectivityOption.DIRECT)
         | 
| 149 152 | 
             
                connection_parameters: Dict[str, StoredConfigurationValue]
         | 
| 150 153 | 
             
                oauth_secret_name: Optional[str] = None
         | 
| 151 154 | 
             
                other_secrets_name: Optional[str] = None
         | 
| @@ -551,6 +551,7 @@ class ConnectionConfigurationParameters(SubscriptableBaseModel): | |
| 551 551 | 
             
                """
         | 
| 552 552 |  | 
| 553 553 | 
             
                connection_method: str
         | 
| 554 | 
            +
                connectivity_option: ConnectivityOption = Field(default=ConnectivityOption.DIRECT)
         | 
| 554 555 | 
             
                connection_parameters: Optional[Dict[str, StoredConfigurationValue]] = Field(default=None)
         | 
| 555 556 | 
             
                connection_secrets: Optional[Dict[str, StoredConfigurationValue]] = Field(default=None)
         | 
| 556 557 | 
             
                ngrok_tunnel_settings: Optional[NgrokTunnelSettings] = Field(default=None)
         | 
| @@ -560,11 +561,9 @@ class ConnectionConfigurationParameters(SubscriptableBaseModel): | |
| 560 561 | 
             
                    default=None
         | 
| 561 562 | 
             
                )
         | 
| 562 563 |  | 
| 563 | 
            -
                @ | 
| 564 | 
            -
                 | 
| 565 | 
            -
             | 
| 566 | 
            -
                    A validator which picks out the ngrok tunnel configuration from the secrets and provides it as a typed object.
         | 
| 567 | 
            -
                    """
         | 
| 564 | 
            +
                @field_validator('ngrok_tunnel_settings',mode='before')
         | 
| 565 | 
            +
                @classmethod
         | 
| 566 | 
            +
                def validate_ngrok_tunnel_settings(cls, values: Optional[dict[str, Any]]) -> Optional[NgrokTunnelSettings]:
         | 
| 568 567 | 
             
                    if "connection_secrets" in values:
         | 
| 569 568 | 
             
                        connection_secrets:Dict[str, StoredConfigurationValue] = values["connection_secrets"]
         | 
| 570 569 | 
             
                        if "ngrok_client_certificate" in connection_secrets and \
         | 
| @@ -99,6 +99,7 @@ class PluginEntrypoint: | |
| 99 99 | 
             
                    # construct some connection parameters for the purpose of getting the api limits
         | 
| 100 100 | 
             
                    connection_parameters = ConnectionConfigurationParameters(
         | 
| 101 101 | 
             
                        connection_method=request.connection_method,
         | 
| 102 | 
            +
                        connectivity_option=request.connectivity_option,
         | 
| 102 103 | 
             
                        connection_parameters=request.connection_parameters,
         | 
| 103 104 | 
             
                        connection_secrets=connection_secrets
         | 
| 104 105 | 
             
                    )
         | 
| @@ -139,6 +140,7 @@ class PluginEntrypoint: | |
| 139 140 | 
             
                    if request.sync_direction == "outbound":
         | 
| 140 141 | 
             
                        parameters = OutboundSyncConfigurationParameters(
         | 
| 141 142 | 
             
                            connection_method=request.connection_method,
         | 
| 143 | 
            +
                            connectivity_option=request.connectivity_option,
         | 
| 142 144 | 
             
                            connection_parameters=request.connection_parameters,
         | 
| 143 145 | 
             
                            connection_secrets=connection_secrets,
         | 
| 144 146 | 
             
                            sync_parameters=request.sync_parameters,
         | 
| @@ -194,6 +196,7 @@ class PluginEntrypoint: | |
| 194 196 | 
             
                        logger.info("Running inbound sync")
         | 
| 195 197 | 
             
                        parameters = InboundSyncConfigurationParameters(
         | 
| 196 198 | 
             
                            connection_method=request.connection_method,
         | 
| 199 | 
            +
                            connectivity_option=request.connectivity_option,
         | 
| 197 200 | 
             
                            connection_parameters=request.connection_parameters,
         | 
| 198 201 | 
             
                            connection_secrets=connection_secrets,
         | 
| 199 202 | 
             
                            sync_parameters=request.sync_parameters,
         | 
| @@ -269,6 +272,7 @@ class PluginEntrypoint: | |
| 269 272 |  | 
| 270 273 | 
             
                def configuration_form(
         | 
| 271 274 | 
             
                    self,
         | 
| 275 | 
            +
                    connectivity_option:str,
         | 
| 272 276 | 
             
                    connection_method: str,
         | 
| 273 277 | 
             
                    connection_parameters: Dict,
         | 
| 274 278 | 
             
                    oauth_secret_name: Optional[str],
         | 
| @@ -284,6 +288,7 @@ class PluginEntrypoint: | |
| 284 288 | 
             
                    oauth_secret_name = normalise_nulls(oauth_secret_name)
         | 
| 285 289 | 
             
                    other_secrets_name = normalise_nulls(other_secrets_name)
         | 
| 286 290 | 
             
                    connection_secrets = get_secrets(oauth_secret_name, other_secrets_name)
         | 
| 291 | 
            +
                    connectivity_option = TypeAdapter(ConnectivityOption).validate_python(connectivity_option)
         | 
| 287 292 | 
             
                    connection_parameters = TypeAdapter(
         | 
| 288 293 | 
             
                        Dict[str, StoredConfigurationValue]).validate_python(connection_parameters)
         | 
| 289 294 | 
             
                    sync_parameters = TypeAdapter(
         | 
| @@ -299,6 +304,7 @@ class PluginEntrypoint: | |
| 299 304 | 
             
                            sync_strategy=sync_strat,
         | 
| 300 305 | 
             
                            sync_parameters=sync_parameters,
         | 
| 301 306 | 
             
                            connection_method=connection_method,
         | 
| 307 | 
            +
                            connectivity_option=connectivity_option,
         | 
| 302 308 | 
             
                            current_form_parameters=form_parameters,
         | 
| 303 309 | 
             
                        )
         | 
| 304 310 | 
             
                    elif sync_direction == "inbound":
         | 
| @@ -307,6 +313,7 @@ class PluginEntrypoint: | |
| 307 313 | 
             
                            connection_secrets=connection_secrets,
         | 
| 308 314 | 
             
                            sync_parameters=sync_parameters,
         | 
| 309 315 | 
             
                            connection_method=connection_method,
         | 
| 316 | 
            +
                            connectivity_option=connectivity_option,
         | 
| 310 317 | 
             
                            current_form_parameters=form_parameters,
         | 
| 311 318 | 
             
                        )
         | 
| 312 319 | 
             
                    else:
         | 
| @@ -327,6 +334,7 @@ class PluginEntrypoint: | |
| 327 334 |  | 
| 328 335 | 
             
                def inbound_list_streams(
         | 
| 329 336 | 
             
                    self,
         | 
| 337 | 
            +
                    connectivity_option:str,
         | 
| 330 338 | 
             
                    connection_method: str,
         | 
| 331 339 | 
             
                    connection_parameters: Dict,
         | 
| 332 340 | 
             
                    oauth_secret_name: Optional[str],
         | 
| @@ -338,6 +346,7 @@ class PluginEntrypoint: | |
| 338 346 | 
             
                    oauth_secret_name = normalise_nulls(oauth_secret_name)
         | 
| 339 347 | 
             
                    other_secrets_name = normalise_nulls(other_secrets_name)
         | 
| 340 348 | 
             
                    connection_secrets = get_secrets(oauth_secret_name, other_secrets_name)
         | 
| 349 | 
            +
                    connectivity_option = TypeAdapter(ConnectivityOption).validate_python(connectivity_option)
         | 
| 341 350 | 
             
                    connection_parameters = TypeAdapter(
         | 
| 342 351 | 
             
                        Dict[str, StoredConfigurationValue]).validate_python(connection_parameters)
         | 
| 343 352 | 
             
                    sync_parameters = TypeAdapter(
         | 
| @@ -346,6 +355,7 @@ class PluginEntrypoint: | |
| 346 355 | 
             
                        connection_parameters=connection_parameters,
         | 
| 347 356 | 
             
                        connection_secrets=connection_secrets,
         | 
| 348 357 | 
             
                        sync_parameters=sync_parameters,
         | 
| 358 | 
            +
                        connectivity_option=connectivity_option,
         | 
| 349 359 | 
             
                        connection_method=connection_method,
         | 
| 350 360 | 
             
                        current_form_parameters=None,
         | 
| 351 361 | 
             
                        currently_selected_streams=selected_streams
         | 
| @@ -385,7 +395,10 @@ class PluginEntrypoint: | |
| 385 395 | 
             
                def connection_form(self,connectivity_option: str):
         | 
| 386 396 | 
             
                    connectivity_option = TypeAdapter(ConnectivityOption).validate_python(connectivity_option)
         | 
| 387 397 | 
             
                    logger.info("Entered connection_form method")
         | 
| 388 | 
            -
                     | 
| 398 | 
            +
                    if self._plugin_instance.connection_form.connection_form.__code__.co_argcount==1:
         | 
| 399 | 
            +
                        form: List[ConnectionMethod] = self._plugin_instance.connection_form()
         | 
| 400 | 
            +
                    else:
         | 
| 401 | 
            +
                        form: List[ConnectionMethod] = self._plugin_instance.connection_form(connectivity_option)
         | 
| 389 402 | 
             
                    return [f.model_dump() for f in form]
         | 
| 390 403 |  | 
| 391 404 | 
             
                def create_billing_events(self, session, event_request: Dict):
         | 
| @@ -433,30 +446,9 @@ class PluginEntrypoint: | |
| 433 446 | 
             
                    other_secrets_name: Optional[str],
         | 
| 434 447 | 
             
                    function_name: str,
         | 
| 435 448 | 
             
                ) -> List[FormInputField]:
         | 
| 436 | 
            -
                     | 
| 437 | 
            -
                    oauth_secret_name = normalise_nulls(oauth_secret_name)
         | 
| 438 | 
            -
                    other_secrets_name = normalise_nulls(other_secrets_name)
         | 
| 439 | 
            -
                    connection_secrets = get_secrets(oauth_secret_name, other_secrets_name)
         | 
| 440 | 
            -
                    connection_parameters = TypeAdapter(
         | 
| 441 | 
            -
                        Dict[str, StoredConfigurationValue]).validate_python(connection_parameters)
         | 
| 442 | 
            -
                    parameters = ConnectionConfigurationParameters(
         | 
| 443 | 
            -
                        connection_method=connection_method,
         | 
| 444 | 
            -
                        connection_parameters=connection_parameters,
         | 
| 445 | 
            -
                        connection_secrets=connection_secrets
         | 
| 446 | 
            -
                    )
         | 
| 447 | 
            -
                    the_function = getattr(
         | 
| 448 | 
            -
                        self._plugin_instance,
         | 
| 449 | 
            -
                        function_name,
         | 
| 450 | 
            -
                    )
         | 
| 451 | 
            -
                    script_result = the_function(parameters)
         | 
| 452 | 
            -
                    if isinstance(script_result, List):
         | 
| 453 | 
            -
                        if len(script_result) > 0 and isinstance(script_result[0], BaseModel):
         | 
| 454 | 
            -
                            script_result = [r.model_dump() for r in script_result]
         | 
| 455 | 
            -
                    else:
         | 
| 456 | 
            -
                        raise ValueError(f"Expected a List from function {function_name}, got {type(script_result)}")
         | 
| 457 | 
            -
                    return script_result
         | 
| 449 | 
            +
                    raise ValueError(f"ngrok_post_tunnel_fields is deprecated")
         | 
| 458 450 |  | 
| 459 | 
            -
                def network_addresses(self, method: str, connection_parameters: Dict) -> List[str]:
         | 
| 451 | 
            +
                def network_addresses(self, connectivity_option:str, method: str, connection_parameters: Dict) -> List[str]:
         | 
| 460 452 | 
             
                    logger.info("Entered network_addresses method")
         | 
| 461 453 | 
             
                    logger.info(f"Connection parameters: {connection_parameters}")
         | 
| 462 454 | 
             
                    from omnata_plugin_runtime.omnata_plugin import (
         | 
| @@ -465,6 +457,7 @@ class PluginEntrypoint: | |
| 465 457 |  | 
| 466 458 | 
             
                    return self._plugin_instance.network_addresses(
         | 
| 467 459 | 
             
                        ConnectionConfigurationParameters(
         | 
| 460 | 
            +
                            connectivity_option=TypeAdapter(ConnectivityOption).validate_python(connectivity_option),
         | 
| 468 461 | 
             
                            connection_method=method,
         | 
| 469 462 | 
             
                            connection_parameters=TypeAdapter(
         | 
| 470 463 | 
             
                                Dict[str, StoredConfigurationValue]).validate_python(connection_parameters),
         | 
| @@ -474,6 +467,7 @@ class PluginEntrypoint: | |
| 474 467 |  | 
| 475 468 | 
             
                def connect(
         | 
| 476 469 | 
             
                    self,
         | 
| 470 | 
            +
                    connectivity_option:str,
         | 
| 477 471 | 
             
                    method:str,
         | 
| 478 472 | 
             
                    connection_parameters: Dict,
         | 
| 479 473 | 
             
                    network_rule_name: str,
         | 
| @@ -488,6 +482,7 @@ class PluginEntrypoint: | |
| 488 482 | 
             
                        ConnectionConfigurationParameters,
         | 
| 489 483 | 
             
                    )
         | 
| 490 484 | 
             
                    parameters = ConnectionConfigurationParameters(
         | 
| 485 | 
            +
                        connectivity_option=TypeAdapter(ConnectivityOption).validate_python(connectivity_option),
         | 
| 491 486 | 
             
                        connection_method=method,
         | 
| 492 487 | 
             
                        connection_parameters=TypeAdapter(
         | 
| 493 488 | 
             
                            Dict[str, StoredConfigurationValue]).validate_python(connection_parameters),
         | 
| @@ -524,6 +519,7 @@ class PluginEntrypoint: | |
| 524 519 | 
             
                    return connect_response.model_dump()
         | 
| 525 520 |  | 
| 526 521 | 
             
                def api_limits(self,
         | 
| 522 | 
            +
                               connectivity_option:str,
         | 
| 527 523 | 
             
                               method:str,
         | 
| 528 524 | 
             
                                connection_parameters: Dict,
         | 
| 529 525 | 
             
                                oauth_secret_name: Optional[str],
         | 
| @@ -534,6 +530,7 @@ class PluginEntrypoint: | |
| 534 530 | 
             
                        ConnectionConfigurationParameters,
         | 
| 535 531 | 
             
                    )
         | 
| 536 532 | 
             
                    connection_parameters = ConnectionConfigurationParameters(
         | 
| 533 | 
            +
                        connectivity_option=TypeAdapter(ConnectivityOption).validate_python(connectivity_option),
         | 
| 537 534 | 
             
                        connection_method=method,
         | 
| 538 535 | 
             
                        connection_parameters=TypeAdapter(
         | 
| 539 536 | 
             
                            Dict[str, StoredConfigurationValue]).validate_python(connection_parameters),
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         |