frogml-core 0.0.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.
- _frogml_proto/__init__.py +0 -0
- _frogml_proto/jfml/model_version/v1/model_repository_spec_pb2.py +35 -0
- _frogml_proto/jfml/model_version/v1/model_repository_spec_pb2.pyi +38 -0
- _frogml_proto/jfml/model_version/v1/model_repository_spec_pb2_grpc.py +4 -0
- _frogml_proto/jfml/model_version/v1/model_version_framework_pb2.py +45 -0
- _frogml_proto/jfml/model_version/v1/model_version_framework_pb2.pyi +41 -0
- _frogml_proto/jfml/model_version/v1/model_version_framework_pb2_grpc.py +4 -0
- _frogml_proto/jfml/model_version/v1/model_version_manager_service_pb2.py +151 -0
- _frogml_proto/jfml/model_version/v1/model_version_manager_service_pb2.pyi +230 -0
- _frogml_proto/jfml/model_version/v1/model_version_manager_service_pb2_grpc.py +237 -0
- _frogml_proto/jfml/model_version/v1/model_version_pb2.py +88 -0
- _frogml_proto/jfml/model_version/v1/model_version_pb2.pyi +133 -0
- _frogml_proto/jfml/model_version/v1/model_version_pb2_grpc.py +4 -0
- _frogml_proto/qwak/administration/account/v1/account_pb2.py +114 -0
- _frogml_proto/qwak/administration/account/v1/account_pb2.pyi +257 -0
- _frogml_proto/qwak/administration/account/v1/account_pb2_grpc.py +4 -0
- _frogml_proto/qwak/administration/account/v1/account_service_pb2.py +212 -0
- _frogml_proto/qwak/administration/account/v1/account_service_pb2.pyi +344 -0
- _frogml_proto/qwak/administration/account/v1/account_service_pb2_grpc.py +338 -0
- _frogml_proto/qwak/administration/account/v1/jfrog_tenant_details_pb2.py +77 -0
- _frogml_proto/qwak/administration/account/v1/jfrog_tenant_details_pb2.pyi +109 -0
- _frogml_proto/qwak/administration/account/v1/jfrog_tenant_details_pb2_grpc.py +4 -0
- _frogml_proto/qwak/administration/account/v1/personalization_pb2.py +45 -0
- _frogml_proto/qwak/administration/account/v1/personalization_pb2.pyi +49 -0
- _frogml_proto/qwak/administration/account/v1/personalization_pb2_grpc.py +4 -0
- _frogml_proto/qwak/administration/account/v1/preferences_pb2.py +36 -0
- _frogml_proto/qwak/administration/account/v1/preferences_pb2.pyi +35 -0
- _frogml_proto/qwak/administration/account/v1/preferences_pb2_grpc.py +4 -0
- _frogml_proto/qwak/administration/account/v1/terms_pb2.py +75 -0
- _frogml_proto/qwak/administration/account/v1/terms_pb2.pyi +94 -0
- _frogml_proto/qwak/administration/account/v1/terms_pb2_grpc.py +4 -0
- _frogml_proto/qwak/administration/authenticated_user/v1/authenticated_user_service_pb2.py +91 -0
- _frogml_proto/qwak/administration/authenticated_user/v1/authenticated_user_service_pb2.pyi +108 -0
- _frogml_proto/qwak/administration/authenticated_user/v1/authenticated_user_service_pb2_grpc.py +135 -0
- _frogml_proto/qwak/administration/authenticated_user/v1/credentials_pb2.py +46 -0
- _frogml_proto/qwak/administration/authenticated_user/v1/credentials_pb2.pyi +62 -0
- _frogml_proto/qwak/administration/authenticated_user/v1/credentials_pb2_grpc.py +4 -0
- _frogml_proto/qwak/administration/authenticated_user/v1/details_pb2.py +75 -0
- _frogml_proto/qwak/administration/authenticated_user/v1/details_pb2.pyi +140 -0
- _frogml_proto/qwak/administration/authenticated_user/v1/details_pb2_grpc.py +4 -0
- _frogml_proto/qwak/administration/v0/authentication/authentication_service_pb2.py +69 -0
- _frogml_proto/qwak/administration/v0/authentication/authentication_service_pb2.pyi +92 -0
- _frogml_proto/qwak/administration/v0/authentication/authentication_service_pb2_grpc.py +67 -0
- _frogml_proto/qwak/administration/v0/environments/configuration_pb2.py +93 -0
- _frogml_proto/qwak/administration/v0/environments/configuration_pb2.pyi +233 -0
- _frogml_proto/qwak/administration/v0/environments/configuration_pb2_grpc.py +4 -0
- _frogml_proto/qwak/administration/v0/environments/environment_pb2.py +66 -0
- _frogml_proto/qwak/administration/v0/environments/environment_pb2.pyi +156 -0
- _frogml_proto/qwak/administration/v0/environments/environment_pb2_grpc.py +4 -0
- _frogml_proto/qwak/administration/v0/environments/environment_service_pb2.py +184 -0
- _frogml_proto/qwak/administration/v0/environments/environment_service_pb2.pyi +274 -0
- _frogml_proto/qwak/administration/v0/environments/environment_service_pb2_grpc.py +272 -0
- _frogml_proto/qwak/administration/v0/environments/personalization_pb2.py +45 -0
- _frogml_proto/qwak/administration/v0/environments/personalization_pb2.pyi +45 -0
- _frogml_proto/qwak/administration/v0/environments/personalization_pb2_grpc.py +4 -0
- _frogml_proto/qwak/administration/v0/users/user_pb2.py +97 -0
- _frogml_proto/qwak/administration/v0/users/user_pb2.pyi +249 -0
- _frogml_proto/qwak/administration/v0/users/user_pb2_grpc.py +4 -0
- _frogml_proto/qwak/admiral/secret/v0/secret_pb2.py +140 -0
- _frogml_proto/qwak/admiral/secret/v0/secret_pb2.pyi +237 -0
- _frogml_proto/qwak/admiral/secret/v0/secret_pb2_grpc.py +4 -0
- _frogml_proto/qwak/admiral/secret/v0/secret_service_pb2.py +89 -0
- _frogml_proto/qwak/admiral/secret/v0/secret_service_pb2.pyi +93 -0
- _frogml_proto/qwak/admiral/secret/v0/secret_service_pb2_grpc.py +135 -0
- _frogml_proto/qwak/admiral/secret/v0/system_secret_service_pb2.py +89 -0
- _frogml_proto/qwak/admiral/secret/v0/system_secret_service_pb2.pyi +101 -0
- _frogml_proto/qwak/admiral/secret/v0/system_secret_service_pb2_grpc.py +135 -0
- _frogml_proto/qwak/admiral/user_application_instance/v0/user_application_instance_pb2.py +198 -0
- _frogml_proto/qwak/admiral/user_application_instance/v0/user_application_instance_pb2.pyi +431 -0
- _frogml_proto/qwak/admiral/user_application_instance/v0/user_application_instance_pb2_grpc.py +4 -0
- _frogml_proto/qwak/admiral/user_application_instance/v0/user_application_instance_service_pb2.py +109 -0
- _frogml_proto/qwak/admiral/user_application_instance/v0/user_application_instance_service_pb2.pyi +128 -0
- _frogml_proto/qwak/admiral/user_application_instance/v0/user_application_instance_service_pb2_grpc.py +169 -0
- _frogml_proto/qwak/analytics/analytics_pb2.py +142 -0
- _frogml_proto/qwak/analytics/analytics_pb2.pyi +308 -0
- _frogml_proto/qwak/analytics/analytics_pb2_grpc.py +4 -0
- _frogml_proto/qwak/analytics/analytics_service_pb2.py +229 -0
- _frogml_proto/qwak/analytics/analytics_service_pb2.pyi +339 -0
- _frogml_proto/qwak/analytics/analytics_service_pb2_grpc.py +370 -0
- _frogml_proto/qwak/audience/v1/audience_api_pb2.py +149 -0
- _frogml_proto/qwak/audience/v1/audience_api_pb2.pyi +176 -0
- _frogml_proto/qwak/audience/v1/audience_api_pb2_grpc.py +240 -0
- _frogml_proto/qwak/audience/v1/audience_pb2.py +137 -0
- _frogml_proto/qwak/audience/v1/audience_pb2.pyi +313 -0
- _frogml_proto/qwak/audience/v1/audience_pb2_grpc.py +4 -0
- _frogml_proto/qwak/auto_scaling/v1/auto_scaling_pb2.py +100 -0
- _frogml_proto/qwak/auto_scaling/v1/auto_scaling_pb2.pyi +187 -0
- _frogml_proto/qwak/auto_scaling/v1/auto_scaling_pb2_grpc.py +4 -0
- _frogml_proto/qwak/auto_scaling/v1/auto_scaling_service_pb2.py +49 -0
- _frogml_proto/qwak/auto_scaling/v1/auto_scaling_service_pb2.pyi +55 -0
- _frogml_proto/qwak/auto_scaling/v1/auto_scaling_service_pb2_grpc.py +67 -0
- _frogml_proto/qwak/automation/v1/action_pb2.py +220 -0
- _frogml_proto/qwak/automation/v1/action_pb2.pyi +513 -0
- _frogml_proto/qwak/automation/v1/action_pb2_grpc.py +4 -0
- _frogml_proto/qwak/automation/v1/auto_scaling_pb2.py +97 -0
- _frogml_proto/qwak/automation/v1/auto_scaling_pb2.pyi +177 -0
- _frogml_proto/qwak/automation/v1/auto_scaling_pb2_grpc.py +4 -0
- _frogml_proto/qwak/automation/v1/automation_execution_pb2.py +65 -0
- _frogml_proto/qwak/automation/v1/automation_execution_pb2.pyi +123 -0
- _frogml_proto/qwak/automation/v1/automation_execution_pb2_grpc.py +4 -0
- _frogml_proto/qwak/automation/v1/automation_management_service_pb2.py +283 -0
- _frogml_proto/qwak/automation/v1/automation_management_service_pb2.pyi +386 -0
- _frogml_proto/qwak/automation/v1/automation_management_service_pb2_grpc.py +429 -0
- _frogml_proto/qwak/automation/v1/automation_pb2.py +59 -0
- _frogml_proto/qwak/automation/v1/automation_pb2.pyi +121 -0
- _frogml_proto/qwak/automation/v1/automation_pb2_grpc.py +4 -0
- _frogml_proto/qwak/automation/v1/common_pb2.py +56 -0
- _frogml_proto/qwak/automation/v1/common_pb2.pyi +71 -0
- _frogml_proto/qwak/automation/v1/common_pb2_grpc.py +4 -0
- _frogml_proto/qwak/automation/v1/notification_pb2.py +93 -0
- _frogml_proto/qwak/automation/v1/notification_pb2.pyi +134 -0
- _frogml_proto/qwak/automation/v1/notification_pb2_grpc.py +4 -0
- _frogml_proto/qwak/automation/v1/trigger_pb2.py +76 -0
- _frogml_proto/qwak/automation/v1/trigger_pb2.pyi +112 -0
- _frogml_proto/qwak/automation/v1/trigger_pb2_grpc.py +4 -0
- _frogml_proto/qwak/batch_job/v1/batch_job_events_pb2.py +148 -0
- _frogml_proto/qwak/batch_job/v1/batch_job_events_pb2.pyi +307 -0
- _frogml_proto/qwak/batch_job/v1/batch_job_events_pb2_grpc.py +4 -0
- _frogml_proto/qwak/batch_job/v1/batch_job_resources_pb2.py +47 -0
- _frogml_proto/qwak/batch_job/v1/batch_job_resources_pb2.pyi +61 -0
- _frogml_proto/qwak/batch_job/v1/batch_job_resources_pb2_grpc.py +4 -0
- _frogml_proto/qwak/batch_job/v1/batch_job_service_pb2.py +570 -0
- _frogml_proto/qwak/batch_job/v1/batch_job_service_pb2.pyi +1328 -0
- _frogml_proto/qwak/batch_job/v1/batch_job_service_pb2_grpc.py +574 -0
- _frogml_proto/qwak/build/v1/build_api_pb2.py +446 -0
- _frogml_proto/qwak/build/v1/build_api_pb2.pyi +682 -0
- _frogml_proto/qwak/build/v1/build_api_pb2_grpc.py +594 -0
- _frogml_proto/qwak/build/v1/build_pb2.py +575 -0
- _frogml_proto/qwak/build/v1/build_pb2.pyi +1328 -0
- _frogml_proto/qwak/build/v1/build_pb2_grpc.py +4 -0
- _frogml_proto/qwak/build_settings/build_settings_api_pb2.py +89 -0
- _frogml_proto/qwak/build_settings/build_settings_api_pb2.pyi +106 -0
- _frogml_proto/qwak/build_settings/build_settings_api_pb2_grpc.py +132 -0
- _frogml_proto/qwak/build_settings/build_settings_pb2.py +95 -0
- _frogml_proto/qwak/build_settings/build_settings_pb2.pyi +148 -0
- _frogml_proto/qwak/build_settings/build_settings_pb2_grpc.py +4 -0
- _frogml_proto/qwak/builds/build_pb2.py +233 -0
- _frogml_proto/qwak/builds/build_pb2.pyi +582 -0
- _frogml_proto/qwak/builds/build_pb2_grpc.py +4 -0
- _frogml_proto/qwak/builds/build_url_pb2.py +86 -0
- _frogml_proto/qwak/builds/build_url_pb2.pyi +179 -0
- _frogml_proto/qwak/builds/build_url_pb2_grpc.py +4 -0
- _frogml_proto/qwak/builds/builds_orchestrator_service_pb2.py +212 -0
- _frogml_proto/qwak/builds/builds_orchestrator_service_pb2.pyi +322 -0
- _frogml_proto/qwak/builds/builds_orchestrator_service_pb2_grpc.py +306 -0
- _frogml_proto/qwak/builds/builds_pb2.py +556 -0
- _frogml_proto/qwak/builds/builds_pb2.pyi +1271 -0
- _frogml_proto/qwak/builds/builds_pb2_grpc.py +237 -0
- _frogml_proto/qwak/builds/internal_builds_orchestrator_service_pb2.py +59 -0
- _frogml_proto/qwak/builds/internal_builds_orchestrator_service_pb2.pyi +64 -0
- _frogml_proto/qwak/builds/internal_builds_orchestrator_service_pb2_grpc.py +67 -0
- _frogml_proto/qwak/data_versioning/data_versioning_pb2.py +45 -0
- _frogml_proto/qwak/data_versioning/data_versioning_pb2.pyi +71 -0
- _frogml_proto/qwak/data_versioning/data_versioning_pb2_grpc.py +4 -0
- _frogml_proto/qwak/data_versioning/data_versioning_service_pb2.py +69 -0
- _frogml_proto/qwak/data_versioning/data_versioning_service_pb2.pyi +83 -0
- _frogml_proto/qwak/data_versioning/data_versioning_service_pb2_grpc.py +101 -0
- _frogml_proto/qwak/deployment/alert_pb2.py +131 -0
- _frogml_proto/qwak/deployment/alert_pb2.pyi +262 -0
- _frogml_proto/qwak/deployment/alert_pb2_grpc.py +4 -0
- _frogml_proto/qwak/deployment/alert_service_pb2.py +153 -0
- _frogml_proto/qwak/deployment/alert_service_pb2.pyi +218 -0
- _frogml_proto/qwak/deployment/alert_service_pb2_grpc.py +237 -0
- _frogml_proto/qwak/deployment/deployment_messages_pb2.py +36 -0
- _frogml_proto/qwak/deployment/deployment_messages_pb2.pyi +61 -0
- _frogml_proto/qwak/deployment/deployment_messages_pb2_grpc.py +4 -0
- _frogml_proto/qwak/deployment/deployment_pb2.py +644 -0
- _frogml_proto/qwak/deployment/deployment_pb2.pyi +1582 -0
- _frogml_proto/qwak/deployment/deployment_pb2_grpc.py +4 -0
- _frogml_proto/qwak/deployment/deployment_service_pb2.py +520 -0
- _frogml_proto/qwak/deployment/deployment_service_pb2.pyi +817 -0
- _frogml_proto/qwak/deployment/deployment_service_pb2_grpc.py +509 -0
- _frogml_proto/qwak/ecosystem/v0/credentials_pb2.py +56 -0
- _frogml_proto/qwak/ecosystem/v0/credentials_pb2.pyi +91 -0
- _frogml_proto/qwak/ecosystem/v0/credentials_pb2_grpc.py +4 -0
- _frogml_proto/qwak/ecosystem/v0/ecosystem_pb2.py +173 -0
- _frogml_proto/qwak/ecosystem/v0/ecosystem_pb2.pyi +332 -0
- _frogml_proto/qwak/ecosystem/v0/ecosystem_pb2_grpc.py +4 -0
- _frogml_proto/qwak/ecosystem/v0/ecosystem_runtime_service_pb2.py +264 -0
- _frogml_proto/qwak/ecosystem/v0/ecosystem_runtime_service_pb2.pyi +434 -0
- _frogml_proto/qwak/ecosystem/v0/ecosystem_runtime_service_pb2_grpc.py +238 -0
- _frogml_proto/qwak/execution/v1/backfill_pb2.py +97 -0
- _frogml_proto/qwak/execution/v1/backfill_pb2.pyi +167 -0
- _frogml_proto/qwak/execution/v1/backfill_pb2_grpc.py +4 -0
- _frogml_proto/qwak/execution/v1/batch_pb2.py +56 -0
- _frogml_proto/qwak/execution/v1/batch_pb2.pyi +76 -0
- _frogml_proto/qwak/execution/v1/batch_pb2_grpc.py +4 -0
- _frogml_proto/qwak/execution/v1/deletion_pb2.py +65 -0
- _frogml_proto/qwak/execution/v1/deletion_pb2.pyi +67 -0
- _frogml_proto/qwak/execution/v1/deletion_pb2_grpc.py +4 -0
- _frogml_proto/qwak/execution/v1/execution_pb2.py +96 -0
- _frogml_proto/qwak/execution/v1/execution_pb2.pyi +201 -0
- _frogml_proto/qwak/execution/v1/execution_pb2_grpc.py +4 -0
- _frogml_proto/qwak/execution/v1/execution_service_pb2.py +294 -0
- _frogml_proto/qwak/execution/v1/execution_service_pb2.pyi +431 -0
- _frogml_proto/qwak/execution/v1/execution_service_pb2_grpc.py +467 -0
- _frogml_proto/qwak/execution/v1/jobs/job_pb2.py +101 -0
- _frogml_proto/qwak/execution/v1/jobs/job_pb2.pyi +282 -0
- _frogml_proto/qwak/execution/v1/jobs/job_pb2_grpc.py +4 -0
- _frogml_proto/qwak/execution/v1/jobs/job_service_pb2.py +270 -0
- _frogml_proto/qwak/execution/v1/jobs/job_service_pb2.pyi +469 -0
- _frogml_proto/qwak/execution/v1/jobs/job_service_pb2_grpc.py +396 -0
- _frogml_proto/qwak/execution/v1/jobs/reports/report_pb2.py +109 -0
- _frogml_proto/qwak/execution/v1/jobs/reports/report_pb2.pyi +266 -0
- _frogml_proto/qwak/execution/v1/jobs/reports/report_pb2_grpc.py +4 -0
- _frogml_proto/qwak/execution/v1/state/execution_state_pb2.py +36 -0
- _frogml_proto/qwak/execution/v1/state/execution_state_pb2.pyi +45 -0
- _frogml_proto/qwak/execution/v1/state/execution_state_pb2_grpc.py +4 -0
- _frogml_proto/qwak/execution/v1/state/execution_state_service_pb2.py +150 -0
- _frogml_proto/qwak/execution/v1/state/execution_state_service_pb2.pyi +192 -0
- _frogml_proto/qwak/execution/v1/state/execution_state_service_pb2_grpc.py +237 -0
- _frogml_proto/qwak/execution/v1/state/featureset_state_pb2.py +35 -0
- _frogml_proto/qwak/execution/v1/state/featureset_state_pb2.pyi +37 -0
- _frogml_proto/qwak/execution/v1/state/featureset_state_pb2_grpc.py +4 -0
- _frogml_proto/qwak/execution/v1/state/spark_execution_state_pb2.py +91 -0
- _frogml_proto/qwak/execution/v1/state/spark_execution_state_pb2.pyi +156 -0
- _frogml_proto/qwak/execution/v1/state/spark_execution_state_pb2_grpc.py +4 -0
- _frogml_proto/qwak/execution/v1/streaming_aggregation_pb2.py +75 -0
- _frogml_proto/qwak/execution/v1/streaming_aggregation_pb2.pyi +95 -0
- _frogml_proto/qwak/execution/v1/streaming_aggregation_pb2_grpc.py +4 -0
- _frogml_proto/qwak/execution/v1/streaming_pb2.py +65 -0
- _frogml_proto/qwak/execution/v1/streaming_pb2.pyi +79 -0
- _frogml_proto/qwak/execution/v1/streaming_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/entities/entity_pb2.py +79 -0
- _frogml_proto/qwak/feature_store/entities/entity_pb2.pyi +166 -0
- _frogml_proto/qwak/feature_store/entities/entity_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/entities/entity_service_pb2.py +149 -0
- _frogml_proto/qwak/feature_store/entities/entity_service_pb2.pyi +203 -0
- _frogml_proto/qwak/feature_store/entities/entity_service_pb2_grpc.py +237 -0
- _frogml_proto/qwak/feature_store/features/aggregation_pb2.py +196 -0
- _frogml_proto/qwak/feature_store/features/aggregation_pb2.pyi +361 -0
- _frogml_proto/qwak/feature_store/features/aggregation_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/features/deployment_pb2.py +189 -0
- _frogml_proto/qwak/feature_store/features/deployment_pb2.pyi +379 -0
- _frogml_proto/qwak/feature_store/features/deployment_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/features/deployment_service_pb2.py +49 -0
- _frogml_proto/qwak/feature_store/features/deployment_service_pb2.pyi +45 -0
- _frogml_proto/qwak/feature_store/features/deployment_service_pb2_grpc.py +67 -0
- _frogml_proto/qwak/feature_store/features/execution_pb2.py +77 -0
- _frogml_proto/qwak/feature_store/features/execution_pb2.pyi +158 -0
- _frogml_proto/qwak/feature_store/features/execution_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/features/feature_set_attribute_pb2.py +36 -0
- _frogml_proto/qwak/feature_store/features/feature_set_attribute_pb2.pyi +33 -0
- _frogml_proto/qwak/feature_store/features/feature_set_attribute_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/features/feature_set_pb2.py +198 -0
- _frogml_proto/qwak/feature_store/features/feature_set_pb2.pyi +443 -0
- _frogml_proto/qwak/feature_store/features/feature_set_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/features/feature_set_service_pb2.py +467 -0
- _frogml_proto/qwak/feature_store/features/feature_set_service_pb2.pyi +663 -0
- _frogml_proto/qwak/feature_store/features/feature_set_service_pb2_grpc.py +746 -0
- _frogml_proto/qwak/feature_store/features/feature_set_state_pb2.py +203 -0
- _frogml_proto/qwak/feature_store/features/feature_set_state_pb2.pyi +329 -0
- _frogml_proto/qwak/feature_store/features/feature_set_state_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/features/feature_set_state_service_pb2.py +129 -0
- _frogml_proto/qwak/feature_store/features/feature_set_state_service_pb2.pyi +175 -0
- _frogml_proto/qwak/feature_store/features/feature_set_state_service_pb2_grpc.py +203 -0
- _frogml_proto/qwak/feature_store/features/feature_set_types_pb2.py +381 -0
- _frogml_proto/qwak/feature_store/features/feature_set_types_pb2.pyi +862 -0
- _frogml_proto/qwak/feature_store/features/feature_set_types_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/features/monitoring_pb2.py +55 -0
- _frogml_proto/qwak/feature_store/features/monitoring_pb2.pyi +67 -0
- _frogml_proto/qwak/feature_store/features/monitoring_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/features/real_time_feature_extractor_pb2.py +167 -0
- _frogml_proto/qwak/feature_store/features/real_time_feature_extractor_pb2.pyi +359 -0
- _frogml_proto/qwak/feature_store/features/real_time_feature_extractor_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/jobs/job_pb2.py +68 -0
- _frogml_proto/qwak/feature_store/jobs/job_pb2.pyi +169 -0
- _frogml_proto/qwak/feature_store/jobs/job_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/jobs/job_service_pb2.py +149 -0
- _frogml_proto/qwak/feature_store/jobs/job_service_pb2.pyi +237 -0
- _frogml_proto/qwak/feature_store/jobs/job_service_pb2_grpc.py +237 -0
- _frogml_proto/qwak/feature_store/jobs/v1/job_pb2.py +67 -0
- _frogml_proto/qwak/feature_store/jobs/v1/job_pb2.pyi +175 -0
- _frogml_proto/qwak/feature_store/jobs/v1/job_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/jobs/v1/job_service_pb2.py +210 -0
- _frogml_proto/qwak/feature_store/jobs/v1/job_service_pb2.pyi +349 -0
- _frogml_proto/qwak/feature_store/jobs/v1/job_service_pb2_grpc.py +338 -0
- _frogml_proto/qwak/feature_store/platform/platform_details_pb2.py +46 -0
- _frogml_proto/qwak/feature_store/platform/platform_details_pb2.pyi +54 -0
- _frogml_proto/qwak/feature_store/platform/platform_details_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/reports/report_pb2.py +75 -0
- _frogml_proto/qwak/feature_store/reports/report_pb2.pyi +159 -0
- _frogml_proto/qwak/feature_store/reports/report_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/repository/common/platform_pb2.py +55 -0
- _frogml_proto/qwak/feature_store/repository/common/platform_pb2.pyi +70 -0
- _frogml_proto/qwak/feature_store/repository/common/platform_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/serving/management_pb2.py +69 -0
- _frogml_proto/qwak/feature_store/serving/management_pb2.pyi +72 -0
- _frogml_proto/qwak/feature_store/serving/management_pb2_grpc.py +101 -0
- _frogml_proto/qwak/feature_store/serving/metadata_pb2.py +67 -0
- _frogml_proto/qwak/feature_store/serving/metadata_pb2.pyi +158 -0
- _frogml_proto/qwak/feature_store/serving/metadata_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/serving/serving_pb2.py +254 -0
- _frogml_proto/qwak/feature_store/serving/serving_pb2.pyi +476 -0
- _frogml_proto/qwak/feature_store/serving/serving_pb2_grpc.py +101 -0
- _frogml_proto/qwak/feature_store/serving/v1/value_pb2.py +46 -0
- _frogml_proto/qwak/feature_store/serving/v1/value_pb2.pyi +91 -0
- _frogml_proto/qwak/feature_store/serving/v1/value_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/sinks/sink_pb2.py +76 -0
- _frogml_proto/qwak/feature_store/sinks/sink_pb2.pyi +137 -0
- _frogml_proto/qwak/feature_store/sinks/sink_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/sources/batch_pb2.py +362 -0
- _frogml_proto/qwak/feature_store/sources/batch_pb2.pyi +911 -0
- _frogml_proto/qwak/feature_store/sources/batch_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/sources/data_source_attribute_pb2.py +36 -0
- _frogml_proto/qwak/feature_store/sources/data_source_attribute_pb2.pyi +33 -0
- _frogml_proto/qwak/feature_store/sources/data_source_attribute_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/sources/data_source_pb2.py +84 -0
- _frogml_proto/qwak/feature_store/sources/data_source_pb2.pyi +169 -0
- _frogml_proto/qwak/feature_store/sources/data_source_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/sources/data_source_service_pb2.py +169 -0
- _frogml_proto/qwak/feature_store/sources/data_source_service_pb2.pyi +237 -0
- _frogml_proto/qwak/feature_store/sources/data_source_service_pb2_grpc.py +305 -0
- _frogml_proto/qwak/feature_store/sources/streaming_pb2.py +175 -0
- _frogml_proto/qwak/feature_store/sources/streaming_pb2.pyi +356 -0
- _frogml_proto/qwak/feature_store/sources/streaming_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/v1/common/source_code/source_code_pb2.py +55 -0
- _frogml_proto/qwak/feature_store/v1/common/source_code/source_code_pb2.pyi +69 -0
- _frogml_proto/qwak/feature_store/v1/common/source_code/source_code_pb2_grpc.py +4 -0
- _frogml_proto/qwak/feature_store/v1/internal/data_source/data_source_service_pb2.py +68 -0
- _frogml_proto/qwak/feature_store/v1/internal/data_source/data_source_service_pb2.pyi +71 -0
- _frogml_proto/qwak/feature_store/v1/internal/data_source/data_source_service_pb2_grpc.py +99 -0
- _frogml_proto/qwak/feature_store/v1/internal/featureset/featureset_token_service_pb2.py +48 -0
- _frogml_proto/qwak/feature_store/v1/internal/featureset/featureset_token_service_pb2.pyi +46 -0
- _frogml_proto/qwak/feature_store/v1/internal/featureset/featureset_token_service_pb2_grpc.py +66 -0
- _frogml_proto/qwak/features_operator/v1/features_operator_pb2.py +76 -0
- _frogml_proto/qwak/features_operator/v1/features_operator_pb2.pyi +129 -0
- _frogml_proto/qwak/features_operator/v1/features_operator_pb2_grpc.py +4 -0
- _frogml_proto/qwak/features_operator/v1/features_operator_service_pb2.py +69 -0
- _frogml_proto/qwak/features_operator/v1/features_operator_service_pb2.pyi +98 -0
- _frogml_proto/qwak/features_operator/v1/features_operator_service_pb2_grpc.py +99 -0
- _frogml_proto/qwak/features_operator/v2/features_operator_pb2.py +86 -0
- _frogml_proto/qwak/features_operator/v2/features_operator_pb2.pyi +138 -0
- _frogml_proto/qwak/features_operator/v2/features_operator_pb2_grpc.py +4 -0
- _frogml_proto/qwak/features_operator/v2/features_operator_service_pb2.py +61 -0
- _frogml_proto/qwak/features_operator/v2/features_operator_service_pb2.pyi +89 -0
- _frogml_proto/qwak/features_operator/v2/features_operator_service_pb2_grpc.py +99 -0
- _frogml_proto/qwak/features_operator/v3/features_operator_async_service_pb2.py +132 -0
- _frogml_proto/qwak/features_operator/v3/features_operator_async_service_pb2.pyi +218 -0
- _frogml_proto/qwak/features_operator/v3/features_operator_async_service_pb2_grpc.py +165 -0
- _frogml_proto/qwak/features_operator/v3/features_operator_pb2.py +86 -0
- _frogml_proto/qwak/features_operator/v3/features_operator_pb2.pyi +143 -0
- _frogml_proto/qwak/features_operator/v3/features_operator_pb2_grpc.py +4 -0
- _frogml_proto/qwak/file_versioning/file_versioning_pb2.py +56 -0
- _frogml_proto/qwak/file_versioning/file_versioning_pb2.pyi +103 -0
- _frogml_proto/qwak/file_versioning/file_versioning_pb2_grpc.py +4 -0
- _frogml_proto/qwak/file_versioning/file_versioning_service_pb2.py +69 -0
- _frogml_proto/qwak/file_versioning/file_versioning_service_pb2.pyi +83 -0
- _frogml_proto/qwak/file_versioning/file_versioning_service_pb2_grpc.py +101 -0
- _frogml_proto/qwak/fitness_service/constructs_pb2.py +120 -0
- _frogml_proto/qwak/fitness_service/constructs_pb2.pyi +297 -0
- _frogml_proto/qwak/fitness_service/constructs_pb2_grpc.py +4 -0
- _frogml_proto/qwak/fitness_service/fitness_pb2.py +54 -0
- _frogml_proto/qwak/fitness_service/fitness_pb2.pyi +126 -0
- _frogml_proto/qwak/fitness_service/fitness_pb2_grpc.py +4 -0
- _frogml_proto/qwak/fitness_service/fitness_service_pb2.py +110 -0
- _frogml_proto/qwak/fitness_service/fitness_service_pb2.pyi +121 -0
- _frogml_proto/qwak/fitness_service/fitness_service_pb2_grpc.py +169 -0
- _frogml_proto/qwak/fitness_service/status_pb2.py +128 -0
- _frogml_proto/qwak/fitness_service/status_pb2.pyi +283 -0
- _frogml_proto/qwak/fitness_service/status_pb2_grpc.py +4 -0
- _frogml_proto/qwak/inference/feedback/feedback_pb2.py +118 -0
- _frogml_proto/qwak/inference/feedback/feedback_pb2.pyi +253 -0
- _frogml_proto/qwak/inference/feedback/feedback_pb2_grpc.py +100 -0
- _frogml_proto/qwak/instance_template/instance_template_pb2.py +62 -0
- _frogml_proto/qwak/instance_template/instance_template_pb2.pyi +108 -0
- _frogml_proto/qwak/instance_template/instance_template_pb2_grpc.py +4 -0
- _frogml_proto/qwak/instance_template/instance_template_service_pb2.py +69 -0
- _frogml_proto/qwak/instance_template/instance_template_service_pb2.pyi +79 -0
- _frogml_proto/qwak/instance_template/instance_template_service_pb2_grpc.py +101 -0
- _frogml_proto/qwak/integration/hugging_face_integration_pb2.py +85 -0
- _frogml_proto/qwak/integration/hugging_face_integration_pb2.pyi +106 -0
- _frogml_proto/qwak/integration/hugging_face_integration_pb2_grpc.py +4 -0
- _frogml_proto/qwak/integration/integration_pb2.py +153 -0
- _frogml_proto/qwak/integration/integration_pb2.pyi +357 -0
- _frogml_proto/qwak/integration/integration_pb2_grpc.py +4 -0
- _frogml_proto/qwak/integration/integration_service_pb2.py +169 -0
- _frogml_proto/qwak/integration/integration_service_pb2.pyi +234 -0
- _frogml_proto/qwak/integration/integration_service_pb2_grpc.py +271 -0
- _frogml_proto/qwak/integration/open_a_i_integration_pb2.py +85 -0
- _frogml_proto/qwak/integration/open_a_i_integration_pb2.pyi +109 -0
- _frogml_proto/qwak/integration/open_a_i_integration_pb2_grpc.py +4 -0
- _frogml_proto/qwak/integration/opsgenie_integration_pb2.py +105 -0
- _frogml_proto/qwak/integration/opsgenie_integration_pb2.pyi +168 -0
- _frogml_proto/qwak/integration/opsgenie_integration_pb2_grpc.py +4 -0
- _frogml_proto/qwak/integration/pagerduty_integration_pb2.py +127 -0
- _frogml_proto/qwak/integration/pagerduty_integration_pb2.pyi +195 -0
- _frogml_proto/qwak/integration/pagerduty_integration_pb2_grpc.py +4 -0
- _frogml_proto/qwak/integration/slack_app_integration_pb2.py +127 -0
- _frogml_proto/qwak/integration/slack_app_integration_pb2.pyi +198 -0
- _frogml_proto/qwak/integration/slack_app_integration_pb2_grpc.py +4 -0
- _frogml_proto/qwak/jfrog/gateway/v0/repository_pb2.py +95 -0
- _frogml_proto/qwak/jfrog/gateway/v0/repository_pb2.pyi +125 -0
- _frogml_proto/qwak/jfrog/gateway/v0/repository_pb2_grpc.py +4 -0
- _frogml_proto/qwak/jfrog/gateway/v0/repository_service_pb2.py +69 -0
- _frogml_proto/qwak/jfrog/gateway/v0/repository_service_pb2.pyi +71 -0
- _frogml_proto/qwak/jfrog/gateway/v0/repository_service_pb2_grpc.py +101 -0
- _frogml_proto/qwak/kube_deployment_captain/alert_pb2.py +120 -0
- _frogml_proto/qwak/kube_deployment_captain/alert_pb2.pyi +232 -0
- _frogml_proto/qwak/kube_deployment_captain/alert_pb2_grpc.py +4 -0
- _frogml_proto/qwak/kube_deployment_captain/alerting_pb2.py +65 -0
- _frogml_proto/qwak/kube_deployment_captain/alerting_pb2.pyi +101 -0
- _frogml_proto/qwak/kube_deployment_captain/alerting_pb2_grpc.py +4 -0
- _frogml_proto/qwak/kube_deployment_captain/batch_job_pb2.py +357 -0
- _frogml_proto/qwak/kube_deployment_captain/batch_job_pb2.pyi +845 -0
- _frogml_proto/qwak/kube_deployment_captain/batch_job_pb2_grpc.py +4 -0
- _frogml_proto/qwak/kube_deployment_captain/deployment_pb2.py +182 -0
- _frogml_proto/qwak/kube_deployment_captain/deployment_pb2.pyi +482 -0
- _frogml_proto/qwak/kube_deployment_captain/deployment_pb2_grpc.py +4 -0
- _frogml_proto/qwak/kube_deployment_captain/feature_set_deployment_pb2.py +172 -0
- _frogml_proto/qwak/kube_deployment_captain/feature_set_deployment_pb2.pyi +370 -0
- _frogml_proto/qwak/kube_deployment_captain/feature_set_deployment_pb2_grpc.py +4 -0
- _frogml_proto/qwak/kube_deployment_captain/kube_deployment_captain_service_pb2.py +562 -0
- _frogml_proto/qwak/kube_deployment_captain/kube_deployment_captain_service_pb2.pyi +924 -0
- _frogml_proto/qwak/kube_deployment_captain/kube_deployment_captain_service_pb2_grpc.py +1226 -0
- _frogml_proto/qwak/kube_deployment_captain/traffic_mapping_pb2.py +45 -0
- _frogml_proto/qwak/kube_deployment_captain/traffic_mapping_pb2.pyi +63 -0
- _frogml_proto/qwak/kube_deployment_captain/traffic_mapping_pb2_grpc.py +4 -0
- _frogml_proto/qwak/logging/log_filter_pb2.py +66 -0
- _frogml_proto/qwak/logging/log_filter_pb2.pyi +102 -0
- _frogml_proto/qwak/logging/log_filter_pb2_grpc.py +4 -0
- _frogml_proto/qwak/logging/log_line_pb2.py +48 -0
- _frogml_proto/qwak/logging/log_line_pb2.pyi +62 -0
- _frogml_proto/qwak/logging/log_line_pb2_grpc.py +4 -0
- _frogml_proto/qwak/logging/log_reader_service_pb2.py +51 -0
- _frogml_proto/qwak/logging/log_reader_service_pb2.pyi +83 -0
- _frogml_proto/qwak/logging/log_reader_service_pb2_grpc.py +67 -0
- _frogml_proto/qwak/logging/log_source_pb2.py +155 -0
- _frogml_proto/qwak/logging/log_source_pb2.pyi +321 -0
- _frogml_proto/qwak/logging/log_source_pb2_grpc.py +4 -0
- _frogml_proto/qwak/model_descriptor/open_ai_descriptor_pb2.py +96 -0
- _frogml_proto/qwak/model_descriptor/open_ai_descriptor_pb2.pyi +215 -0
- _frogml_proto/qwak/model_descriptor/open_ai_descriptor_pb2_grpc.py +4 -0
- _frogml_proto/qwak/models/models_pb2.py +427 -0
- _frogml_proto/qwak/models/models_pb2.pyi +851 -0
- _frogml_proto/qwak/models/models_pb2_grpc.py +402 -0
- _frogml_proto/qwak/monitoring/v0/alerting_channel_management_service_pb2.py +149 -0
- _frogml_proto/qwak/monitoring/v0/alerting_channel_management_service_pb2.pyi +183 -0
- _frogml_proto/qwak/monitoring/v0/alerting_channel_management_service_pb2_grpc.py +237 -0
- _frogml_proto/qwak/monitoring/v0/alerting_channel_pb2.py +175 -0
- _frogml_proto/qwak/monitoring/v0/alerting_channel_pb2.pyi +360 -0
- _frogml_proto/qwak/monitoring/v0/alerting_channel_pb2_grpc.py +4 -0
- _frogml_proto/qwak/monitoring/v0/alerting_channel_sync_service_pb2.py +70 -0
- _frogml_proto/qwak/monitoring/v0/alerting_channel_sync_service_pb2.pyi +85 -0
- _frogml_proto/qwak/monitoring/v0/alerting_channel_sync_service_pb2_grpc.py +101 -0
- _frogml_proto/qwak/offline/serving/v1/feature_values_pb2.py +35 -0
- _frogml_proto/qwak/offline/serving/v1/feature_values_pb2.pyi +37 -0
- _frogml_proto/qwak/offline/serving/v1/feature_values_pb2_grpc.py +4 -0
- _frogml_proto/qwak/offline/serving/v1/offline_serving_async_service_pb2.py +148 -0
- _frogml_proto/qwak/offline/serving/v1/offline_serving_async_service_pb2.pyi +279 -0
- _frogml_proto/qwak/offline/serving/v1/offline_serving_async_service_pb2_grpc.py +165 -0
- _frogml_proto/qwak/offline/serving/v1/options_pb2.py +35 -0
- _frogml_proto/qwak/offline/serving/v1/options_pb2.pyi +30 -0
- _frogml_proto/qwak/offline/serving/v1/options_pb2_grpc.py +4 -0
- _frogml_proto/qwak/offline/serving/v1/population_pb2.py +75 -0
- _frogml_proto/qwak/offline/serving/v1/population_pb2.pyi +99 -0
- _frogml_proto/qwak/offline/serving/v1/population_pb2_grpc.py +4 -0
- _frogml_proto/qwak/projects/projects_pb2.py +225 -0
- _frogml_proto/qwak/projects/projects_pb2.pyi +436 -0
- _frogml_proto/qwak/projects/projects_pb2_grpc.py +203 -0
- _frogml_proto/qwak/prompt/v1/prompt/prompt_manager_service_pb2.py +270 -0
- _frogml_proto/qwak/prompt/v1/prompt/prompt_manager_service_pb2.pyi +417 -0
- _frogml_proto/qwak/prompt/v1/prompt/prompt_manager_service_pb2_grpc.py +441 -0
- _frogml_proto/qwak/prompt/v1/prompt/prompt_pb2.py +237 -0
- _frogml_proto/qwak/prompt/v1/prompt/prompt_pb2.pyi +415 -0
- _frogml_proto/qwak/prompt/v1/prompt/prompt_pb2_grpc.py +4 -0
- _frogml_proto/qwak/secret_service/secret_service_pb2.py +88 -0
- _frogml_proto/qwak/secret_service/secret_service_pb2.pyi +101 -0
- _frogml_proto/qwak/secret_service/secret_service_pb2_grpc.py +135 -0
- _frogml_proto/qwak/self_service/account/v0/account_membership_pb2.py +134 -0
- _frogml_proto/qwak/self_service/account/v0/account_membership_pb2.pyi +274 -0
- _frogml_proto/qwak/self_service/account/v0/account_membership_pb2_grpc.py +4 -0
- _frogml_proto/qwak/self_service/account/v0/account_membership_service_pb2.py +251 -0
- _frogml_proto/qwak/self_service/account/v0/account_membership_service_pb2.pyi +337 -0
- _frogml_proto/qwak/self_service/account/v0/account_membership_service_pb2_grpc.py +407 -0
- _frogml_proto/qwak/self_service/account/v0/account_status_pb2.py +93 -0
- _frogml_proto/qwak/self_service/account/v0/account_status_pb2.pyi +169 -0
- _frogml_proto/qwak/self_service/account/v0/account_status_pb2_grpc.py +4 -0
- _frogml_proto/qwak/self_service/account/v0/managing_account_pb2.py +155 -0
- _frogml_proto/qwak/self_service/account/v0/managing_account_pb2.pyi +279 -0
- _frogml_proto/qwak/self_service/account/v0/managing_account_pb2_grpc.py +4 -0
- _frogml_proto/qwak/self_service/account/v0/managing_account_service_pb2.py +110 -0
- _frogml_proto/qwak/self_service/account/v0/managing_account_service_pb2.pyi +136 -0
- _frogml_proto/qwak/self_service/account/v0/managing_account_service_pb2_grpc.py +169 -0
- _frogml_proto/qwak/self_service/user/v1/api_key_pb2.py +35 -0
- _frogml_proto/qwak/self_service/user/v1/api_key_pb2.pyi +30 -0
- _frogml_proto/qwak/self_service/user/v1/api_key_pb2_grpc.py +4 -0
- _frogml_proto/qwak/self_service/user/v1/user_pb2.py +37 -0
- _frogml_proto/qwak/self_service/user/v1/user_pb2.pyi +62 -0
- _frogml_proto/qwak/self_service/user/v1/user_pb2_grpc.py +4 -0
- _frogml_proto/qwak/self_service/user/v1/user_service_pb2.py +146 -0
- _frogml_proto/qwak/self_service/user/v1/user_service_pb2.pyi +209 -0
- _frogml_proto/qwak/self_service/user/v1/user_service_pb2_grpc.py +203 -0
- _frogml_proto/qwak/traffic/v1/traffic_api_pb2.py +109 -0
- _frogml_proto/qwak/traffic/v1/traffic_api_pb2.pyi +137 -0
- _frogml_proto/qwak/traffic/v1/traffic_api_pb2_grpc.py +169 -0
- _frogml_proto/qwak/traffic/v1/traffic_pb2.py +134 -0
- _frogml_proto/qwak/traffic/v1/traffic_pb2.pyi +285 -0
- _frogml_proto/qwak/traffic/v1/traffic_pb2_grpc.py +4 -0
- _frogml_proto/qwak/user_application/common/v0/resources_pb2.py +159 -0
- _frogml_proto/qwak/user_application/common/v0/resources_pb2.pyi +333 -0
- _frogml_proto/qwak/user_application/common/v0/resources_pb2_grpc.py +4 -0
- _frogml_proto/qwak/user_application/v0/user_application_pb2.py +69 -0
- _frogml_proto/qwak/user_application/v0/user_application_pb2.pyi +89 -0
- _frogml_proto/qwak/user_application/v0/user_application_pb2_grpc.py +4 -0
- _frogml_proto/qwak/vectors/v1/collection/collection_pb2.py +128 -0
- _frogml_proto/qwak/vectors/v1/collection/collection_pb2.pyi +287 -0
- _frogml_proto/qwak/vectors/v1/collection/collection_pb2_grpc.py +4 -0
- _frogml_proto/qwak/vectors/v1/collection/collection_service_pb2.py +189 -0
- _frogml_proto/qwak/vectors/v1/collection/collection_service_pb2.pyi +258 -0
- _frogml_proto/qwak/vectors/v1/collection/collection_service_pb2_grpc.py +304 -0
- _frogml_proto/qwak/vectors/v1/collection/event/collection_event_pb2.py +36 -0
- _frogml_proto/qwak/vectors/v1/collection/event/collection_event_pb2.pyi +41 -0
- _frogml_proto/qwak/vectors/v1/collection/event/collection_event_pb2_grpc.py +4 -0
- _frogml_proto/qwak/vectors/v1/filters_pb2.py +156 -0
- _frogml_proto/qwak/vectors/v1/filters_pb2.pyi +297 -0
- _frogml_proto/qwak/vectors/v1/filters_pb2_grpc.py +4 -0
- _frogml_proto/qwak/vectors/v1/vector_pb2.py +78 -0
- _frogml_proto/qwak/vectors/v1/vector_pb2.pyi +142 -0
- _frogml_proto/qwak/vectors/v1/vector_pb2_grpc.py +4 -0
- _frogml_proto/qwak/vectors/v1/vector_service_pb2.py +134 -0
- _frogml_proto/qwak/vectors/v1/vector_service_pb2.pyi +243 -0
- _frogml_proto/qwak/vectors/v1/vector_service_pb2_grpc.py +201 -0
- _frogml_proto/qwak/workspace/workspace_pb2.py +135 -0
- _frogml_proto/qwak/workspace/workspace_pb2.pyi +331 -0
- _frogml_proto/qwak/workspace/workspace_pb2_grpc.py +4 -0
- _frogml_proto/qwak/workspace/workspace_service_pb2.py +309 -0
- _frogml_proto/qwak/workspace/workspace_service_pb2.pyi +393 -0
- _frogml_proto/qwak/workspace/workspace_service_pb2_grpc.py +507 -0
- frogml/__init__.py +16 -0
- frogml/automations/__init__.py +70 -0
- frogml/automations/automation_executions.py +99 -0
- frogml/automations/automations.py +396 -0
- frogml/automations/batch_execution_action.py +336 -0
- frogml/automations/build_and_deploy_action.py +840 -0
- frogml/automations/common.py +106 -0
- frogml/clients/__init__.py +0 -0
- frogml/clients/_inner/__init__.py +0 -0
- frogml/clients/_inner/edge_communications.py +24 -0
- frogml/clients/administration/__init__.py +4 -0
- frogml/clients/administration/authenticated_user/__init__.py +0 -0
- frogml/clients/administration/authenticated_user/client.py +41 -0
- frogml/clients/administration/authentication/__init__.py +0 -0
- frogml/clients/administration/authentication/client.py +34 -0
- frogml/clients/administration/eco_system/__init__.py +0 -0
- frogml/clients/administration/eco_system/client.py +152 -0
- frogml/clients/administration/eco_system/eco_system_utils.py +15 -0
- frogml/clients/administration/environment/__init__.py +0 -0
- frogml/clients/administration/environment/client.py +77 -0
- frogml/clients/administration/self_service/__init__.py +0 -0
- frogml/clients/administration/self_service/client.py +73 -0
- frogml/clients/alert_management/__init__.py +1 -0
- frogml/clients/alert_management/client.py +64 -0
- frogml/clients/alerts_registry/__init__.py +1 -0
- frogml/clients/alerts_registry/channel.py +132 -0
- frogml/clients/alerts_registry/client.py +137 -0
- frogml/clients/analytics/__init__.py +1 -0
- frogml/clients/analytics/client.py +82 -0
- frogml/clients/audience/__init__.py +1 -0
- frogml/clients/audience/client.py +53 -0
- frogml/clients/automation_management/__init__.py +0 -0
- frogml/clients/automation_management/client.py +274 -0
- frogml/clients/autoscaling/__init__.py +1 -0
- frogml/clients/autoscaling/client.py +34 -0
- frogml/clients/batch_job_management/__init__.py +5 -0
- frogml/clients/batch_job_management/client.py +544 -0
- frogml/clients/batch_job_management/executions_config.py +201 -0
- frogml/clients/batch_job_management/results.py +73 -0
- frogml/clients/build_management/__init__.py +1 -0
- frogml/clients/build_management/client.py +115 -0
- frogml/clients/build_orchestrator/__init__.py +2 -0
- frogml/clients/build_orchestrator/build_model_request_getter.py +138 -0
- frogml/clients/build_orchestrator/client.py +456 -0
- frogml/clients/build_orchestrator/internal_client.py +114 -0
- frogml/clients/data_versioning/__init__.py +0 -0
- frogml/clients/data_versioning/client.py +76 -0
- frogml/clients/data_versioning/data_tag_filter.py +32 -0
- frogml/clients/deployment/__init__.py +0 -0
- frogml/clients/deployment/client.py +191 -0
- frogml/clients/feature_store/__init__.py +1 -0
- frogml/clients/feature_store/execution_management_client.py +102 -0
- frogml/clients/feature_store/job_registry_client.py +71 -0
- frogml/clients/feature_store/management_client.py +570 -0
- frogml/clients/feature_store/offline_serving_client.py +249 -0
- frogml/clients/feature_store/operator_client.py +164 -0
- frogml/clients/file_versioning/__init__.py +0 -0
- frogml/clients/file_versioning/client.py +77 -0
- frogml/clients/file_versioning/file_tag_filter.py +32 -0
- frogml/clients/instance_template/__init__.py +0 -0
- frogml/clients/instance_template/client.py +67 -0
- frogml/clients/integration_management/__init__.py +0 -0
- frogml/clients/integration_management/integration_manager_client.py +35 -0
- frogml/clients/integration_management/integration_utils.py +27 -0
- frogml/clients/integration_management/openai/__init__.py +0 -0
- frogml/clients/integration_management/openai/openai_system_secret.py +56 -0
- frogml/clients/jfrog_gateway/__init__.py +1 -0
- frogml/clients/jfrog_gateway/client.py +42 -0
- frogml/clients/kube_deployment_captain/__init__.py +1 -0
- frogml/clients/kube_deployment_captain/client.py +233 -0
- frogml/clients/logging_client/__init__.py +1 -0
- frogml/clients/logging_client/client.py +148 -0
- frogml/clients/model_management/__init__.py +1 -0
- frogml/clients/model_management/client.py +128 -0
- frogml/clients/model_version_manager/__init__.py +1 -0
- frogml/clients/model_version_manager/client.py +108 -0
- frogml/clients/project/__init__.py +0 -0
- frogml/clients/project/client.py +60 -0
- frogml/clients/prompt_manager/__init__.py +0 -0
- frogml/clients/prompt_manager/model_descriptor_mapper.py +196 -0
- frogml/clients/prompt_manager/prompt_manager_client.py +190 -0
- frogml/clients/prompt_manager/prompt_proto_mapper.py +262 -0
- frogml/clients/secret_service/__init__.py +1 -0
- frogml/clients/secret_service/client.py +96 -0
- frogml/clients/system_secret/__init__.py +0 -0
- frogml/clients/system_secret/system_secret_client.py +31 -0
- frogml/clients/user_application_instance/__init__.py +1 -0
- frogml/clients/user_application_instance/client.py +177 -0
- frogml/clients/vector_store/__init__.py +2 -0
- frogml/clients/vector_store/management_client.py +127 -0
- frogml/clients/vector_store/serving_client.py +157 -0
- frogml/clients/workspace_manager/__init__.py +1 -0
- frogml/clients/workspace_manager/client.py +224 -0
- frogml/exceptions/__init__.py +13 -0
- frogml/exceptions/frogml_decode_exception.py +7 -0
- frogml/exceptions/frogml_exception.py +7 -0
- frogml/exceptions/frogml_external_exception.py +11 -0
- frogml/exceptions/frogml_general_build_exception.py +13 -0
- frogml/exceptions/frogml_http_exception.py +19 -0
- frogml/exceptions/frogml_inference_exception.py +4 -0
- frogml/exceptions/frogml_load_configuration_exception.py +2 -0
- frogml/exceptions/frogml_load_model_failed_exception.py +10 -0
- frogml/exceptions/frogml_login_exception.py +8 -0
- frogml/exceptions/frogml_mock_http_exception.py +4 -0
- frogml/exceptions/frogml_model_initialization_exception.py +4 -0
- frogml/exceptions/frogml_not_found_exception.py +6 -0
- frogml/exceptions/frogml_remote_build_failed.py +5 -0
- frogml/exceptions/frogml_suggestion_exception.py +27 -0
- frogml/exceptions/quiet_error.py +22 -0
- frogml/feature_store/__init__.py +0 -0
- frogml/feature_store/_common/__init__.py +0 -0
- frogml/feature_store/_common/artifact_utils.py +57 -0
- frogml/feature_store/_common/feature_set_utils.py +261 -0
- frogml/feature_store/_common/featureset_asterisk_handler.py +115 -0
- frogml/feature_store/_common/functions.py +37 -0
- frogml/feature_store/_common/packaging.py +244 -0
- frogml/feature_store/_common/source_code_spec.py +62 -0
- frogml/feature_store/_common/source_code_spec_factory.py +51 -0
- frogml/feature_store/_common/value.py +10 -0
- frogml/feature_store/data_sources/__init__.py +65 -0
- frogml/feature_store/data_sources/attributes.py +25 -0
- frogml/feature_store/data_sources/base.py +121 -0
- frogml/feature_store/data_sources/batch/__init__.py +0 -0
- frogml/feature_store/data_sources/batch/_batch.py +9 -0
- frogml/feature_store/data_sources/batch/_jdbc.py +22 -0
- frogml/feature_store/data_sources/batch/athena.py +272 -0
- frogml/feature_store/data_sources/batch/big_query.py +80 -0
- frogml/feature_store/data_sources/batch/clickhouse.py +60 -0
- frogml/feature_store/data_sources/batch/csv.py +62 -0
- frogml/feature_store/data_sources/batch/elastic_search.py +61 -0
- frogml/feature_store/data_sources/batch/filesystem/__init__.py +0 -0
- frogml/feature_store/data_sources/batch/filesystem/aws.py +93 -0
- frogml/feature_store/data_sources/batch/filesystem/base_config.py +13 -0
- frogml/feature_store/data_sources/batch/filesystem/gcp.py +54 -0
- frogml/feature_store/data_sources/batch/filesystem/utils.py +59 -0
- frogml/feature_store/data_sources/batch/mongodb.py +58 -0
- frogml/feature_store/data_sources/batch/mysql.py +50 -0
- frogml/feature_store/data_sources/batch/parquet.py +57 -0
- frogml/feature_store/data_sources/batch/postgres.py +50 -0
- frogml/feature_store/data_sources/batch/redshift.py +85 -0
- frogml/feature_store/data_sources/batch/snowflake.py +77 -0
- frogml/feature_store/data_sources/batch/vertica.py +58 -0
- frogml/feature_store/data_sources/source_authentication.py +35 -0
- frogml/feature_store/data_sources/streaming/__init__.py +0 -0
- frogml/feature_store/data_sources/streaming/_streaming.py +9 -0
- frogml/feature_store/data_sources/streaming/kafka/__init__.py +25 -0
- frogml/feature_store/data_sources/streaming/kafka/authentication.py +124 -0
- frogml/feature_store/data_sources/streaming/kafka/deserialization.py +115 -0
- frogml/feature_store/data_sources/streaming/kafka/kafka.py +121 -0
- frogml/feature_store/data_sources/time_partition_columns.py +178 -0
- frogml/feature_store/entities/__init__.py +0 -0
- frogml/feature_store/entities/entity.py +73 -0
- frogml/feature_store/execution/__init__.py +0 -0
- frogml/feature_store/execution/backfill.py +197 -0
- frogml/feature_store/execution/execution.py +595 -0
- frogml/feature_store/execution/execution_query.py +91 -0
- frogml/feature_store/feature_sets/__init__.py +0 -0
- frogml/feature_store/feature_sets/_utils/_featureset_utils.py +45 -0
- frogml/feature_store/feature_sets/backfill.py +72 -0
- frogml/feature_store/feature_sets/base_feature_set.py +148 -0
- frogml/feature_store/feature_sets/batch.py +472 -0
- frogml/feature_store/feature_sets/context.py +13 -0
- frogml/feature_store/feature_sets/execution_spec.py +75 -0
- frogml/feature_store/feature_sets/metadata.py +75 -0
- frogml/feature_store/feature_sets/read_policies.py +245 -0
- frogml/feature_store/feature_sets/streaming.py +635 -0
- frogml/feature_store/feature_sets/streaming_backfill.py +266 -0
- frogml/feature_store/feature_sets/transformations/__init__.py +35 -0
- frogml/feature_store/feature_sets/transformations/aggregations/__init__.py +0 -0
- frogml/feature_store/feature_sets/transformations/aggregations/aggregations.py +443 -0
- frogml/feature_store/feature_sets/transformations/aggregations/windows.py +70 -0
- frogml/feature_store/feature_sets/transformations/functions/__init__.py +10 -0
- frogml/feature_store/feature_sets/transformations/functions/frogml_pandas.py +64 -0
- frogml/feature_store/feature_sets/transformations/functions/schema.py +57 -0
- frogml/feature_store/feature_sets/transformations/transformations.py +467 -0
- frogml/feature_store/feature_sets/transformations/validations/validations_util.py +78 -0
- frogml/feature_store/offline/__init__.py +4 -0
- frogml/feature_store/offline/_offline_serving_validations.py +32 -0
- frogml/feature_store/offline/_query_engine.py +32 -0
- frogml/feature_store/offline/athena/__init__.py +0 -0
- frogml/feature_store/offline/athena/athena_query_engine.py +154 -0
- frogml/feature_store/offline/client.py +719 -0
- frogml/feature_store/offline/client_v2.py +338 -0
- frogml/feature_store/offline/feature_set_features.py +25 -0
- frogml/feature_store/online/__init__.py +0 -0
- frogml/feature_store/online/client.py +352 -0
- frogml/feature_store/online/endpoint_utils.py +65 -0
- frogml/feature_store/sinks/__init__.py +0 -0
- frogml/feature_store/sinks/base.py +18 -0
- frogml/feature_store/sinks/kafka.py +59 -0
- frogml/feature_store/sinks/streaming/__init__.py +0 -0
- frogml/feature_store/sinks/streaming/attachment.py +34 -0
- frogml/feature_store/sinks/streaming/factory.py +60 -0
- frogml/feature_store/validations/__init__.py +0 -0
- frogml/feature_store/validations/validation_options.py +82 -0
- frogml/feature_store/validations/validation_response.py +121 -0
- frogml/feature_store/validations/validator.py +106 -0
- frogml/frogml_client/__init__.py +0 -0
- frogml/frogml_client/batch_jobs/execution.py +49 -0
- frogml/frogml_client/batch_jobs/task.py +43 -0
- frogml/frogml_client/build_api_helpers/__init__.py +0 -0
- frogml/frogml_client/build_api_helpers/build_api_steps.py +53 -0
- frogml/frogml_client/build_api_helpers/messages.py +6 -0
- frogml/frogml_client/build_api_helpers/trigger_build_api.py +65 -0
- frogml/frogml_client/builds/__init__.py +0 -0
- frogml/frogml_client/builds/build.py +97 -0
- frogml/frogml_client/builds/filters/__init__.py +0 -0
- frogml/frogml_client/builds/filters/metric_filter.py +38 -0
- frogml/frogml_client/builds/filters/parameter_filter.py +36 -0
- frogml/frogml_client/client.py +874 -0
- frogml/frogml_client/data_versioning/__init__.py +0 -0
- frogml/frogml_client/data_versioning/data_tag.py +24 -0
- frogml/frogml_client/deployments/__init__.py +0 -0
- frogml/frogml_client/deployments/deployment.py +409 -0
- frogml/frogml_client/file_versioning/__init__.py +0 -0
- frogml/frogml_client/file_versioning/file_tag.py +24 -0
- frogml/frogml_client/models/__init__.py +0 -0
- frogml/frogml_client/models/model.py +52 -0
- frogml/frogml_client/models/model_metadata.py +31 -0
- frogml/frogml_client/projects/__init__.py +0 -0
- frogml/frogml_client/projects/project.py +56 -0
- frogml/inner/__init__.py +11 -0
- frogml/inner/build_config/__init__.py +0 -0
- frogml/inner/build_config/build_config_v1.py +313 -0
- frogml/inner/build_logic/__init__.py +0 -0
- frogml/inner/build_logic/build_loggers/__init__.py +0 -0
- frogml/inner/build_logic/build_loggers/trigger_build_logger.py +50 -0
- frogml/inner/build_logic/constants/__init__.py +0 -0
- frogml/inner/build_logic/constants/dependencies.py +5 -0
- frogml/inner/build_logic/constants/host_resource.py +4 -0
- frogml/inner/build_logic/constants/messages.py +3 -0
- frogml/inner/build_logic/constants/temp_dir.py +1 -0
- frogml/inner/build_logic/constants/upload_tag.py +7 -0
- frogml/inner/build_logic/dependency_manager_type.py +8 -0
- frogml/inner/build_logic/execute_build_pipeline.py +64 -0
- frogml/inner/build_logic/interface/__init__.py +0 -0
- frogml/inner/build_logic/interface/build_logger_interface.py +28 -0
- frogml/inner/build_logic/interface/build_phase.py +24 -0
- frogml/inner/build_logic/interface/context_interface.py +56 -0
- frogml/inner/build_logic/interface/phase_run_handler.py +71 -0
- frogml/inner/build_logic/interface/step_inteface.py +26 -0
- frogml/inner/build_logic/interface/time_source.py +23 -0
- frogml/inner/build_logic/phases/__init__.py +0 -0
- frogml/inner/build_logic/phases/phase_010_fetch_model/__init__.py +0 -0
- frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_model_step.py +41 -0
- frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/__init__.py +0 -0
- frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/common.py +32 -0
- frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/fetch_strategy_manager.py +62 -0
- frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/strategy/__init__.py +0 -0
- frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/strategy/folder/__init__.py +0 -0
- frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/strategy/folder/folder_strategy.py +131 -0
- frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/strategy/git/__init__.py +0 -0
- frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/strategy/git/git_strategy.py +184 -0
- frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/strategy/strategy.py +48 -0
- frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/strategy/zip/__init__.py +0 -0
- frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/strategy/zip/zip_strategy.py +64 -0
- frogml/inner/build_logic/phases/phase_010_fetch_model/post_fetch_validation_step.py +139 -0
- frogml/inner/build_logic/phases/phase_010_fetch_model/pre_fetch_validation_step.py +263 -0
- frogml/inner/build_logic/phases/phase_010_fetch_model/set_version_step.py +33 -0
- frogml/inner/build_logic/phases/phase_020_remote_register_frogml_build/__init__.py +0 -0
- frogml/inner/build_logic/phases/phase_020_remote_register_frogml_build/cleanup_step.py +20 -0
- frogml/inner/build_logic/phases/phase_020_remote_register_frogml_build/start_remote_build_step.py +42 -0
- frogml/inner/build_logic/phases/phase_020_remote_register_frogml_build/upload_step.py +257 -0
- frogml/inner/build_logic/phases/phases_pipeline.py +44 -0
- frogml/inner/build_logic/run_handlers/__init__.py +0 -0
- frogml/inner/build_logic/run_handlers/programmatic_phase_run_handler.py +101 -0
- frogml/inner/build_logic/tools/__init__.py +0 -0
- frogml/inner/build_logic/tools/dependencies_tools.py +68 -0
- frogml/inner/build_logic/tools/files.py +237 -0
- frogml/inner/build_logic/tools/ignore_files.py +20 -0
- frogml/inner/build_logic/tools/text.py +9 -0
- frogml/inner/build_logic/trigger_build_context.py +10 -0
- frogml/inner/const.py +6 -0
- frogml/inner/di_configuration/__init__.py +73 -0
- frogml/inner/di_configuration/account.py +106 -0
- frogml/inner/di_configuration/config.yml +9 -0
- frogml/inner/di_configuration/containers.py +40 -0
- frogml/inner/instance_template/__init__.py +0 -0
- frogml/inner/instance_template/verify_template_id.py +48 -0
- frogml/inner/model_loggers_utils.py +110 -0
- frogml/inner/provider.py +6 -0
- frogml/inner/runtime_di/__init__.py +13 -0
- frogml/inner/runtime_di/containers.py +17 -0
- frogml/inner/singleton_meta.py +18 -0
- frogml/inner/tool/__init__.py +2 -0
- frogml/inner/tool/auth.py +70 -0
- frogml/inner/tool/grpc/__init__.py +0 -0
- frogml/inner/tool/grpc/grpc_auth.py +42 -0
- frogml/inner/tool/grpc/grpc_tools.py +209 -0
- frogml/inner/tool/grpc/grpc_try_wrapping.py +16 -0
- frogml/inner/tool/protobuf_factory.py +45 -0
- frogml/inner/tool/retry_utils.py +23 -0
- frogml/inner/tool/run_config/__init__.py +12 -0
- frogml/inner/tool/run_config/base.py +127 -0
- frogml/inner/tool/run_config/utils.py +316 -0
- frogml/llmops/__init__.py +0 -0
- frogml/llmops/generation/__init__.py +0 -0
- frogml/llmops/generation/_steaming.py +78 -0
- frogml/llmops/generation/base.py +5 -0
- frogml/llmops/generation/chat/__init__.py +0 -0
- frogml/llmops/generation/chat/openai/LICENSE.txt +201 -0
- frogml/llmops/generation/chat/openai/types/__init__.py +0 -0
- frogml/llmops/generation/chat/openai/types/chat/__init__.py +0 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion.py +88 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion_assistant_message_param.py +65 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion_chunk.py +153 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion_content_part_text_param.py +28 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion_function_call_option_param.py +25 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion_function_message_param.py +33 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion_message.py +56 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion_message_param.py +34 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion_message_tool_call.py +46 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion_message_tool_call_param.py +44 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion_named_tool_choice_param.py +32 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion_role.py +20 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion_system_message_param.py +35 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion_token_logprob.py +71 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion_tool_choice_option_param.py +28 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion_tool_message_param.py +31 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion_tool_param.py +29 -0
- frogml/llmops/generation/chat/openai/types/chat/chat_completion_user_message_param.py +35 -0
- frogml/llmops/generation/chat/openai/types/chat/completion_create_params.py +279 -0
- frogml/llmops/generation/chat/openai/types/completion_choice.py +47 -0
- frogml/llmops/generation/chat/openai/types/completion_create_params.py +209 -0
- frogml/llmops/generation/chat/openai/types/completion_usage.py +30 -0
- frogml/llmops/generation/chat/openai/types/model.py +35 -0
- frogml/llmops/generation/chat/openai/types/shared/__init__.py +3 -0
- frogml/llmops/generation/chat/openai/types/shared/error_object.py +27 -0
- frogml/llmops/generation/chat/openai/types/shared/function_definition.py +49 -0
- frogml/llmops/generation/chat/openai/types/shared/function_parameters.py +20 -0
- frogml/llmops/generation/chat/openai/types/shared_params/__init__.py +2 -0
- frogml/llmops/generation/chat/openai/types/shared_params/function_definition.py +49 -0
- frogml/llmops/generation/chat/openai/types/shared_params/function_parameters.py +22 -0
- frogml/llmops/generation/streaming.py +26 -0
- frogml/llmops/model/__init__.py +0 -0
- frogml/llmops/model/descriptor.py +40 -0
- frogml/llmops/prompt/__init__.py +0 -0
- frogml/llmops/prompt/base.py +136 -0
- frogml/llmops/prompt/chat/__init__.py +0 -0
- frogml/llmops/prompt/chat/message.py +24 -0
- frogml/llmops/prompt/chat/template.py +113 -0
- frogml/llmops/prompt/chat/value.py +10 -0
- frogml/llmops/prompt/manager.py +138 -0
- frogml/llmops/prompt/template.py +24 -0
- frogml/llmops/prompt/value.py +14 -0
- frogml/llmops/provider/__init__.py +0 -0
- frogml/llmops/provider/chat.py +44 -0
- frogml/llmops/provider/openai/__init__.py +0 -0
- frogml/llmops/provider/openai/client.py +126 -0
- frogml/llmops/provider/openai/provider.py +91 -0
- frogml/model/__init__.py +0 -0
- frogml/model/_entity_extraction.py +116 -0
- frogml/model/adapters/__init__.py +39 -0
- frogml/model/adapters/input_adapters/__init__.py +0 -0
- frogml/model/adapters/input_adapters/base_input_adapter.py +8 -0
- frogml/model/adapters/input_adapters/dataframe_input_adapter.py +11 -0
- frogml/model/adapters/input_adapters/file_input_adapter.py +8 -0
- frogml/model/adapters/input_adapters/image_input_adapter.py +8 -0
- frogml/model/adapters/input_adapters/json_input_adapter.py +8 -0
- frogml/model/adapters/input_adapters/multi_input_adapter.py +66 -0
- frogml/model/adapters/input_adapters/numpy_input_adapter.py +100 -0
- frogml/model/adapters/input_adapters/proto_input_adapter.py +32 -0
- frogml/model/adapters/input_adapters/string_input_adapter.py +8 -0
- frogml/model/adapters/input_adapters/tf_tensor_input_adapter.py +8 -0
- frogml/model/adapters/output_adapters/__init__.py +0 -0
- frogml/model/adapters/output_adapters/base_output_adapter.py +13 -0
- frogml/model/adapters/output_adapters/dataframe_output_adapter.py +12 -0
- frogml/model/adapters/output_adapters/default_output_adapter.py +9 -0
- frogml/model/adapters/output_adapters/json_output_adapter.py +9 -0
- frogml/model/adapters/output_adapters/numpy_output_adapter.py +32 -0
- frogml/model/adapters/output_adapters/proto_output_adapter.py +16 -0
- frogml/model/adapters/output_adapters/qwak_with_default_fallback.py +5 -0
- frogml/model/adapters/output_adapters/tf_tensor_output_adapter.py +9 -0
- frogml/model/analytics_logging.py +14 -0
- frogml/model/base.py +86 -0
- frogml/model/decorators/__init__.py +0 -0
- frogml/model/decorators/api.py +62 -0
- frogml/model/decorators/impl/__init__.py +0 -0
- frogml/model/decorators/impl/api_implementation.py +29 -0
- frogml/model/decorators/impl/timer_implementation.py +10 -0
- frogml/model/decorators/timer.py +20 -0
- frogml/model/fs_info_mapping_retriever.py +58 -0
- frogml/model/model_version_tracking.py +57 -0
- frogml/model/schema.py +52 -0
- frogml/model/schema_entities.py +107 -0
- frogml/model/tools/__init__.py +24 -0
- frogml/model/tools/adapters/__init__.py +0 -0
- frogml/model/tools/adapters/encoders.py +46 -0
- frogml/model/tools/adapters/input.py +66 -0
- frogml/model/tools/adapters/input_adapters/__init__.py +0 -0
- frogml/model/tools/adapters/input_adapters/base_input.py +21 -0
- frogml/model/tools/adapters/input_adapters/dataframe_input.py +48 -0
- frogml/model/tools/adapters/input_adapters/file_input.py +8 -0
- frogml/model/tools/adapters/input_adapters/image_input.py +45 -0
- frogml/model/tools/adapters/input_adapters/json_input.py +20 -0
- frogml/model/tools/adapters/input_adapters/string_input.py +6 -0
- frogml/model/tools/adapters/input_adapters/tf_tensor_input.py +44 -0
- frogml/model/tools/adapters/output.py +75 -0
- frogml/model/tools/adapters/output_adapters/__init__.py +0 -0
- frogml/model/tools/adapters/output_adapters/base_output.py +16 -0
- frogml/model/tools/adapters/output_adapters/dataframe_output.py +30 -0
- frogml/model/tools/adapters/output_adapters/default_output.py +58 -0
- frogml/model/tools/adapters/output_adapters/json_output.py +17 -0
- frogml/model/tools/adapters/output_adapters/tf_tensor_output.py +41 -0
- frogml/model/tools/run_model_locally.py +68 -0
- frogml/model/utils/__init__.py +0 -0
- frogml/model/utils/extract_wrapped_function.py +9 -0
- frogml/model/utils/feature_utils.py +69 -0
- frogml/model_loggers/__init__.py +0 -0
- frogml/model_loggers/artifact_logger.py +95 -0
- frogml/model_loggers/data_logger.py +172 -0
- frogml/model_loggers/model_logger.py +30 -0
- frogml/testing/__init__.py +0 -0
- frogml/testing/fixtures.py +7 -0
- frogml/tools/__init__.py +0 -0
- frogml/tools/logger/__init__.py +3 -0
- frogml/tools/logger/logger.py +287 -0
- frogml/tools/logger/logging.yml +79 -0
- frogml/utils/__init__.py +0 -0
- frogml/utils/datetime_utils.py +18 -0
- frogml/utils/dict_utils.py +12 -0
- frogml/vector_store/__init__.py +4 -0
- frogml/vector_store/client.py +151 -0
- frogml/vector_store/collection.py +429 -0
- frogml/vector_store/filters.py +359 -0
- frogml/vector_store/inference_client.py +105 -0
- frogml/vector_store/rest_helpers.py +81 -0
- frogml/vector_store/utils/__init__.py +0 -0
- frogml/vector_store/utils/filter_utils.py +23 -0
- frogml/vector_store/utils/upsert_utils.py +218 -0
- frogml_core-0.0.1.dist-info/METADATA +49 -0
- frogml_core-0.0.1.dist-info/RECORD +1013 -0
- frogml_core-0.0.1.dist-info/WHEEL +4 -0
- frogml_services_mock/__init__.py +1 -0
- frogml_services_mock/mocks/__init__.py +0 -0
- frogml_services_mock/mocks/alert_manager_service_api.py +56 -0
- frogml_services_mock/mocks/alert_registry_service_api.py +62 -0
- frogml_services_mock/mocks/analytics_api.py +54 -0
- frogml_services_mock/mocks/audience_service_api.py +79 -0
- frogml_services_mock/mocks/authentication_service.py +33 -0
- frogml_services_mock/mocks/automation_management_service.py +228 -0
- frogml_services_mock/mocks/autoscaling_service_api.py +31 -0
- frogml_services_mock/mocks/batch_job_manager_service.py +337 -0
- frogml_services_mock/mocks/build_management.py +101 -0
- frogml_services_mock/mocks/build_orchestrator_build_api.py +138 -0
- frogml_services_mock/mocks/build_orchestrator_build_settings_api.py +38 -0
- frogml_services_mock/mocks/build_orchestrator_service_api.py +132 -0
- frogml_services_mock/mocks/data_versioning_service.py +63 -0
- frogml_services_mock/mocks/deployment_management_service.py +461 -0
- frogml_services_mock/mocks/ecosystem_service_api.py +45 -0
- frogml_services_mock/mocks/execution_management_service.py +26 -0
- frogml_services_mock/mocks/feature_store_data_sources_manager_api.py +99 -0
- frogml_services_mock/mocks/feature_store_entities_manager_api.py +99 -0
- frogml_services_mock/mocks/feature_store_feature_set_manager_api.py +269 -0
- frogml_services_mock/mocks/features_online_serving_api.py +169 -0
- frogml_services_mock/mocks/features_operator_v3_service.py +29 -0
- frogml_services_mock/mocks/features_set_state_service_api.py +57 -0
- frogml_services_mock/mocks/feedback_service.py +35 -0
- frogml_services_mock/mocks/file_versioning_service.py +66 -0
- frogml_services_mock/mocks/frogml_mocks.py +133 -0
- frogml_services_mock/mocks/fs_offline_serving_service.py +53 -0
- frogml_services_mock/mocks/instance_template_management_service.py +150 -0
- frogml_services_mock/mocks/integration_management_service.py +73 -0
- frogml_services_mock/mocks/internal_build_orchestrator_service.py +27 -0
- frogml_services_mock/mocks/job_registry_service_api.py +74 -0
- frogml_services_mock/mocks/kube_captain_service_api.py +41 -0
- frogml_services_mock/mocks/logging_service.py +203 -0
- frogml_services_mock/mocks/model_management_service.py +115 -0
- frogml_services_mock/mocks/model_version_manager_service.py +100 -0
- frogml_services_mock/mocks/project_manager_service.py +96 -0
- frogml_services_mock/mocks/prompt_manager_service.py +281 -0
- frogml_services_mock/mocks/repository_service_mock.py +39 -0
- frogml_services_mock/mocks/secret_service.py +43 -0
- frogml_services_mock/mocks/self_service_user_service.py +31 -0
- frogml_services_mock/mocks/system_secret_service.py +55 -0
- frogml_services_mock/mocks/user_application_instance_service_api.py +107 -0
- frogml_services_mock/mocks/utils/__init__.py +0 -0
- frogml_services_mock/mocks/utils/exception_handlers.py +13 -0
- frogml_services_mock/mocks/vector_serving_api.py +159 -0
- frogml_services_mock/mocks/vectors_management_api.py +97 -0
- frogml_services_mock/mocks/workspace_manager_service_mock.py +202 -0
- frogml_services_mock/services_mock.py +542 -0
- frogml_services_mock/utils/__init__.py +0 -0
- frogml_services_mock/utils/service_utils.py +9 -0
@@ -0,0 +1,472 @@
|
|
1
|
+
import functools
|
2
|
+
import inspect
|
3
|
+
from dataclasses import dataclass
|
4
|
+
from datetime import datetime
|
5
|
+
from inspect import Signature
|
6
|
+
from typing import TYPE_CHECKING, Dict, List, Optional, Tuple, Union
|
7
|
+
|
8
|
+
from frogml.feature_store._common.artifact_utils import ArtifactSpec, ArtifactsUploader
|
9
|
+
from frogml.feature_store._common.feature_set_utils import (
|
10
|
+
get_batch_source_for_featureset,
|
11
|
+
)
|
12
|
+
from frogml.feature_store.feature_sets._utils._featureset_utils import FeaturesetUtils
|
13
|
+
from frogml.feature_store.feature_sets.base_feature_set import BaseFeatureSet
|
14
|
+
from frogml.feature_store.validations.validation_options import (
|
15
|
+
FeatureSetValidationOptions,
|
16
|
+
)
|
17
|
+
|
18
|
+
if TYPE_CHECKING:
|
19
|
+
try:
|
20
|
+
import pandas as pd
|
21
|
+
except ImportError:
|
22
|
+
pass
|
23
|
+
|
24
|
+
from typeguard import typechecked
|
25
|
+
|
26
|
+
from _frogml_proto.qwak.feature_store.features.execution_pb2 import (
|
27
|
+
ExecutionSpec as ProtoExecutionSpec,
|
28
|
+
)
|
29
|
+
from _frogml_proto.qwak.feature_store.features.feature_set_pb2 import FeatureSetSpec
|
30
|
+
from _frogml_proto.qwak.feature_store.features.feature_set_types_pb2 import (
|
31
|
+
BatchFeatureSetV1 as ProtoBatchFeatureSetV1,
|
32
|
+
)
|
33
|
+
from _frogml_proto.qwak.feature_store.features.feature_set_types_pb2 import (
|
34
|
+
FeatureSetBatchSource as ProtoFeatureSetBatchSource,
|
35
|
+
)
|
36
|
+
from _frogml_proto.qwak.feature_store.features.feature_set_types_pb2 import (
|
37
|
+
FeatureSetType as ProtoFeatureSetType,
|
38
|
+
)
|
39
|
+
from frogml.feature_store.entities.entity import Entity
|
40
|
+
from frogml.feature_store.feature_sets.backfill import Backfill
|
41
|
+
from frogml.feature_store.feature_sets.context import Context
|
42
|
+
from frogml.feature_store.feature_sets.execution_spec import ClusterTemplate
|
43
|
+
from frogml.feature_store.feature_sets.metadata import (
|
44
|
+
Metadata,
|
45
|
+
get_metadata_from_function,
|
46
|
+
set_metadata_on_function,
|
47
|
+
)
|
48
|
+
from frogml.feature_store.feature_sets.read_policies import ReadPolicy, ReadPolicyABC
|
49
|
+
from frogml.feature_store.feature_sets.transformations import BaseTransformation
|
50
|
+
|
51
|
+
# decorator attributes
|
52
|
+
_BACKFILL_POLICY_ATTRIBUTE = "_qwak_backfill_policy"
|
53
|
+
_EXECUTION_SPECIFICATION_ATTRIBUTE = "_qwak_execution_specification"
|
54
|
+
_SCHEDULING_POLICY_ATTRIBUTE = "_qwak_scheduling_policy"
|
55
|
+
|
56
|
+
# Default timestamp column name for TimeFrame
|
57
|
+
_DEFAULT_TIMEFRAME_TS_COL_NAME = "qwak_window_end_ts"
|
58
|
+
|
59
|
+
|
60
|
+
def feature_set(
|
61
|
+
*,
|
62
|
+
data_sources: Union[Dict[str, ReadPolicyABC], List[str]],
|
63
|
+
timestamp_column_name: str = None,
|
64
|
+
name: str = None,
|
65
|
+
entity: Optional[str] = None,
|
66
|
+
key: Optional[str] = None,
|
67
|
+
):
|
68
|
+
"""
|
69
|
+
Define a batch scheduled feature set. Default scheduling policy is every 4 hours.
|
70
|
+
|
71
|
+
:param name: The name of the feature set. If not defined, taken from the function name
|
72
|
+
:param entity: a string reference to a Frogml entity, or the entity definition itself.
|
73
|
+
Only one of, entity or key, can be provided.
|
74
|
+
:param key: a column name in the feature set which is the key. Only one of, entity or key, can be provided.
|
75
|
+
:param data_sources: a string reference to a Frogml data source, or the data source definition itself
|
76
|
+
:param timestamp_column_name: Timestamp column the feature set should consider when ingesting records.
|
77
|
+
If more than one data source is specified - the field is mandatory. If only one data source is specified - the
|
78
|
+
field will be taken by from the data source definition.
|
79
|
+
|
80
|
+
Example:
|
81
|
+
|
82
|
+
... code-block:: python
|
83
|
+
@batch.feature_set(entity="users", data_sources=["snowflake_users_table"])
|
84
|
+
def user_features():
|
85
|
+
return SparkSqlTransformation("SELECT user_id, age FROM data_source")
|
86
|
+
|
87
|
+
Example with key:
|
88
|
+
|
89
|
+
... code-block:: python
|
90
|
+
@batch.feature_set(key="user_id", data_sources=["snowflake_users_table"])
|
91
|
+
def user_features():
|
92
|
+
return SparkSqlTransformation("SELECT user_id, age FROM data_source")
|
93
|
+
"""
|
94
|
+
|
95
|
+
def decorator(function):
|
96
|
+
sig: Signature = inspect.signature(function)
|
97
|
+
if "context" in sig.parameters:
|
98
|
+
user_transformation = function(context=Context())
|
99
|
+
else:
|
100
|
+
user_transformation = function()
|
101
|
+
|
102
|
+
FeaturesetUtils.validate_base_featureset_decorator(
|
103
|
+
user_transformation=user_transformation, entity=entity, key=key
|
104
|
+
)
|
105
|
+
|
106
|
+
fs_name = name or function.__name__
|
107
|
+
batch_feature_set = BatchFeatureSet(
|
108
|
+
name=fs_name,
|
109
|
+
entity=entity if entity else None,
|
110
|
+
key=key if key else None,
|
111
|
+
data_sources=data_sources,
|
112
|
+
timestamp_column_name=timestamp_column_name,
|
113
|
+
transformation=user_transformation,
|
114
|
+
scheduling_policy=getattr(
|
115
|
+
function, _SCHEDULING_POLICY_ATTRIBUTE, "0 */4 * * *"
|
116
|
+
),
|
117
|
+
metadata=get_metadata_from_function(
|
118
|
+
function, description=fs_name, display_name=fs_name
|
119
|
+
),
|
120
|
+
cluster_template=getattr(
|
121
|
+
function,
|
122
|
+
_EXECUTION_SPECIFICATION_ATTRIBUTE,
|
123
|
+
ClusterTemplate.MEDIUM,
|
124
|
+
),
|
125
|
+
backfill=getattr(function, _BACKFILL_POLICY_ATTRIBUTE, None),
|
126
|
+
__instance_module_path__=inspect.stack()[1].filename,
|
127
|
+
)
|
128
|
+
|
129
|
+
functools.update_wrapper(batch_feature_set, user_transformation)
|
130
|
+
return batch_feature_set
|
131
|
+
|
132
|
+
return decorator
|
133
|
+
|
134
|
+
|
135
|
+
@typechecked
|
136
|
+
def scheduling(*, cron_expression: Optional[str]):
|
137
|
+
"""
|
138
|
+
Sets the scheduling policy of the batch feature set according to the given cron expression
|
139
|
+
A cron expression is a string consisting of six or seven subexpressions (fields) that describe individual details
|
140
|
+
of the schedule. These fields, separated by white space, can contain any of the allowed values with various
|
141
|
+
combinations of the allowed characters for that field.
|
142
|
+
|
143
|
+
If None was passed instead of cron expression, the feature set will not be scheduled,
|
144
|
+
and would be triggered only by user request
|
145
|
+
|
146
|
+
Some more examples:
|
147
|
+
|
148
|
+
Expression Means
|
149
|
+
0 0 12 * * ? Fire at 12:00 PM (noon) every day
|
150
|
+
0 15 10 ? * * Fire at 10:15 AM every day
|
151
|
+
0 15 10 * * ? Fire at 10:15 AM every day
|
152
|
+
0 15 10 * * ? * Fire at 10:15 AM every day
|
153
|
+
0 15 10 * * ? 2005 Fire at 10:15 AM every day during the year 2005
|
154
|
+
0 * 14 * * ? Fire every minute starting at 2:00 PM and ending at 2:59 PM, every day
|
155
|
+
|
156
|
+
:param cron_expression: cron expression
|
157
|
+
|
158
|
+
Example:
|
159
|
+
|
160
|
+
... code-block:: python
|
161
|
+
|
162
|
+
@batch.feature_set(entity="users", data_sources=["snowflake_users_table"])
|
163
|
+
@batch.scheduling(cron_expression="0 8 * * *")
|
164
|
+
def user_features():
|
165
|
+
return SparkSqlTransformation("SELECT user_id, age FROM data_source")
|
166
|
+
|
167
|
+
"""
|
168
|
+
|
169
|
+
# TODO: add backend validation on cron expression
|
170
|
+
def decorator(user_transformation):
|
171
|
+
_validate_decorator_ordering(user_transformation)
|
172
|
+
setattr(user_transformation, _SCHEDULING_POLICY_ATTRIBUTE, cron_expression)
|
173
|
+
|
174
|
+
return user_transformation
|
175
|
+
|
176
|
+
return decorator
|
177
|
+
|
178
|
+
|
179
|
+
@typechecked
|
180
|
+
def metadata(
|
181
|
+
*,
|
182
|
+
owner: Optional[str] = None,
|
183
|
+
description: Optional[str] = None,
|
184
|
+
display_name: Optional[str] = None,
|
185
|
+
version_comment: Optional[str] = None,
|
186
|
+
):
|
187
|
+
"""
|
188
|
+
Sets additional user provided metadata
|
189
|
+
|
190
|
+
:param owner: feature set owner
|
191
|
+
:param description: General description of the feature set
|
192
|
+
:param display_name: Human readable name of the feature set
|
193
|
+
:param version_comment: Comment which describes the version
|
194
|
+
Example:
|
195
|
+
|
196
|
+
... code-block:: python
|
197
|
+
|
198
|
+
@batch.feature_set(entity="users", data_sources=["snowflake_users_table"])
|
199
|
+
@batch.metadata(
|
200
|
+
owner="datainfra@frogml.com",
|
201
|
+
display_name="User Batch Features",
|
202
|
+
description="Users feature from the Snowflake replica of the production users table",
|
203
|
+
)
|
204
|
+
def user_features():
|
205
|
+
return SparkSqlTransformation("SELECT user_id, age FROM data_source")
|
206
|
+
|
207
|
+
"""
|
208
|
+
|
209
|
+
def decorator(user_transformation):
|
210
|
+
_validate_decorator_ordering(user_transformation)
|
211
|
+
set_metadata_on_function(
|
212
|
+
function=user_transformation,
|
213
|
+
owner=owner,
|
214
|
+
description=description,
|
215
|
+
display_name=display_name,
|
216
|
+
version_comment=version_comment,
|
217
|
+
)
|
218
|
+
|
219
|
+
return user_transformation
|
220
|
+
|
221
|
+
return decorator
|
222
|
+
|
223
|
+
|
224
|
+
@typechecked
|
225
|
+
def backfill(
|
226
|
+
*,
|
227
|
+
start_date: datetime,
|
228
|
+
):
|
229
|
+
"""
|
230
|
+
Set the backfill policy of the feature set.
|
231
|
+
|
232
|
+
:param start_date: Start date of the backfill process. Data is extracted starting from this date
|
233
|
+
:param end_date: Optionally the end date of the backfill process. Cuts off the backfill according to this date
|
234
|
+
|
235
|
+
Example:
|
236
|
+
|
237
|
+
... code-block:: python
|
238
|
+
@batch.feature_set(entity="users", data_sources=["snowflake_users_table"])
|
239
|
+
@batch.backfill(start_date=datetime(2022, 1, 1))
|
240
|
+
def user_features():
|
241
|
+
return SparkSqlTransformation("SELECT user_id, age FROM data_source")
|
242
|
+
|
243
|
+
"""
|
244
|
+
|
245
|
+
def decorator(user_transformation):
|
246
|
+
_validate_decorator_ordering(user_transformation)
|
247
|
+
setattr(
|
248
|
+
user_transformation,
|
249
|
+
_BACKFILL_POLICY_ATTRIBUTE,
|
250
|
+
Backfill(start_date=start_date),
|
251
|
+
)
|
252
|
+
|
253
|
+
return user_transformation
|
254
|
+
|
255
|
+
return decorator
|
256
|
+
|
257
|
+
|
258
|
+
@typechecked
|
259
|
+
def execution_specification(
|
260
|
+
*,
|
261
|
+
cluster_template: ClusterTemplate,
|
262
|
+
):
|
263
|
+
"""
|
264
|
+
Set the execution specification of the cluster running the feature set
|
265
|
+
|
266
|
+
:param cluster_template: Predefined template sizes
|
267
|
+
|
268
|
+
Cluster template example:
|
269
|
+
|
270
|
+
... code-block:: python
|
271
|
+
@batch.feature_set(entity="users", data_sources=["snowflake_users_table"])
|
272
|
+
@batch.execution_specification(cluster_template=ClusterTemplate.MEDIUM)
|
273
|
+
def user_features():
|
274
|
+
return SparkSqlTransformation("SELECT user_id, age FROM data_source"
|
275
|
+
|
276
|
+
"""
|
277
|
+
|
278
|
+
def decorator(user_transformation):
|
279
|
+
_validate_decorator_ordering(user_transformation)
|
280
|
+
setattr(
|
281
|
+
user_transformation, _EXECUTION_SPECIFICATION_ATTRIBUTE, cluster_template
|
282
|
+
)
|
283
|
+
|
284
|
+
return user_transformation
|
285
|
+
|
286
|
+
return decorator
|
287
|
+
|
288
|
+
|
289
|
+
def _validate_decorator_ordering(user_transformation):
|
290
|
+
if isinstance(user_transformation, BatchFeatureSet):
|
291
|
+
raise ValueError(
|
292
|
+
"Wrong decorator ordering - @batch.feature_set should be the top most decorator"
|
293
|
+
)
|
294
|
+
|
295
|
+
|
296
|
+
@dataclass
|
297
|
+
class BatchFeatureSet(BaseFeatureSet):
|
298
|
+
timestamp_column_name: str = str()
|
299
|
+
scheduling_policy: str = str()
|
300
|
+
transformation: Optional[BaseTransformation] = None
|
301
|
+
metadata: Optional[Metadata] = None
|
302
|
+
cluster_template: Optional[ClusterTemplate] = None
|
303
|
+
backfill: Optional[Backfill] = None
|
304
|
+
|
305
|
+
def __post_init__(self):
|
306
|
+
self._validate()
|
307
|
+
|
308
|
+
@classmethod
|
309
|
+
def _from_proto(cls, proto: FeatureSetSpec):
|
310
|
+
batch_v1_def = proto.feature_set_type.batch_feature_set_v1
|
311
|
+
|
312
|
+
return cls(
|
313
|
+
name=proto.name,
|
314
|
+
entity=Entity._from_proto(proto.entity),
|
315
|
+
data_sources=[
|
316
|
+
ds.data_source.name for ds in batch_v1_def.feature_set_batch_sources
|
317
|
+
],
|
318
|
+
timestamp_column_name=batch_v1_def.timestamp_column_name,
|
319
|
+
scheduling_policy=batch_v1_def.scheduling_policy,
|
320
|
+
transformation=BaseTransformation._from_proto(batch_v1_def.transformation),
|
321
|
+
metadata=Metadata.from_proto(proto.metadata),
|
322
|
+
cluster_template=ClusterTemplate.from_cluster_template_number(
|
323
|
+
batch_v1_def.execution_spec.cluster_template
|
324
|
+
),
|
325
|
+
backfill=Backfill.from_proto(batch_v1_def.backfill),
|
326
|
+
)
|
327
|
+
|
328
|
+
def _get_data_sources(self, feature_registry) -> List[ProtoFeatureSetBatchSource]:
|
329
|
+
if isinstance(self.data_sources, list):
|
330
|
+
actual_data_sources = {
|
331
|
+
ds_name: ReadPolicy.NewOnly for ds_name in self.data_sources
|
332
|
+
}
|
333
|
+
else:
|
334
|
+
actual_data_sources = self.data_sources
|
335
|
+
|
336
|
+
return [
|
337
|
+
ProtoFeatureSetBatchSource(
|
338
|
+
data_source=get_batch_source_for_featureset(ds, feature_registry),
|
339
|
+
read_policy=(
|
340
|
+
read_policy().to_proto()
|
341
|
+
if inspect.isclass(read_policy)
|
342
|
+
else read_policy.to_proto()
|
343
|
+
),
|
344
|
+
)
|
345
|
+
for ds, read_policy in actual_data_sources.items()
|
346
|
+
]
|
347
|
+
|
348
|
+
def _get_timestamp_column(
|
349
|
+
self, data_sources: List[ProtoFeatureSetBatchSource]
|
350
|
+
) -> str:
|
351
|
+
if self.timestamp_column_name:
|
352
|
+
return self.timestamp_column_name
|
353
|
+
|
354
|
+
# if no explicit timestamp column was set AND there's a TimeFrame
|
355
|
+
# datasource, set the default column name.
|
356
|
+
has_timeframe: bool = any(
|
357
|
+
[ds.read_policy.WhichOneof("type") == "time_frame" for ds in data_sources]
|
358
|
+
)
|
359
|
+
if has_timeframe:
|
360
|
+
return _DEFAULT_TIMEFRAME_TS_COL_NAME
|
361
|
+
|
362
|
+
if len(data_sources) >= 2:
|
363
|
+
raise ValueError(
|
364
|
+
"If more than one data source is defined - `timestamp_column_name` on the feature set decorator must be defined"
|
365
|
+
)
|
366
|
+
|
367
|
+
# if we got here - only one data source is defined
|
368
|
+
return data_sources[0].data_source.date_created_column
|
369
|
+
|
370
|
+
def _validate(self):
|
371
|
+
super()._validate()
|
372
|
+
|
373
|
+
def _to_proto(
|
374
|
+
self,
|
375
|
+
git_commit,
|
376
|
+
features,
|
377
|
+
feature_registry,
|
378
|
+
artifact_url: Optional[str] = str(),
|
379
|
+
**kwargs,
|
380
|
+
) -> Tuple[FeatureSetSpec, Optional[str]]:
|
381
|
+
self._validate()
|
382
|
+
|
383
|
+
data_sources = self._get_data_sources(feature_registry)
|
384
|
+
|
385
|
+
if not artifact_url:
|
386
|
+
artifact: Optional[ArtifactSpec] = ArtifactsUploader.get_artifact_spec(
|
387
|
+
self.transformation, self.name, self.__instance_module_path__
|
388
|
+
)
|
389
|
+
if artifact:
|
390
|
+
artifact_url = ArtifactsUploader.upload(artifact)
|
391
|
+
|
392
|
+
return (
|
393
|
+
FeatureSetSpec(
|
394
|
+
name=self.name,
|
395
|
+
metadata=self.metadata.to_proto(),
|
396
|
+
git_commit=git_commit,
|
397
|
+
features=features,
|
398
|
+
entity=self._get_entity_definition(feature_registry),
|
399
|
+
feature_set_type=ProtoFeatureSetType(
|
400
|
+
batch_feature_set_v1=ProtoBatchFeatureSetV1(
|
401
|
+
online_sink=True,
|
402
|
+
offline_sink=True,
|
403
|
+
timestamp_column_name=self._get_timestamp_column(data_sources),
|
404
|
+
scheduling_policy=self.scheduling_policy,
|
405
|
+
feature_set_batch_sources=data_sources,
|
406
|
+
execution_spec=ProtoExecutionSpec(
|
407
|
+
cluster_template=(
|
408
|
+
ClusterTemplate.to_proto(self.cluster_template)
|
409
|
+
if self.cluster_template
|
410
|
+
else None
|
411
|
+
)
|
412
|
+
),
|
413
|
+
transformation=(
|
414
|
+
self.transformation._to_proto(artifact_path=artifact_url)
|
415
|
+
if self.transformation
|
416
|
+
else None
|
417
|
+
),
|
418
|
+
backfill=self.backfill.to_proto() if self.backfill else None,
|
419
|
+
)
|
420
|
+
),
|
421
|
+
),
|
422
|
+
artifact_url,
|
423
|
+
)
|
424
|
+
|
425
|
+
def get_sample(
|
426
|
+
self,
|
427
|
+
number_of_rows: int = 10,
|
428
|
+
validation_options: Optional[FeatureSetValidationOptions] = None,
|
429
|
+
) -> "pd.DataFrame":
|
430
|
+
"""
|
431
|
+
Fetches a sample of the Feature set transformation by loading requested sample of data from the data source
|
432
|
+
and executing the transformation on that data.
|
433
|
+
|
434
|
+
:param number_of_rows: number of rows requests
|
435
|
+
:param validation_options: validation options
|
436
|
+
:returns Sample Pandas Dataframe
|
437
|
+
|
438
|
+
Example with entity:
|
439
|
+
|
440
|
+
... code-block:: python
|
441
|
+
@batch.feature_set(entity="users", data_sources=["snowflake_users_table"])
|
442
|
+
@batch.backfill(start_date=datetime(2022, 1, 1))
|
443
|
+
def user_features():
|
444
|
+
return SparkSqlTransformation("SELECT user_id, age FROM data_source")
|
445
|
+
|
446
|
+
sample_features = user_features.get_sample()
|
447
|
+
print(sample_feature)
|
448
|
+
# user_id timestamp user_features.age
|
449
|
+
# 0 1 2021-01-02 17:00:00 23
|
450
|
+
# 1 1 2021-01-01 12:00:00 51
|
451
|
+
# 2 2 2021-01-02 12:00:00 66
|
452
|
+
# 3 2 2021-01-01 18:00:00 34
|
453
|
+
|
454
|
+
Example with key:
|
455
|
+
|
456
|
+
... code-block:: python
|
457
|
+
@batch.feature_set(key="user_id", data_sources=["snowflake_users_table"])
|
458
|
+
@batch.backfill(start_date=datetime(2022, 1, 1))
|
459
|
+
def user_features():
|
460
|
+
return SparkSqlTransformation("SELECT user_id, age FROM data_source")
|
461
|
+
|
462
|
+
sample_features = user_features.get_sample()
|
463
|
+
print(sample_feature)
|
464
|
+
# user_id timestamp user_features.age
|
465
|
+
# 0 1 2021-01-02 17:00:00 23
|
466
|
+
# 1 1 2021-01-01 12:00:00 51
|
467
|
+
# 2 2 2021-01-02 12:00:00 66
|
468
|
+
# 3 2 2021-01-01 18:00:00 34
|
469
|
+
"""
|
470
|
+
return super().get_sample(
|
471
|
+
number_of_rows=number_of_rows, validation_options=validation_options
|
472
|
+
)
|
@@ -0,0 +1,13 @@
|
|
1
|
+
from dataclasses import dataclass
|
2
|
+
from datetime import datetime
|
3
|
+
from typing import Union
|
4
|
+
|
5
|
+
|
6
|
+
@dataclass
|
7
|
+
class Context:
|
8
|
+
start_time: Union[
|
9
|
+
str, datetime
|
10
|
+
] = "${qwak_ingestion_start_timestamp}" # todo mlops-2312 - rename?
|
11
|
+
end_time: Union[
|
12
|
+
str, datetime
|
13
|
+
] = "${qwak_ingestion_end_timestamp}" # todo mlops-2312 - rename?
|
@@ -0,0 +1,75 @@
|
|
1
|
+
from enum import Enum, auto
|
2
|
+
|
3
|
+
from _frogml_proto.qwak.feature_store.features.execution_pb2 import LARGE as ProtoLARGE
|
4
|
+
from _frogml_proto.qwak.feature_store.features.execution_pb2 import (
|
5
|
+
MEDIUM as ProtoMEDIUM,
|
6
|
+
)
|
7
|
+
from _frogml_proto.qwak.feature_store.features.execution_pb2 import NANO as ProtoNANO
|
8
|
+
from _frogml_proto.qwak.feature_store.features.execution_pb2 import SMALL as ProtoSMALL
|
9
|
+
from _frogml_proto.qwak.feature_store.features.execution_pb2 import (
|
10
|
+
XLARGE as ProtoXLARGE,
|
11
|
+
)
|
12
|
+
from _frogml_proto.qwak.feature_store.features.execution_pb2 import (
|
13
|
+
XXLARGE as ProtoXXLARGE,
|
14
|
+
)
|
15
|
+
from _frogml_proto.qwak.feature_store.features.execution_pb2 import (
|
16
|
+
XXXLARGE as ProtoXXXLARGE,
|
17
|
+
)
|
18
|
+
from _frogml_proto.qwak.feature_store.features.execution_pb2 import (
|
19
|
+
ClusterTemplate as ProtoClusterTemplate,
|
20
|
+
)
|
21
|
+
|
22
|
+
|
23
|
+
class AutoName(Enum):
|
24
|
+
def _generate_next_value_(name, start, count, last_values):
|
25
|
+
return name
|
26
|
+
|
27
|
+
|
28
|
+
class ClusterTemplate(AutoName):
|
29
|
+
SMALL = auto()
|
30
|
+
MEDIUM = auto()
|
31
|
+
LARGE = auto()
|
32
|
+
XLARGE = auto()
|
33
|
+
XXLARGE = auto()
|
34
|
+
XXXLARGE = auto()
|
35
|
+
NANO = auto()
|
36
|
+
|
37
|
+
_cluster_template_to_proto = {
|
38
|
+
SMALL: ProtoSMALL,
|
39
|
+
MEDIUM: ProtoMEDIUM,
|
40
|
+
LARGE: ProtoLARGE,
|
41
|
+
XLARGE: ProtoXLARGE,
|
42
|
+
XXLARGE: ProtoXXLARGE,
|
43
|
+
XXXLARGE: ProtoXXXLARGE,
|
44
|
+
NANO: ProtoNANO,
|
45
|
+
}
|
46
|
+
|
47
|
+
_proto_to_cluster_template = {v: k for k, v in _cluster_template_to_proto.items()}
|
48
|
+
|
49
|
+
@classmethod
|
50
|
+
def from_proto(cls, proto: ProtoClusterTemplate):
|
51
|
+
return cls(
|
52
|
+
ClusterTemplate._proto_to_cluster_template.value[proto.cluster_template]
|
53
|
+
)
|
54
|
+
|
55
|
+
@classmethod
|
56
|
+
def from_cluster_template_number(cls, cluster_template_number: int):
|
57
|
+
return cls(
|
58
|
+
ClusterTemplate._proto_to_cluster_template.value[cluster_template_number]
|
59
|
+
)
|
60
|
+
|
61
|
+
@staticmethod
|
62
|
+
def to_proto(template):
|
63
|
+
if not template:
|
64
|
+
return None
|
65
|
+
|
66
|
+
_cluster_template_to_proto = {
|
67
|
+
ClusterTemplate.SMALL: ProtoSMALL,
|
68
|
+
ClusterTemplate.MEDIUM: ProtoMEDIUM,
|
69
|
+
ClusterTemplate.LARGE: ProtoLARGE,
|
70
|
+
ClusterTemplate.XLARGE: ProtoXLARGE,
|
71
|
+
ClusterTemplate.XXLARGE: ProtoXXLARGE,
|
72
|
+
ClusterTemplate.XXXLARGE: ProtoXXXLARGE,
|
73
|
+
ClusterTemplate.NANO: ProtoNANO,
|
74
|
+
}
|
75
|
+
return _cluster_template_to_proto[template]
|
@@ -0,0 +1,75 @@
|
|
1
|
+
from dataclasses import dataclass
|
2
|
+
|
3
|
+
from _frogml_proto.qwak.feature_store.features.feature_set_pb2 import (
|
4
|
+
FeatureSetUserMetadata as ProtoMetadata,
|
5
|
+
)
|
6
|
+
from _frogml_proto.qwak.feature_store.features.feature_set_pb2 import (
|
7
|
+
FeaturesetVersionUserMetadata as ProtoFeaturesetVersionUserMetadata,
|
8
|
+
)
|
9
|
+
|
10
|
+
_METADATA_ATTRIBUTE = "_qwak_metadata"
|
11
|
+
|
12
|
+
|
13
|
+
def set_metadata_on_function(
|
14
|
+
function,
|
15
|
+
owner: str = "",
|
16
|
+
description: str = "",
|
17
|
+
display_name: str = "",
|
18
|
+
version_comment="",
|
19
|
+
):
|
20
|
+
setattr(
|
21
|
+
function,
|
22
|
+
_METADATA_ATTRIBUTE,
|
23
|
+
Metadata(
|
24
|
+
owner=owner,
|
25
|
+
description=description,
|
26
|
+
display_name=display_name,
|
27
|
+
version_comment=version_comment,
|
28
|
+
),
|
29
|
+
)
|
30
|
+
|
31
|
+
|
32
|
+
def get_metadata_from_function(
|
33
|
+
function,
|
34
|
+
owner: str = "",
|
35
|
+
description: str = "",
|
36
|
+
display_name: str = "",
|
37
|
+
version_comment="",
|
38
|
+
):
|
39
|
+
return getattr(
|
40
|
+
function,
|
41
|
+
_METADATA_ATTRIBUTE,
|
42
|
+
Metadata(
|
43
|
+
owner=owner,
|
44
|
+
description=description,
|
45
|
+
display_name=display_name,
|
46
|
+
version_comment=version_comment,
|
47
|
+
),
|
48
|
+
)
|
49
|
+
|
50
|
+
|
51
|
+
@dataclass
|
52
|
+
class Metadata:
|
53
|
+
owner: str = ""
|
54
|
+
description: str = ""
|
55
|
+
display_name: str = ""
|
56
|
+
version_comment: str = ""
|
57
|
+
|
58
|
+
@staticmethod
|
59
|
+
def from_proto(metadata: ProtoMetadata):
|
60
|
+
return Metadata(
|
61
|
+
owner=metadata.owner,
|
62
|
+
description=metadata.description,
|
63
|
+
display_name=metadata.display_name,
|
64
|
+
version_comment=metadata.featureset_version_user_metadata.comment,
|
65
|
+
)
|
66
|
+
|
67
|
+
def to_proto(self):
|
68
|
+
return ProtoMetadata(
|
69
|
+
owner=self.owner,
|
70
|
+
description=self.description,
|
71
|
+
display_name=self.display_name,
|
72
|
+
featureset_version_user_metadata=ProtoFeaturesetVersionUserMetadata(
|
73
|
+
comment=self.version_comment
|
74
|
+
),
|
75
|
+
)
|