flwr-nightly 1.20.0.dev20250617__tar.gz → 1.20.0.dev20250618__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 (365) hide show
  1. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/PKG-INFO +1 -1
  2. flwr_nightly-1.20.0.dev20250618/py/flwr/proto/clientappio_pb2.py +53 -0
  3. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/clientappio_pb2.pyi +47 -4
  4. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/clientappio_pb2_grpc.py +70 -2
  5. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/clientappio_pb2_grpc.pyi +30 -4
  6. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supernode/cli/flwr_clientapp.py +8 -2
  7. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supernode/runtime/run_clientapp.py +22 -18
  8. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supernode/servicer/clientappio/clientappio_servicer.py +83 -85
  9. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supernode/start_client_internal.py +22 -35
  10. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/pyproject.toml +1 -1
  11. flwr_nightly-1.20.0.dev20250617/py/flwr/proto/clientappio_pb2.py +0 -45
  12. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/README.md +0 -0
  13. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/__init__.py +0 -0
  14. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/app/__init__.py +0 -0
  15. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/app/error.py +0 -0
  16. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/app/metadata.py +0 -0
  17. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/__init__.py +0 -0
  18. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/app.py +0 -0
  19. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/auth_plugin/__init__.py +0 -0
  20. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/auth_plugin/oidc_cli_plugin.py +0 -0
  21. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/build.py +0 -0
  22. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/cli_user_auth_interceptor.py +0 -0
  23. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/config_utils.py +0 -0
  24. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/constant.py +0 -0
  25. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/example.py +0 -0
  26. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/install.py +0 -0
  27. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/log.py +0 -0
  28. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/login/__init__.py +0 -0
  29. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/login/login.py +0 -0
  30. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/ls.py +0 -0
  31. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/__init__.py +0 -0
  32. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/new.py +0 -0
  33. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/__init__.py +0 -0
  34. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/.gitignore.tpl +0 -0
  35. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/LICENSE.tpl +0 -0
  36. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/README.baseline.md.tpl +0 -0
  37. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/README.flowertune.md.tpl +0 -0
  38. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/README.md.tpl +0 -0
  39. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/__init__.py +0 -0
  40. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/__init__.baseline.py.tpl +0 -0
  41. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/__init__.py +0 -0
  42. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/__init__.py.tpl +0 -0
  43. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/client.baseline.py.tpl +0 -0
  44. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/client.huggingface.py.tpl +0 -0
  45. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/client.jax.py.tpl +0 -0
  46. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/client.mlx.py.tpl +0 -0
  47. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/client.numpy.py.tpl +0 -0
  48. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/client.pytorch.py.tpl +0 -0
  49. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/client.sklearn.py.tpl +0 -0
  50. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/client.tensorflow.py.tpl +0 -0
  51. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/dataset.baseline.py.tpl +0 -0
  52. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/flwr_tune/__init__.py +0 -0
  53. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/flwr_tune/client_app.py.tpl +0 -0
  54. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/flwr_tune/dataset.py.tpl +0 -0
  55. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/flwr_tune/models.py.tpl +0 -0
  56. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/flwr_tune/server_app.py.tpl +0 -0
  57. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/flwr_tune/strategy.py.tpl +0 -0
  58. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/model.baseline.py.tpl +0 -0
  59. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/server.baseline.py.tpl +0 -0
  60. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/server.huggingface.py.tpl +0 -0
  61. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/server.jax.py.tpl +0 -0
  62. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/server.mlx.py.tpl +0 -0
  63. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/server.numpy.py.tpl +0 -0
  64. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/server.pytorch.py.tpl +0 -0
  65. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/server.sklearn.py.tpl +0 -0
  66. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/server.tensorflow.py.tpl +0 -0
  67. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/strategy.baseline.py.tpl +0 -0
  68. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/task.huggingface.py.tpl +0 -0
  69. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/task.jax.py.tpl +0 -0
  70. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/task.mlx.py.tpl +0 -0
  71. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/task.numpy.py.tpl +0 -0
  72. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/task.pytorch.py.tpl +0 -0
  73. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/task.sklearn.py.tpl +0 -0
  74. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/task.tensorflow.py.tpl +0 -0
  75. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/code/utils.baseline.py.tpl +0 -0
  76. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/pyproject.baseline.toml.tpl +0 -0
  77. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/pyproject.flowertune.toml.tpl +0 -0
  78. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/pyproject.huggingface.toml.tpl +0 -0
  79. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/pyproject.jax.toml.tpl +0 -0
  80. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/pyproject.mlx.toml.tpl +0 -0
  81. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/pyproject.numpy.toml.tpl +0 -0
  82. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/pyproject.pytorch.toml.tpl +0 -0
  83. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/pyproject.sklearn.toml.tpl +0 -0
  84. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/new/templates/app/pyproject.tensorflow.toml.tpl +0 -0
  85. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/run/__init__.py +0 -0
  86. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/run/run.py +0 -0
  87. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/stop.py +0 -0
  88. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/cli/utils.py +0 -0
  89. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/__init__.py +0 -0
  90. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/client.py +0 -0
  91. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/client_app.py +0 -0
  92. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/clientapp/__init__.py +0 -0
  93. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/clientapp/utils.py +0 -0
  94. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/dpfedavg_numpy_client.py +0 -0
  95. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/grpc_adapter_client/__init__.py +0 -0
  96. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/grpc_adapter_client/connection.py +0 -0
  97. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/grpc_rere_client/__init__.py +0 -0
  98. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/grpc_rere_client/client_interceptor.py +0 -0
  99. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/grpc_rere_client/connection.py +0 -0
  100. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/grpc_rere_client/grpc_adapter.py +0 -0
  101. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/message_handler/__init__.py +0 -0
  102. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/message_handler/message_handler.py +0 -0
  103. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/mod/__init__.py +0 -0
  104. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/mod/centraldp_mods.py +0 -0
  105. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/mod/comms_mods.py +0 -0
  106. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/mod/localdp_mod.py +0 -0
  107. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/mod/secure_aggregation/__init__.py +0 -0
  108. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/mod/secure_aggregation/secagg_mod.py +0 -0
  109. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/mod/secure_aggregation/secaggplus_mod.py +0 -0
  110. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/mod/utils.py +0 -0
  111. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/numpy_client.py +0 -0
  112. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/rest_client/__init__.py +0 -0
  113. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/rest_client/connection.py +0 -0
  114. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/run_info_store.py +0 -0
  115. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/client/typing.py +0 -0
  116. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/clientapp/__init__.py +0 -0
  117. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/__init__.py +0 -0
  118. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/address.py +0 -0
  119. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/args.py +0 -0
  120. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/auth_plugin/__init__.py +0 -0
  121. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/auth_plugin/auth_plugin.py +0 -0
  122. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/config.py +0 -0
  123. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/constant.py +0 -0
  124. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/context.py +0 -0
  125. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/date.py +0 -0
  126. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/differential_privacy.py +0 -0
  127. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/differential_privacy_constants.py +0 -0
  128. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/dp.py +0 -0
  129. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/event_log_plugin/__init__.py +0 -0
  130. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/event_log_plugin/event_log_plugin.py +0 -0
  131. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/exit/__init__.py +0 -0
  132. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/exit/exit.py +0 -0
  133. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/exit/exit_code.py +0 -0
  134. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/exit_handlers.py +0 -0
  135. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/grpc.py +0 -0
  136. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/heartbeat.py +0 -0
  137. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/inflatable.py +0 -0
  138. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/inflatable_grpc_utils.py +0 -0
  139. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/inflatable_rest_utils.py +0 -0
  140. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/inflatable_utils.py +0 -0
  141. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/logger.py +0 -0
  142. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/message.py +0 -0
  143. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/object_ref.py +0 -0
  144. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/parameter.py +0 -0
  145. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/pyproject.py +0 -0
  146. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/record/__init__.py +0 -0
  147. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/record/array.py +0 -0
  148. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/record/arrayrecord.py +0 -0
  149. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/record/configrecord.py +0 -0
  150. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/record/conversion_utils.py +0 -0
  151. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/record/metricrecord.py +0 -0
  152. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/record/recorddict.py +0 -0
  153. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/record/typeddict.py +0 -0
  154. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/recorddict_compat.py +0 -0
  155. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/retry_invoker.py +0 -0
  156. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/secure_aggregation/__init__.py +0 -0
  157. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/secure_aggregation/crypto/__init__.py +0 -0
  158. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/secure_aggregation/crypto/shamir.py +0 -0
  159. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/secure_aggregation/crypto/symmetric_encryption.py +0 -0
  160. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/secure_aggregation/ndarrays_arithmetic.py +0 -0
  161. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/secure_aggregation/quantization.py +0 -0
  162. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/secure_aggregation/secaggplus_constants.py +0 -0
  163. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/secure_aggregation/secaggplus_utils.py +0 -0
  164. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/serde.py +0 -0
  165. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/serde_utils.py +0 -0
  166. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/telemetry.py +0 -0
  167. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/typing.py +0 -0
  168. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/common/version.py +0 -0
  169. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/compat/__init__.py +0 -0
  170. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/compat/client/__init__.py +0 -0
  171. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/compat/client/app.py +0 -0
  172. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/compat/client/grpc_client/__init__.py +0 -0
  173. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/compat/client/grpc_client/connection.py +0 -0
  174. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/compat/common/__init__.py +0 -0
  175. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/compat/server/__init__.py +0 -0
  176. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/compat/server/app.py +0 -0
  177. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/compat/simulation/__init__.py +0 -0
  178. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/__init__.py +0 -0
  179. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/error_pb2.py +0 -0
  180. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/error_pb2.pyi +0 -0
  181. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/error_pb2_grpc.py +0 -0
  182. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/error_pb2_grpc.pyi +0 -0
  183. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/exec_pb2.py +0 -0
  184. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/exec_pb2.pyi +0 -0
  185. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/exec_pb2_grpc.py +0 -0
  186. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/exec_pb2_grpc.pyi +0 -0
  187. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/fab_pb2.py +0 -0
  188. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/fab_pb2.pyi +0 -0
  189. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/fab_pb2_grpc.py +0 -0
  190. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/fab_pb2_grpc.pyi +0 -0
  191. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/fleet_pb2.py +0 -0
  192. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/fleet_pb2.pyi +0 -0
  193. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/fleet_pb2_grpc.py +0 -0
  194. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/fleet_pb2_grpc.pyi +0 -0
  195. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/grpcadapter_pb2.py +0 -0
  196. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/grpcadapter_pb2.pyi +0 -0
  197. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/grpcadapter_pb2_grpc.py +0 -0
  198. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/grpcadapter_pb2_grpc.pyi +0 -0
  199. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/heartbeat_pb2.py +0 -0
  200. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/heartbeat_pb2.pyi +0 -0
  201. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/heartbeat_pb2_grpc.py +0 -0
  202. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/heartbeat_pb2_grpc.pyi +0 -0
  203. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/log_pb2.py +0 -0
  204. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/log_pb2.pyi +0 -0
  205. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/log_pb2_grpc.py +0 -0
  206. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/log_pb2_grpc.pyi +0 -0
  207. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/message_pb2.py +0 -0
  208. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/message_pb2.pyi +0 -0
  209. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/message_pb2_grpc.py +0 -0
  210. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/message_pb2_grpc.pyi +0 -0
  211. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/node_pb2.py +0 -0
  212. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/node_pb2.pyi +0 -0
  213. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/node_pb2_grpc.py +0 -0
  214. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/node_pb2_grpc.pyi +0 -0
  215. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/recorddict_pb2.py +0 -0
  216. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/recorddict_pb2.pyi +0 -0
  217. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/recorddict_pb2_grpc.py +0 -0
  218. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/recorddict_pb2_grpc.pyi +0 -0
  219. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/run_pb2.py +0 -0
  220. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/run_pb2.pyi +0 -0
  221. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/run_pb2_grpc.py +0 -0
  222. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/run_pb2_grpc.pyi +0 -0
  223. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/serverappio_pb2.py +0 -0
  224. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/serverappio_pb2.pyi +0 -0
  225. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/serverappio_pb2_grpc.py +0 -0
  226. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/serverappio_pb2_grpc.pyi +0 -0
  227. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/simulationio_pb2.py +0 -0
  228. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/simulationio_pb2.pyi +0 -0
  229. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/simulationio_pb2_grpc.py +0 -0
  230. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/simulationio_pb2_grpc.pyi +0 -0
  231. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/transport_pb2.py +0 -0
  232. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/transport_pb2.pyi +0 -0
  233. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/transport_pb2_grpc.py +0 -0
  234. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/proto/transport_pb2_grpc.pyi +0 -0
  235. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/py.typed +0 -0
  236. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/__init__.py +0 -0
  237. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/app.py +0 -0
  238. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/client_manager.py +0 -0
  239. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/client_proxy.py +0 -0
  240. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/compat/__init__.py +0 -0
  241. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/compat/app.py +0 -0
  242. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/compat/app_utils.py +0 -0
  243. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/compat/grid_client_proxy.py +0 -0
  244. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/compat/legacy_context.py +0 -0
  245. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/criterion.py +0 -0
  246. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/fleet_event_log_interceptor.py +0 -0
  247. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/grid/__init__.py +0 -0
  248. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/grid/grid.py +0 -0
  249. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/grid/grpc_grid.py +0 -0
  250. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/grid/inmemory_grid.py +0 -0
  251. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/history.py +0 -0
  252. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/run_serverapp.py +0 -0
  253. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/server.py +0 -0
  254. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/server_app.py +0 -0
  255. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/server_config.py +0 -0
  256. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/serverapp/__init__.py +0 -0
  257. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/serverapp/app.py +0 -0
  258. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/serverapp_components.py +0 -0
  259. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/__init__.py +0 -0
  260. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/aggregate.py +0 -0
  261. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/bulyan.py +0 -0
  262. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/dp_adaptive_clipping.py +0 -0
  263. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/dp_fixed_clipping.py +0 -0
  264. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/dpfedavg_adaptive.py +0 -0
  265. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/dpfedavg_fixed.py +0 -0
  266. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/fault_tolerant_fedavg.py +0 -0
  267. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/fedadagrad.py +0 -0
  268. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/fedadam.py +0 -0
  269. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/fedavg.py +0 -0
  270. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/fedavg_android.py +0 -0
  271. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/fedavgm.py +0 -0
  272. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/fedmedian.py +0 -0
  273. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/fedopt.py +0 -0
  274. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/fedprox.py +0 -0
  275. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/fedtrimmedavg.py +0 -0
  276. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/fedxgb_bagging.py +0 -0
  277. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/fedxgb_cyclic.py +0 -0
  278. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/fedxgb_nn_avg.py +0 -0
  279. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/fedyogi.py +0 -0
  280. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/krum.py +0 -0
  281. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/qfedavg.py +0 -0
  282. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/strategy/strategy.py +0 -0
  283. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/__init__.py +0 -0
  284. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/__init__.py +0 -0
  285. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/grpc_adapter/__init__.py +0 -0
  286. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py +0 -0
  287. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/grpc_bidi/__init__.py +0 -0
  288. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/grpc_bidi/flower_service_servicer.py +0 -0
  289. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_bridge.py +0 -0
  290. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_client_proxy.py +0 -0
  291. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_server.py +0 -0
  292. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/grpc_rere/__init__.py +0 -0
  293. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/grpc_rere/fleet_servicer.py +0 -0
  294. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/grpc_rere/server_interceptor.py +0 -0
  295. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/message_handler/__init__.py +0 -0
  296. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/message_handler/message_handler.py +0 -0
  297. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/rest_rere/__init__.py +0 -0
  298. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/rest_rere/rest_api.py +0 -0
  299. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/vce/__init__.py +0 -0
  300. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/vce/backend/__init__.py +0 -0
  301. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/vce/backend/backend.py +0 -0
  302. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/vce/backend/raybackend.py +0 -0
  303. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/fleet/vce/vce_api.py +0 -0
  304. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/linkstate/__init__.py +0 -0
  305. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/linkstate/in_memory_linkstate.py +0 -0
  306. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/linkstate/linkstate.py +0 -0
  307. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/linkstate/linkstate_factory.py +0 -0
  308. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/linkstate/sqlite_linkstate.py +0 -0
  309. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/linkstate/utils.py +0 -0
  310. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/serverappio/__init__.py +0 -0
  311. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/serverappio/serverappio_grpc.py +0 -0
  312. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/serverappio/serverappio_servicer.py +0 -0
  313. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/simulation/__init__.py +0 -0
  314. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/simulation/simulationio_grpc.py +0 -0
  315. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/simulation/simulationio_servicer.py +0 -0
  316. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/superlink/utils.py +0 -0
  317. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/typing.py +0 -0
  318. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/utils/__init__.py +0 -0
  319. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/utils/tensorboard.py +0 -0
  320. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/utils/validator.py +0 -0
  321. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/workflow/__init__.py +0 -0
  322. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/workflow/constant.py +0 -0
  323. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/workflow/default_workflows.py +0 -0
  324. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/workflow/secure_aggregation/__init__.py +0 -0
  325. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/workflow/secure_aggregation/secagg_workflow.py +0 -0
  326. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/server/workflow/secure_aggregation/secaggplus_workflow.py +0 -0
  327. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/serverapp/__init__.py +0 -0
  328. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/simulation/__init__.py +0 -0
  329. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/simulation/app.py +0 -0
  330. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/simulation/legacy_app.py +0 -0
  331. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/simulation/ray_transport/__init__.py +0 -0
  332. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/simulation/ray_transport/ray_actor.py +0 -0
  333. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/simulation/ray_transport/ray_client_proxy.py +0 -0
  334. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/simulation/ray_transport/utils.py +0 -0
  335. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/simulation/run_simulation.py +0 -0
  336. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/simulation/simulationio_connection.py +0 -0
  337. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supercore/__init__.py +0 -0
  338. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supercore/ffs/__init__.py +0 -0
  339. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supercore/ffs/disk_ffs.py +0 -0
  340. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supercore/ffs/ffs.py +0 -0
  341. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supercore/ffs/ffs_factory.py +0 -0
  342. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supercore/object_store/__init__.py +0 -0
  343. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supercore/object_store/in_memory_object_store.py +0 -0
  344. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supercore/object_store/object_store.py +0 -0
  345. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supercore/object_store/object_store_factory.py +0 -0
  346. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/superexec/__init__.py +0 -0
  347. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/superexec/app.py +0 -0
  348. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/superexec/deployment.py +0 -0
  349. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/superexec/exec_event_log_interceptor.py +0 -0
  350. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/superexec/exec_grpc.py +0 -0
  351. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/superexec/exec_servicer.py +0 -0
  352. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/superexec/exec_user_auth_interceptor.py +0 -0
  353. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/superexec/executor.py +0 -0
  354. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/superexec/simulation.py +0 -0
  355. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/superlink/__init__.py +0 -0
  356. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supernode/__init__.py +0 -0
  357. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supernode/cli/__init__.py +0 -0
  358. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supernode/cli/flower_supernode.py +0 -0
  359. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supernode/nodestate/__init__.py +0 -0
  360. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supernode/nodestate/in_memory_nodestate.py +0 -0
  361. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supernode/nodestate/nodestate.py +0 -0
  362. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supernode/nodestate/nodestate_factory.py +0 -0
  363. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supernode/runtime/__init__.py +0 -0
  364. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supernode/servicer/__init__.py +0 -0
  365. {flwr_nightly-1.20.0.dev20250617 → flwr_nightly-1.20.0.dev20250618}/py/flwr/supernode/servicer/clientappio/__init__.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: flwr-nightly
3
- Version: 1.20.0.dev20250617
3
+ Version: 1.20.0.dev20250618
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
@@ -0,0 +1,53 @@
1
+ # -*- coding: utf-8 -*-
2
+ # Generated by the protocol buffer compiler. DO NOT EDIT!
3
+ # source: flwr/proto/clientappio.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 fab_pb2 as flwr_dot_proto_dot_fab__pb2
16
+ from flwr.proto import run_pb2 as flwr_dot_proto_dot_run__pb2
17
+ from flwr.proto import message_pb2 as flwr_dot_proto_dot_message__pb2
18
+
19
+
20
+ DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x1c\x66lwr/proto/clientappio.proto\x12\nflwr.proto\x1a\x14\x66lwr/proto/fab.proto\x1a\x14\x66lwr/proto/run.proto\x1a\x18\x66lwr/proto/message.proto\"%\n#GetRunIdsWithPendingMessagesRequest\"7\n$GetRunIdsWithPendingMessagesResponse\x12\x0f\n\x07run_ids\x18\x01 \x03(\x04\"%\n\x13RequestTokenRequest\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\"%\n\x14RequestTokenResponse\x12\r\n\x05token\x18\x01 \x01(\t\"W\n\x15\x43lientAppOutputStatus\x12-\n\x04\x63ode\x18\x01 \x01(\x0e\x32\x1f.flwr.proto.ClientAppOutputCode\x12\x0f\n\x07message\x18\x02 \x01(\t\"\x11\n\x0fGetTokenRequest\"!\n\x10GetTokenResponse\x12\r\n\x05token\x18\x01 \x01(\x04\"+\n\x1aPullClientAppInputsRequest\x12\r\n\x05token\x18\x01 \x01(\t\"\xa5\x01\n\x1bPullClientAppInputsResponse\x12$\n\x07message\x18\x01 \x01(\x0b\x32\x13.flwr.proto.Message\x12$\n\x07\x63ontext\x18\x02 \x01(\x0b\x32\x13.flwr.proto.Context\x12\x1c\n\x03run\x18\x03 \x01(\x0b\x32\x0f.flwr.proto.Run\x12\x1c\n\x03\x66\x61\x62\x18\x04 \x01(\x0b\x32\x0f.flwr.proto.Fab\"x\n\x1bPushClientAppOutputsRequest\x12\r\n\x05token\x18\x01 \x01(\t\x12$\n\x07message\x18\x02 \x01(\x0b\x32\x13.flwr.proto.Message\x12$\n\x07\x63ontext\x18\x03 \x01(\x0b\x32\x13.flwr.proto.Context\"Q\n\x1cPushClientAppOutputsResponse\x12\x31\n\x06status\x18\x01 \x01(\x0b\x32!.flwr.proto.ClientAppOutputStatus*L\n\x13\x43lientAppOutputCode\x12\x0b\n\x07SUCCESS\x10\x00\x12\x15\n\x11\x44\x45\x41\x44LINE_EXCEEDED\x10\x01\x12\x11\n\rUNKNOWN_ERROR\x10\x02\x32\x88\x04\n\x0b\x43lientAppIo\x12\x83\x01\n\x1cGetRunIdsWithPendingMessages\x12/.flwr.proto.GetRunIdsWithPendingMessagesRequest\x1a\x30.flwr.proto.GetRunIdsWithPendingMessagesResponse\"\x00\x12S\n\x0cRequestToken\x12\x1f.flwr.proto.RequestTokenRequest\x1a .flwr.proto.RequestTokenResponse\"\x00\x12G\n\x08GetToken\x12\x1b.flwr.proto.GetTokenRequest\x1a\x1c.flwr.proto.GetTokenResponse\"\x00\x12h\n\x13PullClientAppInputs\x12&.flwr.proto.PullClientAppInputsRequest\x1a\'.flwr.proto.PullClientAppInputsResponse\"\x00\x12k\n\x14PushClientAppOutputs\x12\'.flwr.proto.PushClientAppOutputsRequest\x1a(.flwr.proto.PushClientAppOutputsResponse\"\x00\x62\x06proto3')
21
+
22
+ _globals = globals()
23
+ _builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
24
+ _builder.BuildTopDescriptorsAndMessages(DESCRIPTOR, 'flwr.proto.clientappio_pb2', _globals)
25
+ if _descriptor._USE_C_DESCRIPTORS == False:
26
+ DESCRIPTOR._options = None
27
+ _globals['_CLIENTAPPOUTPUTCODE']._serialized_start=849
28
+ _globals['_CLIENTAPPOUTPUTCODE']._serialized_end=925
29
+ _globals['_GETRUNIDSWITHPENDINGMESSAGESREQUEST']._serialized_start=114
30
+ _globals['_GETRUNIDSWITHPENDINGMESSAGESREQUEST']._serialized_end=151
31
+ _globals['_GETRUNIDSWITHPENDINGMESSAGESRESPONSE']._serialized_start=153
32
+ _globals['_GETRUNIDSWITHPENDINGMESSAGESRESPONSE']._serialized_end=208
33
+ _globals['_REQUESTTOKENREQUEST']._serialized_start=210
34
+ _globals['_REQUESTTOKENREQUEST']._serialized_end=247
35
+ _globals['_REQUESTTOKENRESPONSE']._serialized_start=249
36
+ _globals['_REQUESTTOKENRESPONSE']._serialized_end=286
37
+ _globals['_CLIENTAPPOUTPUTSTATUS']._serialized_start=288
38
+ _globals['_CLIENTAPPOUTPUTSTATUS']._serialized_end=375
39
+ _globals['_GETTOKENREQUEST']._serialized_start=377
40
+ _globals['_GETTOKENREQUEST']._serialized_end=394
41
+ _globals['_GETTOKENRESPONSE']._serialized_start=396
42
+ _globals['_GETTOKENRESPONSE']._serialized_end=429
43
+ _globals['_PULLCLIENTAPPINPUTSREQUEST']._serialized_start=431
44
+ _globals['_PULLCLIENTAPPINPUTSREQUEST']._serialized_end=474
45
+ _globals['_PULLCLIENTAPPINPUTSRESPONSE']._serialized_start=477
46
+ _globals['_PULLCLIENTAPPINPUTSRESPONSE']._serialized_end=642
47
+ _globals['_PUSHCLIENTAPPOUTPUTSREQUEST']._serialized_start=644
48
+ _globals['_PUSHCLIENTAPPOUTPUTSREQUEST']._serialized_end=764
49
+ _globals['_PUSHCLIENTAPPOUTPUTSRESPONSE']._serialized_start=766
50
+ _globals['_PUSHCLIENTAPPOUTPUTSRESPONSE']._serialized_end=847
51
+ _globals['_CLIENTAPPIO']._serialized_start=928
52
+ _globals['_CLIENTAPPIO']._serialized_end=1448
53
+ # @@protoc_insertion_point(module_scope)
@@ -7,6 +7,7 @@ import flwr.proto.fab_pb2
7
7
  import flwr.proto.message_pb2
8
8
  import flwr.proto.run_pb2
9
9
  import google.protobuf.descriptor
10
+ import google.protobuf.internal.containers
10
11
  import google.protobuf.internal.enum_type_wrapper
11
12
  import google.protobuf.message
12
13
  import typing
@@ -31,6 +32,48 @@ UNKNOWN_ERROR: ClientAppOutputCode.ValueType # 2
31
32
  global___ClientAppOutputCode = ClientAppOutputCode
32
33
 
33
34
 
35
+ class GetRunIdsWithPendingMessagesRequest(google.protobuf.message.Message):
36
+ DESCRIPTOR: google.protobuf.descriptor.Descriptor
37
+ def __init__(self,
38
+ ) -> None: ...
39
+ global___GetRunIdsWithPendingMessagesRequest = GetRunIdsWithPendingMessagesRequest
40
+
41
+ class GetRunIdsWithPendingMessagesResponse(google.protobuf.message.Message):
42
+ DESCRIPTOR: google.protobuf.descriptor.Descriptor
43
+ RUN_IDS_FIELD_NUMBER: builtins.int
44
+ @property
45
+ def run_ids(self) -> google.protobuf.internal.containers.RepeatedScalarFieldContainer[builtins.int]:
46
+ """List of run IDs"""
47
+ pass
48
+ def __init__(self,
49
+ *,
50
+ run_ids: typing.Optional[typing.Iterable[builtins.int]] = ...,
51
+ ) -> None: ...
52
+ def ClearField(self, field_name: typing_extensions.Literal["run_ids",b"run_ids"]) -> None: ...
53
+ global___GetRunIdsWithPendingMessagesResponse = GetRunIdsWithPendingMessagesResponse
54
+
55
+ class RequestTokenRequest(google.protobuf.message.Message):
56
+ DESCRIPTOR: google.protobuf.descriptor.Descriptor
57
+ RUN_ID_FIELD_NUMBER: builtins.int
58
+ run_id: builtins.int
59
+ def __init__(self,
60
+ *,
61
+ run_id: builtins.int = ...,
62
+ ) -> None: ...
63
+ def ClearField(self, field_name: typing_extensions.Literal["run_id",b"run_id"]) -> None: ...
64
+ global___RequestTokenRequest = RequestTokenRequest
65
+
66
+ class RequestTokenResponse(google.protobuf.message.Message):
67
+ DESCRIPTOR: google.protobuf.descriptor.Descriptor
68
+ TOKEN_FIELD_NUMBER: builtins.int
69
+ token: typing.Text
70
+ def __init__(self,
71
+ *,
72
+ token: typing.Text = ...,
73
+ ) -> None: ...
74
+ def ClearField(self, field_name: typing_extensions.Literal["token",b"token"]) -> None: ...
75
+ global___RequestTokenResponse = RequestTokenResponse
76
+
34
77
  class ClientAppOutputStatus(google.protobuf.message.Message):
35
78
  DESCRIPTOR: google.protobuf.descriptor.Descriptor
36
79
  CODE_FIELD_NUMBER: builtins.int
@@ -65,10 +108,10 @@ global___GetTokenResponse = GetTokenResponse
65
108
  class PullClientAppInputsRequest(google.protobuf.message.Message):
66
109
  DESCRIPTOR: google.protobuf.descriptor.Descriptor
67
110
  TOKEN_FIELD_NUMBER: builtins.int
68
- token: builtins.int
111
+ token: typing.Text
69
112
  def __init__(self,
70
113
  *,
71
- token: builtins.int = ...,
114
+ token: typing.Text = ...,
72
115
  ) -> None: ...
73
116
  def ClearField(self, field_name: typing_extensions.Literal["token",b"token"]) -> None: ...
74
117
  global___PullClientAppInputsRequest = PullClientAppInputsRequest
@@ -103,14 +146,14 @@ class PushClientAppOutputsRequest(google.protobuf.message.Message):
103
146
  TOKEN_FIELD_NUMBER: builtins.int
104
147
  MESSAGE_FIELD_NUMBER: builtins.int
105
148
  CONTEXT_FIELD_NUMBER: builtins.int
106
- token: builtins.int
149
+ token: typing.Text
107
150
  @property
108
151
  def message(self) -> flwr.proto.message_pb2.Message: ...
109
152
  @property
110
153
  def context(self) -> flwr.proto.message_pb2.Context: ...
111
154
  def __init__(self,
112
155
  *,
113
- token: builtins.int = ...,
156
+ token: typing.Text = ...,
114
157
  message: typing.Optional[flwr.proto.message_pb2.Message] = ...,
115
158
  context: typing.Optional[flwr.proto.message_pb2.Context] = ...,
116
159
  ) -> None: ...
@@ -14,6 +14,16 @@ class ClientAppIoStub(object):
14
14
  Args:
15
15
  channel: A grpc.Channel.
16
16
  """
17
+ self.GetRunIdsWithPendingMessages = channel.unary_unary(
18
+ '/flwr.proto.ClientAppIo/GetRunIdsWithPendingMessages',
19
+ request_serializer=flwr_dot_proto_dot_clientappio__pb2.GetRunIdsWithPendingMessagesRequest.SerializeToString,
20
+ response_deserializer=flwr_dot_proto_dot_clientappio__pb2.GetRunIdsWithPendingMessagesResponse.FromString,
21
+ )
22
+ self.RequestToken = channel.unary_unary(
23
+ '/flwr.proto.ClientAppIo/RequestToken',
24
+ request_serializer=flwr_dot_proto_dot_clientappio__pb2.RequestTokenRequest.SerializeToString,
25
+ response_deserializer=flwr_dot_proto_dot_clientappio__pb2.RequestTokenResponse.FromString,
26
+ )
17
27
  self.GetToken = channel.unary_unary(
18
28
  '/flwr.proto.ClientAppIo/GetToken',
19
29
  request_serializer=flwr_dot_proto_dot_clientappio__pb2.GetTokenRequest.SerializeToString,
@@ -34,6 +44,20 @@ class ClientAppIoStub(object):
34
44
  class ClientAppIoServicer(object):
35
45
  """Missing associated documentation comment in .proto file."""
36
46
 
47
+ def GetRunIdsWithPendingMessages(self, request, context):
48
+ """Get run IDs with pending messages
49
+ """
50
+ context.set_code(grpc.StatusCode.UNIMPLEMENTED)
51
+ context.set_details('Method not implemented!')
52
+ raise NotImplementedError('Method not implemented!')
53
+
54
+ def RequestToken(self, request, context):
55
+ """Request token
56
+ """
57
+ context.set_code(grpc.StatusCode.UNIMPLEMENTED)
58
+ context.set_details('Method not implemented!')
59
+ raise NotImplementedError('Method not implemented!')
60
+
37
61
  def GetToken(self, request, context):
38
62
  """Get token
39
63
  """
@@ -42,14 +66,14 @@ class ClientAppIoServicer(object):
42
66
  raise NotImplementedError('Method not implemented!')
43
67
 
44
68
  def PullClientAppInputs(self, request, context):
45
- """Get Message, Context, and Run
69
+ """Pull client app inputs
46
70
  """
47
71
  context.set_code(grpc.StatusCode.UNIMPLEMENTED)
48
72
  context.set_details('Method not implemented!')
49
73
  raise NotImplementedError('Method not implemented!')
50
74
 
51
75
  def PushClientAppOutputs(self, request, context):
52
- """Send updated Message and Context
76
+ """Push client app outputs
53
77
  """
54
78
  context.set_code(grpc.StatusCode.UNIMPLEMENTED)
55
79
  context.set_details('Method not implemented!')
@@ -58,6 +82,16 @@ class ClientAppIoServicer(object):
58
82
 
59
83
  def add_ClientAppIoServicer_to_server(servicer, server):
60
84
  rpc_method_handlers = {
85
+ 'GetRunIdsWithPendingMessages': grpc.unary_unary_rpc_method_handler(
86
+ servicer.GetRunIdsWithPendingMessages,
87
+ request_deserializer=flwr_dot_proto_dot_clientappio__pb2.GetRunIdsWithPendingMessagesRequest.FromString,
88
+ response_serializer=flwr_dot_proto_dot_clientappio__pb2.GetRunIdsWithPendingMessagesResponse.SerializeToString,
89
+ ),
90
+ 'RequestToken': grpc.unary_unary_rpc_method_handler(
91
+ servicer.RequestToken,
92
+ request_deserializer=flwr_dot_proto_dot_clientappio__pb2.RequestTokenRequest.FromString,
93
+ response_serializer=flwr_dot_proto_dot_clientappio__pb2.RequestTokenResponse.SerializeToString,
94
+ ),
61
95
  'GetToken': grpc.unary_unary_rpc_method_handler(
62
96
  servicer.GetToken,
63
97
  request_deserializer=flwr_dot_proto_dot_clientappio__pb2.GetTokenRequest.FromString,
@@ -83,6 +117,40 @@ def add_ClientAppIoServicer_to_server(servicer, server):
83
117
  class ClientAppIo(object):
84
118
  """Missing associated documentation comment in .proto file."""
85
119
 
120
+ @staticmethod
121
+ def GetRunIdsWithPendingMessages(request,
122
+ target,
123
+ options=(),
124
+ channel_credentials=None,
125
+ call_credentials=None,
126
+ insecure=False,
127
+ compression=None,
128
+ wait_for_ready=None,
129
+ timeout=None,
130
+ metadata=None):
131
+ return grpc.experimental.unary_unary(request, target, '/flwr.proto.ClientAppIo/GetRunIdsWithPendingMessages',
132
+ flwr_dot_proto_dot_clientappio__pb2.GetRunIdsWithPendingMessagesRequest.SerializeToString,
133
+ flwr_dot_proto_dot_clientappio__pb2.GetRunIdsWithPendingMessagesResponse.FromString,
134
+ options, channel_credentials,
135
+ insecure, call_credentials, compression, wait_for_ready, timeout, metadata)
136
+
137
+ @staticmethod
138
+ def RequestToken(request,
139
+ target,
140
+ options=(),
141
+ channel_credentials=None,
142
+ call_credentials=None,
143
+ insecure=False,
144
+ compression=None,
145
+ wait_for_ready=None,
146
+ timeout=None,
147
+ metadata=None):
148
+ return grpc.experimental.unary_unary(request, target, '/flwr.proto.ClientAppIo/RequestToken',
149
+ flwr_dot_proto_dot_clientappio__pb2.RequestTokenRequest.SerializeToString,
150
+ flwr_dot_proto_dot_clientappio__pb2.RequestTokenResponse.FromString,
151
+ options, channel_credentials,
152
+ insecure, call_credentials, compression, wait_for_ready, timeout, metadata)
153
+
86
154
  @staticmethod
87
155
  def GetToken(request,
88
156
  target,
@@ -8,6 +8,16 @@ import grpc
8
8
 
9
9
  class ClientAppIoStub:
10
10
  def __init__(self, channel: grpc.Channel) -> None: ...
11
+ GetRunIdsWithPendingMessages: grpc.UnaryUnaryMultiCallable[
12
+ flwr.proto.clientappio_pb2.GetRunIdsWithPendingMessagesRequest,
13
+ flwr.proto.clientappio_pb2.GetRunIdsWithPendingMessagesResponse]
14
+ """Get run IDs with pending messages"""
15
+
16
+ RequestToken: grpc.UnaryUnaryMultiCallable[
17
+ flwr.proto.clientappio_pb2.RequestTokenRequest,
18
+ flwr.proto.clientappio_pb2.RequestTokenResponse]
19
+ """Request token"""
20
+
11
21
  GetToken: grpc.UnaryUnaryMultiCallable[
12
22
  flwr.proto.clientappio_pb2.GetTokenRequest,
13
23
  flwr.proto.clientappio_pb2.GetTokenResponse]
@@ -16,15 +26,31 @@ class ClientAppIoStub:
16
26
  PullClientAppInputs: grpc.UnaryUnaryMultiCallable[
17
27
  flwr.proto.clientappio_pb2.PullClientAppInputsRequest,
18
28
  flwr.proto.clientappio_pb2.PullClientAppInputsResponse]
19
- """Get Message, Context, and Run"""
29
+ """Pull client app inputs"""
20
30
 
21
31
  PushClientAppOutputs: grpc.UnaryUnaryMultiCallable[
22
32
  flwr.proto.clientappio_pb2.PushClientAppOutputsRequest,
23
33
  flwr.proto.clientappio_pb2.PushClientAppOutputsResponse]
24
- """Send updated Message and Context"""
34
+ """Push client app outputs"""
25
35
 
26
36
 
27
37
  class ClientAppIoServicer(metaclass=abc.ABCMeta):
38
+ @abc.abstractmethod
39
+ def GetRunIdsWithPendingMessages(self,
40
+ request: flwr.proto.clientappio_pb2.GetRunIdsWithPendingMessagesRequest,
41
+ context: grpc.ServicerContext,
42
+ ) -> flwr.proto.clientappio_pb2.GetRunIdsWithPendingMessagesResponse:
43
+ """Get run IDs with pending messages"""
44
+ pass
45
+
46
+ @abc.abstractmethod
47
+ def RequestToken(self,
48
+ request: flwr.proto.clientappio_pb2.RequestTokenRequest,
49
+ context: grpc.ServicerContext,
50
+ ) -> flwr.proto.clientappio_pb2.RequestTokenResponse:
51
+ """Request token"""
52
+ pass
53
+
28
54
  @abc.abstractmethod
29
55
  def GetToken(self,
30
56
  request: flwr.proto.clientappio_pb2.GetTokenRequest,
@@ -38,7 +64,7 @@ class ClientAppIoServicer(metaclass=abc.ABCMeta):
38
64
  request: flwr.proto.clientappio_pb2.PullClientAppInputsRequest,
39
65
  context: grpc.ServicerContext,
40
66
  ) -> flwr.proto.clientappio_pb2.PullClientAppInputsResponse:
41
- """Get Message, Context, and Run"""
67
+ """Pull client app inputs"""
42
68
  pass
43
69
 
44
70
  @abc.abstractmethod
@@ -46,7 +72,7 @@ class ClientAppIoServicer(metaclass=abc.ABCMeta):
46
72
  request: flwr.proto.clientappio_pb2.PushClientAppOutputsRequest,
47
73
  context: grpc.ServicerContext,
48
74
  ) -> flwr.proto.clientappio_pb2.PushClientAppOutputsResponse:
49
- """Send updated Message and Context"""
75
+ """Push client app outputs"""
50
76
  pass
51
77
 
52
78
 
@@ -44,7 +44,7 @@ def flwr_clientapp() -> None:
44
44
  )
45
45
  run_clientapp(
46
46
  clientappio_api_address=args.clientappio_api_address,
47
- run_once=(args.token is not None),
47
+ run_once=(args.token is not None) or args.run_once,
48
48
  token=args.token,
49
49
  flwr_dir=args.flwr_dir,
50
50
  certificates=None,
@@ -66,7 +66,7 @@ def _parse_args_run_flwr_clientapp() -> argparse.ArgumentParser:
66
66
  )
67
67
  parser.add_argument(
68
68
  "--token",
69
- type=int,
69
+ type=str,
70
70
  required=False,
71
71
  help="Unique token generated by SuperNode for each ClientApp execution",
72
72
  )
@@ -77,5 +77,11 @@ def _parse_args_run_flwr_clientapp() -> argparse.ArgumentParser:
77
77
  help="The PID of the parent process. When set, the process will terminate "
78
78
  "when the parent process exits.",
79
79
  )
80
+ parser.add_argument(
81
+ "--run-once",
82
+ action="store_true",
83
+ help="When set, this process will start a single ClientApp for a pending "
84
+ "message. If there is no pending message, the process will exit.",
85
+ )
80
86
  add_args_flwr_app_common(parser=parser)
81
87
  return parser
@@ -46,12 +46,14 @@ from flwr.common.typing import Fab, Run
46
46
 
47
47
  # pylint: disable=E0611
48
48
  from flwr.proto.clientappio_pb2 import (
49
- GetTokenRequest,
50
- GetTokenResponse,
49
+ GetRunIdsWithPendingMessagesRequest,
50
+ GetRunIdsWithPendingMessagesResponse,
51
51
  PullClientAppInputsRequest,
52
52
  PullClientAppInputsResponse,
53
53
  PushClientAppOutputsRequest,
54
54
  PushClientAppOutputsResponse,
55
+ RequestTokenRequest,
56
+ RequestTokenResponse,
55
57
  )
56
58
  from flwr.proto.clientappio_pb2_grpc import ClientAppIoStub
57
59
 
@@ -59,7 +61,7 @@ from flwr.proto.clientappio_pb2_grpc import ClientAppIoStub
59
61
  def run_clientapp( # pylint: disable=R0913, R0914, R0917
60
62
  clientappio_api_address: str,
61
63
  run_once: bool,
62
- token: Optional[int] = None,
64
+ token: Optional[str] = None,
63
65
  flwr_dir: Optional[str] = None,
64
66
  certificates: Optional[bytes] = None,
65
67
  parent_pid: Optional[int] = None,
@@ -84,9 +86,8 @@ def run_clientapp( # pylint: disable=R0913, R0914, R0917
84
86
 
85
87
  while True:
86
88
  # If token is not set, loop until token is received from SuperNode
87
- while token is None:
89
+ if token is None:
88
90
  token = get_token(stub)
89
- time.sleep(1)
90
91
 
91
92
  # Pull Message, Context, Run and (optional) FAB from SuperNode
92
93
  message, context, run, fab = pull_clientappinputs(stub=stub, token=token)
@@ -172,23 +173,26 @@ def start_parent_process_monitor(
172
173
  threading.Thread(target=monitor, daemon=True).start()
173
174
 
174
175
 
175
- def get_token(stub: grpc.Channel) -> Optional[int]:
176
+ def get_token(stub: ClientAppIoStub) -> str:
176
177
  """Get a token from SuperNode."""
177
178
  log(DEBUG, "[flwr-clientapp] Request token")
178
- try:
179
- res: GetTokenResponse = stub.GetToken(GetTokenRequest())
180
- log(DEBUG, "[GetToken] Received token: %s", res.token)
181
- return res.token
182
- except grpc.RpcError as e:
183
- if e.code() == grpc.StatusCode.FAILED_PRECONDITION: # pylint: disable=no-member
184
- log(DEBUG, "[GetToken] No token available yet")
185
- else:
186
- log(ERROR, "[GetToken] gRPC error occurred: %s", str(e))
187
- return None
179
+ while True:
180
+ res: GetRunIdsWithPendingMessagesResponse = stub.GetRunIdsWithPendingMessages(
181
+ GetRunIdsWithPendingMessagesRequest()
182
+ )
183
+
184
+ for run_id in res.run_ids:
185
+ tk_res: RequestTokenResponse = stub.RequestToken(
186
+ RequestTokenRequest(run_id=run_id)
187
+ )
188
+ if tk_res.token:
189
+ return tk_res.token
190
+
191
+ time.sleep(1) # Wait before retrying to get run IDs
188
192
 
189
193
 
190
194
  def pull_clientappinputs(
191
- stub: grpc.Channel, token: int
195
+ stub: ClientAppIoStub, token: str
192
196
  ) -> tuple[Message, Context, Run, Optional[Fab]]:
193
197
  """Pull ClientAppInputs from SuperNode."""
194
198
  log(INFO, "[flwr-clientapp] Pull `ClientAppInputs` for token %s", token)
@@ -207,7 +211,7 @@ def pull_clientappinputs(
207
211
 
208
212
 
209
213
  def push_clientappoutputs(
210
- stub: grpc.Channel, token: int, message: Message, context: Context
214
+ stub: ClientAppIoStub, token: str, message: Message, context: Context
211
215
  ) -> PushClientAppOutputsResponse:
212
216
  """Push ClientAppOutputs to SuperNode."""
213
217
  log(INFO, "[flwr-clientapp] Push `ClientAppOutputs` for token %s", token)