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.
Files changed (1013) hide show
  1. _frogml_proto/__init__.py +0 -0
  2. _frogml_proto/jfml/model_version/v1/model_repository_spec_pb2.py +35 -0
  3. _frogml_proto/jfml/model_version/v1/model_repository_spec_pb2.pyi +38 -0
  4. _frogml_proto/jfml/model_version/v1/model_repository_spec_pb2_grpc.py +4 -0
  5. _frogml_proto/jfml/model_version/v1/model_version_framework_pb2.py +45 -0
  6. _frogml_proto/jfml/model_version/v1/model_version_framework_pb2.pyi +41 -0
  7. _frogml_proto/jfml/model_version/v1/model_version_framework_pb2_grpc.py +4 -0
  8. _frogml_proto/jfml/model_version/v1/model_version_manager_service_pb2.py +151 -0
  9. _frogml_proto/jfml/model_version/v1/model_version_manager_service_pb2.pyi +230 -0
  10. _frogml_proto/jfml/model_version/v1/model_version_manager_service_pb2_grpc.py +237 -0
  11. _frogml_proto/jfml/model_version/v1/model_version_pb2.py +88 -0
  12. _frogml_proto/jfml/model_version/v1/model_version_pb2.pyi +133 -0
  13. _frogml_proto/jfml/model_version/v1/model_version_pb2_grpc.py +4 -0
  14. _frogml_proto/qwak/administration/account/v1/account_pb2.py +114 -0
  15. _frogml_proto/qwak/administration/account/v1/account_pb2.pyi +257 -0
  16. _frogml_proto/qwak/administration/account/v1/account_pb2_grpc.py +4 -0
  17. _frogml_proto/qwak/administration/account/v1/account_service_pb2.py +212 -0
  18. _frogml_proto/qwak/administration/account/v1/account_service_pb2.pyi +344 -0
  19. _frogml_proto/qwak/administration/account/v1/account_service_pb2_grpc.py +338 -0
  20. _frogml_proto/qwak/administration/account/v1/jfrog_tenant_details_pb2.py +77 -0
  21. _frogml_proto/qwak/administration/account/v1/jfrog_tenant_details_pb2.pyi +109 -0
  22. _frogml_proto/qwak/administration/account/v1/jfrog_tenant_details_pb2_grpc.py +4 -0
  23. _frogml_proto/qwak/administration/account/v1/personalization_pb2.py +45 -0
  24. _frogml_proto/qwak/administration/account/v1/personalization_pb2.pyi +49 -0
  25. _frogml_proto/qwak/administration/account/v1/personalization_pb2_grpc.py +4 -0
  26. _frogml_proto/qwak/administration/account/v1/preferences_pb2.py +36 -0
  27. _frogml_proto/qwak/administration/account/v1/preferences_pb2.pyi +35 -0
  28. _frogml_proto/qwak/administration/account/v1/preferences_pb2_grpc.py +4 -0
  29. _frogml_proto/qwak/administration/account/v1/terms_pb2.py +75 -0
  30. _frogml_proto/qwak/administration/account/v1/terms_pb2.pyi +94 -0
  31. _frogml_proto/qwak/administration/account/v1/terms_pb2_grpc.py +4 -0
  32. _frogml_proto/qwak/administration/authenticated_user/v1/authenticated_user_service_pb2.py +91 -0
  33. _frogml_proto/qwak/administration/authenticated_user/v1/authenticated_user_service_pb2.pyi +108 -0
  34. _frogml_proto/qwak/administration/authenticated_user/v1/authenticated_user_service_pb2_grpc.py +135 -0
  35. _frogml_proto/qwak/administration/authenticated_user/v1/credentials_pb2.py +46 -0
  36. _frogml_proto/qwak/administration/authenticated_user/v1/credentials_pb2.pyi +62 -0
  37. _frogml_proto/qwak/administration/authenticated_user/v1/credentials_pb2_grpc.py +4 -0
  38. _frogml_proto/qwak/administration/authenticated_user/v1/details_pb2.py +75 -0
  39. _frogml_proto/qwak/administration/authenticated_user/v1/details_pb2.pyi +140 -0
  40. _frogml_proto/qwak/administration/authenticated_user/v1/details_pb2_grpc.py +4 -0
  41. _frogml_proto/qwak/administration/v0/authentication/authentication_service_pb2.py +69 -0
  42. _frogml_proto/qwak/administration/v0/authentication/authentication_service_pb2.pyi +92 -0
  43. _frogml_proto/qwak/administration/v0/authentication/authentication_service_pb2_grpc.py +67 -0
  44. _frogml_proto/qwak/administration/v0/environments/configuration_pb2.py +93 -0
  45. _frogml_proto/qwak/administration/v0/environments/configuration_pb2.pyi +233 -0
  46. _frogml_proto/qwak/administration/v0/environments/configuration_pb2_grpc.py +4 -0
  47. _frogml_proto/qwak/administration/v0/environments/environment_pb2.py +66 -0
  48. _frogml_proto/qwak/administration/v0/environments/environment_pb2.pyi +156 -0
  49. _frogml_proto/qwak/administration/v0/environments/environment_pb2_grpc.py +4 -0
  50. _frogml_proto/qwak/administration/v0/environments/environment_service_pb2.py +184 -0
  51. _frogml_proto/qwak/administration/v0/environments/environment_service_pb2.pyi +274 -0
  52. _frogml_proto/qwak/administration/v0/environments/environment_service_pb2_grpc.py +272 -0
  53. _frogml_proto/qwak/administration/v0/environments/personalization_pb2.py +45 -0
  54. _frogml_proto/qwak/administration/v0/environments/personalization_pb2.pyi +45 -0
  55. _frogml_proto/qwak/administration/v0/environments/personalization_pb2_grpc.py +4 -0
  56. _frogml_proto/qwak/administration/v0/users/user_pb2.py +97 -0
  57. _frogml_proto/qwak/administration/v0/users/user_pb2.pyi +249 -0
  58. _frogml_proto/qwak/administration/v0/users/user_pb2_grpc.py +4 -0
  59. _frogml_proto/qwak/admiral/secret/v0/secret_pb2.py +140 -0
  60. _frogml_proto/qwak/admiral/secret/v0/secret_pb2.pyi +237 -0
  61. _frogml_proto/qwak/admiral/secret/v0/secret_pb2_grpc.py +4 -0
  62. _frogml_proto/qwak/admiral/secret/v0/secret_service_pb2.py +89 -0
  63. _frogml_proto/qwak/admiral/secret/v0/secret_service_pb2.pyi +93 -0
  64. _frogml_proto/qwak/admiral/secret/v0/secret_service_pb2_grpc.py +135 -0
  65. _frogml_proto/qwak/admiral/secret/v0/system_secret_service_pb2.py +89 -0
  66. _frogml_proto/qwak/admiral/secret/v0/system_secret_service_pb2.pyi +101 -0
  67. _frogml_proto/qwak/admiral/secret/v0/system_secret_service_pb2_grpc.py +135 -0
  68. _frogml_proto/qwak/admiral/user_application_instance/v0/user_application_instance_pb2.py +198 -0
  69. _frogml_proto/qwak/admiral/user_application_instance/v0/user_application_instance_pb2.pyi +431 -0
  70. _frogml_proto/qwak/admiral/user_application_instance/v0/user_application_instance_pb2_grpc.py +4 -0
  71. _frogml_proto/qwak/admiral/user_application_instance/v0/user_application_instance_service_pb2.py +109 -0
  72. _frogml_proto/qwak/admiral/user_application_instance/v0/user_application_instance_service_pb2.pyi +128 -0
  73. _frogml_proto/qwak/admiral/user_application_instance/v0/user_application_instance_service_pb2_grpc.py +169 -0
  74. _frogml_proto/qwak/analytics/analytics_pb2.py +142 -0
  75. _frogml_proto/qwak/analytics/analytics_pb2.pyi +308 -0
  76. _frogml_proto/qwak/analytics/analytics_pb2_grpc.py +4 -0
  77. _frogml_proto/qwak/analytics/analytics_service_pb2.py +229 -0
  78. _frogml_proto/qwak/analytics/analytics_service_pb2.pyi +339 -0
  79. _frogml_proto/qwak/analytics/analytics_service_pb2_grpc.py +370 -0
  80. _frogml_proto/qwak/audience/v1/audience_api_pb2.py +149 -0
  81. _frogml_proto/qwak/audience/v1/audience_api_pb2.pyi +176 -0
  82. _frogml_proto/qwak/audience/v1/audience_api_pb2_grpc.py +240 -0
  83. _frogml_proto/qwak/audience/v1/audience_pb2.py +137 -0
  84. _frogml_proto/qwak/audience/v1/audience_pb2.pyi +313 -0
  85. _frogml_proto/qwak/audience/v1/audience_pb2_grpc.py +4 -0
  86. _frogml_proto/qwak/auto_scaling/v1/auto_scaling_pb2.py +100 -0
  87. _frogml_proto/qwak/auto_scaling/v1/auto_scaling_pb2.pyi +187 -0
  88. _frogml_proto/qwak/auto_scaling/v1/auto_scaling_pb2_grpc.py +4 -0
  89. _frogml_proto/qwak/auto_scaling/v1/auto_scaling_service_pb2.py +49 -0
  90. _frogml_proto/qwak/auto_scaling/v1/auto_scaling_service_pb2.pyi +55 -0
  91. _frogml_proto/qwak/auto_scaling/v1/auto_scaling_service_pb2_grpc.py +67 -0
  92. _frogml_proto/qwak/automation/v1/action_pb2.py +220 -0
  93. _frogml_proto/qwak/automation/v1/action_pb2.pyi +513 -0
  94. _frogml_proto/qwak/automation/v1/action_pb2_grpc.py +4 -0
  95. _frogml_proto/qwak/automation/v1/auto_scaling_pb2.py +97 -0
  96. _frogml_proto/qwak/automation/v1/auto_scaling_pb2.pyi +177 -0
  97. _frogml_proto/qwak/automation/v1/auto_scaling_pb2_grpc.py +4 -0
  98. _frogml_proto/qwak/automation/v1/automation_execution_pb2.py +65 -0
  99. _frogml_proto/qwak/automation/v1/automation_execution_pb2.pyi +123 -0
  100. _frogml_proto/qwak/automation/v1/automation_execution_pb2_grpc.py +4 -0
  101. _frogml_proto/qwak/automation/v1/automation_management_service_pb2.py +283 -0
  102. _frogml_proto/qwak/automation/v1/automation_management_service_pb2.pyi +386 -0
  103. _frogml_proto/qwak/automation/v1/automation_management_service_pb2_grpc.py +429 -0
  104. _frogml_proto/qwak/automation/v1/automation_pb2.py +59 -0
  105. _frogml_proto/qwak/automation/v1/automation_pb2.pyi +121 -0
  106. _frogml_proto/qwak/automation/v1/automation_pb2_grpc.py +4 -0
  107. _frogml_proto/qwak/automation/v1/common_pb2.py +56 -0
  108. _frogml_proto/qwak/automation/v1/common_pb2.pyi +71 -0
  109. _frogml_proto/qwak/automation/v1/common_pb2_grpc.py +4 -0
  110. _frogml_proto/qwak/automation/v1/notification_pb2.py +93 -0
  111. _frogml_proto/qwak/automation/v1/notification_pb2.pyi +134 -0
  112. _frogml_proto/qwak/automation/v1/notification_pb2_grpc.py +4 -0
  113. _frogml_proto/qwak/automation/v1/trigger_pb2.py +76 -0
  114. _frogml_proto/qwak/automation/v1/trigger_pb2.pyi +112 -0
  115. _frogml_proto/qwak/automation/v1/trigger_pb2_grpc.py +4 -0
  116. _frogml_proto/qwak/batch_job/v1/batch_job_events_pb2.py +148 -0
  117. _frogml_proto/qwak/batch_job/v1/batch_job_events_pb2.pyi +307 -0
  118. _frogml_proto/qwak/batch_job/v1/batch_job_events_pb2_grpc.py +4 -0
  119. _frogml_proto/qwak/batch_job/v1/batch_job_resources_pb2.py +47 -0
  120. _frogml_proto/qwak/batch_job/v1/batch_job_resources_pb2.pyi +61 -0
  121. _frogml_proto/qwak/batch_job/v1/batch_job_resources_pb2_grpc.py +4 -0
  122. _frogml_proto/qwak/batch_job/v1/batch_job_service_pb2.py +570 -0
  123. _frogml_proto/qwak/batch_job/v1/batch_job_service_pb2.pyi +1328 -0
  124. _frogml_proto/qwak/batch_job/v1/batch_job_service_pb2_grpc.py +574 -0
  125. _frogml_proto/qwak/build/v1/build_api_pb2.py +446 -0
  126. _frogml_proto/qwak/build/v1/build_api_pb2.pyi +682 -0
  127. _frogml_proto/qwak/build/v1/build_api_pb2_grpc.py +594 -0
  128. _frogml_proto/qwak/build/v1/build_pb2.py +575 -0
  129. _frogml_proto/qwak/build/v1/build_pb2.pyi +1328 -0
  130. _frogml_proto/qwak/build/v1/build_pb2_grpc.py +4 -0
  131. _frogml_proto/qwak/build_settings/build_settings_api_pb2.py +89 -0
  132. _frogml_proto/qwak/build_settings/build_settings_api_pb2.pyi +106 -0
  133. _frogml_proto/qwak/build_settings/build_settings_api_pb2_grpc.py +132 -0
  134. _frogml_proto/qwak/build_settings/build_settings_pb2.py +95 -0
  135. _frogml_proto/qwak/build_settings/build_settings_pb2.pyi +148 -0
  136. _frogml_proto/qwak/build_settings/build_settings_pb2_grpc.py +4 -0
  137. _frogml_proto/qwak/builds/build_pb2.py +233 -0
  138. _frogml_proto/qwak/builds/build_pb2.pyi +582 -0
  139. _frogml_proto/qwak/builds/build_pb2_grpc.py +4 -0
  140. _frogml_proto/qwak/builds/build_url_pb2.py +86 -0
  141. _frogml_proto/qwak/builds/build_url_pb2.pyi +179 -0
  142. _frogml_proto/qwak/builds/build_url_pb2_grpc.py +4 -0
  143. _frogml_proto/qwak/builds/builds_orchestrator_service_pb2.py +212 -0
  144. _frogml_proto/qwak/builds/builds_orchestrator_service_pb2.pyi +322 -0
  145. _frogml_proto/qwak/builds/builds_orchestrator_service_pb2_grpc.py +306 -0
  146. _frogml_proto/qwak/builds/builds_pb2.py +556 -0
  147. _frogml_proto/qwak/builds/builds_pb2.pyi +1271 -0
  148. _frogml_proto/qwak/builds/builds_pb2_grpc.py +237 -0
  149. _frogml_proto/qwak/builds/internal_builds_orchestrator_service_pb2.py +59 -0
  150. _frogml_proto/qwak/builds/internal_builds_orchestrator_service_pb2.pyi +64 -0
  151. _frogml_proto/qwak/builds/internal_builds_orchestrator_service_pb2_grpc.py +67 -0
  152. _frogml_proto/qwak/data_versioning/data_versioning_pb2.py +45 -0
  153. _frogml_proto/qwak/data_versioning/data_versioning_pb2.pyi +71 -0
  154. _frogml_proto/qwak/data_versioning/data_versioning_pb2_grpc.py +4 -0
  155. _frogml_proto/qwak/data_versioning/data_versioning_service_pb2.py +69 -0
  156. _frogml_proto/qwak/data_versioning/data_versioning_service_pb2.pyi +83 -0
  157. _frogml_proto/qwak/data_versioning/data_versioning_service_pb2_grpc.py +101 -0
  158. _frogml_proto/qwak/deployment/alert_pb2.py +131 -0
  159. _frogml_proto/qwak/deployment/alert_pb2.pyi +262 -0
  160. _frogml_proto/qwak/deployment/alert_pb2_grpc.py +4 -0
  161. _frogml_proto/qwak/deployment/alert_service_pb2.py +153 -0
  162. _frogml_proto/qwak/deployment/alert_service_pb2.pyi +218 -0
  163. _frogml_proto/qwak/deployment/alert_service_pb2_grpc.py +237 -0
  164. _frogml_proto/qwak/deployment/deployment_messages_pb2.py +36 -0
  165. _frogml_proto/qwak/deployment/deployment_messages_pb2.pyi +61 -0
  166. _frogml_proto/qwak/deployment/deployment_messages_pb2_grpc.py +4 -0
  167. _frogml_proto/qwak/deployment/deployment_pb2.py +644 -0
  168. _frogml_proto/qwak/deployment/deployment_pb2.pyi +1582 -0
  169. _frogml_proto/qwak/deployment/deployment_pb2_grpc.py +4 -0
  170. _frogml_proto/qwak/deployment/deployment_service_pb2.py +520 -0
  171. _frogml_proto/qwak/deployment/deployment_service_pb2.pyi +817 -0
  172. _frogml_proto/qwak/deployment/deployment_service_pb2_grpc.py +509 -0
  173. _frogml_proto/qwak/ecosystem/v0/credentials_pb2.py +56 -0
  174. _frogml_proto/qwak/ecosystem/v0/credentials_pb2.pyi +91 -0
  175. _frogml_proto/qwak/ecosystem/v0/credentials_pb2_grpc.py +4 -0
  176. _frogml_proto/qwak/ecosystem/v0/ecosystem_pb2.py +173 -0
  177. _frogml_proto/qwak/ecosystem/v0/ecosystem_pb2.pyi +332 -0
  178. _frogml_proto/qwak/ecosystem/v0/ecosystem_pb2_grpc.py +4 -0
  179. _frogml_proto/qwak/ecosystem/v0/ecosystem_runtime_service_pb2.py +264 -0
  180. _frogml_proto/qwak/ecosystem/v0/ecosystem_runtime_service_pb2.pyi +434 -0
  181. _frogml_proto/qwak/ecosystem/v0/ecosystem_runtime_service_pb2_grpc.py +238 -0
  182. _frogml_proto/qwak/execution/v1/backfill_pb2.py +97 -0
  183. _frogml_proto/qwak/execution/v1/backfill_pb2.pyi +167 -0
  184. _frogml_proto/qwak/execution/v1/backfill_pb2_grpc.py +4 -0
  185. _frogml_proto/qwak/execution/v1/batch_pb2.py +56 -0
  186. _frogml_proto/qwak/execution/v1/batch_pb2.pyi +76 -0
  187. _frogml_proto/qwak/execution/v1/batch_pb2_grpc.py +4 -0
  188. _frogml_proto/qwak/execution/v1/deletion_pb2.py +65 -0
  189. _frogml_proto/qwak/execution/v1/deletion_pb2.pyi +67 -0
  190. _frogml_proto/qwak/execution/v1/deletion_pb2_grpc.py +4 -0
  191. _frogml_proto/qwak/execution/v1/execution_pb2.py +96 -0
  192. _frogml_proto/qwak/execution/v1/execution_pb2.pyi +201 -0
  193. _frogml_proto/qwak/execution/v1/execution_pb2_grpc.py +4 -0
  194. _frogml_proto/qwak/execution/v1/execution_service_pb2.py +294 -0
  195. _frogml_proto/qwak/execution/v1/execution_service_pb2.pyi +431 -0
  196. _frogml_proto/qwak/execution/v1/execution_service_pb2_grpc.py +467 -0
  197. _frogml_proto/qwak/execution/v1/jobs/job_pb2.py +101 -0
  198. _frogml_proto/qwak/execution/v1/jobs/job_pb2.pyi +282 -0
  199. _frogml_proto/qwak/execution/v1/jobs/job_pb2_grpc.py +4 -0
  200. _frogml_proto/qwak/execution/v1/jobs/job_service_pb2.py +270 -0
  201. _frogml_proto/qwak/execution/v1/jobs/job_service_pb2.pyi +469 -0
  202. _frogml_proto/qwak/execution/v1/jobs/job_service_pb2_grpc.py +396 -0
  203. _frogml_proto/qwak/execution/v1/jobs/reports/report_pb2.py +109 -0
  204. _frogml_proto/qwak/execution/v1/jobs/reports/report_pb2.pyi +266 -0
  205. _frogml_proto/qwak/execution/v1/jobs/reports/report_pb2_grpc.py +4 -0
  206. _frogml_proto/qwak/execution/v1/state/execution_state_pb2.py +36 -0
  207. _frogml_proto/qwak/execution/v1/state/execution_state_pb2.pyi +45 -0
  208. _frogml_proto/qwak/execution/v1/state/execution_state_pb2_grpc.py +4 -0
  209. _frogml_proto/qwak/execution/v1/state/execution_state_service_pb2.py +150 -0
  210. _frogml_proto/qwak/execution/v1/state/execution_state_service_pb2.pyi +192 -0
  211. _frogml_proto/qwak/execution/v1/state/execution_state_service_pb2_grpc.py +237 -0
  212. _frogml_proto/qwak/execution/v1/state/featureset_state_pb2.py +35 -0
  213. _frogml_proto/qwak/execution/v1/state/featureset_state_pb2.pyi +37 -0
  214. _frogml_proto/qwak/execution/v1/state/featureset_state_pb2_grpc.py +4 -0
  215. _frogml_proto/qwak/execution/v1/state/spark_execution_state_pb2.py +91 -0
  216. _frogml_proto/qwak/execution/v1/state/spark_execution_state_pb2.pyi +156 -0
  217. _frogml_proto/qwak/execution/v1/state/spark_execution_state_pb2_grpc.py +4 -0
  218. _frogml_proto/qwak/execution/v1/streaming_aggregation_pb2.py +75 -0
  219. _frogml_proto/qwak/execution/v1/streaming_aggregation_pb2.pyi +95 -0
  220. _frogml_proto/qwak/execution/v1/streaming_aggregation_pb2_grpc.py +4 -0
  221. _frogml_proto/qwak/execution/v1/streaming_pb2.py +65 -0
  222. _frogml_proto/qwak/execution/v1/streaming_pb2.pyi +79 -0
  223. _frogml_proto/qwak/execution/v1/streaming_pb2_grpc.py +4 -0
  224. _frogml_proto/qwak/feature_store/entities/entity_pb2.py +79 -0
  225. _frogml_proto/qwak/feature_store/entities/entity_pb2.pyi +166 -0
  226. _frogml_proto/qwak/feature_store/entities/entity_pb2_grpc.py +4 -0
  227. _frogml_proto/qwak/feature_store/entities/entity_service_pb2.py +149 -0
  228. _frogml_proto/qwak/feature_store/entities/entity_service_pb2.pyi +203 -0
  229. _frogml_proto/qwak/feature_store/entities/entity_service_pb2_grpc.py +237 -0
  230. _frogml_proto/qwak/feature_store/features/aggregation_pb2.py +196 -0
  231. _frogml_proto/qwak/feature_store/features/aggregation_pb2.pyi +361 -0
  232. _frogml_proto/qwak/feature_store/features/aggregation_pb2_grpc.py +4 -0
  233. _frogml_proto/qwak/feature_store/features/deployment_pb2.py +189 -0
  234. _frogml_proto/qwak/feature_store/features/deployment_pb2.pyi +379 -0
  235. _frogml_proto/qwak/feature_store/features/deployment_pb2_grpc.py +4 -0
  236. _frogml_proto/qwak/feature_store/features/deployment_service_pb2.py +49 -0
  237. _frogml_proto/qwak/feature_store/features/deployment_service_pb2.pyi +45 -0
  238. _frogml_proto/qwak/feature_store/features/deployment_service_pb2_grpc.py +67 -0
  239. _frogml_proto/qwak/feature_store/features/execution_pb2.py +77 -0
  240. _frogml_proto/qwak/feature_store/features/execution_pb2.pyi +158 -0
  241. _frogml_proto/qwak/feature_store/features/execution_pb2_grpc.py +4 -0
  242. _frogml_proto/qwak/feature_store/features/feature_set_attribute_pb2.py +36 -0
  243. _frogml_proto/qwak/feature_store/features/feature_set_attribute_pb2.pyi +33 -0
  244. _frogml_proto/qwak/feature_store/features/feature_set_attribute_pb2_grpc.py +4 -0
  245. _frogml_proto/qwak/feature_store/features/feature_set_pb2.py +198 -0
  246. _frogml_proto/qwak/feature_store/features/feature_set_pb2.pyi +443 -0
  247. _frogml_proto/qwak/feature_store/features/feature_set_pb2_grpc.py +4 -0
  248. _frogml_proto/qwak/feature_store/features/feature_set_service_pb2.py +467 -0
  249. _frogml_proto/qwak/feature_store/features/feature_set_service_pb2.pyi +663 -0
  250. _frogml_proto/qwak/feature_store/features/feature_set_service_pb2_grpc.py +746 -0
  251. _frogml_proto/qwak/feature_store/features/feature_set_state_pb2.py +203 -0
  252. _frogml_proto/qwak/feature_store/features/feature_set_state_pb2.pyi +329 -0
  253. _frogml_proto/qwak/feature_store/features/feature_set_state_pb2_grpc.py +4 -0
  254. _frogml_proto/qwak/feature_store/features/feature_set_state_service_pb2.py +129 -0
  255. _frogml_proto/qwak/feature_store/features/feature_set_state_service_pb2.pyi +175 -0
  256. _frogml_proto/qwak/feature_store/features/feature_set_state_service_pb2_grpc.py +203 -0
  257. _frogml_proto/qwak/feature_store/features/feature_set_types_pb2.py +381 -0
  258. _frogml_proto/qwak/feature_store/features/feature_set_types_pb2.pyi +862 -0
  259. _frogml_proto/qwak/feature_store/features/feature_set_types_pb2_grpc.py +4 -0
  260. _frogml_proto/qwak/feature_store/features/monitoring_pb2.py +55 -0
  261. _frogml_proto/qwak/feature_store/features/monitoring_pb2.pyi +67 -0
  262. _frogml_proto/qwak/feature_store/features/monitoring_pb2_grpc.py +4 -0
  263. _frogml_proto/qwak/feature_store/features/real_time_feature_extractor_pb2.py +167 -0
  264. _frogml_proto/qwak/feature_store/features/real_time_feature_extractor_pb2.pyi +359 -0
  265. _frogml_proto/qwak/feature_store/features/real_time_feature_extractor_pb2_grpc.py +4 -0
  266. _frogml_proto/qwak/feature_store/jobs/job_pb2.py +68 -0
  267. _frogml_proto/qwak/feature_store/jobs/job_pb2.pyi +169 -0
  268. _frogml_proto/qwak/feature_store/jobs/job_pb2_grpc.py +4 -0
  269. _frogml_proto/qwak/feature_store/jobs/job_service_pb2.py +149 -0
  270. _frogml_proto/qwak/feature_store/jobs/job_service_pb2.pyi +237 -0
  271. _frogml_proto/qwak/feature_store/jobs/job_service_pb2_grpc.py +237 -0
  272. _frogml_proto/qwak/feature_store/jobs/v1/job_pb2.py +67 -0
  273. _frogml_proto/qwak/feature_store/jobs/v1/job_pb2.pyi +175 -0
  274. _frogml_proto/qwak/feature_store/jobs/v1/job_pb2_grpc.py +4 -0
  275. _frogml_proto/qwak/feature_store/jobs/v1/job_service_pb2.py +210 -0
  276. _frogml_proto/qwak/feature_store/jobs/v1/job_service_pb2.pyi +349 -0
  277. _frogml_proto/qwak/feature_store/jobs/v1/job_service_pb2_grpc.py +338 -0
  278. _frogml_proto/qwak/feature_store/platform/platform_details_pb2.py +46 -0
  279. _frogml_proto/qwak/feature_store/platform/platform_details_pb2.pyi +54 -0
  280. _frogml_proto/qwak/feature_store/platform/platform_details_pb2_grpc.py +4 -0
  281. _frogml_proto/qwak/feature_store/reports/report_pb2.py +75 -0
  282. _frogml_proto/qwak/feature_store/reports/report_pb2.pyi +159 -0
  283. _frogml_proto/qwak/feature_store/reports/report_pb2_grpc.py +4 -0
  284. _frogml_proto/qwak/feature_store/repository/common/platform_pb2.py +55 -0
  285. _frogml_proto/qwak/feature_store/repository/common/platform_pb2.pyi +70 -0
  286. _frogml_proto/qwak/feature_store/repository/common/platform_pb2_grpc.py +4 -0
  287. _frogml_proto/qwak/feature_store/serving/management_pb2.py +69 -0
  288. _frogml_proto/qwak/feature_store/serving/management_pb2.pyi +72 -0
  289. _frogml_proto/qwak/feature_store/serving/management_pb2_grpc.py +101 -0
  290. _frogml_proto/qwak/feature_store/serving/metadata_pb2.py +67 -0
  291. _frogml_proto/qwak/feature_store/serving/metadata_pb2.pyi +158 -0
  292. _frogml_proto/qwak/feature_store/serving/metadata_pb2_grpc.py +4 -0
  293. _frogml_proto/qwak/feature_store/serving/serving_pb2.py +254 -0
  294. _frogml_proto/qwak/feature_store/serving/serving_pb2.pyi +476 -0
  295. _frogml_proto/qwak/feature_store/serving/serving_pb2_grpc.py +101 -0
  296. _frogml_proto/qwak/feature_store/serving/v1/value_pb2.py +46 -0
  297. _frogml_proto/qwak/feature_store/serving/v1/value_pb2.pyi +91 -0
  298. _frogml_proto/qwak/feature_store/serving/v1/value_pb2_grpc.py +4 -0
  299. _frogml_proto/qwak/feature_store/sinks/sink_pb2.py +76 -0
  300. _frogml_proto/qwak/feature_store/sinks/sink_pb2.pyi +137 -0
  301. _frogml_proto/qwak/feature_store/sinks/sink_pb2_grpc.py +4 -0
  302. _frogml_proto/qwak/feature_store/sources/batch_pb2.py +362 -0
  303. _frogml_proto/qwak/feature_store/sources/batch_pb2.pyi +911 -0
  304. _frogml_proto/qwak/feature_store/sources/batch_pb2_grpc.py +4 -0
  305. _frogml_proto/qwak/feature_store/sources/data_source_attribute_pb2.py +36 -0
  306. _frogml_proto/qwak/feature_store/sources/data_source_attribute_pb2.pyi +33 -0
  307. _frogml_proto/qwak/feature_store/sources/data_source_attribute_pb2_grpc.py +4 -0
  308. _frogml_proto/qwak/feature_store/sources/data_source_pb2.py +84 -0
  309. _frogml_proto/qwak/feature_store/sources/data_source_pb2.pyi +169 -0
  310. _frogml_proto/qwak/feature_store/sources/data_source_pb2_grpc.py +4 -0
  311. _frogml_proto/qwak/feature_store/sources/data_source_service_pb2.py +169 -0
  312. _frogml_proto/qwak/feature_store/sources/data_source_service_pb2.pyi +237 -0
  313. _frogml_proto/qwak/feature_store/sources/data_source_service_pb2_grpc.py +305 -0
  314. _frogml_proto/qwak/feature_store/sources/streaming_pb2.py +175 -0
  315. _frogml_proto/qwak/feature_store/sources/streaming_pb2.pyi +356 -0
  316. _frogml_proto/qwak/feature_store/sources/streaming_pb2_grpc.py +4 -0
  317. _frogml_proto/qwak/feature_store/v1/common/source_code/source_code_pb2.py +55 -0
  318. _frogml_proto/qwak/feature_store/v1/common/source_code/source_code_pb2.pyi +69 -0
  319. _frogml_proto/qwak/feature_store/v1/common/source_code/source_code_pb2_grpc.py +4 -0
  320. _frogml_proto/qwak/feature_store/v1/internal/data_source/data_source_service_pb2.py +68 -0
  321. _frogml_proto/qwak/feature_store/v1/internal/data_source/data_source_service_pb2.pyi +71 -0
  322. _frogml_proto/qwak/feature_store/v1/internal/data_source/data_source_service_pb2_grpc.py +99 -0
  323. _frogml_proto/qwak/feature_store/v1/internal/featureset/featureset_token_service_pb2.py +48 -0
  324. _frogml_proto/qwak/feature_store/v1/internal/featureset/featureset_token_service_pb2.pyi +46 -0
  325. _frogml_proto/qwak/feature_store/v1/internal/featureset/featureset_token_service_pb2_grpc.py +66 -0
  326. _frogml_proto/qwak/features_operator/v1/features_operator_pb2.py +76 -0
  327. _frogml_proto/qwak/features_operator/v1/features_operator_pb2.pyi +129 -0
  328. _frogml_proto/qwak/features_operator/v1/features_operator_pb2_grpc.py +4 -0
  329. _frogml_proto/qwak/features_operator/v1/features_operator_service_pb2.py +69 -0
  330. _frogml_proto/qwak/features_operator/v1/features_operator_service_pb2.pyi +98 -0
  331. _frogml_proto/qwak/features_operator/v1/features_operator_service_pb2_grpc.py +99 -0
  332. _frogml_proto/qwak/features_operator/v2/features_operator_pb2.py +86 -0
  333. _frogml_proto/qwak/features_operator/v2/features_operator_pb2.pyi +138 -0
  334. _frogml_proto/qwak/features_operator/v2/features_operator_pb2_grpc.py +4 -0
  335. _frogml_proto/qwak/features_operator/v2/features_operator_service_pb2.py +61 -0
  336. _frogml_proto/qwak/features_operator/v2/features_operator_service_pb2.pyi +89 -0
  337. _frogml_proto/qwak/features_operator/v2/features_operator_service_pb2_grpc.py +99 -0
  338. _frogml_proto/qwak/features_operator/v3/features_operator_async_service_pb2.py +132 -0
  339. _frogml_proto/qwak/features_operator/v3/features_operator_async_service_pb2.pyi +218 -0
  340. _frogml_proto/qwak/features_operator/v3/features_operator_async_service_pb2_grpc.py +165 -0
  341. _frogml_proto/qwak/features_operator/v3/features_operator_pb2.py +86 -0
  342. _frogml_proto/qwak/features_operator/v3/features_operator_pb2.pyi +143 -0
  343. _frogml_proto/qwak/features_operator/v3/features_operator_pb2_grpc.py +4 -0
  344. _frogml_proto/qwak/file_versioning/file_versioning_pb2.py +56 -0
  345. _frogml_proto/qwak/file_versioning/file_versioning_pb2.pyi +103 -0
  346. _frogml_proto/qwak/file_versioning/file_versioning_pb2_grpc.py +4 -0
  347. _frogml_proto/qwak/file_versioning/file_versioning_service_pb2.py +69 -0
  348. _frogml_proto/qwak/file_versioning/file_versioning_service_pb2.pyi +83 -0
  349. _frogml_proto/qwak/file_versioning/file_versioning_service_pb2_grpc.py +101 -0
  350. _frogml_proto/qwak/fitness_service/constructs_pb2.py +120 -0
  351. _frogml_proto/qwak/fitness_service/constructs_pb2.pyi +297 -0
  352. _frogml_proto/qwak/fitness_service/constructs_pb2_grpc.py +4 -0
  353. _frogml_proto/qwak/fitness_service/fitness_pb2.py +54 -0
  354. _frogml_proto/qwak/fitness_service/fitness_pb2.pyi +126 -0
  355. _frogml_proto/qwak/fitness_service/fitness_pb2_grpc.py +4 -0
  356. _frogml_proto/qwak/fitness_service/fitness_service_pb2.py +110 -0
  357. _frogml_proto/qwak/fitness_service/fitness_service_pb2.pyi +121 -0
  358. _frogml_proto/qwak/fitness_service/fitness_service_pb2_grpc.py +169 -0
  359. _frogml_proto/qwak/fitness_service/status_pb2.py +128 -0
  360. _frogml_proto/qwak/fitness_service/status_pb2.pyi +283 -0
  361. _frogml_proto/qwak/fitness_service/status_pb2_grpc.py +4 -0
  362. _frogml_proto/qwak/inference/feedback/feedback_pb2.py +118 -0
  363. _frogml_proto/qwak/inference/feedback/feedback_pb2.pyi +253 -0
  364. _frogml_proto/qwak/inference/feedback/feedback_pb2_grpc.py +100 -0
  365. _frogml_proto/qwak/instance_template/instance_template_pb2.py +62 -0
  366. _frogml_proto/qwak/instance_template/instance_template_pb2.pyi +108 -0
  367. _frogml_proto/qwak/instance_template/instance_template_pb2_grpc.py +4 -0
  368. _frogml_proto/qwak/instance_template/instance_template_service_pb2.py +69 -0
  369. _frogml_proto/qwak/instance_template/instance_template_service_pb2.pyi +79 -0
  370. _frogml_proto/qwak/instance_template/instance_template_service_pb2_grpc.py +101 -0
  371. _frogml_proto/qwak/integration/hugging_face_integration_pb2.py +85 -0
  372. _frogml_proto/qwak/integration/hugging_face_integration_pb2.pyi +106 -0
  373. _frogml_proto/qwak/integration/hugging_face_integration_pb2_grpc.py +4 -0
  374. _frogml_proto/qwak/integration/integration_pb2.py +153 -0
  375. _frogml_proto/qwak/integration/integration_pb2.pyi +357 -0
  376. _frogml_proto/qwak/integration/integration_pb2_grpc.py +4 -0
  377. _frogml_proto/qwak/integration/integration_service_pb2.py +169 -0
  378. _frogml_proto/qwak/integration/integration_service_pb2.pyi +234 -0
  379. _frogml_proto/qwak/integration/integration_service_pb2_grpc.py +271 -0
  380. _frogml_proto/qwak/integration/open_a_i_integration_pb2.py +85 -0
  381. _frogml_proto/qwak/integration/open_a_i_integration_pb2.pyi +109 -0
  382. _frogml_proto/qwak/integration/open_a_i_integration_pb2_grpc.py +4 -0
  383. _frogml_proto/qwak/integration/opsgenie_integration_pb2.py +105 -0
  384. _frogml_proto/qwak/integration/opsgenie_integration_pb2.pyi +168 -0
  385. _frogml_proto/qwak/integration/opsgenie_integration_pb2_grpc.py +4 -0
  386. _frogml_proto/qwak/integration/pagerduty_integration_pb2.py +127 -0
  387. _frogml_proto/qwak/integration/pagerduty_integration_pb2.pyi +195 -0
  388. _frogml_proto/qwak/integration/pagerduty_integration_pb2_grpc.py +4 -0
  389. _frogml_proto/qwak/integration/slack_app_integration_pb2.py +127 -0
  390. _frogml_proto/qwak/integration/slack_app_integration_pb2.pyi +198 -0
  391. _frogml_proto/qwak/integration/slack_app_integration_pb2_grpc.py +4 -0
  392. _frogml_proto/qwak/jfrog/gateway/v0/repository_pb2.py +95 -0
  393. _frogml_proto/qwak/jfrog/gateway/v0/repository_pb2.pyi +125 -0
  394. _frogml_proto/qwak/jfrog/gateway/v0/repository_pb2_grpc.py +4 -0
  395. _frogml_proto/qwak/jfrog/gateway/v0/repository_service_pb2.py +69 -0
  396. _frogml_proto/qwak/jfrog/gateway/v0/repository_service_pb2.pyi +71 -0
  397. _frogml_proto/qwak/jfrog/gateway/v0/repository_service_pb2_grpc.py +101 -0
  398. _frogml_proto/qwak/kube_deployment_captain/alert_pb2.py +120 -0
  399. _frogml_proto/qwak/kube_deployment_captain/alert_pb2.pyi +232 -0
  400. _frogml_proto/qwak/kube_deployment_captain/alert_pb2_grpc.py +4 -0
  401. _frogml_proto/qwak/kube_deployment_captain/alerting_pb2.py +65 -0
  402. _frogml_proto/qwak/kube_deployment_captain/alerting_pb2.pyi +101 -0
  403. _frogml_proto/qwak/kube_deployment_captain/alerting_pb2_grpc.py +4 -0
  404. _frogml_proto/qwak/kube_deployment_captain/batch_job_pb2.py +357 -0
  405. _frogml_proto/qwak/kube_deployment_captain/batch_job_pb2.pyi +845 -0
  406. _frogml_proto/qwak/kube_deployment_captain/batch_job_pb2_grpc.py +4 -0
  407. _frogml_proto/qwak/kube_deployment_captain/deployment_pb2.py +182 -0
  408. _frogml_proto/qwak/kube_deployment_captain/deployment_pb2.pyi +482 -0
  409. _frogml_proto/qwak/kube_deployment_captain/deployment_pb2_grpc.py +4 -0
  410. _frogml_proto/qwak/kube_deployment_captain/feature_set_deployment_pb2.py +172 -0
  411. _frogml_proto/qwak/kube_deployment_captain/feature_set_deployment_pb2.pyi +370 -0
  412. _frogml_proto/qwak/kube_deployment_captain/feature_set_deployment_pb2_grpc.py +4 -0
  413. _frogml_proto/qwak/kube_deployment_captain/kube_deployment_captain_service_pb2.py +562 -0
  414. _frogml_proto/qwak/kube_deployment_captain/kube_deployment_captain_service_pb2.pyi +924 -0
  415. _frogml_proto/qwak/kube_deployment_captain/kube_deployment_captain_service_pb2_grpc.py +1226 -0
  416. _frogml_proto/qwak/kube_deployment_captain/traffic_mapping_pb2.py +45 -0
  417. _frogml_proto/qwak/kube_deployment_captain/traffic_mapping_pb2.pyi +63 -0
  418. _frogml_proto/qwak/kube_deployment_captain/traffic_mapping_pb2_grpc.py +4 -0
  419. _frogml_proto/qwak/logging/log_filter_pb2.py +66 -0
  420. _frogml_proto/qwak/logging/log_filter_pb2.pyi +102 -0
  421. _frogml_proto/qwak/logging/log_filter_pb2_grpc.py +4 -0
  422. _frogml_proto/qwak/logging/log_line_pb2.py +48 -0
  423. _frogml_proto/qwak/logging/log_line_pb2.pyi +62 -0
  424. _frogml_proto/qwak/logging/log_line_pb2_grpc.py +4 -0
  425. _frogml_proto/qwak/logging/log_reader_service_pb2.py +51 -0
  426. _frogml_proto/qwak/logging/log_reader_service_pb2.pyi +83 -0
  427. _frogml_proto/qwak/logging/log_reader_service_pb2_grpc.py +67 -0
  428. _frogml_proto/qwak/logging/log_source_pb2.py +155 -0
  429. _frogml_proto/qwak/logging/log_source_pb2.pyi +321 -0
  430. _frogml_proto/qwak/logging/log_source_pb2_grpc.py +4 -0
  431. _frogml_proto/qwak/model_descriptor/open_ai_descriptor_pb2.py +96 -0
  432. _frogml_proto/qwak/model_descriptor/open_ai_descriptor_pb2.pyi +215 -0
  433. _frogml_proto/qwak/model_descriptor/open_ai_descriptor_pb2_grpc.py +4 -0
  434. _frogml_proto/qwak/models/models_pb2.py +427 -0
  435. _frogml_proto/qwak/models/models_pb2.pyi +851 -0
  436. _frogml_proto/qwak/models/models_pb2_grpc.py +402 -0
  437. _frogml_proto/qwak/monitoring/v0/alerting_channel_management_service_pb2.py +149 -0
  438. _frogml_proto/qwak/monitoring/v0/alerting_channel_management_service_pb2.pyi +183 -0
  439. _frogml_proto/qwak/monitoring/v0/alerting_channel_management_service_pb2_grpc.py +237 -0
  440. _frogml_proto/qwak/monitoring/v0/alerting_channel_pb2.py +175 -0
  441. _frogml_proto/qwak/monitoring/v0/alerting_channel_pb2.pyi +360 -0
  442. _frogml_proto/qwak/monitoring/v0/alerting_channel_pb2_grpc.py +4 -0
  443. _frogml_proto/qwak/monitoring/v0/alerting_channel_sync_service_pb2.py +70 -0
  444. _frogml_proto/qwak/monitoring/v0/alerting_channel_sync_service_pb2.pyi +85 -0
  445. _frogml_proto/qwak/monitoring/v0/alerting_channel_sync_service_pb2_grpc.py +101 -0
  446. _frogml_proto/qwak/offline/serving/v1/feature_values_pb2.py +35 -0
  447. _frogml_proto/qwak/offline/serving/v1/feature_values_pb2.pyi +37 -0
  448. _frogml_proto/qwak/offline/serving/v1/feature_values_pb2_grpc.py +4 -0
  449. _frogml_proto/qwak/offline/serving/v1/offline_serving_async_service_pb2.py +148 -0
  450. _frogml_proto/qwak/offline/serving/v1/offline_serving_async_service_pb2.pyi +279 -0
  451. _frogml_proto/qwak/offline/serving/v1/offline_serving_async_service_pb2_grpc.py +165 -0
  452. _frogml_proto/qwak/offline/serving/v1/options_pb2.py +35 -0
  453. _frogml_proto/qwak/offline/serving/v1/options_pb2.pyi +30 -0
  454. _frogml_proto/qwak/offline/serving/v1/options_pb2_grpc.py +4 -0
  455. _frogml_proto/qwak/offline/serving/v1/population_pb2.py +75 -0
  456. _frogml_proto/qwak/offline/serving/v1/population_pb2.pyi +99 -0
  457. _frogml_proto/qwak/offline/serving/v1/population_pb2_grpc.py +4 -0
  458. _frogml_proto/qwak/projects/projects_pb2.py +225 -0
  459. _frogml_proto/qwak/projects/projects_pb2.pyi +436 -0
  460. _frogml_proto/qwak/projects/projects_pb2_grpc.py +203 -0
  461. _frogml_proto/qwak/prompt/v1/prompt/prompt_manager_service_pb2.py +270 -0
  462. _frogml_proto/qwak/prompt/v1/prompt/prompt_manager_service_pb2.pyi +417 -0
  463. _frogml_proto/qwak/prompt/v1/prompt/prompt_manager_service_pb2_grpc.py +441 -0
  464. _frogml_proto/qwak/prompt/v1/prompt/prompt_pb2.py +237 -0
  465. _frogml_proto/qwak/prompt/v1/prompt/prompt_pb2.pyi +415 -0
  466. _frogml_proto/qwak/prompt/v1/prompt/prompt_pb2_grpc.py +4 -0
  467. _frogml_proto/qwak/secret_service/secret_service_pb2.py +88 -0
  468. _frogml_proto/qwak/secret_service/secret_service_pb2.pyi +101 -0
  469. _frogml_proto/qwak/secret_service/secret_service_pb2_grpc.py +135 -0
  470. _frogml_proto/qwak/self_service/account/v0/account_membership_pb2.py +134 -0
  471. _frogml_proto/qwak/self_service/account/v0/account_membership_pb2.pyi +274 -0
  472. _frogml_proto/qwak/self_service/account/v0/account_membership_pb2_grpc.py +4 -0
  473. _frogml_proto/qwak/self_service/account/v0/account_membership_service_pb2.py +251 -0
  474. _frogml_proto/qwak/self_service/account/v0/account_membership_service_pb2.pyi +337 -0
  475. _frogml_proto/qwak/self_service/account/v0/account_membership_service_pb2_grpc.py +407 -0
  476. _frogml_proto/qwak/self_service/account/v0/account_status_pb2.py +93 -0
  477. _frogml_proto/qwak/self_service/account/v0/account_status_pb2.pyi +169 -0
  478. _frogml_proto/qwak/self_service/account/v0/account_status_pb2_grpc.py +4 -0
  479. _frogml_proto/qwak/self_service/account/v0/managing_account_pb2.py +155 -0
  480. _frogml_proto/qwak/self_service/account/v0/managing_account_pb2.pyi +279 -0
  481. _frogml_proto/qwak/self_service/account/v0/managing_account_pb2_grpc.py +4 -0
  482. _frogml_proto/qwak/self_service/account/v0/managing_account_service_pb2.py +110 -0
  483. _frogml_proto/qwak/self_service/account/v0/managing_account_service_pb2.pyi +136 -0
  484. _frogml_proto/qwak/self_service/account/v0/managing_account_service_pb2_grpc.py +169 -0
  485. _frogml_proto/qwak/self_service/user/v1/api_key_pb2.py +35 -0
  486. _frogml_proto/qwak/self_service/user/v1/api_key_pb2.pyi +30 -0
  487. _frogml_proto/qwak/self_service/user/v1/api_key_pb2_grpc.py +4 -0
  488. _frogml_proto/qwak/self_service/user/v1/user_pb2.py +37 -0
  489. _frogml_proto/qwak/self_service/user/v1/user_pb2.pyi +62 -0
  490. _frogml_proto/qwak/self_service/user/v1/user_pb2_grpc.py +4 -0
  491. _frogml_proto/qwak/self_service/user/v1/user_service_pb2.py +146 -0
  492. _frogml_proto/qwak/self_service/user/v1/user_service_pb2.pyi +209 -0
  493. _frogml_proto/qwak/self_service/user/v1/user_service_pb2_grpc.py +203 -0
  494. _frogml_proto/qwak/traffic/v1/traffic_api_pb2.py +109 -0
  495. _frogml_proto/qwak/traffic/v1/traffic_api_pb2.pyi +137 -0
  496. _frogml_proto/qwak/traffic/v1/traffic_api_pb2_grpc.py +169 -0
  497. _frogml_proto/qwak/traffic/v1/traffic_pb2.py +134 -0
  498. _frogml_proto/qwak/traffic/v1/traffic_pb2.pyi +285 -0
  499. _frogml_proto/qwak/traffic/v1/traffic_pb2_grpc.py +4 -0
  500. _frogml_proto/qwak/user_application/common/v0/resources_pb2.py +159 -0
  501. _frogml_proto/qwak/user_application/common/v0/resources_pb2.pyi +333 -0
  502. _frogml_proto/qwak/user_application/common/v0/resources_pb2_grpc.py +4 -0
  503. _frogml_proto/qwak/user_application/v0/user_application_pb2.py +69 -0
  504. _frogml_proto/qwak/user_application/v0/user_application_pb2.pyi +89 -0
  505. _frogml_proto/qwak/user_application/v0/user_application_pb2_grpc.py +4 -0
  506. _frogml_proto/qwak/vectors/v1/collection/collection_pb2.py +128 -0
  507. _frogml_proto/qwak/vectors/v1/collection/collection_pb2.pyi +287 -0
  508. _frogml_proto/qwak/vectors/v1/collection/collection_pb2_grpc.py +4 -0
  509. _frogml_proto/qwak/vectors/v1/collection/collection_service_pb2.py +189 -0
  510. _frogml_proto/qwak/vectors/v1/collection/collection_service_pb2.pyi +258 -0
  511. _frogml_proto/qwak/vectors/v1/collection/collection_service_pb2_grpc.py +304 -0
  512. _frogml_proto/qwak/vectors/v1/collection/event/collection_event_pb2.py +36 -0
  513. _frogml_proto/qwak/vectors/v1/collection/event/collection_event_pb2.pyi +41 -0
  514. _frogml_proto/qwak/vectors/v1/collection/event/collection_event_pb2_grpc.py +4 -0
  515. _frogml_proto/qwak/vectors/v1/filters_pb2.py +156 -0
  516. _frogml_proto/qwak/vectors/v1/filters_pb2.pyi +297 -0
  517. _frogml_proto/qwak/vectors/v1/filters_pb2_grpc.py +4 -0
  518. _frogml_proto/qwak/vectors/v1/vector_pb2.py +78 -0
  519. _frogml_proto/qwak/vectors/v1/vector_pb2.pyi +142 -0
  520. _frogml_proto/qwak/vectors/v1/vector_pb2_grpc.py +4 -0
  521. _frogml_proto/qwak/vectors/v1/vector_service_pb2.py +134 -0
  522. _frogml_proto/qwak/vectors/v1/vector_service_pb2.pyi +243 -0
  523. _frogml_proto/qwak/vectors/v1/vector_service_pb2_grpc.py +201 -0
  524. _frogml_proto/qwak/workspace/workspace_pb2.py +135 -0
  525. _frogml_proto/qwak/workspace/workspace_pb2.pyi +331 -0
  526. _frogml_proto/qwak/workspace/workspace_pb2_grpc.py +4 -0
  527. _frogml_proto/qwak/workspace/workspace_service_pb2.py +309 -0
  528. _frogml_proto/qwak/workspace/workspace_service_pb2.pyi +393 -0
  529. _frogml_proto/qwak/workspace/workspace_service_pb2_grpc.py +507 -0
  530. frogml/__init__.py +16 -0
  531. frogml/automations/__init__.py +70 -0
  532. frogml/automations/automation_executions.py +99 -0
  533. frogml/automations/automations.py +396 -0
  534. frogml/automations/batch_execution_action.py +336 -0
  535. frogml/automations/build_and_deploy_action.py +840 -0
  536. frogml/automations/common.py +106 -0
  537. frogml/clients/__init__.py +0 -0
  538. frogml/clients/_inner/__init__.py +0 -0
  539. frogml/clients/_inner/edge_communications.py +24 -0
  540. frogml/clients/administration/__init__.py +4 -0
  541. frogml/clients/administration/authenticated_user/__init__.py +0 -0
  542. frogml/clients/administration/authenticated_user/client.py +41 -0
  543. frogml/clients/administration/authentication/__init__.py +0 -0
  544. frogml/clients/administration/authentication/client.py +34 -0
  545. frogml/clients/administration/eco_system/__init__.py +0 -0
  546. frogml/clients/administration/eco_system/client.py +152 -0
  547. frogml/clients/administration/eco_system/eco_system_utils.py +15 -0
  548. frogml/clients/administration/environment/__init__.py +0 -0
  549. frogml/clients/administration/environment/client.py +77 -0
  550. frogml/clients/administration/self_service/__init__.py +0 -0
  551. frogml/clients/administration/self_service/client.py +73 -0
  552. frogml/clients/alert_management/__init__.py +1 -0
  553. frogml/clients/alert_management/client.py +64 -0
  554. frogml/clients/alerts_registry/__init__.py +1 -0
  555. frogml/clients/alerts_registry/channel.py +132 -0
  556. frogml/clients/alerts_registry/client.py +137 -0
  557. frogml/clients/analytics/__init__.py +1 -0
  558. frogml/clients/analytics/client.py +82 -0
  559. frogml/clients/audience/__init__.py +1 -0
  560. frogml/clients/audience/client.py +53 -0
  561. frogml/clients/automation_management/__init__.py +0 -0
  562. frogml/clients/automation_management/client.py +274 -0
  563. frogml/clients/autoscaling/__init__.py +1 -0
  564. frogml/clients/autoscaling/client.py +34 -0
  565. frogml/clients/batch_job_management/__init__.py +5 -0
  566. frogml/clients/batch_job_management/client.py +544 -0
  567. frogml/clients/batch_job_management/executions_config.py +201 -0
  568. frogml/clients/batch_job_management/results.py +73 -0
  569. frogml/clients/build_management/__init__.py +1 -0
  570. frogml/clients/build_management/client.py +115 -0
  571. frogml/clients/build_orchestrator/__init__.py +2 -0
  572. frogml/clients/build_orchestrator/build_model_request_getter.py +138 -0
  573. frogml/clients/build_orchestrator/client.py +456 -0
  574. frogml/clients/build_orchestrator/internal_client.py +114 -0
  575. frogml/clients/data_versioning/__init__.py +0 -0
  576. frogml/clients/data_versioning/client.py +76 -0
  577. frogml/clients/data_versioning/data_tag_filter.py +32 -0
  578. frogml/clients/deployment/__init__.py +0 -0
  579. frogml/clients/deployment/client.py +191 -0
  580. frogml/clients/feature_store/__init__.py +1 -0
  581. frogml/clients/feature_store/execution_management_client.py +102 -0
  582. frogml/clients/feature_store/job_registry_client.py +71 -0
  583. frogml/clients/feature_store/management_client.py +570 -0
  584. frogml/clients/feature_store/offline_serving_client.py +249 -0
  585. frogml/clients/feature_store/operator_client.py +164 -0
  586. frogml/clients/file_versioning/__init__.py +0 -0
  587. frogml/clients/file_versioning/client.py +77 -0
  588. frogml/clients/file_versioning/file_tag_filter.py +32 -0
  589. frogml/clients/instance_template/__init__.py +0 -0
  590. frogml/clients/instance_template/client.py +67 -0
  591. frogml/clients/integration_management/__init__.py +0 -0
  592. frogml/clients/integration_management/integration_manager_client.py +35 -0
  593. frogml/clients/integration_management/integration_utils.py +27 -0
  594. frogml/clients/integration_management/openai/__init__.py +0 -0
  595. frogml/clients/integration_management/openai/openai_system_secret.py +56 -0
  596. frogml/clients/jfrog_gateway/__init__.py +1 -0
  597. frogml/clients/jfrog_gateway/client.py +42 -0
  598. frogml/clients/kube_deployment_captain/__init__.py +1 -0
  599. frogml/clients/kube_deployment_captain/client.py +233 -0
  600. frogml/clients/logging_client/__init__.py +1 -0
  601. frogml/clients/logging_client/client.py +148 -0
  602. frogml/clients/model_management/__init__.py +1 -0
  603. frogml/clients/model_management/client.py +128 -0
  604. frogml/clients/model_version_manager/__init__.py +1 -0
  605. frogml/clients/model_version_manager/client.py +108 -0
  606. frogml/clients/project/__init__.py +0 -0
  607. frogml/clients/project/client.py +60 -0
  608. frogml/clients/prompt_manager/__init__.py +0 -0
  609. frogml/clients/prompt_manager/model_descriptor_mapper.py +196 -0
  610. frogml/clients/prompt_manager/prompt_manager_client.py +190 -0
  611. frogml/clients/prompt_manager/prompt_proto_mapper.py +262 -0
  612. frogml/clients/secret_service/__init__.py +1 -0
  613. frogml/clients/secret_service/client.py +96 -0
  614. frogml/clients/system_secret/__init__.py +0 -0
  615. frogml/clients/system_secret/system_secret_client.py +31 -0
  616. frogml/clients/user_application_instance/__init__.py +1 -0
  617. frogml/clients/user_application_instance/client.py +177 -0
  618. frogml/clients/vector_store/__init__.py +2 -0
  619. frogml/clients/vector_store/management_client.py +127 -0
  620. frogml/clients/vector_store/serving_client.py +157 -0
  621. frogml/clients/workspace_manager/__init__.py +1 -0
  622. frogml/clients/workspace_manager/client.py +224 -0
  623. frogml/exceptions/__init__.py +13 -0
  624. frogml/exceptions/frogml_decode_exception.py +7 -0
  625. frogml/exceptions/frogml_exception.py +7 -0
  626. frogml/exceptions/frogml_external_exception.py +11 -0
  627. frogml/exceptions/frogml_general_build_exception.py +13 -0
  628. frogml/exceptions/frogml_http_exception.py +19 -0
  629. frogml/exceptions/frogml_inference_exception.py +4 -0
  630. frogml/exceptions/frogml_load_configuration_exception.py +2 -0
  631. frogml/exceptions/frogml_load_model_failed_exception.py +10 -0
  632. frogml/exceptions/frogml_login_exception.py +8 -0
  633. frogml/exceptions/frogml_mock_http_exception.py +4 -0
  634. frogml/exceptions/frogml_model_initialization_exception.py +4 -0
  635. frogml/exceptions/frogml_not_found_exception.py +6 -0
  636. frogml/exceptions/frogml_remote_build_failed.py +5 -0
  637. frogml/exceptions/frogml_suggestion_exception.py +27 -0
  638. frogml/exceptions/quiet_error.py +22 -0
  639. frogml/feature_store/__init__.py +0 -0
  640. frogml/feature_store/_common/__init__.py +0 -0
  641. frogml/feature_store/_common/artifact_utils.py +57 -0
  642. frogml/feature_store/_common/feature_set_utils.py +261 -0
  643. frogml/feature_store/_common/featureset_asterisk_handler.py +115 -0
  644. frogml/feature_store/_common/functions.py +37 -0
  645. frogml/feature_store/_common/packaging.py +244 -0
  646. frogml/feature_store/_common/source_code_spec.py +62 -0
  647. frogml/feature_store/_common/source_code_spec_factory.py +51 -0
  648. frogml/feature_store/_common/value.py +10 -0
  649. frogml/feature_store/data_sources/__init__.py +65 -0
  650. frogml/feature_store/data_sources/attributes.py +25 -0
  651. frogml/feature_store/data_sources/base.py +121 -0
  652. frogml/feature_store/data_sources/batch/__init__.py +0 -0
  653. frogml/feature_store/data_sources/batch/_batch.py +9 -0
  654. frogml/feature_store/data_sources/batch/_jdbc.py +22 -0
  655. frogml/feature_store/data_sources/batch/athena.py +272 -0
  656. frogml/feature_store/data_sources/batch/big_query.py +80 -0
  657. frogml/feature_store/data_sources/batch/clickhouse.py +60 -0
  658. frogml/feature_store/data_sources/batch/csv.py +62 -0
  659. frogml/feature_store/data_sources/batch/elastic_search.py +61 -0
  660. frogml/feature_store/data_sources/batch/filesystem/__init__.py +0 -0
  661. frogml/feature_store/data_sources/batch/filesystem/aws.py +93 -0
  662. frogml/feature_store/data_sources/batch/filesystem/base_config.py +13 -0
  663. frogml/feature_store/data_sources/batch/filesystem/gcp.py +54 -0
  664. frogml/feature_store/data_sources/batch/filesystem/utils.py +59 -0
  665. frogml/feature_store/data_sources/batch/mongodb.py +58 -0
  666. frogml/feature_store/data_sources/batch/mysql.py +50 -0
  667. frogml/feature_store/data_sources/batch/parquet.py +57 -0
  668. frogml/feature_store/data_sources/batch/postgres.py +50 -0
  669. frogml/feature_store/data_sources/batch/redshift.py +85 -0
  670. frogml/feature_store/data_sources/batch/snowflake.py +77 -0
  671. frogml/feature_store/data_sources/batch/vertica.py +58 -0
  672. frogml/feature_store/data_sources/source_authentication.py +35 -0
  673. frogml/feature_store/data_sources/streaming/__init__.py +0 -0
  674. frogml/feature_store/data_sources/streaming/_streaming.py +9 -0
  675. frogml/feature_store/data_sources/streaming/kafka/__init__.py +25 -0
  676. frogml/feature_store/data_sources/streaming/kafka/authentication.py +124 -0
  677. frogml/feature_store/data_sources/streaming/kafka/deserialization.py +115 -0
  678. frogml/feature_store/data_sources/streaming/kafka/kafka.py +121 -0
  679. frogml/feature_store/data_sources/time_partition_columns.py +178 -0
  680. frogml/feature_store/entities/__init__.py +0 -0
  681. frogml/feature_store/entities/entity.py +73 -0
  682. frogml/feature_store/execution/__init__.py +0 -0
  683. frogml/feature_store/execution/backfill.py +197 -0
  684. frogml/feature_store/execution/execution.py +595 -0
  685. frogml/feature_store/execution/execution_query.py +91 -0
  686. frogml/feature_store/feature_sets/__init__.py +0 -0
  687. frogml/feature_store/feature_sets/_utils/_featureset_utils.py +45 -0
  688. frogml/feature_store/feature_sets/backfill.py +72 -0
  689. frogml/feature_store/feature_sets/base_feature_set.py +148 -0
  690. frogml/feature_store/feature_sets/batch.py +472 -0
  691. frogml/feature_store/feature_sets/context.py +13 -0
  692. frogml/feature_store/feature_sets/execution_spec.py +75 -0
  693. frogml/feature_store/feature_sets/metadata.py +75 -0
  694. frogml/feature_store/feature_sets/read_policies.py +245 -0
  695. frogml/feature_store/feature_sets/streaming.py +635 -0
  696. frogml/feature_store/feature_sets/streaming_backfill.py +266 -0
  697. frogml/feature_store/feature_sets/transformations/__init__.py +35 -0
  698. frogml/feature_store/feature_sets/transformations/aggregations/__init__.py +0 -0
  699. frogml/feature_store/feature_sets/transformations/aggregations/aggregations.py +443 -0
  700. frogml/feature_store/feature_sets/transformations/aggregations/windows.py +70 -0
  701. frogml/feature_store/feature_sets/transformations/functions/__init__.py +10 -0
  702. frogml/feature_store/feature_sets/transformations/functions/frogml_pandas.py +64 -0
  703. frogml/feature_store/feature_sets/transformations/functions/schema.py +57 -0
  704. frogml/feature_store/feature_sets/transformations/transformations.py +467 -0
  705. frogml/feature_store/feature_sets/transformations/validations/validations_util.py +78 -0
  706. frogml/feature_store/offline/__init__.py +4 -0
  707. frogml/feature_store/offline/_offline_serving_validations.py +32 -0
  708. frogml/feature_store/offline/_query_engine.py +32 -0
  709. frogml/feature_store/offline/athena/__init__.py +0 -0
  710. frogml/feature_store/offline/athena/athena_query_engine.py +154 -0
  711. frogml/feature_store/offline/client.py +719 -0
  712. frogml/feature_store/offline/client_v2.py +338 -0
  713. frogml/feature_store/offline/feature_set_features.py +25 -0
  714. frogml/feature_store/online/__init__.py +0 -0
  715. frogml/feature_store/online/client.py +352 -0
  716. frogml/feature_store/online/endpoint_utils.py +65 -0
  717. frogml/feature_store/sinks/__init__.py +0 -0
  718. frogml/feature_store/sinks/base.py +18 -0
  719. frogml/feature_store/sinks/kafka.py +59 -0
  720. frogml/feature_store/sinks/streaming/__init__.py +0 -0
  721. frogml/feature_store/sinks/streaming/attachment.py +34 -0
  722. frogml/feature_store/sinks/streaming/factory.py +60 -0
  723. frogml/feature_store/validations/__init__.py +0 -0
  724. frogml/feature_store/validations/validation_options.py +82 -0
  725. frogml/feature_store/validations/validation_response.py +121 -0
  726. frogml/feature_store/validations/validator.py +106 -0
  727. frogml/frogml_client/__init__.py +0 -0
  728. frogml/frogml_client/batch_jobs/execution.py +49 -0
  729. frogml/frogml_client/batch_jobs/task.py +43 -0
  730. frogml/frogml_client/build_api_helpers/__init__.py +0 -0
  731. frogml/frogml_client/build_api_helpers/build_api_steps.py +53 -0
  732. frogml/frogml_client/build_api_helpers/messages.py +6 -0
  733. frogml/frogml_client/build_api_helpers/trigger_build_api.py +65 -0
  734. frogml/frogml_client/builds/__init__.py +0 -0
  735. frogml/frogml_client/builds/build.py +97 -0
  736. frogml/frogml_client/builds/filters/__init__.py +0 -0
  737. frogml/frogml_client/builds/filters/metric_filter.py +38 -0
  738. frogml/frogml_client/builds/filters/parameter_filter.py +36 -0
  739. frogml/frogml_client/client.py +874 -0
  740. frogml/frogml_client/data_versioning/__init__.py +0 -0
  741. frogml/frogml_client/data_versioning/data_tag.py +24 -0
  742. frogml/frogml_client/deployments/__init__.py +0 -0
  743. frogml/frogml_client/deployments/deployment.py +409 -0
  744. frogml/frogml_client/file_versioning/__init__.py +0 -0
  745. frogml/frogml_client/file_versioning/file_tag.py +24 -0
  746. frogml/frogml_client/models/__init__.py +0 -0
  747. frogml/frogml_client/models/model.py +52 -0
  748. frogml/frogml_client/models/model_metadata.py +31 -0
  749. frogml/frogml_client/projects/__init__.py +0 -0
  750. frogml/frogml_client/projects/project.py +56 -0
  751. frogml/inner/__init__.py +11 -0
  752. frogml/inner/build_config/__init__.py +0 -0
  753. frogml/inner/build_config/build_config_v1.py +313 -0
  754. frogml/inner/build_logic/__init__.py +0 -0
  755. frogml/inner/build_logic/build_loggers/__init__.py +0 -0
  756. frogml/inner/build_logic/build_loggers/trigger_build_logger.py +50 -0
  757. frogml/inner/build_logic/constants/__init__.py +0 -0
  758. frogml/inner/build_logic/constants/dependencies.py +5 -0
  759. frogml/inner/build_logic/constants/host_resource.py +4 -0
  760. frogml/inner/build_logic/constants/messages.py +3 -0
  761. frogml/inner/build_logic/constants/temp_dir.py +1 -0
  762. frogml/inner/build_logic/constants/upload_tag.py +7 -0
  763. frogml/inner/build_logic/dependency_manager_type.py +8 -0
  764. frogml/inner/build_logic/execute_build_pipeline.py +64 -0
  765. frogml/inner/build_logic/interface/__init__.py +0 -0
  766. frogml/inner/build_logic/interface/build_logger_interface.py +28 -0
  767. frogml/inner/build_logic/interface/build_phase.py +24 -0
  768. frogml/inner/build_logic/interface/context_interface.py +56 -0
  769. frogml/inner/build_logic/interface/phase_run_handler.py +71 -0
  770. frogml/inner/build_logic/interface/step_inteface.py +26 -0
  771. frogml/inner/build_logic/interface/time_source.py +23 -0
  772. frogml/inner/build_logic/phases/__init__.py +0 -0
  773. frogml/inner/build_logic/phases/phase_010_fetch_model/__init__.py +0 -0
  774. frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_model_step.py +41 -0
  775. frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/__init__.py +0 -0
  776. frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/common.py +32 -0
  777. frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/fetch_strategy_manager.py +62 -0
  778. frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/strategy/__init__.py +0 -0
  779. frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/strategy/folder/__init__.py +0 -0
  780. frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/strategy/folder/folder_strategy.py +131 -0
  781. frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/strategy/git/__init__.py +0 -0
  782. frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/strategy/git/git_strategy.py +184 -0
  783. frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/strategy/strategy.py +48 -0
  784. frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/strategy/zip/__init__.py +0 -0
  785. frogml/inner/build_logic/phases/phase_010_fetch_model/fetch_strategy_manager/strategy/zip/zip_strategy.py +64 -0
  786. frogml/inner/build_logic/phases/phase_010_fetch_model/post_fetch_validation_step.py +139 -0
  787. frogml/inner/build_logic/phases/phase_010_fetch_model/pre_fetch_validation_step.py +263 -0
  788. frogml/inner/build_logic/phases/phase_010_fetch_model/set_version_step.py +33 -0
  789. frogml/inner/build_logic/phases/phase_020_remote_register_frogml_build/__init__.py +0 -0
  790. frogml/inner/build_logic/phases/phase_020_remote_register_frogml_build/cleanup_step.py +20 -0
  791. frogml/inner/build_logic/phases/phase_020_remote_register_frogml_build/start_remote_build_step.py +42 -0
  792. frogml/inner/build_logic/phases/phase_020_remote_register_frogml_build/upload_step.py +257 -0
  793. frogml/inner/build_logic/phases/phases_pipeline.py +44 -0
  794. frogml/inner/build_logic/run_handlers/__init__.py +0 -0
  795. frogml/inner/build_logic/run_handlers/programmatic_phase_run_handler.py +101 -0
  796. frogml/inner/build_logic/tools/__init__.py +0 -0
  797. frogml/inner/build_logic/tools/dependencies_tools.py +68 -0
  798. frogml/inner/build_logic/tools/files.py +237 -0
  799. frogml/inner/build_logic/tools/ignore_files.py +20 -0
  800. frogml/inner/build_logic/tools/text.py +9 -0
  801. frogml/inner/build_logic/trigger_build_context.py +10 -0
  802. frogml/inner/const.py +6 -0
  803. frogml/inner/di_configuration/__init__.py +73 -0
  804. frogml/inner/di_configuration/account.py +106 -0
  805. frogml/inner/di_configuration/config.yml +9 -0
  806. frogml/inner/di_configuration/containers.py +40 -0
  807. frogml/inner/instance_template/__init__.py +0 -0
  808. frogml/inner/instance_template/verify_template_id.py +48 -0
  809. frogml/inner/model_loggers_utils.py +110 -0
  810. frogml/inner/provider.py +6 -0
  811. frogml/inner/runtime_di/__init__.py +13 -0
  812. frogml/inner/runtime_di/containers.py +17 -0
  813. frogml/inner/singleton_meta.py +18 -0
  814. frogml/inner/tool/__init__.py +2 -0
  815. frogml/inner/tool/auth.py +70 -0
  816. frogml/inner/tool/grpc/__init__.py +0 -0
  817. frogml/inner/tool/grpc/grpc_auth.py +42 -0
  818. frogml/inner/tool/grpc/grpc_tools.py +209 -0
  819. frogml/inner/tool/grpc/grpc_try_wrapping.py +16 -0
  820. frogml/inner/tool/protobuf_factory.py +45 -0
  821. frogml/inner/tool/retry_utils.py +23 -0
  822. frogml/inner/tool/run_config/__init__.py +12 -0
  823. frogml/inner/tool/run_config/base.py +127 -0
  824. frogml/inner/tool/run_config/utils.py +316 -0
  825. frogml/llmops/__init__.py +0 -0
  826. frogml/llmops/generation/__init__.py +0 -0
  827. frogml/llmops/generation/_steaming.py +78 -0
  828. frogml/llmops/generation/base.py +5 -0
  829. frogml/llmops/generation/chat/__init__.py +0 -0
  830. frogml/llmops/generation/chat/openai/LICENSE.txt +201 -0
  831. frogml/llmops/generation/chat/openai/types/__init__.py +0 -0
  832. frogml/llmops/generation/chat/openai/types/chat/__init__.py +0 -0
  833. frogml/llmops/generation/chat/openai/types/chat/chat_completion.py +88 -0
  834. frogml/llmops/generation/chat/openai/types/chat/chat_completion_assistant_message_param.py +65 -0
  835. frogml/llmops/generation/chat/openai/types/chat/chat_completion_chunk.py +153 -0
  836. frogml/llmops/generation/chat/openai/types/chat/chat_completion_content_part_text_param.py +28 -0
  837. frogml/llmops/generation/chat/openai/types/chat/chat_completion_function_call_option_param.py +25 -0
  838. frogml/llmops/generation/chat/openai/types/chat/chat_completion_function_message_param.py +33 -0
  839. frogml/llmops/generation/chat/openai/types/chat/chat_completion_message.py +56 -0
  840. frogml/llmops/generation/chat/openai/types/chat/chat_completion_message_param.py +34 -0
  841. frogml/llmops/generation/chat/openai/types/chat/chat_completion_message_tool_call.py +46 -0
  842. frogml/llmops/generation/chat/openai/types/chat/chat_completion_message_tool_call_param.py +44 -0
  843. frogml/llmops/generation/chat/openai/types/chat/chat_completion_named_tool_choice_param.py +32 -0
  844. frogml/llmops/generation/chat/openai/types/chat/chat_completion_role.py +20 -0
  845. frogml/llmops/generation/chat/openai/types/chat/chat_completion_system_message_param.py +35 -0
  846. frogml/llmops/generation/chat/openai/types/chat/chat_completion_token_logprob.py +71 -0
  847. frogml/llmops/generation/chat/openai/types/chat/chat_completion_tool_choice_option_param.py +28 -0
  848. frogml/llmops/generation/chat/openai/types/chat/chat_completion_tool_message_param.py +31 -0
  849. frogml/llmops/generation/chat/openai/types/chat/chat_completion_tool_param.py +29 -0
  850. frogml/llmops/generation/chat/openai/types/chat/chat_completion_user_message_param.py +35 -0
  851. frogml/llmops/generation/chat/openai/types/chat/completion_create_params.py +279 -0
  852. frogml/llmops/generation/chat/openai/types/completion_choice.py +47 -0
  853. frogml/llmops/generation/chat/openai/types/completion_create_params.py +209 -0
  854. frogml/llmops/generation/chat/openai/types/completion_usage.py +30 -0
  855. frogml/llmops/generation/chat/openai/types/model.py +35 -0
  856. frogml/llmops/generation/chat/openai/types/shared/__init__.py +3 -0
  857. frogml/llmops/generation/chat/openai/types/shared/error_object.py +27 -0
  858. frogml/llmops/generation/chat/openai/types/shared/function_definition.py +49 -0
  859. frogml/llmops/generation/chat/openai/types/shared/function_parameters.py +20 -0
  860. frogml/llmops/generation/chat/openai/types/shared_params/__init__.py +2 -0
  861. frogml/llmops/generation/chat/openai/types/shared_params/function_definition.py +49 -0
  862. frogml/llmops/generation/chat/openai/types/shared_params/function_parameters.py +22 -0
  863. frogml/llmops/generation/streaming.py +26 -0
  864. frogml/llmops/model/__init__.py +0 -0
  865. frogml/llmops/model/descriptor.py +40 -0
  866. frogml/llmops/prompt/__init__.py +0 -0
  867. frogml/llmops/prompt/base.py +136 -0
  868. frogml/llmops/prompt/chat/__init__.py +0 -0
  869. frogml/llmops/prompt/chat/message.py +24 -0
  870. frogml/llmops/prompt/chat/template.py +113 -0
  871. frogml/llmops/prompt/chat/value.py +10 -0
  872. frogml/llmops/prompt/manager.py +138 -0
  873. frogml/llmops/prompt/template.py +24 -0
  874. frogml/llmops/prompt/value.py +14 -0
  875. frogml/llmops/provider/__init__.py +0 -0
  876. frogml/llmops/provider/chat.py +44 -0
  877. frogml/llmops/provider/openai/__init__.py +0 -0
  878. frogml/llmops/provider/openai/client.py +126 -0
  879. frogml/llmops/provider/openai/provider.py +91 -0
  880. frogml/model/__init__.py +0 -0
  881. frogml/model/_entity_extraction.py +116 -0
  882. frogml/model/adapters/__init__.py +39 -0
  883. frogml/model/adapters/input_adapters/__init__.py +0 -0
  884. frogml/model/adapters/input_adapters/base_input_adapter.py +8 -0
  885. frogml/model/adapters/input_adapters/dataframe_input_adapter.py +11 -0
  886. frogml/model/adapters/input_adapters/file_input_adapter.py +8 -0
  887. frogml/model/adapters/input_adapters/image_input_adapter.py +8 -0
  888. frogml/model/adapters/input_adapters/json_input_adapter.py +8 -0
  889. frogml/model/adapters/input_adapters/multi_input_adapter.py +66 -0
  890. frogml/model/adapters/input_adapters/numpy_input_adapter.py +100 -0
  891. frogml/model/adapters/input_adapters/proto_input_adapter.py +32 -0
  892. frogml/model/adapters/input_adapters/string_input_adapter.py +8 -0
  893. frogml/model/adapters/input_adapters/tf_tensor_input_adapter.py +8 -0
  894. frogml/model/adapters/output_adapters/__init__.py +0 -0
  895. frogml/model/adapters/output_adapters/base_output_adapter.py +13 -0
  896. frogml/model/adapters/output_adapters/dataframe_output_adapter.py +12 -0
  897. frogml/model/adapters/output_adapters/default_output_adapter.py +9 -0
  898. frogml/model/adapters/output_adapters/json_output_adapter.py +9 -0
  899. frogml/model/adapters/output_adapters/numpy_output_adapter.py +32 -0
  900. frogml/model/adapters/output_adapters/proto_output_adapter.py +16 -0
  901. frogml/model/adapters/output_adapters/qwak_with_default_fallback.py +5 -0
  902. frogml/model/adapters/output_adapters/tf_tensor_output_adapter.py +9 -0
  903. frogml/model/analytics_logging.py +14 -0
  904. frogml/model/base.py +86 -0
  905. frogml/model/decorators/__init__.py +0 -0
  906. frogml/model/decorators/api.py +62 -0
  907. frogml/model/decorators/impl/__init__.py +0 -0
  908. frogml/model/decorators/impl/api_implementation.py +29 -0
  909. frogml/model/decorators/impl/timer_implementation.py +10 -0
  910. frogml/model/decorators/timer.py +20 -0
  911. frogml/model/fs_info_mapping_retriever.py +58 -0
  912. frogml/model/model_version_tracking.py +57 -0
  913. frogml/model/schema.py +52 -0
  914. frogml/model/schema_entities.py +107 -0
  915. frogml/model/tools/__init__.py +24 -0
  916. frogml/model/tools/adapters/__init__.py +0 -0
  917. frogml/model/tools/adapters/encoders.py +46 -0
  918. frogml/model/tools/adapters/input.py +66 -0
  919. frogml/model/tools/adapters/input_adapters/__init__.py +0 -0
  920. frogml/model/tools/adapters/input_adapters/base_input.py +21 -0
  921. frogml/model/tools/adapters/input_adapters/dataframe_input.py +48 -0
  922. frogml/model/tools/adapters/input_adapters/file_input.py +8 -0
  923. frogml/model/tools/adapters/input_adapters/image_input.py +45 -0
  924. frogml/model/tools/adapters/input_adapters/json_input.py +20 -0
  925. frogml/model/tools/adapters/input_adapters/string_input.py +6 -0
  926. frogml/model/tools/adapters/input_adapters/tf_tensor_input.py +44 -0
  927. frogml/model/tools/adapters/output.py +75 -0
  928. frogml/model/tools/adapters/output_adapters/__init__.py +0 -0
  929. frogml/model/tools/adapters/output_adapters/base_output.py +16 -0
  930. frogml/model/tools/adapters/output_adapters/dataframe_output.py +30 -0
  931. frogml/model/tools/adapters/output_adapters/default_output.py +58 -0
  932. frogml/model/tools/adapters/output_adapters/json_output.py +17 -0
  933. frogml/model/tools/adapters/output_adapters/tf_tensor_output.py +41 -0
  934. frogml/model/tools/run_model_locally.py +68 -0
  935. frogml/model/utils/__init__.py +0 -0
  936. frogml/model/utils/extract_wrapped_function.py +9 -0
  937. frogml/model/utils/feature_utils.py +69 -0
  938. frogml/model_loggers/__init__.py +0 -0
  939. frogml/model_loggers/artifact_logger.py +95 -0
  940. frogml/model_loggers/data_logger.py +172 -0
  941. frogml/model_loggers/model_logger.py +30 -0
  942. frogml/testing/__init__.py +0 -0
  943. frogml/testing/fixtures.py +7 -0
  944. frogml/tools/__init__.py +0 -0
  945. frogml/tools/logger/__init__.py +3 -0
  946. frogml/tools/logger/logger.py +287 -0
  947. frogml/tools/logger/logging.yml +79 -0
  948. frogml/utils/__init__.py +0 -0
  949. frogml/utils/datetime_utils.py +18 -0
  950. frogml/utils/dict_utils.py +12 -0
  951. frogml/vector_store/__init__.py +4 -0
  952. frogml/vector_store/client.py +151 -0
  953. frogml/vector_store/collection.py +429 -0
  954. frogml/vector_store/filters.py +359 -0
  955. frogml/vector_store/inference_client.py +105 -0
  956. frogml/vector_store/rest_helpers.py +81 -0
  957. frogml/vector_store/utils/__init__.py +0 -0
  958. frogml/vector_store/utils/filter_utils.py +23 -0
  959. frogml/vector_store/utils/upsert_utils.py +218 -0
  960. frogml_core-0.0.1.dist-info/METADATA +49 -0
  961. frogml_core-0.0.1.dist-info/RECORD +1013 -0
  962. frogml_core-0.0.1.dist-info/WHEEL +4 -0
  963. frogml_services_mock/__init__.py +1 -0
  964. frogml_services_mock/mocks/__init__.py +0 -0
  965. frogml_services_mock/mocks/alert_manager_service_api.py +56 -0
  966. frogml_services_mock/mocks/alert_registry_service_api.py +62 -0
  967. frogml_services_mock/mocks/analytics_api.py +54 -0
  968. frogml_services_mock/mocks/audience_service_api.py +79 -0
  969. frogml_services_mock/mocks/authentication_service.py +33 -0
  970. frogml_services_mock/mocks/automation_management_service.py +228 -0
  971. frogml_services_mock/mocks/autoscaling_service_api.py +31 -0
  972. frogml_services_mock/mocks/batch_job_manager_service.py +337 -0
  973. frogml_services_mock/mocks/build_management.py +101 -0
  974. frogml_services_mock/mocks/build_orchestrator_build_api.py +138 -0
  975. frogml_services_mock/mocks/build_orchestrator_build_settings_api.py +38 -0
  976. frogml_services_mock/mocks/build_orchestrator_service_api.py +132 -0
  977. frogml_services_mock/mocks/data_versioning_service.py +63 -0
  978. frogml_services_mock/mocks/deployment_management_service.py +461 -0
  979. frogml_services_mock/mocks/ecosystem_service_api.py +45 -0
  980. frogml_services_mock/mocks/execution_management_service.py +26 -0
  981. frogml_services_mock/mocks/feature_store_data_sources_manager_api.py +99 -0
  982. frogml_services_mock/mocks/feature_store_entities_manager_api.py +99 -0
  983. frogml_services_mock/mocks/feature_store_feature_set_manager_api.py +269 -0
  984. frogml_services_mock/mocks/features_online_serving_api.py +169 -0
  985. frogml_services_mock/mocks/features_operator_v3_service.py +29 -0
  986. frogml_services_mock/mocks/features_set_state_service_api.py +57 -0
  987. frogml_services_mock/mocks/feedback_service.py +35 -0
  988. frogml_services_mock/mocks/file_versioning_service.py +66 -0
  989. frogml_services_mock/mocks/frogml_mocks.py +133 -0
  990. frogml_services_mock/mocks/fs_offline_serving_service.py +53 -0
  991. frogml_services_mock/mocks/instance_template_management_service.py +150 -0
  992. frogml_services_mock/mocks/integration_management_service.py +73 -0
  993. frogml_services_mock/mocks/internal_build_orchestrator_service.py +27 -0
  994. frogml_services_mock/mocks/job_registry_service_api.py +74 -0
  995. frogml_services_mock/mocks/kube_captain_service_api.py +41 -0
  996. frogml_services_mock/mocks/logging_service.py +203 -0
  997. frogml_services_mock/mocks/model_management_service.py +115 -0
  998. frogml_services_mock/mocks/model_version_manager_service.py +100 -0
  999. frogml_services_mock/mocks/project_manager_service.py +96 -0
  1000. frogml_services_mock/mocks/prompt_manager_service.py +281 -0
  1001. frogml_services_mock/mocks/repository_service_mock.py +39 -0
  1002. frogml_services_mock/mocks/secret_service.py +43 -0
  1003. frogml_services_mock/mocks/self_service_user_service.py +31 -0
  1004. frogml_services_mock/mocks/system_secret_service.py +55 -0
  1005. frogml_services_mock/mocks/user_application_instance_service_api.py +107 -0
  1006. frogml_services_mock/mocks/utils/__init__.py +0 -0
  1007. frogml_services_mock/mocks/utils/exception_handlers.py +13 -0
  1008. frogml_services_mock/mocks/vector_serving_api.py +159 -0
  1009. frogml_services_mock/mocks/vectors_management_api.py +97 -0
  1010. frogml_services_mock/mocks/workspace_manager_service_mock.py +202 -0
  1011. frogml_services_mock/services_mock.py +542 -0
  1012. frogml_services_mock/utils/__init__.py +0 -0
  1013. frogml_services_mock/utils/service_utils.py +9 -0
@@ -0,0 +1,352 @@
1
+ import logging
2
+ import math
3
+ from typing import TYPE_CHECKING, List, Optional, Sequence, Tuple
4
+
5
+ from _frogml_proto.qwak.ecosystem.v0.ecosystem_pb2 import (
6
+ AuthenticatedUnifiedUserContext,
7
+ )
8
+ from _frogml_proto.qwak.feature_store.serving.serving_pb2 import (
9
+ BatchFeature as ServingProtoBatchFeature,
10
+ )
11
+ from _frogml_proto.qwak.feature_store.serving.serving_pb2 import (
12
+ BatchV1Feature as ServingProtoBatchV1Feature,
13
+ )
14
+ from _frogml_proto.qwak.feature_store.serving.serving_pb2 import (
15
+ EntitiesHeader,
16
+ EntityToFeatures,
17
+ EntityValueRow,
18
+ )
19
+ from _frogml_proto.qwak.feature_store.serving.serving_pb2 import (
20
+ Feature as ServingProtoFeature,
21
+ )
22
+ from _frogml_proto.qwak.feature_store.serving.serving_pb2 import (
23
+ RequestedEntitiesMatrix,
24
+ RequestedEntitiesMatrixRequest,
25
+ RequestMetaData,
26
+ )
27
+ from _frogml_proto.qwak.feature_store.serving.serving_pb2 import (
28
+ StreamingAggregationFeature as ServingProtoStreamingAggregationFeature,
29
+ )
30
+ from _frogml_proto.qwak.feature_store.serving.serving_pb2 import (
31
+ StreamingFeature as ServingProtoStreamingFeature,
32
+ )
33
+ from _frogml_proto.qwak.feature_store.serving.serving_pb2 import (
34
+ StreamingV1Feature as ServingProtoStreamingV1Feature,
35
+ )
36
+ from _frogml_proto.qwak.feature_store.serving.serving_pb2_grpc import ServingServiceStub
37
+ from frogml.clients.administration.eco_system.client import EcosystemClient
38
+ from frogml.exceptions import FrogmlException
39
+ from frogml.feature_store._common.feature_set_utils import (
40
+ BatchFeature,
41
+ BatchFeatureV1,
42
+ StreamingAggregationFeature,
43
+ StreamingFeature,
44
+ StreamingFeatureV1,
45
+ )
46
+ from frogml.feature_store.online import endpoint_utils
47
+ from frogml.feature_store.online.endpoint_utils import EndpointConfig
48
+ from frogml.inner.tool.grpc.grpc_tools import create_grpc_channel
49
+ from frogml.model.schema import ModelSchema
50
+ from frogml.model.schema_entities import BaseFeature, RequestInput
51
+
52
+ logger = logging.getLogger(__name__)
53
+
54
+ if TYPE_CHECKING:
55
+ try:
56
+ import pandas as pd
57
+ except ImportError:
58
+ pass
59
+
60
+
61
+ class OnlineClient:
62
+ """
63
+ Online Feature Serving client
64
+ """
65
+
66
+ def __init__(
67
+ self,
68
+ enable_ssl=True,
69
+ endpoint_url: Optional[str] = None,
70
+ metadata: Optional[Sequence[Tuple[str]]] = None,
71
+ ):
72
+ self._metadata = metadata
73
+
74
+ options = (
75
+ ("grpc.keepalive_timeout_ms", 1500),
76
+ ("grpc.client_idle_timeout_ms", 60 * 1000),
77
+ )
78
+
79
+ if endpoint_url is None:
80
+ user_context: AuthenticatedUnifiedUserContext = (
81
+ EcosystemClient().get_authenticated_user_context().user
82
+ )
83
+ conf: EndpointConfig = endpoint_utils.get_config_by_account_type(
84
+ user_context
85
+ )
86
+ endpoint_url = conf.endpoint_url
87
+ if conf.enable_ssl is not None:
88
+ enable_ssl = conf.enable_ssl
89
+
90
+ if conf.metadata is not None:
91
+ self._metadata = conf.metadata
92
+
93
+ channel = create_grpc_channel(
94
+ url=endpoint_url, enable_ssl=enable_ssl, options=options
95
+ )
96
+
97
+ self._serving_client: ServingServiceStub = ServingServiceStub(channel)
98
+
99
+ @staticmethod
100
+ def to_string_entities_values(values) -> List[str]:
101
+ return [str(value) for value in values]
102
+
103
+ def get_feature_values(
104
+ self,
105
+ schema: ModelSchema,
106
+ df: "pd.DataFrame",
107
+ model_name: str = "no-model",
108
+ *,
109
+ max_keys_per_request: int = 500,
110
+ ) -> "pd.DataFrame":
111
+ """
112
+ :param schema: a ModelSchema object - defines the entities, features and prediction (irelevant in this case).
113
+ :param df: a pandas data-frame with a column for each explicit feature needed
114
+ and a column for each entity key defined in the schema.
115
+ :param model_name: the name of the model to retrieve the features for.
116
+ :param max_keys_per_request: the maximum number of keys per request to the backend
117
+ :return: a pandas data-frame - the feature values defined in the schema
118
+ of the requested entities in the df.
119
+
120
+ each row in the returned data-frame is constructed by retrieving the most recent requested feature values
121
+ of the entity key(s) for the specific entity value(s) defined in the df.
122
+
123
+ TODO: fix imports and align example
124
+ Examples:
125
+ >>> import pandas as pd
126
+ >>> from frogml.feature_store import OnlineClient
127
+ >>> from frogml.model.schema import (
128
+ >>> ModelSchema, FeatureStoreInput
129
+ >>> )
130
+ >>>
131
+ >>> user_id = Entity(name='uuid', type=str)
132
+ >>>
133
+ >>> model_schema = ModelSchema(
134
+ >>> entities=[
135
+ >>> user_id
136
+ >>> ],
137
+ >>> inputs=[
138
+ >>> FeatureStoreInput(entity=user_id, name='user_purchases.number_of_purchases'),
139
+ >>> FeatureStoreInput(entity=user_id, name='user_purchases.avg_purchase_amount'),
140
+ >>> ],
141
+ >>> outputs=[
142
+ >>> InferenceOutput(name="score", type=float)
143
+ >>> ])
144
+ >>>
145
+ >>> online_client = OnlineClient()
146
+ >>>
147
+ >>> df = pd.DataFrame(columns= ['uuid', 'explicit_feature_purchase_price'],
148
+ >>> data = [ '1' , 22 ])
149
+ >>>
150
+ >>> user_features = online_client.get_feature_values(
151
+ >>> model_schema,
152
+ >>> df)
153
+ >>>
154
+ >>> print(user_features.head())
155
+ >>> # user_purchases.number_of_purchases user_purchases.avg_purchase_amount otf_quad_price
156
+ >>> # 0 76 4.796842 484
157
+ """
158
+ try:
159
+ import pandas as pd
160
+ except ImportError:
161
+ raise FrogmlException(
162
+ "Missing Pandas dependency required for querying the online feature store"
163
+ )
164
+
165
+ (
166
+ entity_features_compounds,
167
+ entities_with_index,
168
+ feature_set_names,
169
+ ) = self._create_entity_and_features_sets(
170
+ schema, pd.DataFrame(df.iloc[0]).transpose()
171
+ )
172
+
173
+ if not entity_features_compounds:
174
+ df_result = pd.DataFrame(
175
+ columns=[
176
+ input_field.name
177
+ for input_field in schema._inputs
178
+ if isinstance(input_field, BaseFeature)
179
+ ]
180
+ )
181
+
182
+ return pd.concat([df, df_result], axis=1, join="inner")
183
+
184
+ entities_to_features = []
185
+ for entity_features_compound in entity_features_compounds.values():
186
+ entities_to_features.append(
187
+ EntityToFeatures(
188
+ features=entity_features_compound.features,
189
+ entity_name=entity_features_compound.entity_name,
190
+ )
191
+ )
192
+
193
+ ordered_entities_tuple = sorted(
194
+ entities_with_index, key=lambda entity: entity[1]
195
+ )
196
+ ordered_entities = [entity[0] for entity in ordered_entities_tuple]
197
+
198
+ request_chunks: List[
199
+ Tuple[RequestedEntitiesMatrix, pd.DataFrame]
200
+ ] = OnlineClient._split_entities(
201
+ entity_names=ordered_entities,
202
+ population_df=df,
203
+ max_entities_per_split=max_keys_per_request,
204
+ )
205
+
206
+ results: List[pd.DataFrame] = []
207
+ for matrix, population_df in request_chunks:
208
+ request = RequestedEntitiesMatrixRequest(
209
+ entity_values_matrix=matrix,
210
+ entities_to_features=entities_to_features,
211
+ request_meta_data=RequestMetaData(
212
+ model_name=model_name,
213
+ feature_set_names=list(feature_set_names),
214
+ num_keys=len(population_df),
215
+ ),
216
+ )
217
+ try:
218
+ response_df_json, _ = self._serving_client.GetMultiFeatures.with_call(
219
+ request, metadata=self._metadata
220
+ )
221
+ features_df: pd.DataFrame = pd.read_json(
222
+ response_df_json.pandas_df_as_json, orient="split"
223
+ )
224
+ results.append(
225
+ pd.concat(
226
+ [population_df.reset_index(drop=True), features_df],
227
+ axis=1,
228
+ join="inner",
229
+ )
230
+ )
231
+ except Exception as e:
232
+ raise FrogmlException(
233
+ f"Failed to retrieve online feature values, got {repr(e)}"
234
+ )
235
+
236
+ res = pd.concat(results, axis=0)
237
+ res.index = df.index
238
+ return res
239
+
240
+ @staticmethod
241
+ def _split_entities(
242
+ entity_names: List[str],
243
+ population_df: "pd.DataFrame",
244
+ max_entities_per_split: int,
245
+ ) -> List[Tuple[RequestedEntitiesMatrix, "pd.DataFrame"]]:
246
+ entity_values: List[List[str]] = population_df[entity_names].values.tolist()
247
+
248
+ num_batches: int = math.ceil(len(entity_values) / max_entities_per_split)
249
+
250
+ res: List[Tuple[RequestedEntitiesMatrix, pd.DataFrame]] = []
251
+ for i in range(num_batches):
252
+ curr_entities: List[List[str]] = entity_values[
253
+ i * max_entities_per_split : (i + 1) * max_entities_per_split
254
+ ]
255
+ curr_population_df = population_df[
256
+ i * max_entities_per_split : (i + 1) * max_entities_per_split
257
+ ]
258
+ curr_entity_rows: List[EntityValueRow] = [
259
+ EntityValueRow(
260
+ index=idx, entity_values=OnlineClient.to_string_entities_values(v)
261
+ )
262
+ for idx, v in enumerate(curr_entities)
263
+ ]
264
+
265
+ res.append(
266
+ (
267
+ RequestedEntitiesMatrix(
268
+ header=EntitiesHeader(entity_names=entity_names),
269
+ rows=curr_entity_rows,
270
+ ),
271
+ curr_population_df,
272
+ )
273
+ )
274
+ return res
275
+
276
+ @staticmethod
277
+ def _create_entity_and_features_sets(schema: ModelSchema, df: "pd.DataFrame"):
278
+ entity_features_compounds = {}
279
+ list_of_df_columns = df.columns.to_list()
280
+ entities_and_indexes = []
281
+ feature_set_names = set()
282
+ for entity in schema._entities:
283
+ if entity.name not in df:
284
+ logger.error(
285
+ f"Schema entity key '{entity.name}' does not exist in the request DataFrame"
286
+ )
287
+ else:
288
+ entity_features_compounds[entity.name] = EntityFeaturesCompound(
289
+ entity.name, df[entity.name]
290
+ )
291
+ entities_and_indexes.append(
292
+ (entity.name, list_of_df_columns.index(entity.name))
293
+ )
294
+
295
+ for feature in [
296
+ feature
297
+ for feature in schema._inputs
298
+ if not isinstance(feature, RequestInput)
299
+ ]:
300
+ if feature.entity.name not in entity_features_compounds:
301
+ logger.info(
302
+ f"The entity: {feature.entity.name} of the Feature: {feature} does not exist in the entities list"
303
+ )
304
+
305
+ else:
306
+ if isinstance(feature, BatchFeatureV1):
307
+ feature_proto = ServingProtoFeature(
308
+ batch_v1_feature=ServingProtoBatchV1Feature(name=feature.name)
309
+ )
310
+ elif isinstance(feature, BatchFeature):
311
+ feature_proto = ServingProtoFeature(
312
+ batch_feature=ServingProtoBatchFeature(name=feature.name)
313
+ )
314
+ elif isinstance(feature, StreamingFeature):
315
+ feature_proto = ServingProtoFeature(
316
+ streaming_feature=ServingProtoStreamingFeature(
317
+ name=feature.name
318
+ )
319
+ )
320
+ elif isinstance(feature, StreamingFeatureV1):
321
+ feature_proto = ServingProtoFeature(
322
+ streaming_v1_feature=ServingProtoStreamingV1Feature(
323
+ name=feature.name
324
+ )
325
+ )
326
+ elif isinstance(feature, StreamingAggregationFeature):
327
+ feature_proto = ServingProtoFeature(
328
+ streaming_aggregation=ServingProtoStreamingAggregationFeature(
329
+ name=feature.name
330
+ )
331
+ )
332
+ else:
333
+ raise ValueError(
334
+ f"Not support type for feature extraction - {type(feature)}"
335
+ )
336
+
337
+ entity_features_compounds[feature.entity.name].add_feature(
338
+ feature_proto
339
+ )
340
+ feature_set_names.add(feature.name.split(".")[0])
341
+
342
+ return entity_features_compounds, entities_and_indexes, feature_set_names
343
+
344
+
345
+ class EntityFeaturesCompound:
346
+ def __init__(self, entity_name, entity_value):
347
+ self.entity_name = entity_name
348
+ self.entity_value = entity_value
349
+ self.features = []
350
+
351
+ def add_feature(self, feature):
352
+ self.features.append(feature)
@@ -0,0 +1,65 @@
1
+ import os
2
+ from dataclasses import dataclass
3
+ from typing import Optional, Sequence, Tuple
4
+
5
+ from _frogml_proto.qwak.administration.account.v1.account_pb2 import AccountType
6
+ from _frogml_proto.qwak.ecosystem.v0.ecosystem_pb2 import (
7
+ AuthenticatedUnifiedUserContext,
8
+ )
9
+ from frogml.exceptions import FrogmlException
10
+
11
+ _ONLINE_SERVING_ENDPOINT_OVERRIDE_ENV_VAR = "ONLINE_SERVING_ENDPOINT"
12
+ _default_endpoint_url = "fs-serving-webapp.frogml.svc.cluster.local:6577/com.frogml.ai.feature.store.serving.api.ServingService"
13
+
14
+
15
+ @dataclass
16
+ class EndpointConfig:
17
+ endpoint_url: str
18
+ metadata: Optional[Sequence[Tuple[str, str]]]
19
+ enable_ssl: Optional[bool]
20
+
21
+
22
+ def _get_direct_endpoint(
23
+ user_context: AuthenticatedUnifiedUserContext,
24
+ ) -> EndpointConfig:
25
+ endpoint_url: str = os.environ.get(
26
+ _ONLINE_SERVING_ENDPOINT_OVERRIDE_ENV_VAR, _default_endpoint_url
27
+ )
28
+ # As of time of writing, feature-store is single env!
29
+ metadata = (
30
+ ("frogml-user-id", user_context.user_id),
31
+ ("frogml-account-id", user_context.account_details.id),
32
+ ("frogml-environment-id", user_context.account_details.default_environment_id),
33
+ )
34
+
35
+ return EndpointConfig(
36
+ endpoint_url=endpoint_url, metadata=metadata, enable_ssl=False
37
+ )
38
+
39
+
40
+ def _get_edge_services_endpoint(
41
+ user_context: AuthenticatedUnifiedUserContext,
42
+ ) -> EndpointConfig:
43
+ environment_id: str = user_context.account_details.default_environment_id
44
+
45
+ if environment_id not in user_context.account_details.environment_by_id:
46
+ raise FrogmlException(
47
+ f"Configuration for environment [{environment_id}] was not found"
48
+ )
49
+
50
+ endpoint_url: str = user_context.account_details.environment_by_id[
51
+ environment_id
52
+ ].configuration.edge_services_url
53
+
54
+ return EndpointConfig(endpoint_url=endpoint_url, metadata=None, enable_ssl=None)
55
+
56
+
57
+ def get_config_by_account_type(
58
+ user_context: AuthenticatedUnifiedUserContext,
59
+ ) -> EndpointConfig:
60
+ user_account_type: AccountType = user_context.account_details.type
61
+
62
+ if user_account_type == AccountType.HYBRID and "K8S_POD_NAME" in os.environ:
63
+ return _get_direct_endpoint(user_context)
64
+ else:
65
+ return _get_edge_services_endpoint(user_context)
File without changes
@@ -0,0 +1,18 @@
1
+ from abc import ABC, abstractmethod
2
+ from dataclasses import dataclass
3
+
4
+ from _frogml_proto.qwak.feature_store.sinks.sink_pb2 import (
5
+ StreamingSink as ProtoStreamingSink,
6
+ )
7
+
8
+
9
+ @dataclass
10
+ class BaseSink(ABC):
11
+ name: str
12
+
13
+ @abstractmethod
14
+ def to_proto_streaming_sink(self) -> ProtoStreamingSink:
15
+ pass
16
+
17
+ def __post_init__(self):
18
+ pass
@@ -0,0 +1,59 @@
1
+ from dataclasses import dataclass
2
+ from enum import Enum
3
+ from typing import Optional
4
+
5
+ from _frogml_proto.qwak.feature_store.sinks.sink_pb2 import KafkaSink as ProtoKafkaSink
6
+ from _frogml_proto.qwak.feature_store.sinks.sink_pb2 import (
7
+ StreamingSink as ProtoStreamingSink,
8
+ )
9
+ from _frogml_proto.qwak.feature_store.sources.streaming_pb2 import (
10
+ MessageFormat as ProtoMessageFormat,
11
+ )
12
+ from frogml.exceptions import FrogmlException
13
+ from frogml.feature_store.data_sources.streaming.kafka.authentication import (
14
+ BaseAuthentication,
15
+ )
16
+ from frogml.feature_store.sinks.base import BaseSink
17
+ from frogml.feature_store.sinks.streaming.attachment import StreamingAttachmentPoint
18
+
19
+
20
+ class MessageFormat(Enum):
21
+ JSON = ProtoMessageFormat.JSON
22
+
23
+
24
+ @dataclass
25
+ class KafkaSink(BaseSink):
26
+ topic: str
27
+ bootstrap_servers: str
28
+ message_format: MessageFormat
29
+ auth_configuration: BaseAuthentication
30
+ attachment_point: Optional[StreamingAttachmentPoint]
31
+
32
+ def _to_proto_kafka_sink(self) -> ProtoKafkaSink:
33
+ return ProtoKafkaSink(
34
+ topic=self.topic,
35
+ bootstrap_servers=self.bootstrap_servers,
36
+ message_format=self.message_format.value,
37
+ auth_config=self.auth_configuration._to_proto(),
38
+ )
39
+
40
+ def to_proto_streaming_sink(self) -> ProtoStreamingSink:
41
+ if self.attachment_point is None:
42
+ raise FrogmlException(
43
+ "A Sink must have an attachment point configured in order for it to be used as a streaming sink"
44
+ )
45
+
46
+ proto_kafka_sink: ProtoKafkaSink = self._to_proto_kafka_sink()
47
+
48
+ return ProtoStreamingSink(
49
+ name=self.name,
50
+ kafka_sink=proto_kafka_sink,
51
+ attachment_point=self.attachment_point._to_proto(),
52
+ )
53
+
54
+ def __post_init__(self):
55
+ super().__post_init__()
56
+ self._validate()
57
+
58
+ def _validate(self):
59
+ pass
File without changes
@@ -0,0 +1,34 @@
1
+ from abc import ABC, abstractmethod
2
+ from dataclasses import dataclass
3
+
4
+ from _frogml_proto.qwak.feature_store.sinks.sink_pb2 import (
5
+ OfflineStreamingAttachmentPoint as ProtoOfflineStreamingAttachmentPoint,
6
+ )
7
+ from _frogml_proto.qwak.feature_store.sinks.sink_pb2 import (
8
+ OnlineStreamingAttachmentPoint as ProtoOnlineStreamingAttachmentPoint,
9
+ )
10
+ from _frogml_proto.qwak.feature_store.sinks.sink_pb2 import (
11
+ StreamingAttachmentPoint as ProtoStreamingAttachmentPoint,
12
+ )
13
+
14
+
15
+ class StreamingAttachmentPoint(ABC):
16
+ @abstractmethod
17
+ def _to_proto(self) -> ProtoStreamingAttachmentPoint:
18
+ pass
19
+
20
+
21
+ @dataclass
22
+ class OfflineStreamingAttachmentPoint(StreamingAttachmentPoint):
23
+ def _to_proto(self) -> ProtoStreamingAttachmentPoint:
24
+ return ProtoStreamingAttachmentPoint(
25
+ offline_streaming_attachment_point=ProtoOfflineStreamingAttachmentPoint()
26
+ )
27
+
28
+
29
+ @dataclass
30
+ class OnlineStreamingAttachmentPoint(StreamingAttachmentPoint):
31
+ def _to_proto(self) -> ProtoStreamingAttachmentPoint:
32
+ return ProtoStreamingAttachmentPoint(
33
+ online_streaming_attachment_point=ProtoOnlineStreamingAttachmentPoint()
34
+ )
@@ -0,0 +1,60 @@
1
+ from typing import cast
2
+
3
+ from _frogml_proto.qwak.feature_store.sinks.sink_pb2 import KafkaSink as ProtoKafkaSink
4
+ from _frogml_proto.qwak.feature_store.sinks.sink_pb2 import (
5
+ StreamingAttachmentPoint as ProtoStreamingAttachmentPoint,
6
+ )
7
+ from _frogml_proto.qwak.feature_store.sinks.sink_pb2 import (
8
+ StreamingSink as ProtoStreamingSink,
9
+ )
10
+ from frogml.feature_store.data_sources.streaming.kafka.authentication import (
11
+ BaseAuthentication,
12
+ )
13
+ from frogml.feature_store.sinks.base import BaseSink
14
+ from frogml.feature_store.sinks.kafka import KafkaSink
15
+ from frogml.feature_store.sinks.kafka import MessageFormat as KafkaMessageFormat
16
+ from frogml.feature_store.sinks.streaming.attachment import (
17
+ OfflineStreamingAttachmentPoint,
18
+ OnlineStreamingAttachmentPoint,
19
+ StreamingAttachmentPoint,
20
+ )
21
+
22
+
23
+ class StreamingSinkFactory:
24
+ @staticmethod
25
+ def get_streaming_sink(proto_streaming_sink: ProtoStreamingSink) -> BaseSink:
26
+ sink_type = proto_streaming_sink.WhichOneof("sink_type")
27
+
28
+ auth_conf: BaseAuthentication
29
+ if sink_type == "kafka_sink":
30
+ proto_kafka_sink: ProtoKafkaSink = proto_streaming_sink.kafka_sink
31
+ auth_configuration: BaseAuthentication = cast(
32
+ BaseAuthentication,
33
+ BaseAuthentication._from_proto(proto_kafka_sink.auth_config),
34
+ )
35
+ return KafkaSink(
36
+ name=proto_streaming_sink.name,
37
+ topic=proto_kafka_sink.topic,
38
+ bootstrap_servers=proto_kafka_sink.bootstrap_servers,
39
+ message_format=KafkaMessageFormat(proto_kafka_sink.message_format),
40
+ auth_configuration=auth_configuration,
41
+ attachment_point=StreamingSinkFactory._get_attachment_point(
42
+ proto_streaming_sink.attachment_point
43
+ ),
44
+ )
45
+
46
+ @staticmethod
47
+ def _get_attachment_point(
48
+ proto_attachment_point: ProtoStreamingAttachmentPoint,
49
+ ) -> StreamingAttachmentPoint:
50
+ attachment_point_type = proto_attachment_point.WhichOneof(
51
+ "attachment_point_type"
52
+ )
53
+ if attachment_point_type == "online_streaming_attachment_point":
54
+ return OnlineStreamingAttachmentPoint()
55
+ elif attachment_point_type == "offline_streaming_attachment_point":
56
+ return OfflineStreamingAttachmentPoint()
57
+ else:
58
+ raise ValueError(
59
+ f"Unidentified streaming attachment point type: {attachment_point_type}"
60
+ )
File without changes
@@ -0,0 +1,82 @@
1
+ from dataclasses import dataclass, field
2
+ from datetime import datetime
3
+ from typing import Optional
4
+
5
+ from google.protobuf.timestamp_pb2 import Timestamp as ProtoTimestamp
6
+
7
+ from _frogml_proto.qwak.features_operator.v3.features_operator_async_service_pb2 import (
8
+ DataSourceValidationOptions as ProtoDataSourceValidationOptions,
9
+ )
10
+ from _frogml_proto.qwak.features_operator.v3.features_operator_async_service_pb2 import (
11
+ FeatureSetValidationOptions as ProtoFeatureSetValidationOptions,
12
+ )
13
+ from _frogml_proto.qwak.features_operator.v3.features_operator_async_service_pb2 import (
14
+ ValidationTimeRange as ProtoValidationTimeRange,
15
+ )
16
+ from frogml.utils.datetime_utils import datetime_to_pts
17
+
18
+
19
+ @dataclass
20
+ class ValidationTimeRange:
21
+ lower_time_bound: Optional[datetime] = None
22
+ upper_time_bound: Optional[datetime] = None
23
+
24
+ def to_proto(self) -> ProtoValidationTimeRange:
25
+ lower_time_bound_proto: Optional[ProtoTimestamp] = None
26
+ upper_time_bound_proto: Optional[ProtoTimestamp] = None
27
+
28
+ if self.lower_time_bound:
29
+ lower_time_bound_proto = datetime_to_pts(self.lower_time_bound)
30
+ if self.upper_time_bound:
31
+ upper_time_bound_proto = datetime_to_pts(self.upper_time_bound)
32
+
33
+ return ProtoValidationTimeRange(
34
+ lower_time_bound=lower_time_bound_proto,
35
+ upper_time_bound=upper_time_bound_proto,
36
+ )
37
+
38
+
39
+ @dataclass
40
+ class DataSourceValidationOptions:
41
+ time_range: Optional[ValidationTimeRange] = field(
42
+ default_factory=lambda: ValidationTimeRange()
43
+ )
44
+
45
+ def __init__(
46
+ self,
47
+ lower_time_bound: Optional[datetime] = None,
48
+ upper_time_bound: Optional[datetime] = None,
49
+ ):
50
+ self.time_range = ValidationTimeRange(
51
+ lower_time_bound=lower_time_bound, upper_time_bound=upper_time_bound
52
+ )
53
+
54
+ def to_proto(self) -> ProtoDataSourceValidationOptions:
55
+ return ProtoDataSourceValidationOptions(
56
+ validation_time_range=self.time_range.to_proto()
57
+ )
58
+
59
+
60
+ @dataclass
61
+ class FeatureSetValidationOptions:
62
+ time_range: Optional[ValidationTimeRange] = field(
63
+ default_factory=lambda: ValidationTimeRange()
64
+ )
65
+ data_source_limit: Optional[int] = None
66
+
67
+ def __init__(
68
+ self,
69
+ lower_time_bound: Optional[datetime] = None,
70
+ upper_time_bound: Optional[datetime] = None,
71
+ data_source_limit: Optional[int] = None,
72
+ ):
73
+ self.time_range = ValidationTimeRange(
74
+ lower_time_bound=lower_time_bound, upper_time_bound=upper_time_bound
75
+ )
76
+ self.data_source_limit = data_source_limit
77
+
78
+ def to_proto(self) -> ProtoFeatureSetValidationOptions:
79
+ return ProtoFeatureSetValidationOptions(
80
+ data_source_limit=self.data_source_limit,
81
+ validation_time_range=self.time_range.to_proto(),
82
+ )