flwr-nightly 1.14.0.dev20241204__tar.gz → 1.14.0.dev20241207__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.

Potentially problematic release.


This version of flwr-nightly might be problematic. Click here for more details.

Files changed (319) hide show
  1. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/PKG-INFO +1 -1
  2. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/pyproject.toml +1 -1
  3. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/exec_pb2.py +7 -3
  4. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/exec_pb2.pyi +22 -0
  5. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/exec_pb2_grpc.py +34 -0
  6. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/exec_pb2_grpc.pyi +13 -0
  7. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/superexec/exec_servicer.py +30 -1
  8. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/LICENSE +0 -0
  9. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/README.md +0 -0
  10. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/__init__.py +0 -0
  11. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/__init__.py +0 -0
  12. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/app.py +0 -0
  13. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/build.py +0 -0
  14. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/config_utils.py +0 -0
  15. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/example.py +0 -0
  16. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/install.py +0 -0
  17. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/log.py +0 -0
  18. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/ls.py +0 -0
  19. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/__init__.py +0 -0
  20. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/new.py +0 -0
  21. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/__init__.py +0 -0
  22. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/.gitignore.tpl +0 -0
  23. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/LICENSE.tpl +0 -0
  24. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/README.baseline.md.tpl +0 -0
  25. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/README.flowertune.md.tpl +0 -0
  26. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/README.md.tpl +0 -0
  27. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/__init__.py +0 -0
  28. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/__init__.baseline.py.tpl +0 -0
  29. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/__init__.py +0 -0
  30. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/__init__.py.tpl +0 -0
  31. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/client.baseline.py.tpl +0 -0
  32. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/client.huggingface.py.tpl +0 -0
  33. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/client.jax.py.tpl +0 -0
  34. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/client.mlx.py.tpl +0 -0
  35. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/client.numpy.py.tpl +0 -0
  36. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/client.pytorch.py.tpl +0 -0
  37. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/client.sklearn.py.tpl +0 -0
  38. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/client.tensorflow.py.tpl +0 -0
  39. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/dataset.baseline.py.tpl +0 -0
  40. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/flwr_tune/__init__.py +0 -0
  41. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/flwr_tune/client_app.py.tpl +0 -0
  42. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/flwr_tune/dataset.py.tpl +0 -0
  43. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/flwr_tune/models.py.tpl +0 -0
  44. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/flwr_tune/server_app.py.tpl +0 -0
  45. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/flwr_tune/strategy.py.tpl +0 -0
  46. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/model.baseline.py.tpl +0 -0
  47. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/server.baseline.py.tpl +0 -0
  48. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/server.huggingface.py.tpl +0 -0
  49. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/server.jax.py.tpl +0 -0
  50. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/server.mlx.py.tpl +0 -0
  51. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/server.numpy.py.tpl +0 -0
  52. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/server.pytorch.py.tpl +0 -0
  53. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/server.sklearn.py.tpl +0 -0
  54. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/server.tensorflow.py.tpl +0 -0
  55. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/strategy.baseline.py.tpl +0 -0
  56. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/task.huggingface.py.tpl +0 -0
  57. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/task.jax.py.tpl +0 -0
  58. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/task.mlx.py.tpl +0 -0
  59. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/task.numpy.py.tpl +0 -0
  60. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/task.pytorch.py.tpl +0 -0
  61. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/task.sklearn.py.tpl +0 -0
  62. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/task.tensorflow.py.tpl +0 -0
  63. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/code/utils.baseline.py.tpl +0 -0
  64. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/pyproject.baseline.toml.tpl +0 -0
  65. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/pyproject.flowertune.toml.tpl +0 -0
  66. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/pyproject.huggingface.toml.tpl +0 -0
  67. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/pyproject.jax.toml.tpl +0 -0
  68. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/pyproject.mlx.toml.tpl +0 -0
  69. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/pyproject.numpy.toml.tpl +0 -0
  70. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/pyproject.pytorch.toml.tpl +0 -0
  71. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/pyproject.sklearn.toml.tpl +0 -0
  72. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/new/templates/app/pyproject.tensorflow.toml.tpl +0 -0
  73. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/run/__init__.py +0 -0
  74. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/run/run.py +0 -0
  75. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/cli/utils.py +0 -0
  76. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/__init__.py +0 -0
  77. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/app.py +0 -0
  78. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/client.py +0 -0
  79. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/client_app.py +0 -0
  80. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/clientapp/__init__.py +0 -0
  81. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/clientapp/app.py +0 -0
  82. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/clientapp/clientappio_servicer.py +0 -0
  83. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/clientapp/utils.py +0 -0
  84. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/dpfedavg_numpy_client.py +0 -0
  85. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/grpc_adapter_client/__init__.py +0 -0
  86. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/grpc_adapter_client/connection.py +0 -0
  87. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/grpc_client/__init__.py +0 -0
  88. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/grpc_client/connection.py +0 -0
  89. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/grpc_rere_client/__init__.py +0 -0
  90. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/grpc_rere_client/client_interceptor.py +0 -0
  91. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/grpc_rere_client/connection.py +0 -0
  92. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/grpc_rere_client/grpc_adapter.py +0 -0
  93. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/heartbeat.py +0 -0
  94. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/message_handler/__init__.py +0 -0
  95. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/message_handler/message_handler.py +0 -0
  96. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/message_handler/task_handler.py +0 -0
  97. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/mod/__init__.py +0 -0
  98. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/mod/centraldp_mods.py +0 -0
  99. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/mod/comms_mods.py +0 -0
  100. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/mod/localdp_mod.py +0 -0
  101. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/mod/secure_aggregation/__init__.py +0 -0
  102. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/mod/secure_aggregation/secagg_mod.py +0 -0
  103. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/mod/secure_aggregation/secaggplus_mod.py +0 -0
  104. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/mod/utils.py +0 -0
  105. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/nodestate/__init__.py +0 -0
  106. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/nodestate/in_memory_nodestate.py +0 -0
  107. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/nodestate/nodestate.py +0 -0
  108. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/nodestate/nodestate_factory.py +0 -0
  109. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/numpy_client.py +0 -0
  110. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/rest_client/__init__.py +0 -0
  111. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/rest_client/connection.py +0 -0
  112. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/run_info_store.py +0 -0
  113. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/supernode/__init__.py +0 -0
  114. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/supernode/app.py +0 -0
  115. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/client/typing.py +0 -0
  116. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/__init__.py +0 -0
  117. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/address.py +0 -0
  118. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/args.py +0 -0
  119. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/config.py +0 -0
  120. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/constant.py +0 -0
  121. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/context.py +0 -0
  122. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/date.py +0 -0
  123. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/differential_privacy.py +0 -0
  124. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/differential_privacy_constants.py +0 -0
  125. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/dp.py +0 -0
  126. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/exit_handlers.py +0 -0
  127. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/grpc.py +0 -0
  128. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/logger.py +0 -0
  129. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/message.py +0 -0
  130. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/object_ref.py +0 -0
  131. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/parameter.py +0 -0
  132. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/pyproject.py +0 -0
  133. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/record/__init__.py +0 -0
  134. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/record/configsrecord.py +0 -0
  135. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/record/conversion_utils.py +0 -0
  136. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/record/metricsrecord.py +0 -0
  137. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/record/parametersrecord.py +0 -0
  138. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/record/recordset.py +0 -0
  139. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/record/typeddict.py +0 -0
  140. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/recordset_compat.py +0 -0
  141. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/retry_invoker.py +0 -0
  142. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/secure_aggregation/__init__.py +0 -0
  143. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/secure_aggregation/crypto/__init__.py +0 -0
  144. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/secure_aggregation/crypto/shamir.py +0 -0
  145. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/secure_aggregation/crypto/symmetric_encryption.py +0 -0
  146. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/secure_aggregation/ndarrays_arithmetic.py +0 -0
  147. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/secure_aggregation/quantization.py +0 -0
  148. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/secure_aggregation/secaggplus_constants.py +0 -0
  149. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/secure_aggregation/secaggplus_utils.py +0 -0
  150. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/serde.py +0 -0
  151. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/telemetry.py +0 -0
  152. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/typing.py +0 -0
  153. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/common/version.py +0 -0
  154. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/__init__.py +0 -0
  155. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/clientappio_pb2.py +0 -0
  156. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/clientappio_pb2.pyi +0 -0
  157. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/clientappio_pb2_grpc.py +0 -0
  158. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/clientappio_pb2_grpc.pyi +0 -0
  159. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/error_pb2.py +0 -0
  160. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/error_pb2.pyi +0 -0
  161. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/error_pb2_grpc.py +0 -0
  162. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/error_pb2_grpc.pyi +0 -0
  163. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/fab_pb2.py +0 -0
  164. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/fab_pb2.pyi +0 -0
  165. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/fab_pb2_grpc.py +0 -0
  166. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/fab_pb2_grpc.pyi +0 -0
  167. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/fleet_pb2.py +0 -0
  168. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/fleet_pb2.pyi +0 -0
  169. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/fleet_pb2_grpc.py +0 -0
  170. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/fleet_pb2_grpc.pyi +0 -0
  171. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/grpcadapter_pb2.py +0 -0
  172. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/grpcadapter_pb2.pyi +0 -0
  173. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/grpcadapter_pb2_grpc.py +0 -0
  174. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/grpcadapter_pb2_grpc.pyi +0 -0
  175. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/log_pb2.py +0 -0
  176. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/log_pb2.pyi +0 -0
  177. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/log_pb2_grpc.py +0 -0
  178. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/log_pb2_grpc.pyi +0 -0
  179. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/message_pb2.py +0 -0
  180. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/message_pb2.pyi +0 -0
  181. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/message_pb2_grpc.py +0 -0
  182. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/message_pb2_grpc.pyi +0 -0
  183. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/node_pb2.py +0 -0
  184. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/node_pb2.pyi +0 -0
  185. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/node_pb2_grpc.py +0 -0
  186. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/node_pb2_grpc.pyi +0 -0
  187. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/recordset_pb2.py +0 -0
  188. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/recordset_pb2.pyi +0 -0
  189. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/recordset_pb2_grpc.py +0 -0
  190. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/recordset_pb2_grpc.pyi +0 -0
  191. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/run_pb2.py +0 -0
  192. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/run_pb2.pyi +0 -0
  193. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/run_pb2_grpc.py +0 -0
  194. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/run_pb2_grpc.pyi +0 -0
  195. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/serverappio_pb2.py +0 -0
  196. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/serverappio_pb2.pyi +0 -0
  197. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/serverappio_pb2_grpc.py +0 -0
  198. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/serverappio_pb2_grpc.pyi +0 -0
  199. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/simulationio_pb2.py +0 -0
  200. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/simulationio_pb2.pyi +0 -0
  201. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/simulationio_pb2_grpc.py +0 -0
  202. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/simulationio_pb2_grpc.pyi +0 -0
  203. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/task_pb2.py +0 -0
  204. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/task_pb2.pyi +0 -0
  205. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/task_pb2_grpc.py +0 -0
  206. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/task_pb2_grpc.pyi +0 -0
  207. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/transport_pb2.py +0 -0
  208. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/transport_pb2.pyi +0 -0
  209. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/transport_pb2_grpc.py +0 -0
  210. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/proto/transport_pb2_grpc.pyi +0 -0
  211. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/py.typed +0 -0
  212. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/__init__.py +0 -0
  213. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/app.py +0 -0
  214. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/client_manager.py +0 -0
  215. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/client_proxy.py +0 -0
  216. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/compat/__init__.py +0 -0
  217. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/compat/app.py +0 -0
  218. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/compat/app_utils.py +0 -0
  219. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/compat/driver_client_proxy.py +0 -0
  220. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/compat/legacy_context.py +0 -0
  221. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/criterion.py +0 -0
  222. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/driver/__init__.py +0 -0
  223. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/driver/driver.py +0 -0
  224. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/driver/grpc_driver.py +0 -0
  225. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/driver/inmemory_driver.py +0 -0
  226. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/history.py +0 -0
  227. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/run_serverapp.py +0 -0
  228. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/server.py +0 -0
  229. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/server_app.py +0 -0
  230. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/server_config.py +0 -0
  231. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/serverapp/__init__.py +0 -0
  232. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/serverapp/app.py +0 -0
  233. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/serverapp_components.py +0 -0
  234. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/__init__.py +0 -0
  235. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/aggregate.py +0 -0
  236. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/bulyan.py +0 -0
  237. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/dp_adaptive_clipping.py +0 -0
  238. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/dp_fixed_clipping.py +0 -0
  239. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/dpfedavg_adaptive.py +0 -0
  240. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/dpfedavg_fixed.py +0 -0
  241. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/fault_tolerant_fedavg.py +0 -0
  242. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/fedadagrad.py +0 -0
  243. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/fedadam.py +0 -0
  244. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/fedavg.py +0 -0
  245. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/fedavg_android.py +0 -0
  246. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/fedavgm.py +0 -0
  247. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/fedmedian.py +0 -0
  248. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/fedopt.py +0 -0
  249. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/fedprox.py +0 -0
  250. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/fedtrimmedavg.py +0 -0
  251. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/fedxgb_bagging.py +0 -0
  252. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/fedxgb_cyclic.py +0 -0
  253. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/fedxgb_nn_avg.py +0 -0
  254. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/fedyogi.py +0 -0
  255. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/krum.py +0 -0
  256. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/qfedavg.py +0 -0
  257. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/strategy/strategy.py +0 -0
  258. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/__init__.py +0 -0
  259. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/driver/__init__.py +0 -0
  260. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/driver/serverappio_grpc.py +0 -0
  261. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/driver/serverappio_servicer.py +0 -0
  262. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/ffs/__init__.py +0 -0
  263. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/ffs/disk_ffs.py +0 -0
  264. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/ffs/ffs.py +0 -0
  265. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/ffs/ffs_factory.py +0 -0
  266. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/__init__.py +0 -0
  267. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/grpc_adapter/__init__.py +0 -0
  268. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py +0 -0
  269. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/grpc_bidi/__init__.py +0 -0
  270. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/grpc_bidi/flower_service_servicer.py +0 -0
  271. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_bridge.py +0 -0
  272. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_client_proxy.py +0 -0
  273. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_server.py +0 -0
  274. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/grpc_rere/__init__.py +0 -0
  275. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/grpc_rere/fleet_servicer.py +0 -0
  276. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/grpc_rere/server_interceptor.py +0 -0
  277. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/message_handler/__init__.py +0 -0
  278. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/message_handler/message_handler.py +0 -0
  279. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/rest_rere/__init__.py +0 -0
  280. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/rest_rere/rest_api.py +0 -0
  281. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/vce/__init__.py +0 -0
  282. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/vce/backend/__init__.py +0 -0
  283. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/vce/backend/backend.py +0 -0
  284. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/vce/backend/raybackend.py +0 -0
  285. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/fleet/vce/vce_api.py +0 -0
  286. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/linkstate/__init__.py +0 -0
  287. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/linkstate/in_memory_linkstate.py +0 -0
  288. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/linkstate/linkstate.py +0 -0
  289. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/linkstate/linkstate_factory.py +0 -0
  290. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/linkstate/sqlite_linkstate.py +0 -0
  291. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/linkstate/utils.py +0 -0
  292. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/simulation/__init__.py +0 -0
  293. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/simulation/simulationio_grpc.py +0 -0
  294. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/superlink/simulation/simulationio_servicer.py +0 -0
  295. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/typing.py +0 -0
  296. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/utils/__init__.py +0 -0
  297. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/utils/tensorboard.py +0 -0
  298. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/utils/validator.py +0 -0
  299. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/workflow/__init__.py +0 -0
  300. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/workflow/constant.py +0 -0
  301. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/workflow/default_workflows.py +0 -0
  302. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/workflow/secure_aggregation/__init__.py +0 -0
  303. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/workflow/secure_aggregation/secagg_workflow.py +0 -0
  304. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/server/workflow/secure_aggregation/secaggplus_workflow.py +0 -0
  305. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/simulation/__init__.py +0 -0
  306. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/simulation/app.py +0 -0
  307. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/simulation/legacy_app.py +0 -0
  308. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/simulation/ray_transport/__init__.py +0 -0
  309. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/simulation/ray_transport/ray_actor.py +0 -0
  310. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/simulation/ray_transport/ray_client_proxy.py +0 -0
  311. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/simulation/ray_transport/utils.py +0 -0
  312. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/simulation/run_simulation.py +0 -0
  313. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/simulation/simulationio_connection.py +0 -0
  314. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/superexec/__init__.py +0 -0
  315. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/superexec/app.py +0 -0
  316. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/superexec/deployment.py +0 -0
  317. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/superexec/exec_grpc.py +0 -0
  318. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/superexec/executor.py +0 -0
  319. {flwr_nightly-1.14.0.dev20241204 → flwr_nightly-1.14.0.dev20241207}/src/py/flwr/superexec/simulation.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: flwr-nightly
3
- Version: 1.14.0.dev20241204
3
+ Version: 1.14.0.dev20241207
4
4
  Summary: Flower: A Friendly Federated AI Framework
5
5
  Home-page: https://flower.ai
6
6
  License: Apache-2.0
@@ -4,7 +4,7 @@ build-backend = "poetry.core.masonry.api"
4
4
 
5
5
  [tool.poetry]
6
6
  name = "flwr-nightly"
7
- version = "1.14.0.dev20241204"
7
+ version = "1.14.0.dev20241207"
8
8
  description = "Flower: A Friendly Federated AI Framework"
9
9
  license = "Apache-2.0"
10
10
  authors = ["The Flower Authors <hello@flower.ai>"]
@@ -18,7 +18,7 @@ from flwr.proto import recordset_pb2 as flwr_dot_proto_dot_recordset__pb2
18
18
  from flwr.proto import run_pb2 as flwr_dot_proto_dot_run__pb2
19
19
 
20
20
 
21
- DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x15\x66lwr/proto/exec.proto\x12\nflwr.proto\x1a\x14\x66lwr/proto/fab.proto\x1a\x1a\x66lwr/proto/transport.proto\x1a\x1a\x66lwr/proto/recordset.proto\x1a\x14\x66lwr/proto/run.proto\"\xfb\x01\n\x0fStartRunRequest\x12\x1c\n\x03\x66\x61\x62\x18\x01 \x01(\x0b\x32\x0f.flwr.proto.Fab\x12H\n\x0foverride_config\x18\x02 \x03(\x0b\x32/.flwr.proto.StartRunRequest.OverrideConfigEntry\x12\x35\n\x12\x66\x65\x64\x65ration_options\x18\x03 \x01(\x0b\x32\x19.flwr.proto.ConfigsRecord\x1aI\n\x13OverrideConfigEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12!\n\x05value\x18\x02 \x01(\x0b\x32\x12.flwr.proto.Scalar:\x02\x38\x01\"2\n\x10StartRunResponse\x12\x13\n\x06run_id\x18\x01 \x01(\x04H\x00\x88\x01\x01\x42\t\n\x07_run_id\"<\n\x11StreamLogsRequest\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\x12\x17\n\x0f\x61\x66ter_timestamp\x18\x02 \x01(\x01\"B\n\x12StreamLogsResponse\x12\x12\n\nlog_output\x18\x01 \x01(\t\x12\x18\n\x10latest_timestamp\x18\x02 \x01(\x01\"1\n\x0fListRunsRequest\x12\x13\n\x06run_id\x18\x01 \x01(\x04H\x00\x88\x01\x01\x42\t\n\x07_run_id\"\x9d\x01\n\x10ListRunsResponse\x12;\n\x08run_dict\x18\x01 \x03(\x0b\x32).flwr.proto.ListRunsResponse.RunDictEntry\x12\x0b\n\x03now\x18\x02 \x01(\t\x1a?\n\x0cRunDictEntry\x12\x0b\n\x03key\x18\x01 \x01(\x04\x12\x1e\n\x05value\x18\x02 \x01(\x0b\x32\x0f.flwr.proto.Run:\x02\x38\x01\x32\xe9\x01\n\x04\x45xec\x12G\n\x08StartRun\x12\x1b.flwr.proto.StartRunRequest\x1a\x1c.flwr.proto.StartRunResponse\"\x00\x12O\n\nStreamLogs\x12\x1d.flwr.proto.StreamLogsRequest\x1a\x1e.flwr.proto.StreamLogsResponse\"\x00\x30\x01\x12G\n\x08ListRuns\x12\x1b.flwr.proto.ListRunsRequest\x1a\x1c.flwr.proto.ListRunsResponse\"\x00\x62\x06proto3')
21
+ DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x15\x66lwr/proto/exec.proto\x12\nflwr.proto\x1a\x14\x66lwr/proto/fab.proto\x1a\x1a\x66lwr/proto/transport.proto\x1a\x1a\x66lwr/proto/recordset.proto\x1a\x14\x66lwr/proto/run.proto\"\xfb\x01\n\x0fStartRunRequest\x12\x1c\n\x03\x66\x61\x62\x18\x01 \x01(\x0b\x32\x0f.flwr.proto.Fab\x12H\n\x0foverride_config\x18\x02 \x03(\x0b\x32/.flwr.proto.StartRunRequest.OverrideConfigEntry\x12\x35\n\x12\x66\x65\x64\x65ration_options\x18\x03 \x01(\x0b\x32\x19.flwr.proto.ConfigsRecord\x1aI\n\x13OverrideConfigEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12!\n\x05value\x18\x02 \x01(\x0b\x32\x12.flwr.proto.Scalar:\x02\x38\x01\"2\n\x10StartRunResponse\x12\x13\n\x06run_id\x18\x01 \x01(\x04H\x00\x88\x01\x01\x42\t\n\x07_run_id\"<\n\x11StreamLogsRequest\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\x12\x17\n\x0f\x61\x66ter_timestamp\x18\x02 \x01(\x01\"B\n\x12StreamLogsResponse\x12\x12\n\nlog_output\x18\x01 \x01(\t\x12\x18\n\x10latest_timestamp\x18\x02 \x01(\x01\"1\n\x0fListRunsRequest\x12\x13\n\x06run_id\x18\x01 \x01(\x04H\x00\x88\x01\x01\x42\t\n\x07_run_id\"\x9d\x01\n\x10ListRunsResponse\x12;\n\x08run_dict\x18\x01 \x03(\x0b\x32).flwr.proto.ListRunsResponse.RunDictEntry\x12\x0b\n\x03now\x18\x02 \x01(\t\x1a?\n\x0cRunDictEntry\x12\x0b\n\x03key\x18\x01 \x01(\x04\x12\x1e\n\x05value\x18\x02 \x01(\x0b\x32\x0f.flwr.proto.Run:\x02\x38\x01\" \n\x0eStopRunRequest\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\"\"\n\x0fStopRunResponse\x12\x0f\n\x07success\x18\x01 \x01(\x08\x32\xaf\x02\n\x04\x45xec\x12G\n\x08StartRun\x12\x1b.flwr.proto.StartRunRequest\x1a\x1c.flwr.proto.StartRunResponse\"\x00\x12\x44\n\x07StopRun\x12\x1a.flwr.proto.StopRunRequest\x1a\x1b.flwr.proto.StopRunResponse\"\x00\x12O\n\nStreamLogs\x12\x1d.flwr.proto.StreamLogsRequest\x1a\x1e.flwr.proto.StreamLogsResponse\"\x00\x30\x01\x12G\n\x08ListRuns\x12\x1b.flwr.proto.ListRunsRequest\x1a\x1c.flwr.proto.ListRunsResponse\"\x00\x62\x06proto3')
22
22
 
23
23
  _globals = globals()
24
24
  _builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
@@ -45,6 +45,10 @@ if _descriptor._USE_C_DESCRIPTORS == False:
45
45
  _globals['_LISTRUNSRESPONSE']._serialized_end=782
46
46
  _globals['_LISTRUNSRESPONSE_RUNDICTENTRY']._serialized_start=719
47
47
  _globals['_LISTRUNSRESPONSE_RUNDICTENTRY']._serialized_end=782
48
- _globals['_EXEC']._serialized_start=785
49
- _globals['_EXEC']._serialized_end=1018
48
+ _globals['_STOPRUNREQUEST']._serialized_start=784
49
+ _globals['_STOPRUNREQUEST']._serialized_end=816
50
+ _globals['_STOPRUNRESPONSE']._serialized_start=818
51
+ _globals['_STOPRUNRESPONSE']._serialized_end=852
52
+ _globals['_EXEC']._serialized_start=855
53
+ _globals['_EXEC']._serialized_end=1158
50
54
  # @@protoc_insertion_point(module_scope)
@@ -134,3 +134,25 @@ class ListRunsResponse(google.protobuf.message.Message):
134
134
  ) -> None: ...
135
135
  def ClearField(self, field_name: typing_extensions.Literal["now",b"now","run_dict",b"run_dict"]) -> None: ...
136
136
  global___ListRunsResponse = ListRunsResponse
137
+
138
+ class StopRunRequest(google.protobuf.message.Message):
139
+ DESCRIPTOR: google.protobuf.descriptor.Descriptor
140
+ RUN_ID_FIELD_NUMBER: builtins.int
141
+ run_id: builtins.int
142
+ def __init__(self,
143
+ *,
144
+ run_id: builtins.int = ...,
145
+ ) -> None: ...
146
+ def ClearField(self, field_name: typing_extensions.Literal["run_id",b"run_id"]) -> None: ...
147
+ global___StopRunRequest = StopRunRequest
148
+
149
+ class StopRunResponse(google.protobuf.message.Message):
150
+ DESCRIPTOR: google.protobuf.descriptor.Descriptor
151
+ SUCCESS_FIELD_NUMBER: builtins.int
152
+ success: builtins.bool
153
+ def __init__(self,
154
+ *,
155
+ success: builtins.bool = ...,
156
+ ) -> None: ...
157
+ def ClearField(self, field_name: typing_extensions.Literal["success",b"success"]) -> None: ...
158
+ global___StopRunResponse = StopRunResponse
@@ -19,6 +19,11 @@ class ExecStub(object):
19
19
  request_serializer=flwr_dot_proto_dot_exec__pb2.StartRunRequest.SerializeToString,
20
20
  response_deserializer=flwr_dot_proto_dot_exec__pb2.StartRunResponse.FromString,
21
21
  )
22
+ self.StopRun = channel.unary_unary(
23
+ '/flwr.proto.Exec/StopRun',
24
+ request_serializer=flwr_dot_proto_dot_exec__pb2.StopRunRequest.SerializeToString,
25
+ response_deserializer=flwr_dot_proto_dot_exec__pb2.StopRunResponse.FromString,
26
+ )
22
27
  self.StreamLogs = channel.unary_stream(
23
28
  '/flwr.proto.Exec/StreamLogs',
24
29
  request_serializer=flwr_dot_proto_dot_exec__pb2.StreamLogsRequest.SerializeToString,
@@ -41,6 +46,13 @@ class ExecServicer(object):
41
46
  context.set_details('Method not implemented!')
42
47
  raise NotImplementedError('Method not implemented!')
43
48
 
49
+ def StopRun(self, request, context):
50
+ """Stop run upon request
51
+ """
52
+ context.set_code(grpc.StatusCode.UNIMPLEMENTED)
53
+ context.set_details('Method not implemented!')
54
+ raise NotImplementedError('Method not implemented!')
55
+
44
56
  def StreamLogs(self, request, context):
45
57
  """Start log stream upon request
46
58
  """
@@ -63,6 +75,11 @@ def add_ExecServicer_to_server(servicer, server):
63
75
  request_deserializer=flwr_dot_proto_dot_exec__pb2.StartRunRequest.FromString,
64
76
  response_serializer=flwr_dot_proto_dot_exec__pb2.StartRunResponse.SerializeToString,
65
77
  ),
78
+ 'StopRun': grpc.unary_unary_rpc_method_handler(
79
+ servicer.StopRun,
80
+ request_deserializer=flwr_dot_proto_dot_exec__pb2.StopRunRequest.FromString,
81
+ response_serializer=flwr_dot_proto_dot_exec__pb2.StopRunResponse.SerializeToString,
82
+ ),
66
83
  'StreamLogs': grpc.unary_stream_rpc_method_handler(
67
84
  servicer.StreamLogs,
68
85
  request_deserializer=flwr_dot_proto_dot_exec__pb2.StreamLogsRequest.FromString,
@@ -100,6 +117,23 @@ class Exec(object):
100
117
  options, channel_credentials,
101
118
  insecure, call_credentials, compression, wait_for_ready, timeout, metadata)
102
119
 
120
+ @staticmethod
121
+ def StopRun(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.Exec/StopRun',
132
+ flwr_dot_proto_dot_exec__pb2.StopRunRequest.SerializeToString,
133
+ flwr_dot_proto_dot_exec__pb2.StopRunResponse.FromString,
134
+ options, channel_credentials,
135
+ insecure, call_credentials, compression, wait_for_ready, timeout, metadata)
136
+
103
137
  @staticmethod
104
138
  def StreamLogs(request,
105
139
  target,
@@ -14,6 +14,11 @@ class ExecStub:
14
14
  flwr.proto.exec_pb2.StartRunResponse]
15
15
  """Start run upon request"""
16
16
 
17
+ StopRun: grpc.UnaryUnaryMultiCallable[
18
+ flwr.proto.exec_pb2.StopRunRequest,
19
+ flwr.proto.exec_pb2.StopRunResponse]
20
+ """Stop run upon request"""
21
+
17
22
  StreamLogs: grpc.UnaryStreamMultiCallable[
18
23
  flwr.proto.exec_pb2.StreamLogsRequest,
19
24
  flwr.proto.exec_pb2.StreamLogsResponse]
@@ -34,6 +39,14 @@ class ExecServicer(metaclass=abc.ABCMeta):
34
39
  """Start run upon request"""
35
40
  pass
36
41
 
42
+ @abc.abstractmethod
43
+ def StopRun(self,
44
+ request: flwr.proto.exec_pb2.StopRunRequest,
45
+ context: grpc.ServicerContext,
46
+ ) -> flwr.proto.exec_pb2.StopRunResponse:
47
+ """Stop run upon request"""
48
+ pass
49
+
37
50
  @abc.abstractmethod
38
51
  def StreamLogs(self,
39
52
  request: flwr.proto.exec_pb2.StreamLogsRequest,
@@ -23,19 +23,22 @@ from typing import Any
23
23
  import grpc
24
24
 
25
25
  from flwr.common import now
26
- from flwr.common.constant import LOG_STREAM_INTERVAL, Status
26
+ from flwr.common.constant import LOG_STREAM_INTERVAL, Status, SubStatus
27
27
  from flwr.common.logger import log
28
28
  from flwr.common.serde import (
29
29
  configs_record_from_proto,
30
30
  run_to_proto,
31
31
  user_config_from_proto,
32
32
  )
33
+ from flwr.common.typing import RunStatus
33
34
  from flwr.proto import exec_pb2_grpc # pylint: disable=E0611
34
35
  from flwr.proto.exec_pb2 import ( # pylint: disable=E0611
35
36
  ListRunsRequest,
36
37
  ListRunsResponse,
37
38
  StartRunRequest,
38
39
  StartRunResponse,
40
+ StopRunRequest,
41
+ StopRunResponse,
39
42
  StreamLogsRequest,
40
43
  StreamLogsResponse,
41
44
  )
@@ -126,6 +129,32 @@ class ExecServicer(exec_pb2_grpc.ExecServicer):
126
129
  # Handle `flwr ls --run-id <run_id>`
127
130
  return _create_list_runs_response({request.run_id}, state)
128
131
 
132
+ def StopRun(
133
+ self, request: StopRunRequest, context: grpc.ServicerContext
134
+ ) -> StopRunResponse:
135
+ """Stop a given run ID."""
136
+ log(INFO, "ExecServicer.StopRun")
137
+ state = self.linkstate_factory.state()
138
+
139
+ # Exit if `run_id` not found
140
+ if not state.get_run(request.run_id):
141
+ context.abort(
142
+ grpc.StatusCode.NOT_FOUND, f"Run ID {request.run_id} not found"
143
+ )
144
+
145
+ run_status = state.get_run_status({request.run_id})[request.run_id]
146
+ if run_status.status == Status.FINISHED:
147
+ context.abort(
148
+ grpc.StatusCode.FAILED_PRECONDITION,
149
+ f"Run ID {request.run_id} is already finished",
150
+ )
151
+
152
+ update_success = state.update_run_status(
153
+ run_id=request.run_id,
154
+ new_status=RunStatus(Status.FINISHED, SubStatus.STOPPED, ""),
155
+ )
156
+ return StopRunResponse(success=update_success)
157
+
129
158
 
130
159
  def _create_list_runs_response(run_ids: set[int], state: LinkState) -> ListRunsResponse:
131
160
  """Create response for `flwr ls --runs` and `flwr ls --run-id <run_id>`."""