flwr-nightly 1.23.0.dev20251020__tar.gz → 1.23.0.dev20251021__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.
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/PKG-INFO +1 -1
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/ls.py +5 -5
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/supernode/ls.py +8 -15
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/constant.py +12 -4
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/inflatable_utils.py +10 -10
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/record/array.py +3 -3
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/control_pb2.py +6 -6
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/control_pb2.pyi +0 -5
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/linkstate/in_memory_linkstate.py +5 -1
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/linkstate/sqlite_linkstate.py +29 -106
- flwr_nightly-1.23.0.dev20251021/py/flwr/supercore/sqlite_mixin.py +188 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/superlink/servicer/control/control_servicer.py +6 -70
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/pyproject.toml +1 -1
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/README.md +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/app/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/app/error.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/app/exception.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/app/metadata.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/app.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/auth_plugin/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/auth_plugin/auth_plugin.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/auth_plugin/noop_auth_plugin.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/auth_plugin/oidc_cli_plugin.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/build.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/cli_account_auth_interceptor.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/config_utils.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/constant.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/example.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/install.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/log.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/login/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/login/login.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/new.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/.gitignore.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/LICENSE.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/README.baseline.md.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/README.flowertune.md.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/README.md.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/__init__.baseline.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/__init__.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/__init__.pytorch_legacy_api.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/client.baseline.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/client.huggingface.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/client.jax.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/client.mlx.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/client.numpy.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/client.pytorch.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/client.pytorch_legacy_api.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/client.sklearn.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/client.tensorflow.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/client.xgboost.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/dataset.baseline.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/flwr_tune/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/flwr_tune/client_app.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/flwr_tune/dataset.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/flwr_tune/models.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/flwr_tune/server_app.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/flwr_tune/strategy.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/model.baseline.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/server.baseline.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/server.huggingface.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/server.jax.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/server.mlx.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/server.numpy.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/server.pytorch.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/server.pytorch_legacy_api.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/server.sklearn.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/server.tensorflow.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/server.xgboost.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/strategy.baseline.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/task.huggingface.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/task.jax.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/task.mlx.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/task.numpy.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/task.pytorch.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/task.pytorch_legacy_api.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/task.sklearn.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/task.tensorflow.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/task.xgboost.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/code/utils.baseline.py.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/pyproject.baseline.toml.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/pyproject.flowertune.toml.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/pyproject.huggingface.toml.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/pyproject.jax.toml.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/pyproject.mlx.toml.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/pyproject.numpy.toml.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/pyproject.pytorch.toml.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/pyproject.pytorch_legacy_api.toml.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/pyproject.sklearn.toml.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/pyproject.tensorflow.toml.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/new/templates/app/pyproject.xgboost.toml.tpl +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/pull.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/run/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/run/run.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/stop.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/supernode/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/supernode/register.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/supernode/unregister.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/utils.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/client.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/dpfedavg_numpy_client.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/grpc_adapter_client/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/grpc_adapter_client/connection.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/grpc_rere_client/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/grpc_rere_client/connection.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/grpc_rere_client/grpc_adapter.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/grpc_rere_client/node_auth_client_interceptor.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/message_handler/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/message_handler/message_handler.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/mod/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/mod/centraldp_mods.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/mod/comms_mods.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/mod/localdp_mod.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/mod/secure_aggregation/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/mod/secure_aggregation/secagg_mod.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/mod/secure_aggregation/secaggplus_mod.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/mod/utils.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/numpy_client.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/rest_client/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/rest_client/connection.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/run_info_store.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/client/typing.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/clientapp/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/clientapp/client_app.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/clientapp/mod/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/clientapp/mod/centraldp_mods.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/clientapp/mod/localdp_mod.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/clientapp/typing.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/clientapp/utils.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/address.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/args.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/config.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/context.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/date.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/differential_privacy.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/differential_privacy_constants.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/dp.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/event_log_plugin/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/event_log_plugin/event_log_plugin.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/exit/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/exit/exit.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/exit/exit_code.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/exit/exit_handler.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/exit/signal_handler.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/heartbeat.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/inflatable.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/inflatable_protobuf_utils.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/logger.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/message.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/object_ref.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/parameter.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/pyproject.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/record/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/record/arraychunk.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/record/arrayrecord.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/record/configrecord.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/record/conversion_utils.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/record/metricrecord.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/record/recorddict.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/record/typeddict.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/recorddict_compat.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/retry_invoker.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/secure_aggregation/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/secure_aggregation/crypto/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/secure_aggregation/crypto/shamir.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/secure_aggregation/crypto/symmetric_encryption.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/secure_aggregation/ndarrays_arithmetic.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/secure_aggregation/quantization.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/secure_aggregation/secaggplus_constants.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/secure_aggregation/secaggplus_utils.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/serde.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/serde_utils.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/telemetry.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/typing.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/version.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/compat/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/compat/client/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/compat/client/app.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/compat/client/grpc_client/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/compat/client/grpc_client/connection.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/compat/common/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/compat/server/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/compat/server/app.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/compat/simulation/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/appio_pb2.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/appio_pb2.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/appio_pb2_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/appio_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/clientappio_pb2.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/clientappio_pb2.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/clientappio_pb2_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/clientappio_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/control_pb2_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/control_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/error_pb2.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/error_pb2.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/error_pb2_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/error_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/fab_pb2.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/fab_pb2.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/fab_pb2_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/fab_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/fleet_pb2.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/fleet_pb2.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/fleet_pb2_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/fleet_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/grpcadapter_pb2.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/grpcadapter_pb2.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/grpcadapter_pb2_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/grpcadapter_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/heartbeat_pb2.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/heartbeat_pb2.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/heartbeat_pb2_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/heartbeat_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/log_pb2.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/log_pb2.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/log_pb2_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/log_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/message_pb2.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/message_pb2.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/message_pb2_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/message_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/node_pb2.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/node_pb2.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/node_pb2_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/node_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/recorddict_pb2.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/recorddict_pb2.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/recorddict_pb2_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/recorddict_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/run_pb2.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/run_pb2.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/run_pb2_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/run_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/serverappio_pb2.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/serverappio_pb2.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/serverappio_pb2_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/serverappio_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/simulationio_pb2.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/simulationio_pb2.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/simulationio_pb2_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/simulationio_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/transport_pb2.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/transport_pb2.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/transport_pb2_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/transport_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/py.typed +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/app.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/client_manager.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/client_proxy.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/compat/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/compat/app.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/compat/app_utils.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/compat/grid_client_proxy.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/compat/legacy_context.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/criterion.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/fleet_event_log_interceptor.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/grid/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/grid/grid.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/grid/grpc_grid.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/grid/inmemory_grid.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/history.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/run_serverapp.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/server.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/server_app.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/server_config.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/serverapp/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/serverapp/app.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/serverapp_components.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/aggregate.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/bulyan.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/dp_adaptive_clipping.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/dp_fixed_clipping.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/dpfedavg_adaptive.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/dpfedavg_fixed.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/fault_tolerant_fedavg.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/fedadagrad.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/fedadam.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/fedavg.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/fedavg_android.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/fedavgm.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/fedmedian.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/fedopt.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/fedprox.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/fedtrimmedavg.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/fedxgb_bagging.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/fedxgb_cyclic.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/fedxgb_nn_avg.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/fedyogi.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/krum.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/qfedavg.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/strategy/strategy.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/grpc_adapter/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/grpc_bidi/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/grpc_bidi/flower_service_servicer.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_bridge.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_client_proxy.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_server.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/grpc_rere/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/grpc_rere/fleet_servicer.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/grpc_rere/node_auth_server_interceptor.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/message_handler/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/message_handler/message_handler.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/rest_rere/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/rest_rere/rest_api.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/vce/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/vce/backend/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/vce/backend/backend.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/vce/backend/raybackend.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/fleet/vce/vce_api.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/linkstate/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/linkstate/linkstate.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/linkstate/linkstate_factory.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/linkstate/utils.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/serverappio/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/serverappio/serverappio_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/serverappio/serverappio_servicer.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/simulation/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/simulation/simulationio_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/simulation/simulationio_servicer.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/superlink/utils.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/typing.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/utils/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/utils/tensorboard.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/utils/validator.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/workflow/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/workflow/constant.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/workflow/default_workflows.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/workflow/secure_aggregation/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/workflow/secure_aggregation/secagg_workflow.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/server/workflow/secure_aggregation/secaggplus_workflow.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/exception.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/bulyan.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/dp_adaptive_clipping.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/dp_fixed_clipping.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/fedadagrad.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/fedadam.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/fedavg.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/fedavgm.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/fedmedian.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/fedopt.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/fedprox.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/fedtrimmedavg.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/fedxgb_bagging.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/fedxgb_cyclic.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/fedyogi.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/krum.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/multikrum.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/qfedavg.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/result.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/strategy.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/serverapp/strategy/strategy_utils.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/simulation/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/simulation/app.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/simulation/legacy_app.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/simulation/ray_transport/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/simulation/ray_transport/ray_actor.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/simulation/ray_transport/ray_client_proxy.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/simulation/ray_transport/utils.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/simulation/run_simulation.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/simulation/simulationio_connection.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/app_utils.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/cli/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/cli/flower_superexec.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/constant.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/corestate/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/corestate/corestate.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/ffs/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/ffs/disk_ffs.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/ffs/ffs.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/ffs/ffs_factory.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/grpc_health/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/grpc_health/health_server.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/grpc_health/simple_health_servicer.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/license_plugin/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/license_plugin/license_plugin.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/object_store/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/object_store/in_memory_object_store.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/object_store/object_store.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/object_store/object_store_factory.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/object_store/utils.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/primitives/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/primitives/asymmetric.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/superexec/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/superexec/plugin/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/superexec/plugin/base_exec_plugin.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/superexec/plugin/clientapp_exec_plugin.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/superexec/plugin/exec_plugin.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/superexec/plugin/serverapp_exec_plugin.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/superexec/plugin/simulation_exec_plugin.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/superexec/run_superexec.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supercore/utils.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/superlink/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/superlink/artifact_provider/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/superlink/artifact_provider/artifact_provider.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/superlink/auth_plugin/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/superlink/auth_plugin/auth_plugin.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/superlink/auth_plugin/noop_auth_plugin.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/superlink/servicer/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/superlink/servicer/control/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/superlink/servicer/control/control_account_auth_interceptor.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/superlink/servicer/control/control_event_log_interceptor.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/superlink/servicer/control/control_grpc.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/superlink/servicer/control/control_license_interceptor.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supernode/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supernode/cli/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supernode/cli/flower_supernode.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supernode/cli/flwr_clientapp.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supernode/nodestate/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supernode/nodestate/in_memory_nodestate.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supernode/nodestate/nodestate.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supernode/nodestate/nodestate_factory.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supernode/runtime/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supernode/runtime/run_clientapp.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supernode/servicer/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supernode/servicer/clientappio/__init__.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supernode/servicer/clientappio/clientappio_servicer.py +0 -0
- {flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/supernode/start_client_internal.py +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.3
|
|
2
2
|
Name: flwr-nightly
|
|
3
|
-
Version: 1.23.0.
|
|
3
|
+
Version: 1.23.0.dev20251021
|
|
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
|
|
@@ -220,14 +220,14 @@ def _to_table(run_list: list[_RunListType]) -> Table:
|
|
|
220
220
|
|
|
221
221
|
# Add columns
|
|
222
222
|
table.add_column(
|
|
223
|
-
Text("Run ID", justify="center"), style="
|
|
223
|
+
Text("Run ID", justify="center"), style="bright_black", no_wrap=True
|
|
224
224
|
)
|
|
225
|
-
table.add_column(Text("FAB", justify="center"), style="
|
|
225
|
+
table.add_column(Text("FAB", justify="center"), style="bright_black")
|
|
226
226
|
table.add_column(Text("Status", justify="center"))
|
|
227
227
|
table.add_column(Text("Elapsed", justify="center"), style="blue")
|
|
228
|
-
table.add_column(Text("Created At", justify="center"), style="
|
|
229
|
-
table.add_column(Text("Running At", justify="center"), style="
|
|
230
|
-
table.add_column(Text("Finished At", justify="center"), style="
|
|
228
|
+
table.add_column(Text("Created At", justify="center"), style="bright_black")
|
|
229
|
+
table.add_column(Text("Running At", justify="center"), style="bright_black")
|
|
230
|
+
table.add_column(Text("Finished At", justify="center"), style="bright_black")
|
|
231
231
|
|
|
232
232
|
for row in run_list:
|
|
233
233
|
(
|
{flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/cli/supernode/ls.py
RENAMED
|
@@ -32,7 +32,7 @@ from flwr.cli.config_utils import (
|
|
|
32
32
|
process_loaded_project_config,
|
|
33
33
|
validate_federation_in_project_config,
|
|
34
34
|
)
|
|
35
|
-
from flwr.common.constant import FAB_CONFIG_FILE, CliOutputFormat
|
|
35
|
+
from flwr.common.constant import FAB_CONFIG_FILE, NOOP_FLWR_AID, CliOutputFormat
|
|
36
36
|
from flwr.common.date import format_timedelta, isoformat8601_utc
|
|
37
37
|
from flwr.common.logger import print_json_error, redirect_output, restore_output
|
|
38
38
|
from flwr.proto.control_pb2 import ( # pylint: disable=E0611
|
|
@@ -73,13 +73,6 @@ def ls( # pylint: disable=R0914, R0913, R0917
|
|
|
73
73
|
help="Enable verbose output",
|
|
74
74
|
),
|
|
75
75
|
] = False,
|
|
76
|
-
dry_run: Annotated[
|
|
77
|
-
bool,
|
|
78
|
-
typer.Option(
|
|
79
|
-
"--dry-run",
|
|
80
|
-
help="Simulate the command without contacting any SuperNodes",
|
|
81
|
-
),
|
|
82
|
-
] = False,
|
|
83
76
|
) -> None:
|
|
84
77
|
"""List SuperNodes in the federation."""
|
|
85
78
|
# Resolve command used (list or ls)
|
|
@@ -105,7 +98,7 @@ def ls( # pylint: disable=R0914, R0913, R0917
|
|
|
105
98
|
channel = init_channel(app, federation_config, auth_plugin)
|
|
106
99
|
stub = ControlStub(channel)
|
|
107
100
|
typer.echo("📄 Listing all nodes...")
|
|
108
|
-
formatted_nodes = _list_nodes(stub
|
|
101
|
+
formatted_nodes = _list_nodes(stub)
|
|
109
102
|
restore_output()
|
|
110
103
|
if output_format == CliOutputFormat.JSON:
|
|
111
104
|
Console().print_json(_to_json(formatted_nodes, verbose=verbose))
|
|
@@ -132,10 +125,10 @@ def ls( # pylint: disable=R0914, R0913, R0917
|
|
|
132
125
|
captured_output.close()
|
|
133
126
|
|
|
134
127
|
|
|
135
|
-
def _list_nodes(stub: ControlStub
|
|
128
|
+
def _list_nodes(stub: ControlStub) -> list[_NodeListType]:
|
|
136
129
|
"""List all nodes."""
|
|
137
130
|
with flwr_cli_grpc_exc_handler():
|
|
138
|
-
res: ListNodesResponse = stub.ListNodes(ListNodesRequest(
|
|
131
|
+
res: ListNodesResponse = stub.ListNodes(ListNodesRequest())
|
|
139
132
|
|
|
140
133
|
return _format_nodes(list(res.nodes_info), res.now)
|
|
141
134
|
|
|
@@ -185,12 +178,12 @@ def _to_table(nodes_info: list[_NodeListType], verbose: bool) -> Table:
|
|
|
185
178
|
|
|
186
179
|
# Add columns
|
|
187
180
|
table.add_column(
|
|
188
|
-
Text("Node ID", justify="center"), style="
|
|
181
|
+
Text("Node ID", justify="center"), style="bright_black", no_wrap=True
|
|
189
182
|
)
|
|
190
|
-
table.add_column(Text("Owner", justify="center")
|
|
183
|
+
table.add_column(Text("Owner", justify="center"))
|
|
191
184
|
table.add_column(Text("Status", justify="center"))
|
|
192
185
|
table.add_column(Text("Elapsed", justify="center"))
|
|
193
|
-
table.add_column(Text("Status Changed @", justify="center"), style="
|
|
186
|
+
table.add_column(Text("Status Changed @", justify="center"), style="bright_black")
|
|
194
187
|
|
|
195
188
|
for row in nodes_info:
|
|
196
189
|
(
|
|
@@ -223,7 +216,7 @@ def _to_table(nodes_info: list[_NodeListType], verbose: bool) -> Table:
|
|
|
223
216
|
|
|
224
217
|
formatted_row = (
|
|
225
218
|
f"[bold]{node_id}[/bold]",
|
|
226
|
-
f"{owner_aid}",
|
|
219
|
+
f"{owner_aid}" if owner_aid != NOOP_FLWR_AID else f"[dim]{owner_aid}[/dim]",
|
|
227
220
|
f"[{status_style}]{status}",
|
|
228
221
|
f"[cyan]{elapse_activated}[/cyan]" if status == "online" else "",
|
|
229
222
|
time_at,
|
{flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/constant.py
RENAMED
|
@@ -17,6 +17,8 @@
|
|
|
17
17
|
|
|
18
18
|
from __future__ import annotations
|
|
19
19
|
|
|
20
|
+
import os
|
|
21
|
+
|
|
20
22
|
TRANSPORT_TYPE_GRPC_BIDI = "grpc-bidi"
|
|
21
23
|
TRANSPORT_TYPE_GRPC_RERE = "grpc-rere"
|
|
22
24
|
TRANSPORT_TYPE_GRPC_ADAPTER = "grpc-adapter"
|
|
@@ -135,7 +137,9 @@ GC_THRESHOLD = 200_000_000 # 200 MB
|
|
|
135
137
|
# Constants for Inflatable
|
|
136
138
|
HEAD_BODY_DIVIDER = b"\x00"
|
|
137
139
|
HEAD_VALUE_DIVIDER = " "
|
|
138
|
-
|
|
140
|
+
FLWR_PRIVATE_MAX_ARRAY_CHUNK_SIZE = int(
|
|
141
|
+
os.getenv("FLWR_PRIVATE_MAX_ARRAY_CHUNK_SIZE", "5242880")
|
|
142
|
+
) # 5 MB
|
|
139
143
|
|
|
140
144
|
# Constants for serialization
|
|
141
145
|
INT64_MAX_VALUE = 9223372036854775807 # (1 << 63) - 1
|
|
@@ -144,8 +148,12 @@ INT64_MAX_VALUE = 9223372036854775807 # (1 << 63) - 1
|
|
|
144
148
|
FLWR_APP_TOKEN_LENGTH = 128 # Length of the token used
|
|
145
149
|
|
|
146
150
|
# Constants for object pushing and pulling
|
|
147
|
-
|
|
148
|
-
|
|
151
|
+
FLWR_PRIVATE_MAX_CONCURRENT_OBJ_PUSHES = int(
|
|
152
|
+
os.getenv("FLWR_PRIVATE_MAX_CONCURRENT_OBJ_PUSHES", "2")
|
|
153
|
+
) # Default maximum number of concurrent pushes
|
|
154
|
+
FLWR_PRIVATE_MAX_CONCURRENT_OBJ_PULLS = int(
|
|
155
|
+
os.getenv("FLWR_PRIVATE_MAX_CONCURRENT_OBJ_PULLS", "2")
|
|
156
|
+
) # Default maximum number of concurrent pulls
|
|
149
157
|
PULL_MAX_TIME = 7200 # Default maximum time to wait for pulling objects
|
|
150
158
|
PULL_MAX_TRIES_PER_OBJECT = 500 # Default maximum number of tries to pull an object
|
|
151
159
|
PULL_INITIAL_BACKOFF = 1 # Initial backoff time for pulling objects
|
|
@@ -299,5 +307,5 @@ class ExecPluginType:
|
|
|
299
307
|
|
|
300
308
|
|
|
301
309
|
# Constants for No-op auth plugins
|
|
302
|
-
NOOP_FLWR_AID = "
|
|
310
|
+
NOOP_FLWR_AID = "<none>"
|
|
303
311
|
NOOP_ACCOUNT_NAME = "sys_noauth"
|
|
@@ -25,10 +25,10 @@ from typing import Callable, Optional, TypeVar
|
|
|
25
25
|
from flwr.proto.message_pb2 import ObjectTree # pylint: disable=E0611
|
|
26
26
|
|
|
27
27
|
from .constant import (
|
|
28
|
+
FLWR_PRIVATE_MAX_CONCURRENT_OBJ_PULLS,
|
|
29
|
+
FLWR_PRIVATE_MAX_CONCURRENT_OBJ_PUSHES,
|
|
28
30
|
HEAD_BODY_DIVIDER,
|
|
29
31
|
HEAD_VALUE_DIVIDER,
|
|
30
|
-
MAX_CONCURRENT_PULLS,
|
|
31
|
-
MAX_CONCURRENT_PUSHES,
|
|
32
32
|
PULL_BACKOFF_CAP,
|
|
33
33
|
PULL_INITIAL_BACKOFF,
|
|
34
34
|
PULL_MAX_TIME,
|
|
@@ -118,7 +118,7 @@ def push_objects(
|
|
|
118
118
|
*,
|
|
119
119
|
object_ids_to_push: Optional[set[str]] = None,
|
|
120
120
|
keep_objects: bool = False,
|
|
121
|
-
max_concurrent_pushes: int =
|
|
121
|
+
max_concurrent_pushes: int = FLWR_PRIVATE_MAX_CONCURRENT_OBJ_PUSHES,
|
|
122
122
|
) -> None:
|
|
123
123
|
"""Push multiple objects to the servicer.
|
|
124
124
|
|
|
@@ -137,7 +137,7 @@ def push_objects(
|
|
|
137
137
|
If `True`, the original objects will be kept in the `objects` dictionary
|
|
138
138
|
after pushing. If `False`, they will be removed from the dictionary to avoid
|
|
139
139
|
high memory usage.
|
|
140
|
-
max_concurrent_pushes : int (default:
|
|
140
|
+
max_concurrent_pushes : int (default: FLWR_PRIVATE_MAX_CONCURRENT_OBJ_PUSHES)
|
|
141
141
|
The maximum number of concurrent pushes to perform.
|
|
142
142
|
"""
|
|
143
143
|
lock = threading.Lock()
|
|
@@ -168,7 +168,7 @@ def push_object_contents_from_iterable(
|
|
|
168
168
|
object_contents: Iterable[tuple[str, bytes]],
|
|
169
169
|
push_object_fn: Callable[[str, bytes], None],
|
|
170
170
|
*,
|
|
171
|
-
max_concurrent_pushes: int =
|
|
171
|
+
max_concurrent_pushes: int = FLWR_PRIVATE_MAX_CONCURRENT_OBJ_PUSHES,
|
|
172
172
|
) -> None:
|
|
173
173
|
"""Push multiple object contents to the servicer.
|
|
174
174
|
|
|
@@ -181,7 +181,7 @@ def push_object_contents_from_iterable(
|
|
|
181
181
|
A function that takes an object ID and its content as bytes, and pushes
|
|
182
182
|
it to the servicer. This function should raise `ObjectIdNotPreregisteredError`
|
|
183
183
|
if the object ID is not pre-registered.
|
|
184
|
-
max_concurrent_pushes : int (default:
|
|
184
|
+
max_concurrent_pushes : int (default: FLWR_PRIVATE_MAX_CONCURRENT_OBJ_PUSHES)
|
|
185
185
|
The maximum number of concurrent pushes to perform.
|
|
186
186
|
"""
|
|
187
187
|
|
|
@@ -210,7 +210,7 @@ def pull_objects( # pylint: disable=too-many-arguments,too-many-locals
|
|
|
210
210
|
object_ids: list[str],
|
|
211
211
|
pull_object_fn: Callable[[str], bytes],
|
|
212
212
|
*,
|
|
213
|
-
max_concurrent_pulls: int =
|
|
213
|
+
max_concurrent_pulls: int = FLWR_PRIVATE_MAX_CONCURRENT_OBJ_PULLS,
|
|
214
214
|
max_time: Optional[float] = PULL_MAX_TIME,
|
|
215
215
|
max_tries_per_object: Optional[int] = PULL_MAX_TRIES_PER_OBJECT,
|
|
216
216
|
initial_backoff: float = PULL_INITIAL_BACKOFF,
|
|
@@ -227,7 +227,7 @@ def pull_objects( # pylint: disable=too-many-arguments,too-many-locals
|
|
|
227
227
|
The function should raise `ObjectUnavailableError` if the object is not yet
|
|
228
228
|
available, or `ObjectIdNotPreregisteredError` if the object ID is not
|
|
229
229
|
pre-registered.
|
|
230
|
-
max_concurrent_pulls : int (default:
|
|
230
|
+
max_concurrent_pulls : int (default: FLWR_PRIVATE_MAX_CONCURRENT_OBJ_PULLS)
|
|
231
231
|
The maximum number of concurrent pulls to perform.
|
|
232
232
|
max_time : Optional[float] (default: PULL_MAX_TIME)
|
|
233
233
|
The maximum time to wait for all pulls to complete. If `None`, waits
|
|
@@ -442,7 +442,7 @@ def pull_and_inflate_object_from_tree( # pylint: disable=R0913
|
|
|
442
442
|
confirm_object_received_fn: Callable[[str], None],
|
|
443
443
|
*,
|
|
444
444
|
return_type: type[T] = InflatableObject, # type: ignore
|
|
445
|
-
max_concurrent_pulls: int =
|
|
445
|
+
max_concurrent_pulls: int = FLWR_PRIVATE_MAX_CONCURRENT_OBJ_PULLS,
|
|
446
446
|
max_time: Optional[float] = PULL_MAX_TIME,
|
|
447
447
|
max_tries_per_object: Optional[int] = PULL_MAX_TRIES_PER_OBJECT,
|
|
448
448
|
initial_backoff: float = PULL_INITIAL_BACKOFF,
|
|
@@ -460,7 +460,7 @@ def pull_and_inflate_object_from_tree( # pylint: disable=R0913
|
|
|
460
460
|
A function to confirm that the object has been received.
|
|
461
461
|
return_type : type[T] (default: InflatableObject)
|
|
462
462
|
The type of the object to return. Must be a subclass of `InflatableObject`.
|
|
463
|
-
max_concurrent_pulls : int (default:
|
|
463
|
+
max_concurrent_pulls : int (default: FLWR_PRIVATE_MAX_CONCURRENT_OBJ_PULLS)
|
|
464
464
|
The maximum number of concurrent pulls to perform.
|
|
465
465
|
max_time : Optional[float] (default: PULL_MAX_TIME)
|
|
466
466
|
The maximum time to wait for all pulls to complete. If `None`, waits
|
{flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/common/record/array.py
RENAMED
|
@@ -25,7 +25,7 @@ from typing import TYPE_CHECKING, Any, cast, overload
|
|
|
25
25
|
|
|
26
26
|
import numpy as np
|
|
27
27
|
|
|
28
|
-
from ..constant import
|
|
28
|
+
from ..constant import FLWR_PRIVATE_MAX_ARRAY_CHUNK_SIZE, SType
|
|
29
29
|
from ..inflatable import (
|
|
30
30
|
InflatableObject,
|
|
31
31
|
add_header_to_object_body,
|
|
@@ -272,8 +272,8 @@ class Array(InflatableObject):
|
|
|
272
272
|
chunks: list[tuple[str, InflatableObject]] = []
|
|
273
273
|
# memoryview allows for zero-copy slicing
|
|
274
274
|
data_view = memoryview(self.data)
|
|
275
|
-
for start in range(0, len(data_view),
|
|
276
|
-
end = min(start +
|
|
275
|
+
for start in range(0, len(data_view), FLWR_PRIVATE_MAX_ARRAY_CHUNK_SIZE):
|
|
276
|
+
end = min(start + FLWR_PRIVATE_MAX_ARRAY_CHUNK_SIZE, len(data_view))
|
|
277
277
|
ac = ArrayChunk(data_view[start:end])
|
|
278
278
|
chunks.append((ac.object_id, ac))
|
|
279
279
|
|
{flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/control_pb2.py
RENAMED
|
@@ -19,7 +19,7 @@ from flwr.proto import run_pb2 as flwr_dot_proto_dot_run__pb2
|
|
|
19
19
|
from flwr.proto import node_pb2 as flwr_dot_proto_dot_node__pb2
|
|
20
20
|
|
|
21
21
|
|
|
22
|
-
DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x18\x66lwr/proto/control.proto\x12\nflwr.proto\x1a\x14\x66lwr/proto/fab.proto\x1a\x1a\x66lwr/proto/transport.proto\x1a\x1b\x66lwr/proto/recorddict.proto\x1a\x14\x66lwr/proto/run.proto\x1a\x15\x66lwr/proto/node.proto\"\xfa\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\x34\n\x12\x66\x65\x64\x65ration_options\x18\x03 \x01(\x0b\x32\x18.flwr.proto.ConfigRecord\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\"\x18\n\x16GetLoginDetailsRequest\"\x8b\x01\n\x17GetLoginDetailsResponse\x12\x12\n\nauthn_type\x18\x01 \x01(\t\x12\x13\n\x0b\x64\x65vice_code\x18\x02 \x01(\t\x12!\n\x19verification_uri_complete\x18\x03 \x01(\t\x12\x12\n\nexpires_in\x18\x04 \x01(\x03\x12\x10\n\x08interval\x18\x05 \x01(\x03\"+\n\x14GetAuthTokensRequest\x12\x13\n\x0b\x64\x65vice_code\x18\x01 \x01(\t\"D\n\x15GetAuthTokensResponse\x12\x14\n\x0c\x61\x63\x63\x65ss_token\x18\x01 \x01(\t\x12\x15\n\rrefresh_token\x18\x02 \x01(\t\" \n\x0eStopRunRequest\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\"\"\n\x0fStopRunResponse\x12\x0f\n\x07success\x18\x01 \x01(\x08\"&\n\x14PullArtifactsRequest\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\"1\n\x15PullArtifactsResponse\x12\x10\n\x03url\x18\x01 \x01(\tH\x00\x88\x01\x01\x42\x06\n\x04_url\")\n\x13RegisterNodeRequest\x12\x12\n\npublic_key\x18\x01 \x01(\x0c\"8\n\x14RegisterNodeResponse\x12\x14\n\x07node_id\x18\x01 \x01(\x04H\x00\x88\x01\x01\x42\n\n\x08_node_id\"(\n\x15UnregisterNodeRequest\x12\x0f\n\x07node_id\x18\x01 \x01(\x04\"\x18\n\x16UnregisterNodeResponse\"
|
|
22
|
+
DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x18\x66lwr/proto/control.proto\x12\nflwr.proto\x1a\x14\x66lwr/proto/fab.proto\x1a\x1a\x66lwr/proto/transport.proto\x1a\x1b\x66lwr/proto/recorddict.proto\x1a\x14\x66lwr/proto/run.proto\x1a\x15\x66lwr/proto/node.proto\"\xfa\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\x34\n\x12\x66\x65\x64\x65ration_options\x18\x03 \x01(\x0b\x32\x18.flwr.proto.ConfigRecord\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\"\x18\n\x16GetLoginDetailsRequest\"\x8b\x01\n\x17GetLoginDetailsResponse\x12\x12\n\nauthn_type\x18\x01 \x01(\t\x12\x13\n\x0b\x64\x65vice_code\x18\x02 \x01(\t\x12!\n\x19verification_uri_complete\x18\x03 \x01(\t\x12\x12\n\nexpires_in\x18\x04 \x01(\x03\x12\x10\n\x08interval\x18\x05 \x01(\x03\"+\n\x14GetAuthTokensRequest\x12\x13\n\x0b\x64\x65vice_code\x18\x01 \x01(\t\"D\n\x15GetAuthTokensResponse\x12\x14\n\x0c\x61\x63\x63\x65ss_token\x18\x01 \x01(\t\x12\x15\n\rrefresh_token\x18\x02 \x01(\t\" \n\x0eStopRunRequest\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\"\"\n\x0fStopRunResponse\x12\x0f\n\x07success\x18\x01 \x01(\x08\"&\n\x14PullArtifactsRequest\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\"1\n\x15PullArtifactsResponse\x12\x10\n\x03url\x18\x01 \x01(\tH\x00\x88\x01\x01\x42\x06\n\x04_url\")\n\x13RegisterNodeRequest\x12\x12\n\npublic_key\x18\x01 \x01(\x0c\"8\n\x14RegisterNodeResponse\x12\x14\n\x07node_id\x18\x01 \x01(\x04H\x00\x88\x01\x01\x42\n\n\x08_node_id\"(\n\x15UnregisterNodeRequest\x12\x0f\n\x07node_id\x18\x01 \x01(\x04\"\x18\n\x16UnregisterNodeResponse\"\x12\n\x10ListNodesRequest\"J\n\x11ListNodesResponse\x12(\n\nnodes_info\x18\x01 \x03(\x0b\x32\x14.flwr.proto.NodeInfo\x12\x0b\n\x03now\x18\x02 \x01(\t2\xbc\x06\n\x07\x43ontrol\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\x12\\\n\x0fGetLoginDetails\x12\".flwr.proto.GetLoginDetailsRequest\x1a#.flwr.proto.GetLoginDetailsResponse\"\x00\x12V\n\rGetAuthTokens\x12 .flwr.proto.GetAuthTokensRequest\x1a!.flwr.proto.GetAuthTokensResponse\"\x00\x12V\n\rPullArtifacts\x12 .flwr.proto.PullArtifactsRequest\x1a!.flwr.proto.PullArtifactsResponse\"\x00\x12S\n\x0cRegisterNode\x12\x1f.flwr.proto.RegisterNodeRequest\x1a .flwr.proto.RegisterNodeResponse\"\x00\x12Y\n\x0eUnregisterNode\x12!.flwr.proto.UnregisterNodeRequest\x1a\".flwr.proto.UnregisterNodeResponse\"\x00\x12J\n\tListNodes\x12\x1c.flwr.proto.ListNodesRequest\x1a\x1d.flwr.proto.ListNodesResponse\"\x00\x62\x06proto3')
|
|
23
23
|
|
|
24
24
|
_globals = globals()
|
|
25
25
|
_builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
|
|
@@ -71,9 +71,9 @@ if _descriptor._USE_C_DESCRIPTORS == False:
|
|
|
71
71
|
_globals['_UNREGISTERNODERESPONSE']._serialized_start=1397
|
|
72
72
|
_globals['_UNREGISTERNODERESPONSE']._serialized_end=1421
|
|
73
73
|
_globals['_LISTNODESREQUEST']._serialized_start=1423
|
|
74
|
-
_globals['_LISTNODESREQUEST']._serialized_end=
|
|
75
|
-
_globals['_LISTNODESRESPONSE']._serialized_start=
|
|
76
|
-
_globals['_LISTNODESRESPONSE']._serialized_end=
|
|
77
|
-
_globals['_CONTROL']._serialized_start=
|
|
78
|
-
_globals['_CONTROL']._serialized_end=
|
|
74
|
+
_globals['_LISTNODESREQUEST']._serialized_end=1441
|
|
75
|
+
_globals['_LISTNODESRESPONSE']._serialized_start=1443
|
|
76
|
+
_globals['_LISTNODESRESPONSE']._serialized_end=1517
|
|
77
|
+
_globals['_CONTROL']._serialized_start=1520
|
|
78
|
+
_globals['_CONTROL']._serialized_end=2348
|
|
79
79
|
# @@protoc_insertion_point(module_scope)
|
{flwr_nightly-1.23.0.dev20251020 → flwr_nightly-1.23.0.dev20251021}/py/flwr/proto/control_pb2.pyi
RENAMED
|
@@ -279,13 +279,8 @@ global___UnregisterNodeResponse = UnregisterNodeResponse
|
|
|
279
279
|
|
|
280
280
|
class ListNodesRequest(google.protobuf.message.Message):
|
|
281
281
|
DESCRIPTOR: google.protobuf.descriptor.Descriptor
|
|
282
|
-
DRY_RUN_FIELD_NUMBER: builtins.int
|
|
283
|
-
dry_run: builtins.bool
|
|
284
282
|
def __init__(self,
|
|
285
|
-
*,
|
|
286
|
-
dry_run: builtins.bool = ...,
|
|
287
283
|
) -> None: ...
|
|
288
|
-
def ClearField(self, field_name: typing_extensions.Literal["dry_run",b"dry_run"]) -> None: ...
|
|
289
284
|
global___ListNodesRequest = ListNodesRequest
|
|
290
285
|
|
|
291
286
|
class ListNodesResponse(google.protobuf.message.Message):
|
|
@@ -262,6 +262,7 @@ class InMemoryLinkState(LinkState): # pylint: disable=R0902,R0904
|
|
|
262
262
|
node_id: self.nodes[node_id].online_until
|
|
263
263
|
for node_id in dst_node_ids
|
|
264
264
|
if node_id in self.nodes
|
|
265
|
+
and self.nodes[node_id].status != NodeStatus.UNREGISTERED
|
|
265
266
|
},
|
|
266
267
|
current_time=current,
|
|
267
268
|
)
|
|
@@ -380,7 +381,10 @@ class InMemoryLinkState(LinkState): # pylint: disable=R0902,R0904
|
|
|
380
381
|
)
|
|
381
382
|
|
|
382
383
|
node.status = NodeStatus.UNREGISTERED
|
|
383
|
-
|
|
384
|
+
current = now()
|
|
385
|
+
node.unregistered_at = current.isoformat()
|
|
386
|
+
# Set online_until to current timestamp on deletion, if it is in the future
|
|
387
|
+
node.online_until = min(node.online_until, current.timestamp())
|
|
384
388
|
|
|
385
389
|
def get_nodes(self, run_id: int) -> set[int]:
|
|
386
390
|
"""Return all available nodes.
|
|
@@ -18,11 +18,10 @@
|
|
|
18
18
|
# pylint: disable=too-many-lines
|
|
19
19
|
|
|
20
20
|
import json
|
|
21
|
-
import re
|
|
22
21
|
import secrets
|
|
23
22
|
import sqlite3
|
|
24
23
|
from collections.abc import Sequence
|
|
25
|
-
from logging import
|
|
24
|
+
from logging import ERROR, WARNING
|
|
26
25
|
from typing import Any, Optional, Union, cast
|
|
27
26
|
|
|
28
27
|
from flwr.common import Context, Message, Metadata, log, now
|
|
@@ -52,6 +51,7 @@ from flwr.proto.recorddict_pb2 import RecordDict as ProtoRecordDict
|
|
|
52
51
|
# pylint: enable=E0611
|
|
53
52
|
from flwr.server.utils.validator import validate_message
|
|
54
53
|
from flwr.supercore.constant import NodeStatus
|
|
54
|
+
from flwr.supercore.sqlite_mixin import SqliteMixin
|
|
55
55
|
|
|
56
56
|
from .linkstate import LinkState
|
|
57
57
|
from .utils import (
|
|
@@ -183,95 +183,25 @@ CREATE TABLE IF NOT EXISTS token_store (
|
|
|
183
183
|
);
|
|
184
184
|
"""
|
|
185
185
|
|
|
186
|
-
DictOrTuple = Union[tuple[Any, ...], dict[str, Any]]
|
|
187
186
|
|
|
188
|
-
|
|
189
|
-
class SqliteLinkState(LinkState): # pylint: disable=R0904
|
|
187
|
+
class SqliteLinkState(LinkState, SqliteMixin): # pylint: disable=R0904
|
|
190
188
|
"""SQLite-based LinkState implementation."""
|
|
191
189
|
|
|
192
|
-
def __init__(
|
|
193
|
-
self,
|
|
194
|
-
database_path: str,
|
|
195
|
-
) -> None:
|
|
196
|
-
"""Initialize an SqliteLinkState.
|
|
197
|
-
|
|
198
|
-
Parameters
|
|
199
|
-
----------
|
|
200
|
-
database : (path-like object)
|
|
201
|
-
The path to the database file to be opened. Pass ":memory:" to open
|
|
202
|
-
a connection to a database that is in RAM, instead of on disk.
|
|
203
|
-
"""
|
|
204
|
-
self.database_path = database_path
|
|
205
|
-
self.conn: Optional[sqlite3.Connection] = None
|
|
206
|
-
|
|
207
190
|
def initialize(self, log_queries: bool = False) -> list[tuple[str]]:
|
|
208
|
-
"""
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
self.conn.row_factory = dict_factory
|
|
223
|
-
if log_queries:
|
|
224
|
-
self.conn.set_trace_callback(lambda query: log(DEBUG, query))
|
|
225
|
-
cur = self.conn.cursor()
|
|
226
|
-
|
|
227
|
-
# Create each table if not exists queries
|
|
228
|
-
cur.execute(SQL_CREATE_TABLE_RUN)
|
|
229
|
-
cur.execute(SQL_CREATE_TABLE_LOGS)
|
|
230
|
-
cur.execute(SQL_CREATE_TABLE_CONTEXT)
|
|
231
|
-
cur.execute(SQL_CREATE_TABLE_MESSAGE_INS)
|
|
232
|
-
cur.execute(SQL_CREATE_TABLE_MESSAGE_RES)
|
|
233
|
-
cur.execute(SQL_CREATE_TABLE_NODE)
|
|
234
|
-
cur.execute(SQL_CREATE_TABLE_PUBLIC_KEY)
|
|
235
|
-
cur.execute(SQL_CREATE_TABLE_TOKEN_STORE)
|
|
236
|
-
cur.execute(SQL_CREATE_INDEX_ONLINE_UNTIL)
|
|
237
|
-
cur.execute(SQL_CREATE_INDEX_OWNER_AID)
|
|
238
|
-
res = cur.execute("SELECT name FROM sqlite_schema;")
|
|
239
|
-
return res.fetchall()
|
|
240
|
-
|
|
241
|
-
def query(
|
|
242
|
-
self,
|
|
243
|
-
query: str,
|
|
244
|
-
data: Optional[Union[Sequence[DictOrTuple], DictOrTuple]] = None,
|
|
245
|
-
) -> list[dict[str, Any]]:
|
|
246
|
-
"""Execute a SQL query."""
|
|
247
|
-
if self.conn is None:
|
|
248
|
-
raise AttributeError("LinkState is not initialized.")
|
|
249
|
-
|
|
250
|
-
if data is None:
|
|
251
|
-
data = []
|
|
252
|
-
|
|
253
|
-
# Clean up whitespace to make the logs nicer
|
|
254
|
-
query = re.sub(r"\s+", " ", query)
|
|
255
|
-
|
|
256
|
-
try:
|
|
257
|
-
with self.conn:
|
|
258
|
-
if (
|
|
259
|
-
len(data) > 0
|
|
260
|
-
and isinstance(data, (tuple, list))
|
|
261
|
-
and isinstance(data[0], (tuple, dict))
|
|
262
|
-
):
|
|
263
|
-
rows = self.conn.executemany(query, data)
|
|
264
|
-
else:
|
|
265
|
-
rows = self.conn.execute(query, data)
|
|
266
|
-
|
|
267
|
-
# Extract results before committing to support
|
|
268
|
-
# INSERT/UPDATE ... RETURNING
|
|
269
|
-
# style queries
|
|
270
|
-
result = rows.fetchall()
|
|
271
|
-
except KeyError as exc:
|
|
272
|
-
log(ERROR, {"query": query, "data": data, "exception": exc})
|
|
273
|
-
|
|
274
|
-
return result
|
|
191
|
+
"""Connect to the DB, enable FK support, and create tables if needed."""
|
|
192
|
+
return self._ensure_initialized(
|
|
193
|
+
SQL_CREATE_TABLE_RUN,
|
|
194
|
+
SQL_CREATE_TABLE_LOGS,
|
|
195
|
+
SQL_CREATE_TABLE_CONTEXT,
|
|
196
|
+
SQL_CREATE_TABLE_MESSAGE_INS,
|
|
197
|
+
SQL_CREATE_TABLE_MESSAGE_RES,
|
|
198
|
+
SQL_CREATE_TABLE_NODE,
|
|
199
|
+
SQL_CREATE_TABLE_PUBLIC_KEY,
|
|
200
|
+
SQL_CREATE_TABLE_TOKEN_STORE,
|
|
201
|
+
SQL_CREATE_INDEX_ONLINE_UNTIL,
|
|
202
|
+
SQL_CREATE_INDEX_OWNER_AID,
|
|
203
|
+
log_queries=log_queries,
|
|
204
|
+
)
|
|
275
205
|
|
|
276
206
|
def store_message_ins(self, message: Message) -> Optional[str]:
|
|
277
207
|
"""Store one Message."""
|
|
@@ -490,11 +420,12 @@ class SqliteLinkState(LinkState): # pylint: disable=R0904
|
|
|
490
420
|
sint_node_id = convert_uint64_to_sint64(in_message.metadata.dst_node_id)
|
|
491
421
|
dst_node_ids.add(sint_node_id)
|
|
492
422
|
query = f"""
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
423
|
+
SELECT node_id, online_until
|
|
424
|
+
FROM node
|
|
425
|
+
WHERE node_id IN ({",".join(["?"] * len(dst_node_ids))})
|
|
426
|
+
AND status != ?
|
|
427
|
+
"""
|
|
428
|
+
rows = self.query(query, tuple(dst_node_ids) + (NodeStatus.UNREGISTERED,))
|
|
498
429
|
tmp_ret_dict = check_node_availability_for_in_message(
|
|
499
430
|
inquired_in_message_ids=message_ids,
|
|
500
431
|
found_in_message_dict=found_message_ins_dict,
|
|
@@ -662,13 +593,17 @@ class SqliteLinkState(LinkState): # pylint: disable=R0904
|
|
|
662
593
|
|
|
663
594
|
query = """
|
|
664
595
|
UPDATE node
|
|
665
|
-
SET status = ?, unregistered_at =
|
|
596
|
+
SET status = ?, unregistered_at = ?,
|
|
597
|
+
online_until = IIF(online_until > ?, ?, online_until)
|
|
666
598
|
WHERE node_id = ? AND status != ? AND owner_aid = ?
|
|
667
599
|
RETURNING node_id
|
|
668
600
|
"""
|
|
601
|
+
current = now()
|
|
669
602
|
params = (
|
|
670
603
|
NodeStatus.UNREGISTERED,
|
|
671
|
-
|
|
604
|
+
current.isoformat(),
|
|
605
|
+
current.timestamp(),
|
|
606
|
+
current.timestamp(),
|
|
672
607
|
sint64_node_id,
|
|
673
608
|
NodeStatus.UNREGISTERED,
|
|
674
609
|
owner_aid,
|
|
@@ -1250,18 +1185,6 @@ class SqliteLinkState(LinkState): # pylint: disable=R0904
|
|
|
1250
1185
|
return convert_sint64_to_uint64(rows[0]["run_id"])
|
|
1251
1186
|
|
|
1252
1187
|
|
|
1253
|
-
def dict_factory(
|
|
1254
|
-
cursor: sqlite3.Cursor,
|
|
1255
|
-
row: sqlite3.Row,
|
|
1256
|
-
) -> dict[str, Any]:
|
|
1257
|
-
"""Turn SQLite results into dicts.
|
|
1258
|
-
|
|
1259
|
-
Less efficent for retrival of large amounts of data but easier to use.
|
|
1260
|
-
"""
|
|
1261
|
-
fields = [column[0] for column in cursor.description]
|
|
1262
|
-
return dict(zip(fields, row))
|
|
1263
|
-
|
|
1264
|
-
|
|
1265
1188
|
def message_to_dict(message: Message) -> dict[str, Any]:
|
|
1266
1189
|
"""Transform Message to dict."""
|
|
1267
1190
|
result = {
|