flwr-nightly 1.19.0.dev20250513__tar.gz → 1.19.0.dev20250514__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (340) hide show
  1. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/PKG-INFO +1 -1
  2. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/grpc_rere_client/grpc_adapter.py +18 -0
  3. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/heartbeat.py +58 -1
  4. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/inflatable.py +21 -2
  5. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/fleet_pb2.py +2 -2
  6. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/fleet_pb2_grpc.py +69 -0
  7. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/fleet_pb2_grpc.pyi +27 -0
  8. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/heartbeat_pb2.py +5 -1
  9. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/heartbeat_pb2.pyi +26 -0
  10. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/message_pb2.py +9 -1
  11. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/message_pb2.pyi +44 -0
  12. flwr_nightly-1.19.0.dev20250514/py/flwr/proto/serverappio_pb2.py +52 -0
  13. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/serverappio_pb2_grpc.py +104 -0
  14. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/serverappio_pb2_grpc.pyi +41 -0
  15. flwr_nightly-1.19.0.dev20250514/py/flwr/proto/simulationio_pb2.py +39 -0
  16. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/simulationio_pb2_grpc.py +35 -0
  17. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/simulationio_pb2_grpc.pyi +14 -0
  18. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/serverapp/app.py +18 -0
  19. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py +8 -0
  20. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/grpc_rere/fleet_servicer.py +35 -0
  21. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/serverappio/serverappio_servicer.py +50 -0
  22. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/simulation/simulationio_servicer.py +23 -0
  23. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/simulation/app.py +17 -0
  24. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/pyproject.toml +1 -1
  25. flwr_nightly-1.19.0.dev20250513/py/flwr/proto/serverappio_pb2.py +0 -51
  26. flwr_nightly-1.19.0.dev20250513/py/flwr/proto/simulationio_pb2.py +0 -38
  27. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/README.md +0 -0
  28. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/__init__.py +0 -0
  29. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/__init__.py +0 -0
  30. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/app.py +0 -0
  31. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/auth_plugin/__init__.py +0 -0
  32. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/auth_plugin/oidc_cli_plugin.py +0 -0
  33. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/build.py +0 -0
  34. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/cli_user_auth_interceptor.py +0 -0
  35. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/config_utils.py +0 -0
  36. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/constant.py +0 -0
  37. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/example.py +0 -0
  38. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/install.py +0 -0
  39. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/log.py +0 -0
  40. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/login/__init__.py +0 -0
  41. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/login/login.py +0 -0
  42. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/ls.py +0 -0
  43. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/__init__.py +0 -0
  44. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/new.py +0 -0
  45. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/__init__.py +0 -0
  46. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/.gitignore.tpl +0 -0
  47. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/LICENSE.tpl +0 -0
  48. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/README.baseline.md.tpl +0 -0
  49. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/README.flowertune.md.tpl +0 -0
  50. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/README.md.tpl +0 -0
  51. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/__init__.py +0 -0
  52. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/__init__.baseline.py.tpl +0 -0
  53. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/__init__.py +0 -0
  54. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/__init__.py.tpl +0 -0
  55. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/client.baseline.py.tpl +0 -0
  56. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/client.huggingface.py.tpl +0 -0
  57. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/client.jax.py.tpl +0 -0
  58. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/client.mlx.py.tpl +0 -0
  59. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/client.numpy.py.tpl +0 -0
  60. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/client.pytorch.py.tpl +0 -0
  61. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/client.sklearn.py.tpl +0 -0
  62. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/client.tensorflow.py.tpl +0 -0
  63. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/dataset.baseline.py.tpl +0 -0
  64. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/flwr_tune/__init__.py +0 -0
  65. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/flwr_tune/client_app.py.tpl +0 -0
  66. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/flwr_tune/dataset.py.tpl +0 -0
  67. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/flwr_tune/models.py.tpl +0 -0
  68. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/flwr_tune/server_app.py.tpl +0 -0
  69. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/flwr_tune/strategy.py.tpl +0 -0
  70. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/model.baseline.py.tpl +0 -0
  71. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/server.baseline.py.tpl +0 -0
  72. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/server.huggingface.py.tpl +0 -0
  73. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/server.jax.py.tpl +0 -0
  74. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/server.mlx.py.tpl +0 -0
  75. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/server.numpy.py.tpl +0 -0
  76. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/server.pytorch.py.tpl +0 -0
  77. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/server.sklearn.py.tpl +0 -0
  78. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/server.tensorflow.py.tpl +0 -0
  79. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/strategy.baseline.py.tpl +0 -0
  80. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/task.huggingface.py.tpl +0 -0
  81. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/task.jax.py.tpl +0 -0
  82. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/task.mlx.py.tpl +0 -0
  83. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/task.numpy.py.tpl +0 -0
  84. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/task.pytorch.py.tpl +0 -0
  85. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/task.sklearn.py.tpl +0 -0
  86. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/task.tensorflow.py.tpl +0 -0
  87. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/code/utils.baseline.py.tpl +0 -0
  88. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/pyproject.baseline.toml.tpl +0 -0
  89. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/pyproject.flowertune.toml.tpl +0 -0
  90. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/pyproject.huggingface.toml.tpl +0 -0
  91. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/pyproject.jax.toml.tpl +0 -0
  92. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/pyproject.mlx.toml.tpl +0 -0
  93. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/pyproject.numpy.toml.tpl +0 -0
  94. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/pyproject.pytorch.toml.tpl +0 -0
  95. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/pyproject.sklearn.toml.tpl +0 -0
  96. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/new/templates/app/pyproject.tensorflow.toml.tpl +0 -0
  97. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/run/__init__.py +0 -0
  98. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/run/run.py +0 -0
  99. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/stop.py +0 -0
  100. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/cli/utils.py +0 -0
  101. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/__init__.py +0 -0
  102. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/app.py +0 -0
  103. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/client.py +0 -0
  104. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/client_app.py +0 -0
  105. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/clientapp/__init__.py +0 -0
  106. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/clientapp/app.py +0 -0
  107. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/clientapp/clientappio_servicer.py +0 -0
  108. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/clientapp/utils.py +0 -0
  109. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/dpfedavg_numpy_client.py +0 -0
  110. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/grpc_adapter_client/__init__.py +0 -0
  111. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/grpc_adapter_client/connection.py +0 -0
  112. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/grpc_client/__init__.py +0 -0
  113. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/grpc_client/connection.py +0 -0
  114. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/grpc_rere_client/__init__.py +0 -0
  115. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/grpc_rere_client/client_interceptor.py +0 -0
  116. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/grpc_rere_client/connection.py +0 -0
  117. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/message_handler/__init__.py +0 -0
  118. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/message_handler/message_handler.py +0 -0
  119. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/mod/__init__.py +0 -0
  120. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/mod/centraldp_mods.py +0 -0
  121. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/mod/comms_mods.py +0 -0
  122. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/mod/localdp_mod.py +0 -0
  123. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/mod/secure_aggregation/__init__.py +0 -0
  124. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/mod/secure_aggregation/secagg_mod.py +0 -0
  125. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/mod/secure_aggregation/secaggplus_mod.py +0 -0
  126. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/mod/utils.py +0 -0
  127. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/nodestate/__init__.py +0 -0
  128. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/nodestate/in_memory_nodestate.py +0 -0
  129. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/nodestate/nodestate.py +0 -0
  130. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/nodestate/nodestate_factory.py +0 -0
  131. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/numpy_client.py +0 -0
  132. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/rest_client/__init__.py +0 -0
  133. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/rest_client/connection.py +0 -0
  134. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/run_info_store.py +0 -0
  135. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/supernode/__init__.py +0 -0
  136. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/supernode/app.py +0 -0
  137. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/client/typing.py +0 -0
  138. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/__init__.py +0 -0
  139. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/address.py +0 -0
  140. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/args.py +0 -0
  141. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/auth_plugin/__init__.py +0 -0
  142. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/auth_plugin/auth_plugin.py +0 -0
  143. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/config.py +0 -0
  144. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/constant.py +0 -0
  145. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/context.py +0 -0
  146. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/date.py +0 -0
  147. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/differential_privacy.py +0 -0
  148. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/differential_privacy_constants.py +0 -0
  149. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/dp.py +0 -0
  150. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/event_log_plugin/__init__.py +0 -0
  151. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/event_log_plugin/event_log_plugin.py +0 -0
  152. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/exit/__init__.py +0 -0
  153. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/exit/exit.py +0 -0
  154. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/exit/exit_code.py +0 -0
  155. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/exit_handlers.py +0 -0
  156. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/grpc.py +0 -0
  157. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/logger.py +0 -0
  158. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/message.py +0 -0
  159. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/object_ref.py +0 -0
  160. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/parameter.py +0 -0
  161. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/pyproject.py +0 -0
  162. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/record/__init__.py +0 -0
  163. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/record/array.py +0 -0
  164. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/record/arrayrecord.py +0 -0
  165. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/record/configrecord.py +0 -0
  166. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/record/conversion_utils.py +0 -0
  167. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/record/metricrecord.py +0 -0
  168. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/record/recorddict.py +0 -0
  169. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/record/typeddict.py +0 -0
  170. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/recorddict_compat.py +0 -0
  171. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/retry_invoker.py +0 -0
  172. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/secure_aggregation/__init__.py +0 -0
  173. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/secure_aggregation/crypto/__init__.py +0 -0
  174. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/secure_aggregation/crypto/shamir.py +0 -0
  175. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/secure_aggregation/crypto/symmetric_encryption.py +0 -0
  176. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/secure_aggregation/ndarrays_arithmetic.py +0 -0
  177. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/secure_aggregation/quantization.py +0 -0
  178. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/secure_aggregation/secaggplus_constants.py +0 -0
  179. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/secure_aggregation/secaggplus_utils.py +0 -0
  180. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/serde.py +0 -0
  181. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/serde_utils.py +0 -0
  182. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/telemetry.py +0 -0
  183. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/typing.py +0 -0
  184. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/common/version.py +0 -0
  185. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/__init__.py +0 -0
  186. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/clientappio_pb2.py +0 -0
  187. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/clientappio_pb2.pyi +0 -0
  188. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/clientappio_pb2_grpc.py +0 -0
  189. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/clientappio_pb2_grpc.pyi +0 -0
  190. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/error_pb2.py +0 -0
  191. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/error_pb2.pyi +0 -0
  192. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/error_pb2_grpc.py +0 -0
  193. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/error_pb2_grpc.pyi +0 -0
  194. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/exec_pb2.py +0 -0
  195. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/exec_pb2.pyi +0 -0
  196. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/exec_pb2_grpc.py +0 -0
  197. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/exec_pb2_grpc.pyi +0 -0
  198. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/fab_pb2.py +0 -0
  199. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/fab_pb2.pyi +0 -0
  200. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/fab_pb2_grpc.py +0 -0
  201. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/fab_pb2_grpc.pyi +0 -0
  202. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/fleet_pb2.pyi +0 -0
  203. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/grpcadapter_pb2.py +0 -0
  204. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/grpcadapter_pb2.pyi +0 -0
  205. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/grpcadapter_pb2_grpc.py +0 -0
  206. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/grpcadapter_pb2_grpc.pyi +0 -0
  207. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/heartbeat_pb2_grpc.py +0 -0
  208. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/heartbeat_pb2_grpc.pyi +0 -0
  209. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/log_pb2.py +0 -0
  210. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/log_pb2.pyi +0 -0
  211. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/log_pb2_grpc.py +0 -0
  212. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/log_pb2_grpc.pyi +0 -0
  213. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/message_pb2_grpc.py +0 -0
  214. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/message_pb2_grpc.pyi +0 -0
  215. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/node_pb2.py +0 -0
  216. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/node_pb2.pyi +0 -0
  217. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/node_pb2_grpc.py +0 -0
  218. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/node_pb2_grpc.pyi +0 -0
  219. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/recorddict_pb2.py +0 -0
  220. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/recorddict_pb2.pyi +0 -0
  221. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/recorddict_pb2_grpc.py +0 -0
  222. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/recorddict_pb2_grpc.pyi +0 -0
  223. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/run_pb2.py +0 -0
  224. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/run_pb2.pyi +0 -0
  225. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/run_pb2_grpc.py +0 -0
  226. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/run_pb2_grpc.pyi +0 -0
  227. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/serverappio_pb2.pyi +0 -0
  228. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/simulationio_pb2.pyi +0 -0
  229. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/transport_pb2.py +0 -0
  230. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/transport_pb2.pyi +0 -0
  231. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/transport_pb2_grpc.py +0 -0
  232. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/proto/transport_pb2_grpc.pyi +0 -0
  233. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/py.typed +0 -0
  234. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/__init__.py +0 -0
  235. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/app.py +0 -0
  236. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/client_manager.py +0 -0
  237. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/client_proxy.py +0 -0
  238. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/compat/__init__.py +0 -0
  239. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/compat/app.py +0 -0
  240. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/compat/app_utils.py +0 -0
  241. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/compat/grid_client_proxy.py +0 -0
  242. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/compat/legacy_context.py +0 -0
  243. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/criterion.py +0 -0
  244. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/fleet_event_log_interceptor.py +0 -0
  245. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/grid/__init__.py +0 -0
  246. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/grid/grid.py +0 -0
  247. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/grid/grpc_grid.py +0 -0
  248. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/grid/inmemory_grid.py +0 -0
  249. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/history.py +0 -0
  250. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/run_serverapp.py +0 -0
  251. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/server.py +0 -0
  252. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/server_app.py +0 -0
  253. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/server_config.py +0 -0
  254. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/serverapp/__init__.py +0 -0
  255. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/serverapp_components.py +0 -0
  256. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/__init__.py +0 -0
  257. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/aggregate.py +0 -0
  258. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/bulyan.py +0 -0
  259. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/dp_adaptive_clipping.py +0 -0
  260. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/dp_fixed_clipping.py +0 -0
  261. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/dpfedavg_adaptive.py +0 -0
  262. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/dpfedavg_fixed.py +0 -0
  263. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/fault_tolerant_fedavg.py +0 -0
  264. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/fedadagrad.py +0 -0
  265. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/fedadam.py +0 -0
  266. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/fedavg.py +0 -0
  267. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/fedavg_android.py +0 -0
  268. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/fedavgm.py +0 -0
  269. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/fedmedian.py +0 -0
  270. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/fedopt.py +0 -0
  271. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/fedprox.py +0 -0
  272. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/fedtrimmedavg.py +0 -0
  273. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/fedxgb_bagging.py +0 -0
  274. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/fedxgb_cyclic.py +0 -0
  275. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/fedxgb_nn_avg.py +0 -0
  276. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/fedyogi.py +0 -0
  277. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/krum.py +0 -0
  278. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/qfedavg.py +0 -0
  279. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/strategy/strategy.py +0 -0
  280. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/__init__.py +0 -0
  281. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/ffs/__init__.py +0 -0
  282. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/ffs/disk_ffs.py +0 -0
  283. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/ffs/ffs.py +0 -0
  284. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/ffs/ffs_factory.py +0 -0
  285. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/__init__.py +0 -0
  286. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/grpc_adapter/__init__.py +0 -0
  287. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/grpc_bidi/__init__.py +0 -0
  288. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/grpc_bidi/flower_service_servicer.py +0 -0
  289. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_bridge.py +0 -0
  290. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_client_proxy.py +0 -0
  291. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_server.py +0 -0
  292. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/grpc_rere/__init__.py +0 -0
  293. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/grpc_rere/server_interceptor.py +0 -0
  294. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/message_handler/__init__.py +0 -0
  295. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/message_handler/message_handler.py +0 -0
  296. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/rest_rere/__init__.py +0 -0
  297. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/rest_rere/rest_api.py +0 -0
  298. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/vce/__init__.py +0 -0
  299. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/vce/backend/__init__.py +0 -0
  300. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/vce/backend/backend.py +0 -0
  301. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/vce/backend/raybackend.py +0 -0
  302. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/fleet/vce/vce_api.py +0 -0
  303. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/linkstate/__init__.py +0 -0
  304. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/linkstate/in_memory_linkstate.py +0 -0
  305. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/linkstate/linkstate.py +0 -0
  306. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/linkstate/linkstate_factory.py +0 -0
  307. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/linkstate/sqlite_linkstate.py +0 -0
  308. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/linkstate/utils.py +0 -0
  309. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/serverappio/__init__.py +0 -0
  310. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/serverappio/serverappio_grpc.py +0 -0
  311. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/simulation/__init__.py +0 -0
  312. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/simulation/simulationio_grpc.py +0 -0
  313. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/superlink/utils.py +0 -0
  314. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/typing.py +0 -0
  315. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/utils/__init__.py +0 -0
  316. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/utils/tensorboard.py +0 -0
  317. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/utils/validator.py +0 -0
  318. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/workflow/__init__.py +0 -0
  319. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/workflow/constant.py +0 -0
  320. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/workflow/default_workflows.py +0 -0
  321. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/workflow/secure_aggregation/__init__.py +0 -0
  322. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/workflow/secure_aggregation/secagg_workflow.py +0 -0
  323. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/server/workflow/secure_aggregation/secaggplus_workflow.py +0 -0
  324. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/simulation/__init__.py +0 -0
  325. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/simulation/legacy_app.py +0 -0
  326. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/simulation/ray_transport/__init__.py +0 -0
  327. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/simulation/ray_transport/ray_actor.py +0 -0
  328. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/simulation/ray_transport/ray_client_proxy.py +0 -0
  329. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/simulation/ray_transport/utils.py +0 -0
  330. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/simulation/run_simulation.py +0 -0
  331. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/simulation/simulationio_connection.py +0 -0
  332. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/superexec/__init__.py +0 -0
  333. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/superexec/app.py +0 -0
  334. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/superexec/deployment.py +0 -0
  335. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/superexec/exec_event_log_interceptor.py +0 -0
  336. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/superexec/exec_grpc.py +0 -0
  337. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/superexec/exec_servicer.py +0 -0
  338. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/superexec/exec_user_auth_interceptor.py +0 -0
  339. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/superexec/executor.py +0 -0
  340. {flwr_nightly-1.19.0.dev20250513 → flwr_nightly-1.19.0.dev20250514}/py/flwr/superexec/simulation.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: flwr-nightly
3
- Version: 1.19.0.dev20250513
3
+ Version: 1.19.0.dev20250514
4
4
  Summary: Flower: A Friendly Federated AI Framework
5
5
  License: Apache-2.0
6
6
  Keywords: Artificial Intelligence,Federated AI,Federated Analytics,Federated Evaluation,Federated Learning,Flower,Machine Learning
@@ -49,6 +49,12 @@ from flwr.proto.heartbeat_pb2 import ( # pylint: disable=E0611
49
49
  SendNodeHeartbeatRequest,
50
50
  SendNodeHeartbeatResponse,
51
51
  )
52
+ from flwr.proto.message_pb2 import ( # pylint: disable=E0611
53
+ PullObjectRequest,
54
+ PullObjectResponse,
55
+ PushObjectRequest,
56
+ PushObjectResponse,
57
+ )
52
58
  from flwr.proto.run_pb2 import GetRunRequest, GetRunResponse # pylint: disable=E0611
53
59
 
54
60
  T = TypeVar("T", bound=GrpcMessage)
@@ -151,3 +157,15 @@ class GrpcAdapter:
151
157
  ) -> GetFabResponse:
152
158
  """."""
153
159
  return self._send_and_receive(request, GetFabResponse, **kwargs)
160
+
161
+ def PushObject( # pylint: disable=C0103
162
+ self, request: PushObjectRequest, **kwargs: Any
163
+ ) -> PushObjectResponse:
164
+ """."""
165
+ return self._send_and_receive(request, PushObjectResponse, **kwargs)
166
+
167
+ def PullObject( # pylint: disable=C0103
168
+ self, request: PullObjectRequest, **kwargs: Any
169
+ ) -> PullObjectResponse:
170
+ """."""
171
+ return self._send_and_receive(request, PullObjectResponse, **kwargs)
@@ -17,8 +17,16 @@
17
17
 
18
18
  import random
19
19
  import threading
20
- from typing import Callable
20
+ from typing import Callable, Union
21
21
 
22
+ import grpc
23
+
24
+ # pylint: disable=E0611
25
+ from flwr.proto.heartbeat_pb2 import SendAppHeartbeatRequest
26
+ from flwr.proto.serverappio_pb2_grpc import ServerAppIoStub
27
+ from flwr.proto.simulationio_pb2_grpc import SimulationIoStub
28
+
29
+ # pylint: enable=E0611
22
30
  from .constant import (
23
31
  HEARTBEAT_BASE_MULTIPLIER,
24
32
  HEARTBEAT_CALL_TIMEOUT,
@@ -106,3 +114,52 @@ class HeartbeatSender:
106
114
  if not self._stop_event.is_set():
107
115
  if not self.heartbeat_fn():
108
116
  raise HeartbeatFailure
117
+
118
+
119
+ def get_grpc_app_heartbeat_fn(
120
+ stub: Union[ServerAppIoStub, SimulationIoStub],
121
+ run_id: int,
122
+ *,
123
+ failure_message: str,
124
+ ) -> Callable[[], bool]:
125
+ """Get the function to send a heartbeat to gRPC endpoint.
126
+
127
+ This function is for app heartbeats only. It is not used for node heartbeats.
128
+
129
+ Parameters
130
+ ----------
131
+ stub : Union[ServerAppIoStub, SimulationIoStub]
132
+ gRPC stub to send the heartbeat.
133
+ run_id : int
134
+ The run ID to use in the heartbeat request.
135
+ failure_message : str
136
+ Error message to raise if the heartbeat fails.
137
+
138
+ Returns
139
+ -------
140
+ Callable[[], bool]
141
+ Function that sends a heartbeat to the gRPC endpoint.
142
+ """
143
+ # Construct the heartbeat request
144
+ req = SendAppHeartbeatRequest(
145
+ run_id=run_id, heartbeat_interval=HEARTBEAT_DEFAULT_INTERVAL
146
+ )
147
+
148
+ def fn() -> bool:
149
+ # Call ServerAppIo API
150
+ try:
151
+ res = stub.SendAppHeartbeat(req)
152
+ except grpc.RpcError as e:
153
+ status_code = e.code()
154
+ if status_code == grpc.StatusCode.UNAVAILABLE:
155
+ return False
156
+ if status_code == grpc.StatusCode.DEADLINE_EXCEEDED:
157
+ return False
158
+ raise
159
+
160
+ # Check if not successful
161
+ if not res.success:
162
+ raise RuntimeError(failure_message)
163
+ return True
164
+
165
+ return fn
@@ -105,5 +105,24 @@ def _get_object_body(object_content: bytes) -> bytes:
105
105
 
106
106
  def get_object_type_from_object_content(object_content: bytes) -> str:
107
107
  """Return object type from bytes."""
108
- obj_head: str = _get_object_head(object_content).decode(encoding="utf-8")
109
- return obj_head.split(TYPE_BODY_LEN_DIVIDER, 1)[0]
108
+ return get_object_head_values_from_object_content(object_content)[0]
109
+
110
+
111
+ def get_object_body_len_from_object_content(object_content: bytes) -> int:
112
+ """Return length of the object body."""
113
+ return get_object_head_values_from_object_content(object_content)[1]
114
+
115
+
116
+ def check_body_len_consistency(object_content: bytes) -> bool:
117
+ """Check that the object body is of length as specified in the head."""
118
+ body_len = get_object_body_len_from_object_content(object_content)
119
+ return body_len == len(_get_object_body(object_content))
120
+
121
+
122
+ def get_object_head_values_from_object_content(
123
+ object_content: bytes,
124
+ ) -> tuple[str, int]:
125
+ """Return object type and body length from object content."""
126
+ head = _get_object_head(object_content).decode(encoding="utf-8")
127
+ obj_type, body_len = head.split(TYPE_BODY_LEN_DIVIDER, 1)
128
+ return obj_type, int(body_len)
@@ -19,7 +19,7 @@ from flwr.proto import fab_pb2 as flwr_dot_proto_dot_fab__pb2
19
19
  from flwr.proto import message_pb2 as flwr_dot_proto_dot_message__pb2
20
20
 
21
21
 
22
- DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x16\x66lwr/proto/fleet.proto\x12\nflwr.proto\x1a\x1a\x66lwr/proto/heartbeat.proto\x1a\x15\x66lwr/proto/node.proto\x1a\x14\x66lwr/proto/run.proto\x1a\x14\x66lwr/proto/fab.proto\x1a\x18\x66lwr/proto/message.proto\"/\n\x11\x43reateNodeRequest\x12\x1a\n\x12heartbeat_interval\x18\x01 \x01(\x01\"4\n\x12\x43reateNodeResponse\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\"3\n\x11\x44\x65leteNodeRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\"\x14\n\x12\x44\x65leteNodeResponse\"J\n\x13PullMessagesRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\x12\x13\n\x0bmessage_ids\x18\x02 \x03(\t\"l\n\x14PullMessagesResponse\x12(\n\treconnect\x18\x01 \x01(\x0b\x32\x15.flwr.proto.Reconnect\x12*\n\rmessages_list\x18\x02 \x03(\x0b\x32\x13.flwr.proto.Message\"a\n\x13PushMessagesRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\x12*\n\rmessages_list\x18\x02 \x03(\x0b\x32\x13.flwr.proto.Message\"\xb0\x01\n\x14PushMessagesResponse\x12(\n\treconnect\x18\x01 \x01(\x0b\x32\x15.flwr.proto.Reconnect\x12>\n\x07results\x18\x02 \x03(\x0b\x32-.flwr.proto.PushMessagesResponse.ResultsEntry\x1a.\n\x0cResultsEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12\r\n\x05value\x18\x02 \x01(\r:\x02\x38\x01\"\x1e\n\tReconnect\x12\x11\n\treconnect\x18\x01 \x01(\x04\x32\xb9\x04\n\x05\x46leet\x12M\n\nCreateNode\x12\x1d.flwr.proto.CreateNodeRequest\x1a\x1e.flwr.proto.CreateNodeResponse\"\x00\x12M\n\nDeleteNode\x12\x1d.flwr.proto.DeleteNodeRequest\x1a\x1e.flwr.proto.DeleteNodeResponse\"\x00\x12\x62\n\x11SendNodeHeartbeat\x12$.flwr.proto.SendNodeHeartbeatRequest\x1a%.flwr.proto.SendNodeHeartbeatResponse\"\x00\x12S\n\x0cPullMessages\x12\x1f.flwr.proto.PullMessagesRequest\x1a .flwr.proto.PullMessagesResponse\"\x00\x12S\n\x0cPushMessages\x12\x1f.flwr.proto.PushMessagesRequest\x1a .flwr.proto.PushMessagesResponse\"\x00\x12\x41\n\x06GetRun\x12\x19.flwr.proto.GetRunRequest\x1a\x1a.flwr.proto.GetRunResponse\"\x00\x12\x41\n\x06GetFab\x12\x19.flwr.proto.GetFabRequest\x1a\x1a.flwr.proto.GetFabResponse\"\x00\x62\x06proto3')
22
+ DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x16\x66lwr/proto/fleet.proto\x12\nflwr.proto\x1a\x1a\x66lwr/proto/heartbeat.proto\x1a\x15\x66lwr/proto/node.proto\x1a\x14\x66lwr/proto/run.proto\x1a\x14\x66lwr/proto/fab.proto\x1a\x18\x66lwr/proto/message.proto\"/\n\x11\x43reateNodeRequest\x12\x1a\n\x12heartbeat_interval\x18\x01 \x01(\x01\"4\n\x12\x43reateNodeResponse\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\"3\n\x11\x44\x65leteNodeRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\"\x14\n\x12\x44\x65leteNodeResponse\"J\n\x13PullMessagesRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\x12\x13\n\x0bmessage_ids\x18\x02 \x03(\t\"l\n\x14PullMessagesResponse\x12(\n\treconnect\x18\x01 \x01(\x0b\x32\x15.flwr.proto.Reconnect\x12*\n\rmessages_list\x18\x02 \x03(\x0b\x32\x13.flwr.proto.Message\"a\n\x13PushMessagesRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\x12*\n\rmessages_list\x18\x02 \x03(\x0b\x32\x13.flwr.proto.Message\"\xb0\x01\n\x14PushMessagesResponse\x12(\n\treconnect\x18\x01 \x01(\x0b\x32\x15.flwr.proto.Reconnect\x12>\n\x07results\x18\x02 \x03(\x0b\x32-.flwr.proto.PushMessagesResponse.ResultsEntry\x1a.\n\x0cResultsEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12\r\n\x05value\x18\x02 \x01(\r:\x02\x38\x01\"\x1e\n\tReconnect\x12\x11\n\treconnect\x18\x01 \x01(\x04\x32\xd7\x05\n\x05\x46leet\x12M\n\nCreateNode\x12\x1d.flwr.proto.CreateNodeRequest\x1a\x1e.flwr.proto.CreateNodeResponse\"\x00\x12M\n\nDeleteNode\x12\x1d.flwr.proto.DeleteNodeRequest\x1a\x1e.flwr.proto.DeleteNodeResponse\"\x00\x12\x62\n\x11SendNodeHeartbeat\x12$.flwr.proto.SendNodeHeartbeatRequest\x1a%.flwr.proto.SendNodeHeartbeatResponse\"\x00\x12S\n\x0cPullMessages\x12\x1f.flwr.proto.PullMessagesRequest\x1a .flwr.proto.PullMessagesResponse\"\x00\x12S\n\x0cPushMessages\x12\x1f.flwr.proto.PushMessagesRequest\x1a .flwr.proto.PushMessagesResponse\"\x00\x12\x41\n\x06GetRun\x12\x19.flwr.proto.GetRunRequest\x1a\x1a.flwr.proto.GetRunResponse\"\x00\x12\x41\n\x06GetFab\x12\x19.flwr.proto.GetFabRequest\x1a\x1a.flwr.proto.GetFabResponse\"\x00\x12M\n\nPushObject\x12\x1d.flwr.proto.PushObjectRequest\x1a\x1e.flwr.proto.PushObjectResponse\"\x00\x12M\n\nPullObject\x12\x1d.flwr.proto.PullObjectRequest\x1a\x1e.flwr.proto.PullObjectResponse\"\x00\x62\x06proto3')
23
23
 
24
24
  _globals = globals()
25
25
  _builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
@@ -49,5 +49,5 @@ if _descriptor._USE_C_DESCRIPTORS == False:
49
49
  _globals['_RECONNECT']._serialized_start=801
50
50
  _globals['_RECONNECT']._serialized_end=831
51
51
  _globals['_FLEET']._serialized_start=834
52
- _globals['_FLEET']._serialized_end=1403
52
+ _globals['_FLEET']._serialized_end=1561
53
53
  # @@protoc_insertion_point(module_scope)
@@ -5,6 +5,7 @@ import grpc
5
5
  from flwr.proto import fab_pb2 as flwr_dot_proto_dot_fab__pb2
6
6
  from flwr.proto import fleet_pb2 as flwr_dot_proto_dot_fleet__pb2
7
7
  from flwr.proto import heartbeat_pb2 as flwr_dot_proto_dot_heartbeat__pb2
8
+ from flwr.proto import message_pb2 as flwr_dot_proto_dot_message__pb2
8
9
  from flwr.proto import run_pb2 as flwr_dot_proto_dot_run__pb2
9
10
 
10
11
 
@@ -52,6 +53,16 @@ class FleetStub(object):
52
53
  request_serializer=flwr_dot_proto_dot_fab__pb2.GetFabRequest.SerializeToString,
53
54
  response_deserializer=flwr_dot_proto_dot_fab__pb2.GetFabResponse.FromString,
54
55
  )
56
+ self.PushObject = channel.unary_unary(
57
+ '/flwr.proto.Fleet/PushObject',
58
+ request_serializer=flwr_dot_proto_dot_message__pb2.PushObjectRequest.SerializeToString,
59
+ response_deserializer=flwr_dot_proto_dot_message__pb2.PushObjectResponse.FromString,
60
+ )
61
+ self.PullObject = channel.unary_unary(
62
+ '/flwr.proto.Fleet/PullObject',
63
+ request_serializer=flwr_dot_proto_dot_message__pb2.PullObjectRequest.SerializeToString,
64
+ response_deserializer=flwr_dot_proto_dot_message__pb2.PullObjectResponse.FromString,
65
+ )
55
66
 
56
67
 
57
68
  class FleetServicer(object):
@@ -106,6 +117,20 @@ class FleetServicer(object):
106
117
  context.set_details('Method not implemented!')
107
118
  raise NotImplementedError('Method not implemented!')
108
119
 
120
+ def PushObject(self, request, context):
121
+ """Push Object
122
+ """
123
+ context.set_code(grpc.StatusCode.UNIMPLEMENTED)
124
+ context.set_details('Method not implemented!')
125
+ raise NotImplementedError('Method not implemented!')
126
+
127
+ def PullObject(self, request, context):
128
+ """Pull Object
129
+ """
130
+ context.set_code(grpc.StatusCode.UNIMPLEMENTED)
131
+ context.set_details('Method not implemented!')
132
+ raise NotImplementedError('Method not implemented!')
133
+
109
134
 
110
135
  def add_FleetServicer_to_server(servicer, server):
111
136
  rpc_method_handlers = {
@@ -144,6 +169,16 @@ def add_FleetServicer_to_server(servicer, server):
144
169
  request_deserializer=flwr_dot_proto_dot_fab__pb2.GetFabRequest.FromString,
145
170
  response_serializer=flwr_dot_proto_dot_fab__pb2.GetFabResponse.SerializeToString,
146
171
  ),
172
+ 'PushObject': grpc.unary_unary_rpc_method_handler(
173
+ servicer.PushObject,
174
+ request_deserializer=flwr_dot_proto_dot_message__pb2.PushObjectRequest.FromString,
175
+ response_serializer=flwr_dot_proto_dot_message__pb2.PushObjectResponse.SerializeToString,
176
+ ),
177
+ 'PullObject': grpc.unary_unary_rpc_method_handler(
178
+ servicer.PullObject,
179
+ request_deserializer=flwr_dot_proto_dot_message__pb2.PullObjectRequest.FromString,
180
+ response_serializer=flwr_dot_proto_dot_message__pb2.PullObjectResponse.SerializeToString,
181
+ ),
147
182
  }
148
183
  generic_handler = grpc.method_handlers_generic_handler(
149
184
  'flwr.proto.Fleet', rpc_method_handlers)
@@ -272,3 +307,37 @@ class Fleet(object):
272
307
  flwr_dot_proto_dot_fab__pb2.GetFabResponse.FromString,
273
308
  options, channel_credentials,
274
309
  insecure, call_credentials, compression, wait_for_ready, timeout, metadata)
310
+
311
+ @staticmethod
312
+ def PushObject(request,
313
+ target,
314
+ options=(),
315
+ channel_credentials=None,
316
+ call_credentials=None,
317
+ insecure=False,
318
+ compression=None,
319
+ wait_for_ready=None,
320
+ timeout=None,
321
+ metadata=None):
322
+ return grpc.experimental.unary_unary(request, target, '/flwr.proto.Fleet/PushObject',
323
+ flwr_dot_proto_dot_message__pb2.PushObjectRequest.SerializeToString,
324
+ flwr_dot_proto_dot_message__pb2.PushObjectResponse.FromString,
325
+ options, channel_credentials,
326
+ insecure, call_credentials, compression, wait_for_ready, timeout, metadata)
327
+
328
+ @staticmethod
329
+ def PullObject(request,
330
+ target,
331
+ options=(),
332
+ channel_credentials=None,
333
+ call_credentials=None,
334
+ insecure=False,
335
+ compression=None,
336
+ wait_for_ready=None,
337
+ timeout=None,
338
+ metadata=None):
339
+ return grpc.experimental.unary_unary(request, target, '/flwr.proto.Fleet/PullObject',
340
+ flwr_dot_proto_dot_message__pb2.PullObjectRequest.SerializeToString,
341
+ flwr_dot_proto_dot_message__pb2.PullObjectResponse.FromString,
342
+ options, channel_credentials,
343
+ insecure, call_credentials, compression, wait_for_ready, timeout, metadata)
@@ -6,6 +6,7 @@ import abc
6
6
  import flwr.proto.fab_pb2
7
7
  import flwr.proto.fleet_pb2
8
8
  import flwr.proto.heartbeat_pb2
9
+ import flwr.proto.message_pb2
9
10
  import flwr.proto.run_pb2
10
11
  import grpc
11
12
 
@@ -48,6 +49,16 @@ class FleetStub:
48
49
  flwr.proto.fab_pb2.GetFabResponse]
49
50
  """Get FAB"""
50
51
 
52
+ PushObject: grpc.UnaryUnaryMultiCallable[
53
+ flwr.proto.message_pb2.PushObjectRequest,
54
+ flwr.proto.message_pb2.PushObjectResponse]
55
+ """Push Object"""
56
+
57
+ PullObject: grpc.UnaryUnaryMultiCallable[
58
+ flwr.proto.message_pb2.PullObjectRequest,
59
+ flwr.proto.message_pb2.PullObjectResponse]
60
+ """Pull Object"""
61
+
51
62
 
52
63
  class FleetServicer(metaclass=abc.ABCMeta):
53
64
  @abc.abstractmethod
@@ -104,5 +115,21 @@ class FleetServicer(metaclass=abc.ABCMeta):
104
115
  """Get FAB"""
105
116
  pass
106
117
 
118
+ @abc.abstractmethod
119
+ def PushObject(self,
120
+ request: flwr.proto.message_pb2.PushObjectRequest,
121
+ context: grpc.ServicerContext,
122
+ ) -> flwr.proto.message_pb2.PushObjectResponse:
123
+ """Push Object"""
124
+ pass
125
+
126
+ @abc.abstractmethod
127
+ def PullObject(self,
128
+ request: flwr.proto.message_pb2.PullObjectRequest,
129
+ context: grpc.ServicerContext,
130
+ ) -> flwr.proto.message_pb2.PullObjectResponse:
131
+ """Pull Object"""
132
+ pass
133
+
107
134
 
108
135
  def add_FleetServicer_to_server(servicer: FleetServicer, server: grpc.Server) -> None: ...
@@ -15,7 +15,7 @@ _sym_db = _symbol_database.Default()
15
15
  from flwr.proto import node_pb2 as flwr_dot_proto_dot_node__pb2
16
16
 
17
17
 
18
- DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x1a\x66lwr/proto/heartbeat.proto\x12\nflwr.proto\x1a\x15\x66lwr/proto/node.proto\"V\n\x18SendNodeHeartbeatRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\x12\x1a\n\x12heartbeat_interval\x18\x02 \x01(\x01\",\n\x19SendNodeHeartbeatResponse\x12\x0f\n\x07success\x18\x01 \x01(\x08\x62\x06proto3')
18
+ DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x1a\x66lwr/proto/heartbeat.proto\x12\nflwr.proto\x1a\x15\x66lwr/proto/node.proto\"V\n\x18SendNodeHeartbeatRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\x12\x1a\n\x12heartbeat_interval\x18\x02 \x01(\x01\",\n\x19SendNodeHeartbeatResponse\x12\x0f\n\x07success\x18\x01 \x01(\x08\"E\n\x17SendAppHeartbeatRequest\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\x12\x1a\n\x12heartbeat_interval\x18\x02 \x01(\x01\"+\n\x18SendAppHeartbeatResponse\x12\x0f\n\x07success\x18\x01 \x01(\x08\x62\x06proto3')
19
19
 
20
20
  _globals = globals()
21
21
  _builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
@@ -26,4 +26,8 @@ if _descriptor._USE_C_DESCRIPTORS == False:
26
26
  _globals['_SENDNODEHEARTBEATREQUEST']._serialized_end=151
27
27
  _globals['_SENDNODEHEARTBEATRESPONSE']._serialized_start=153
28
28
  _globals['_SENDNODEHEARTBEATRESPONSE']._serialized_end=197
29
+ _globals['_SENDAPPHEARTBEATREQUEST']._serialized_start=199
30
+ _globals['_SENDAPPHEARTBEATREQUEST']._serialized_end=268
31
+ _globals['_SENDAPPHEARTBEATRESPONSE']._serialized_start=270
32
+ _globals['_SENDAPPHEARTBEATRESPONSE']._serialized_end=313
29
33
  # @@protoc_insertion_point(module_scope)
@@ -38,3 +38,29 @@ class SendNodeHeartbeatResponse(google.protobuf.message.Message):
38
38
  ) -> None: ...
39
39
  def ClearField(self, field_name: typing_extensions.Literal["success",b"success"]) -> None: ...
40
40
  global___SendNodeHeartbeatResponse = SendNodeHeartbeatResponse
41
+
42
+ class SendAppHeartbeatRequest(google.protobuf.message.Message):
43
+ """App Heartbeat messages"""
44
+ DESCRIPTOR: google.protobuf.descriptor.Descriptor
45
+ RUN_ID_FIELD_NUMBER: builtins.int
46
+ HEARTBEAT_INTERVAL_FIELD_NUMBER: builtins.int
47
+ run_id: builtins.int
48
+ heartbeat_interval: builtins.float
49
+ def __init__(self,
50
+ *,
51
+ run_id: builtins.int = ...,
52
+ heartbeat_interval: builtins.float = ...,
53
+ ) -> None: ...
54
+ def ClearField(self, field_name: typing_extensions.Literal["heartbeat_interval",b"heartbeat_interval","run_id",b"run_id"]) -> None: ...
55
+ global___SendAppHeartbeatRequest = SendAppHeartbeatRequest
56
+
57
+ class SendAppHeartbeatResponse(google.protobuf.message.Message):
58
+ DESCRIPTOR: google.protobuf.descriptor.Descriptor
59
+ SUCCESS_FIELD_NUMBER: builtins.int
60
+ success: builtins.bool
61
+ def __init__(self,
62
+ *,
63
+ success: builtins.bool = ...,
64
+ ) -> None: ...
65
+ def ClearField(self, field_name: typing_extensions.Literal["success",b"success"]) -> None: ...
66
+ global___SendAppHeartbeatResponse = SendAppHeartbeatResponse
@@ -17,7 +17,7 @@ from flwr.proto import recorddict_pb2 as flwr_dot_proto_dot_recorddict__pb2
17
17
  from flwr.proto import transport_pb2 as flwr_dot_proto_dot_transport__pb2
18
18
 
19
19
 
20
- DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x18\x66lwr/proto/message.proto\x12\nflwr.proto\x1a\x16\x66lwr/proto/error.proto\x1a\x1b\x66lwr/proto/recorddict.proto\x1a\x1a\x66lwr/proto/transport.proto\"|\n\x07Message\x12&\n\x08metadata\x18\x01 \x01(\x0b\x32\x14.flwr.proto.Metadata\x12\'\n\x07\x63ontent\x18\x02 \x01(\x0b\x32\x16.flwr.proto.RecordDict\x12 \n\x05\x65rror\x18\x03 \x01(\x0b\x32\x11.flwr.proto.Error\"\xd0\x02\n\x07\x43ontext\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\x12\x0f\n\x07node_id\x18\x02 \x01(\x04\x12\x38\n\x0bnode_config\x18\x03 \x03(\x0b\x32#.flwr.proto.Context.NodeConfigEntry\x12%\n\x05state\x18\x04 \x01(\x0b\x32\x16.flwr.proto.RecordDict\x12\x36\n\nrun_config\x18\x05 \x03(\x0b\x32\".flwr.proto.Context.RunConfigEntry\x1a\x45\n\x0fNodeConfigEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12!\n\x05value\x18\x02 \x01(\x0b\x32\x12.flwr.proto.Scalar:\x02\x38\x01\x1a\x44\n\x0eRunConfigEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12!\n\x05value\x18\x02 \x01(\x0b\x32\x12.flwr.proto.Scalar:\x02\x38\x01\"\xbe\x01\n\x08Metadata\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\x12\x12\n\nmessage_id\x18\x02 \x01(\t\x12\x13\n\x0bsrc_node_id\x18\x03 \x01(\x04\x12\x13\n\x0b\x64st_node_id\x18\x04 \x01(\x04\x12\x1b\n\x13reply_to_message_id\x18\x05 \x01(\t\x12\x10\n\x08group_id\x18\x06 \x01(\t\x12\x0b\n\x03ttl\x18\x07 \x01(\x01\x12\x14\n\x0cmessage_type\x18\x08 \x01(\t\x12\x12\n\ncreated_at\x18\t \x01(\x01\x62\x06proto3')
20
+ DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x18\x66lwr/proto/message.proto\x12\nflwr.proto\x1a\x16\x66lwr/proto/error.proto\x1a\x1b\x66lwr/proto/recorddict.proto\x1a\x1a\x66lwr/proto/transport.proto\"|\n\x07Message\x12&\n\x08metadata\x18\x01 \x01(\x0b\x32\x14.flwr.proto.Metadata\x12\'\n\x07\x63ontent\x18\x02 \x01(\x0b\x32\x16.flwr.proto.RecordDict\x12 \n\x05\x65rror\x18\x03 \x01(\x0b\x32\x11.flwr.proto.Error\"\xd0\x02\n\x07\x43ontext\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\x12\x0f\n\x07node_id\x18\x02 \x01(\x04\x12\x38\n\x0bnode_config\x18\x03 \x03(\x0b\x32#.flwr.proto.Context.NodeConfigEntry\x12%\n\x05state\x18\x04 \x01(\x0b\x32\x16.flwr.proto.RecordDict\x12\x36\n\nrun_config\x18\x05 \x03(\x0b\x32\".flwr.proto.Context.RunConfigEntry\x1a\x45\n\x0fNodeConfigEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12!\n\x05value\x18\x02 \x01(\x0b\x32\x12.flwr.proto.Scalar:\x02\x38\x01\x1a\x44\n\x0eRunConfigEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12!\n\x05value\x18\x02 \x01(\x0b\x32\x12.flwr.proto.Scalar:\x02\x38\x01\"\xbe\x01\n\x08Metadata\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\x12\x12\n\nmessage_id\x18\x02 \x01(\t\x12\x13\n\x0bsrc_node_id\x18\x03 \x01(\x04\x12\x13\n\x0b\x64st_node_id\x18\x04 \x01(\x04\x12\x1b\n\x13reply_to_message_id\x18\x05 \x01(\t\x12\x10\n\x08group_id\x18\x06 \x01(\t\x12\x0b\n\x03ttl\x18\x07 \x01(\x01\x12\x14\n\x0cmessage_type\x18\x08 \x01(\t\x12\x12\n\ncreated_at\x18\t \x01(\x01\">\n\x11PushObjectRequest\x12\x11\n\tobject_id\x18\x01 \x01(\t\x12\x16\n\x0eobject_content\x18\x02 \x01(\x0c\"\x14\n\x12PushObjectResponse\"&\n\x11PullObjectRequest\x12\x11\n\tobject_id\x18\x01 \x01(\t\",\n\x12PullObjectResponse\x12\x16\n\x0eobject_content\x18\x01 \x01(\x0c\x62\x06proto3')
21
21
 
22
22
  _globals = globals()
23
23
  _builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
@@ -38,4 +38,12 @@ if _descriptor._USE_C_DESCRIPTORS == False:
38
38
  _globals['_CONTEXT_RUNCONFIGENTRY']._serialized_end=584
39
39
  _globals['_METADATA']._serialized_start=587
40
40
  _globals['_METADATA']._serialized_end=777
41
+ _globals['_PUSHOBJECTREQUEST']._serialized_start=779
42
+ _globals['_PUSHOBJECTREQUEST']._serialized_end=841
43
+ _globals['_PUSHOBJECTRESPONSE']._serialized_start=843
44
+ _globals['_PUSHOBJECTRESPONSE']._serialized_end=863
45
+ _globals['_PULLOBJECTREQUEST']._serialized_start=865
46
+ _globals['_PULLOBJECTREQUEST']._serialized_end=903
47
+ _globals['_PULLOBJECTRESPONSE']._serialized_start=905
48
+ _globals['_PULLOBJECTRESPONSE']._serialized_end=949
41
49
  # @@protoc_insertion_point(module_scope)
@@ -126,3 +126,47 @@ class Metadata(google.protobuf.message.Message):
126
126
  ) -> None: ...
127
127
  def ClearField(self, field_name: typing_extensions.Literal["created_at",b"created_at","dst_node_id",b"dst_node_id","group_id",b"group_id","message_id",b"message_id","message_type",b"message_type","reply_to_message_id",b"reply_to_message_id","run_id",b"run_id","src_node_id",b"src_node_id","ttl",b"ttl"]) -> None: ...
128
128
  global___Metadata = Metadata
129
+
130
+ class PushObjectRequest(google.protobuf.message.Message):
131
+ """PushObject messages"""
132
+ DESCRIPTOR: google.protobuf.descriptor.Descriptor
133
+ OBJECT_ID_FIELD_NUMBER: builtins.int
134
+ OBJECT_CONTENT_FIELD_NUMBER: builtins.int
135
+ object_id: typing.Text
136
+ object_content: builtins.bytes
137
+ def __init__(self,
138
+ *,
139
+ object_id: typing.Text = ...,
140
+ object_content: builtins.bytes = ...,
141
+ ) -> None: ...
142
+ def ClearField(self, field_name: typing_extensions.Literal["object_content",b"object_content","object_id",b"object_id"]) -> None: ...
143
+ global___PushObjectRequest = PushObjectRequest
144
+
145
+ class PushObjectResponse(google.protobuf.message.Message):
146
+ DESCRIPTOR: google.protobuf.descriptor.Descriptor
147
+ def __init__(self,
148
+ ) -> None: ...
149
+ global___PushObjectResponse = PushObjectResponse
150
+
151
+ class PullObjectRequest(google.protobuf.message.Message):
152
+ """PullObject messages"""
153
+ DESCRIPTOR: google.protobuf.descriptor.Descriptor
154
+ OBJECT_ID_FIELD_NUMBER: builtins.int
155
+ object_id: typing.Text
156
+ def __init__(self,
157
+ *,
158
+ object_id: typing.Text = ...,
159
+ ) -> None: ...
160
+ def ClearField(self, field_name: typing_extensions.Literal["object_id",b"object_id"]) -> None: ...
161
+ global___PullObjectRequest = PullObjectRequest
162
+
163
+ class PullObjectResponse(google.protobuf.message.Message):
164
+ DESCRIPTOR: google.protobuf.descriptor.Descriptor
165
+ OBJECT_CONTENT_FIELD_NUMBER: builtins.int
166
+ object_content: builtins.bytes
167
+ def __init__(self,
168
+ *,
169
+ object_content: builtins.bytes = ...,
170
+ ) -> None: ...
171
+ def ClearField(self, field_name: typing_extensions.Literal["object_content",b"object_content"]) -> None: ...
172
+ global___PullObjectResponse = PullObjectResponse
@@ -0,0 +1,52 @@
1
+ # -*- coding: utf-8 -*-
2
+ # Generated by the protocol buffer compiler. DO NOT EDIT!
3
+ # source: flwr/proto/serverappio.proto
4
+ # Protobuf Python Version: 4.25.1
5
+ """Generated protocol buffer code."""
6
+ from google.protobuf import descriptor as _descriptor
7
+ from google.protobuf import descriptor_pool as _descriptor_pool
8
+ from google.protobuf import symbol_database as _symbol_database
9
+ from google.protobuf.internal import builder as _builder
10
+ # @@protoc_insertion_point(imports)
11
+
12
+ _sym_db = _symbol_database.Default()
13
+
14
+
15
+ from flwr.proto import heartbeat_pb2 as flwr_dot_proto_dot_heartbeat__pb2
16
+ from flwr.proto import log_pb2 as flwr_dot_proto_dot_log__pb2
17
+ from flwr.proto import node_pb2 as flwr_dot_proto_dot_node__pb2
18
+ from flwr.proto import message_pb2 as flwr_dot_proto_dot_message__pb2
19
+ from flwr.proto import run_pb2 as flwr_dot_proto_dot_run__pb2
20
+ from flwr.proto import fab_pb2 as flwr_dot_proto_dot_fab__pb2
21
+
22
+
23
+ DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x1c\x66lwr/proto/serverappio.proto\x12\nflwr.proto\x1a\x1a\x66lwr/proto/heartbeat.proto\x1a\x14\x66lwr/proto/log.proto\x1a\x15\x66lwr/proto/node.proto\x1a\x18\x66lwr/proto/message.proto\x1a\x14\x66lwr/proto/run.proto\x1a\x14\x66lwr/proto/fab.proto\"!\n\x0fGetNodesRequest\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\"3\n\x10GetNodesResponse\x12\x1f\n\x05nodes\x18\x01 \x03(\x0b\x32\x10.flwr.proto.Node\"T\n\x16PushInsMessagesRequest\x12*\n\rmessages_list\x18\x01 \x03(\x0b\x32\x13.flwr.proto.Message\x12\x0e\n\x06run_id\x18\x02 \x01(\x04\".\n\x17PushInsMessagesResponse\x12\x13\n\x0bmessage_ids\x18\x01 \x03(\t\"=\n\x16PullResMessagesRequest\x12\x13\n\x0bmessage_ids\x18\x01 \x03(\t\x12\x0e\n\x06run_id\x18\x02 \x01(\x04\"E\n\x17PullResMessagesResponse\x12*\n\rmessages_list\x18\x01 \x03(\x0b\x32\x13.flwr.proto.Message\"\x1c\n\x1aPullServerAppInputsRequest\"\x7f\n\x1bPullServerAppInputsResponse\x12$\n\x07\x63ontext\x18\x01 \x01(\x0b\x32\x13.flwr.proto.Context\x12\x1c\n\x03run\x18\x02 \x01(\x0b\x32\x0f.flwr.proto.Run\x12\x1c\n\x03\x66\x61\x62\x18\x03 \x01(\x0b\x32\x0f.flwr.proto.Fab\"S\n\x1bPushServerAppOutputsRequest\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\x12$\n\x07\x63ontext\x18\x02 \x01(\x0b\x32\x13.flwr.proto.Context\"\x1e\n\x1cPushServerAppOutputsResponse2\xb0\t\n\x0bServerAppIo\x12J\n\tCreateRun\x12\x1c.flwr.proto.CreateRunRequest\x1a\x1d.flwr.proto.CreateRunResponse\"\x00\x12G\n\x08GetNodes\x12\x1b.flwr.proto.GetNodesRequest\x1a\x1c.flwr.proto.GetNodesResponse\"\x00\x12Y\n\x0cPushMessages\x12\".flwr.proto.PushInsMessagesRequest\x1a#.flwr.proto.PushInsMessagesResponse\"\x00\x12Y\n\x0cPullMessages\x12\".flwr.proto.PullResMessagesRequest\x1a#.flwr.proto.PullResMessagesResponse\"\x00\x12\x41\n\x06GetRun\x12\x19.flwr.proto.GetRunRequest\x1a\x1a.flwr.proto.GetRunResponse\"\x00\x12\x41\n\x06GetFab\x12\x19.flwr.proto.GetFabRequest\x1a\x1a.flwr.proto.GetFabResponse\"\x00\x12h\n\x13PullServerAppInputs\x12&.flwr.proto.PullServerAppInputsRequest\x1a\'.flwr.proto.PullServerAppInputsResponse\"\x00\x12k\n\x14PushServerAppOutputs\x12\'.flwr.proto.PushServerAppOutputsRequest\x1a(.flwr.proto.PushServerAppOutputsResponse\"\x00\x12\\\n\x0fUpdateRunStatus\x12\".flwr.proto.UpdateRunStatusRequest\x1a#.flwr.proto.UpdateRunStatusResponse\"\x00\x12S\n\x0cGetRunStatus\x12\x1f.flwr.proto.GetRunStatusRequest\x1a .flwr.proto.GetRunStatusResponse\"\x00\x12G\n\x08PushLogs\x12\x1b.flwr.proto.PushLogsRequest\x1a\x1c.flwr.proto.PushLogsResponse\"\x00\x12_\n\x10SendAppHeartbeat\x12#.flwr.proto.SendAppHeartbeatRequest\x1a$.flwr.proto.SendAppHeartbeatResponse\"\x00\x12M\n\nPushObject\x12\x1d.flwr.proto.PushObjectRequest\x1a\x1e.flwr.proto.PushObjectResponse\"\x00\x12M\n\nPullObject\x12\x1d.flwr.proto.PullObjectRequest\x1a\x1e.flwr.proto.PullObjectResponse\"\x00\x62\x06proto3')
24
+
25
+ _globals = globals()
26
+ _builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
27
+ _builder.BuildTopDescriptorsAndMessages(DESCRIPTOR, 'flwr.proto.serverappio_pb2', _globals)
28
+ if _descriptor._USE_C_DESCRIPTORS == False:
29
+ DESCRIPTOR._options = None
30
+ _globals['_GETNODESREQUEST']._serialized_start=187
31
+ _globals['_GETNODESREQUEST']._serialized_end=220
32
+ _globals['_GETNODESRESPONSE']._serialized_start=222
33
+ _globals['_GETNODESRESPONSE']._serialized_end=273
34
+ _globals['_PUSHINSMESSAGESREQUEST']._serialized_start=275
35
+ _globals['_PUSHINSMESSAGESREQUEST']._serialized_end=359
36
+ _globals['_PUSHINSMESSAGESRESPONSE']._serialized_start=361
37
+ _globals['_PUSHINSMESSAGESRESPONSE']._serialized_end=407
38
+ _globals['_PULLRESMESSAGESREQUEST']._serialized_start=409
39
+ _globals['_PULLRESMESSAGESREQUEST']._serialized_end=470
40
+ _globals['_PULLRESMESSAGESRESPONSE']._serialized_start=472
41
+ _globals['_PULLRESMESSAGESRESPONSE']._serialized_end=541
42
+ _globals['_PULLSERVERAPPINPUTSREQUEST']._serialized_start=543
43
+ _globals['_PULLSERVERAPPINPUTSREQUEST']._serialized_end=571
44
+ _globals['_PULLSERVERAPPINPUTSRESPONSE']._serialized_start=573
45
+ _globals['_PULLSERVERAPPINPUTSRESPONSE']._serialized_end=700
46
+ _globals['_PUSHSERVERAPPOUTPUTSREQUEST']._serialized_start=702
47
+ _globals['_PUSHSERVERAPPOUTPUTSREQUEST']._serialized_end=785
48
+ _globals['_PUSHSERVERAPPOUTPUTSRESPONSE']._serialized_start=787
49
+ _globals['_PUSHSERVERAPPOUTPUTSRESPONSE']._serialized_end=817
50
+ _globals['_SERVERAPPIO']._serialized_start=820
51
+ _globals['_SERVERAPPIO']._serialized_end=2020
52
+ # @@protoc_insertion_point(module_scope)
@@ -3,7 +3,9 @@
3
3
  import grpc
4
4
 
5
5
  from flwr.proto import fab_pb2 as flwr_dot_proto_dot_fab__pb2
6
+ from flwr.proto import heartbeat_pb2 as flwr_dot_proto_dot_heartbeat__pb2
6
7
  from flwr.proto import log_pb2 as flwr_dot_proto_dot_log__pb2
8
+ from flwr.proto import message_pb2 as flwr_dot_proto_dot_message__pb2
7
9
  from flwr.proto import run_pb2 as flwr_dot_proto_dot_run__pb2
8
10
  from flwr.proto import serverappio_pb2 as flwr_dot_proto_dot_serverappio__pb2
9
11
 
@@ -72,6 +74,21 @@ class ServerAppIoStub(object):
72
74
  request_serializer=flwr_dot_proto_dot_log__pb2.PushLogsRequest.SerializeToString,
73
75
  response_deserializer=flwr_dot_proto_dot_log__pb2.PushLogsResponse.FromString,
74
76
  )
77
+ self.SendAppHeartbeat = channel.unary_unary(
78
+ '/flwr.proto.ServerAppIo/SendAppHeartbeat',
79
+ request_serializer=flwr_dot_proto_dot_heartbeat__pb2.SendAppHeartbeatRequest.SerializeToString,
80
+ response_deserializer=flwr_dot_proto_dot_heartbeat__pb2.SendAppHeartbeatResponse.FromString,
81
+ )
82
+ self.PushObject = channel.unary_unary(
83
+ '/flwr.proto.ServerAppIo/PushObject',
84
+ request_serializer=flwr_dot_proto_dot_message__pb2.PushObjectRequest.SerializeToString,
85
+ response_deserializer=flwr_dot_proto_dot_message__pb2.PushObjectResponse.FromString,
86
+ )
87
+ self.PullObject = channel.unary_unary(
88
+ '/flwr.proto.ServerAppIo/PullObject',
89
+ request_serializer=flwr_dot_proto_dot_message__pb2.PullObjectRequest.SerializeToString,
90
+ response_deserializer=flwr_dot_proto_dot_message__pb2.PullObjectResponse.FromString,
91
+ )
75
92
 
76
93
 
77
94
  class ServerAppIoServicer(object):
@@ -154,6 +171,27 @@ class ServerAppIoServicer(object):
154
171
  context.set_details('Method not implemented!')
155
172
  raise NotImplementedError('Method not implemented!')
156
173
 
174
+ def SendAppHeartbeat(self, request, context):
175
+ """Heartbeat
176
+ """
177
+ context.set_code(grpc.StatusCode.UNIMPLEMENTED)
178
+ context.set_details('Method not implemented!')
179
+ raise NotImplementedError('Method not implemented!')
180
+
181
+ def PushObject(self, request, context):
182
+ """Push Object
183
+ """
184
+ context.set_code(grpc.StatusCode.UNIMPLEMENTED)
185
+ context.set_details('Method not implemented!')
186
+ raise NotImplementedError('Method not implemented!')
187
+
188
+ def PullObject(self, request, context):
189
+ """Pull Object
190
+ """
191
+ context.set_code(grpc.StatusCode.UNIMPLEMENTED)
192
+ context.set_details('Method not implemented!')
193
+ raise NotImplementedError('Method not implemented!')
194
+
157
195
 
158
196
  def add_ServerAppIoServicer_to_server(servicer, server):
159
197
  rpc_method_handlers = {
@@ -212,6 +250,21 @@ def add_ServerAppIoServicer_to_server(servicer, server):
212
250
  request_deserializer=flwr_dot_proto_dot_log__pb2.PushLogsRequest.FromString,
213
251
  response_serializer=flwr_dot_proto_dot_log__pb2.PushLogsResponse.SerializeToString,
214
252
  ),
253
+ 'SendAppHeartbeat': grpc.unary_unary_rpc_method_handler(
254
+ servicer.SendAppHeartbeat,
255
+ request_deserializer=flwr_dot_proto_dot_heartbeat__pb2.SendAppHeartbeatRequest.FromString,
256
+ response_serializer=flwr_dot_proto_dot_heartbeat__pb2.SendAppHeartbeatResponse.SerializeToString,
257
+ ),
258
+ 'PushObject': grpc.unary_unary_rpc_method_handler(
259
+ servicer.PushObject,
260
+ request_deserializer=flwr_dot_proto_dot_message__pb2.PushObjectRequest.FromString,
261
+ response_serializer=flwr_dot_proto_dot_message__pb2.PushObjectResponse.SerializeToString,
262
+ ),
263
+ 'PullObject': grpc.unary_unary_rpc_method_handler(
264
+ servicer.PullObject,
265
+ request_deserializer=flwr_dot_proto_dot_message__pb2.PullObjectRequest.FromString,
266
+ response_serializer=flwr_dot_proto_dot_message__pb2.PullObjectResponse.SerializeToString,
267
+ ),
215
268
  }
216
269
  generic_handler = grpc.method_handlers_generic_handler(
217
270
  'flwr.proto.ServerAppIo', rpc_method_handlers)
@@ -408,3 +461,54 @@ class ServerAppIo(object):
408
461
  flwr_dot_proto_dot_log__pb2.PushLogsResponse.FromString,
409
462
  options, channel_credentials,
410
463
  insecure, call_credentials, compression, wait_for_ready, timeout, metadata)
464
+
465
+ @staticmethod
466
+ def SendAppHeartbeat(request,
467
+ target,
468
+ options=(),
469
+ channel_credentials=None,
470
+ call_credentials=None,
471
+ insecure=False,
472
+ compression=None,
473
+ wait_for_ready=None,
474
+ timeout=None,
475
+ metadata=None):
476
+ return grpc.experimental.unary_unary(request, target, '/flwr.proto.ServerAppIo/SendAppHeartbeat',
477
+ flwr_dot_proto_dot_heartbeat__pb2.SendAppHeartbeatRequest.SerializeToString,
478
+ flwr_dot_proto_dot_heartbeat__pb2.SendAppHeartbeatResponse.FromString,
479
+ options, channel_credentials,
480
+ insecure, call_credentials, compression, wait_for_ready, timeout, metadata)
481
+
482
+ @staticmethod
483
+ def PushObject(request,
484
+ target,
485
+ options=(),
486
+ channel_credentials=None,
487
+ call_credentials=None,
488
+ insecure=False,
489
+ compression=None,
490
+ wait_for_ready=None,
491
+ timeout=None,
492
+ metadata=None):
493
+ return grpc.experimental.unary_unary(request, target, '/flwr.proto.ServerAppIo/PushObject',
494
+ flwr_dot_proto_dot_message__pb2.PushObjectRequest.SerializeToString,
495
+ flwr_dot_proto_dot_message__pb2.PushObjectResponse.FromString,
496
+ options, channel_credentials,
497
+ insecure, call_credentials, compression, wait_for_ready, timeout, metadata)
498
+
499
+ @staticmethod
500
+ def PullObject(request,
501
+ target,
502
+ options=(),
503
+ channel_credentials=None,
504
+ call_credentials=None,
505
+ insecure=False,
506
+ compression=None,
507
+ wait_for_ready=None,
508
+ timeout=None,
509
+ metadata=None):
510
+ return grpc.experimental.unary_unary(request, target, '/flwr.proto.ServerAppIo/PullObject',
511
+ flwr_dot_proto_dot_message__pb2.PullObjectRequest.SerializeToString,
512
+ flwr_dot_proto_dot_message__pb2.PullObjectResponse.FromString,
513
+ options, channel_credentials,
514
+ insecure, call_credentials, compression, wait_for_ready, timeout, metadata)