flwr-nightly 1.15.0.dev20250107__tar.gz → 1.15.0.dev20250109__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.
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/PKG-INFO +4 -4
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/README.md +1 -1
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/pyproject.toml +3 -3
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/cli_user_auth_interceptor.py +6 -2
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/login/login.py +11 -4
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/utils.py +4 -4
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/grpc_rere_client/client_interceptor.py +6 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/grpc_rere_client/grpc_adapter.py +16 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/auth_plugin/auth_plugin.py +33 -23
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/constant.py +2 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/typing.py +20 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/exec_pb2.py +12 -24
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/exec_pb2.pyi +27 -54
- flwr_nightly-1.15.0.dev20250109/src/py/flwr/proto/fleet_pb2.py +69 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/fleet_pb2.pyi +84 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/fleet_pb2_grpc.py +66 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/fleet_pb2_grpc.pyi +20 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/app.py +11 -13
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/driver/serverappio_servicer.py +22 -8
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/grpc_rere/fleet_servicer.py +16 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/grpc_rere/server_interceptor.py +2 -1
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/linkstate/in_memory_linkstate.py +26 -22
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/linkstate/linkstate.py +10 -4
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/linkstate/sqlite_linkstate.py +50 -29
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/superexec/exec_servicer.py +23 -2
- flwr_nightly-1.15.0.dev20250107/src/py/flwr/proto/fleet_pb2.py +0 -56
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/LICENSE +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/app.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/build.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/config_utils.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/example.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/install.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/log.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/login/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/ls.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/new.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/.gitignore.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/LICENSE.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/README.baseline.md.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/README.flowertune.md.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/README.md.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/__init__.baseline.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/__init__.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/client.baseline.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/client.huggingface.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/client.jax.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/client.mlx.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/client.numpy.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/client.pytorch.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/client.sklearn.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/client.tensorflow.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/dataset.baseline.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/flwr_tune/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/flwr_tune/client_app.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/flwr_tune/dataset.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/flwr_tune/models.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/flwr_tune/server_app.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/flwr_tune/strategy.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/model.baseline.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/server.baseline.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/server.huggingface.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/server.jax.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/server.mlx.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/server.numpy.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/server.pytorch.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/server.sklearn.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/server.tensorflow.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/strategy.baseline.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/task.huggingface.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/task.jax.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/task.mlx.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/task.numpy.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/task.pytorch.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/task.sklearn.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/task.tensorflow.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/code/utils.baseline.py.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/pyproject.baseline.toml.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/pyproject.flowertune.toml.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/pyproject.huggingface.toml.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/pyproject.jax.toml.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/pyproject.mlx.toml.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/pyproject.numpy.toml.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/pyproject.pytorch.toml.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/pyproject.sklearn.toml.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/new/templates/app/pyproject.tensorflow.toml.tpl +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/run/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/run/run.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/stop.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/app.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/client.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/client_app.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/clientapp/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/clientapp/app.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/clientapp/clientappio_servicer.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/clientapp/utils.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/dpfedavg_numpy_client.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/grpc_adapter_client/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/grpc_adapter_client/connection.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/grpc_client/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/grpc_client/connection.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/grpc_rere_client/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/grpc_rere_client/connection.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/heartbeat.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/message_handler/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/message_handler/message_handler.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/message_handler/task_handler.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/mod/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/mod/centraldp_mods.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/mod/comms_mods.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/mod/localdp_mod.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/mod/secure_aggregation/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/mod/secure_aggregation/secagg_mod.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/mod/secure_aggregation/secaggplus_mod.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/mod/utils.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/nodestate/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/nodestate/in_memory_nodestate.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/nodestate/nodestate.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/nodestate/nodestate_factory.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/numpy_client.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/rest_client/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/rest_client/connection.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/run_info_store.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/supernode/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/supernode/app.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/client/typing.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/address.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/args.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/auth_plugin/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/config.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/context.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/date.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/differential_privacy.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/differential_privacy_constants.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/dp.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/exit_handlers.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/logger.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/message.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/object_ref.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/parameter.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/pyproject.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/record/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/record/configsrecord.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/record/conversion_utils.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/record/metricsrecord.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/record/parametersrecord.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/record/recordset.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/record/typeddict.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/recordset_compat.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/retry_invoker.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/secure_aggregation/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/secure_aggregation/crypto/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/secure_aggregation/crypto/shamir.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/secure_aggregation/crypto/symmetric_encryption.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/secure_aggregation/ndarrays_arithmetic.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/secure_aggregation/quantization.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/secure_aggregation/secaggplus_constants.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/secure_aggregation/secaggplus_utils.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/serde.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/telemetry.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/version.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/clientappio_pb2.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/clientappio_pb2.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/clientappio_pb2_grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/clientappio_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/error_pb2.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/error_pb2.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/error_pb2_grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/error_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/exec_pb2_grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/exec_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/fab_pb2.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/fab_pb2.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/fab_pb2_grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/fab_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/grpcadapter_pb2.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/grpcadapter_pb2.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/grpcadapter_pb2_grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/grpcadapter_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/log_pb2.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/log_pb2.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/log_pb2_grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/log_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/message_pb2.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/message_pb2.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/message_pb2_grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/message_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/node_pb2.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/node_pb2.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/node_pb2_grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/node_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/recordset_pb2.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/recordset_pb2.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/recordset_pb2_grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/recordset_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/run_pb2.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/run_pb2.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/run_pb2_grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/run_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/serverappio_pb2.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/serverappio_pb2.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/serverappio_pb2_grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/serverappio_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/simulationio_pb2.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/simulationio_pb2.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/simulationio_pb2_grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/simulationio_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/task_pb2.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/task_pb2.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/task_pb2_grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/task_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/transport_pb2.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/transport_pb2.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/transport_pb2_grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/transport_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/py.typed +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/client_manager.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/client_proxy.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/compat/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/compat/app.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/compat/app_utils.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/compat/driver_client_proxy.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/compat/legacy_context.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/criterion.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/driver/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/driver/driver.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/driver/grpc_driver.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/driver/inmemory_driver.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/history.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/run_serverapp.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/server.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/server_app.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/server_config.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/serverapp/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/serverapp/app.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/serverapp_components.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/aggregate.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/bulyan.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/dp_adaptive_clipping.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/dp_fixed_clipping.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/dpfedavg_adaptive.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/dpfedavg_fixed.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/fault_tolerant_fedavg.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/fedadagrad.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/fedadam.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/fedavg.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/fedavg_android.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/fedavgm.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/fedmedian.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/fedopt.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/fedprox.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/fedtrimmedavg.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/fedxgb_bagging.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/fedxgb_cyclic.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/fedxgb_nn_avg.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/fedyogi.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/krum.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/qfedavg.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/strategy/strategy.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/driver/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/driver/serverappio_grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/ffs/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/ffs/disk_ffs.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/ffs/ffs.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/ffs/ffs_factory.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/grpc_adapter/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/grpc_bidi/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/grpc_bidi/flower_service_servicer.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_bridge.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_client_proxy.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_server.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/grpc_rere/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/message_handler/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/message_handler/message_handler.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/rest_rere/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/rest_rere/rest_api.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/vce/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/vce/backend/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/vce/backend/backend.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/vce/backend/raybackend.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/fleet/vce/vce_api.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/linkstate/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/linkstate/linkstate_factory.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/linkstate/utils.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/simulation/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/simulation/simulationio_grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/simulation/simulationio_servicer.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/superlink/utils.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/typing.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/utils/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/utils/tensorboard.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/utils/validator.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/workflow/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/workflow/constant.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/workflow/default_workflows.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/workflow/secure_aggregation/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/workflow/secure_aggregation/secagg_workflow.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/server/workflow/secure_aggregation/secaggplus_workflow.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/simulation/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/simulation/app.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/simulation/legacy_app.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/simulation/ray_transport/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/simulation/ray_transport/ray_actor.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/simulation/ray_transport/ray_client_proxy.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/simulation/ray_transport/utils.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/simulation/run_simulation.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/simulation/simulationio_connection.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/superexec/__init__.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/superexec/app.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/superexec/deployment.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/superexec/exec_grpc.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/superexec/exec_user_auth_interceptor.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/superexec/executor.py +0 -0
- {flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/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.15.0.
|
3
|
+
Version: 1.15.0.dev20250109
|
4
4
|
Summary: Flower: A Friendly Federated AI Framework
|
5
5
|
Home-page: https://flower.ai
|
6
6
|
License: Apache-2.0
|
@@ -43,11 +43,11 @@ Requires-Dist: pyyaml (>=6.0.2,<7.0.0)
|
|
43
43
|
Requires-Dist: ray (==2.10.0) ; (python_version >= "3.9" and python_version < "3.12") and (extra == "simulation")
|
44
44
|
Requires-Dist: requests (>=2.31.0,<3.0.0)
|
45
45
|
Requires-Dist: rich (>=13.5.0,<14.0.0)
|
46
|
-
Requires-Dist: starlette (>=0.
|
46
|
+
Requires-Dist: starlette (>=0.45.2,<0.46.0) ; extra == "rest"
|
47
47
|
Requires-Dist: tomli (>=2.0.1,<3.0.0)
|
48
48
|
Requires-Dist: tomli-w (>=1.0.0,<2.0.0)
|
49
49
|
Requires-Dist: typer (>=0.12.5,<0.13.0)
|
50
|
-
Requires-Dist: uvicorn[standard] (>=0.
|
50
|
+
Requires-Dist: uvicorn[standard] (>=0.34.0,<0.35.0) ; extra == "rest"
|
51
51
|
Project-URL: Documentation, https://flower.ai
|
52
52
|
Project-URL: Repository, https://github.com/adap/flower
|
53
53
|
Description-Content-Type: text/markdown
|
@@ -88,7 +88,7 @@ design of Flower is based on a few guiding principles:
|
|
88
88
|
|
89
89
|
- **Framework-agnostic**: Different machine learning frameworks have different
|
90
90
|
strengths. Flower can be used with any machine learning framework, for
|
91
|
-
example, [PyTorch](https://pytorch.org), [TensorFlow](https://tensorflow.org), [Hugging Face Transformers](https://huggingface.co/), [PyTorch Lightning](https://pytorchlightning.ai/), [scikit-learn](https://scikit-learn.org/), [JAX](https://jax.readthedocs.io/), [TFLite](https://tensorflow.org/lite/), [MONAI](https://docs.monai.io/en/latest/index.html), [fastai](https://www.fast.ai/), [MLX](https://ml-explore.github.io/mlx/build/html/index.html), [XGBoost](https://xgboost.readthedocs.io/en/stable/), [Pandas](https://pandas.pydata.org/) for federated analytics, or even raw [NumPy](https://numpy.org/)
|
91
|
+
example, [PyTorch](https://pytorch.org), [TensorFlow](https://tensorflow.org), [Hugging Face Transformers](https://huggingface.co/), [PyTorch Lightning](https://pytorchlightning.ai/), [scikit-learn](https://scikit-learn.org/), [JAX](https://jax.readthedocs.io/), [TFLite](https://tensorflow.org/lite/), [MONAI](https://docs.monai.io/en/latest/index.html), [fastai](https://www.fast.ai/), [MLX](https://ml-explore.github.io/mlx/build/html/index.html), [XGBoost](https://xgboost.readthedocs.io/en/stable/), [LeRobot](https://github.com/huggingface/lerobot) for federated robots, [Pandas](https://pandas.pydata.org/) for federated analytics, or even raw [NumPy](https://numpy.org/)
|
92
92
|
for users who enjoy computing gradients by hand.
|
93
93
|
|
94
94
|
- **Understandable**: Flower is written with maintainability in mind. The
|
@@ -34,7 +34,7 @@ design of Flower is based on a few guiding principles:
|
|
34
34
|
|
35
35
|
- **Framework-agnostic**: Different machine learning frameworks have different
|
36
36
|
strengths. Flower can be used with any machine learning framework, for
|
37
|
-
example, [PyTorch](https://pytorch.org), [TensorFlow](https://tensorflow.org), [Hugging Face Transformers](https://huggingface.co/), [PyTorch Lightning](https://pytorchlightning.ai/), [scikit-learn](https://scikit-learn.org/), [JAX](https://jax.readthedocs.io/), [TFLite](https://tensorflow.org/lite/), [MONAI](https://docs.monai.io/en/latest/index.html), [fastai](https://www.fast.ai/), [MLX](https://ml-explore.github.io/mlx/build/html/index.html), [XGBoost](https://xgboost.readthedocs.io/en/stable/), [Pandas](https://pandas.pydata.org/) for federated analytics, or even raw [NumPy](https://numpy.org/)
|
37
|
+
example, [PyTorch](https://pytorch.org), [TensorFlow](https://tensorflow.org), [Hugging Face Transformers](https://huggingface.co/), [PyTorch Lightning](https://pytorchlightning.ai/), [scikit-learn](https://scikit-learn.org/), [JAX](https://jax.readthedocs.io/), [TFLite](https://tensorflow.org/lite/), [MONAI](https://docs.monai.io/en/latest/index.html), [fastai](https://www.fast.ai/), [MLX](https://ml-explore.github.io/mlx/build/html/index.html), [XGBoost](https://xgboost.readthedocs.io/en/stable/), [LeRobot](https://github.com/huggingface/lerobot) for federated robots, [Pandas](https://pandas.pydata.org/) for federated analytics, or even raw [NumPy](https://numpy.org/)
|
38
38
|
for users who enjoy computing gradients by hand.
|
39
39
|
|
40
40
|
- **Understandable**: Flower is written with maintainability in mind. The
|
@@ -4,7 +4,7 @@ build-backend = "poetry.core.masonry.api"
|
|
4
4
|
|
5
5
|
[tool.poetry]
|
6
6
|
name = "flwr-nightly"
|
7
|
-
version = "1.15.0.
|
7
|
+
version = "1.15.0.dev20250109"
|
8
8
|
description = "Flower: A Friendly Federated AI Framework"
|
9
9
|
license = "Apache-2.0"
|
10
10
|
authors = ["The Flower Authors <hello@flower.ai>"]
|
@@ -83,8 +83,8 @@ requests = "^2.31.0"
|
|
83
83
|
# Optional dependencies (Simulation Engine)
|
84
84
|
ray = { version = "==2.10.0", optional = true, python = ">=3.9,<3.12" }
|
85
85
|
# Optional dependencies (REST transport layer)
|
86
|
-
starlette = { version = "^0.
|
87
|
-
uvicorn = { version = "^0.
|
86
|
+
starlette = { version = "^0.45.2", optional = true }
|
87
|
+
uvicorn = { version = "^0.34.0", extras = ["standard"], optional = true }
|
88
88
|
|
89
89
|
[tool.poetry.extras]
|
90
90
|
simulation = ["ray"]
|
@@ -54,8 +54,12 @@ class CliUserAuthInterceptor(
|
|
54
54
|
|
55
55
|
response = continuation(details, request)
|
56
56
|
if response.initial_metadata():
|
57
|
-
|
58
|
-
|
57
|
+
credentials = self.auth_plugin.read_tokens_from_metadata(
|
58
|
+
response.initial_metadata()
|
59
|
+
)
|
60
|
+
# The metadata contains tokens only if they have been refreshed
|
61
|
+
if credentials is not None:
|
62
|
+
self.auth_plugin.store_tokens(credentials)
|
59
63
|
|
60
64
|
return response
|
61
65
|
|
{flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/login/login.py
RENAMED
@@ -26,7 +26,7 @@ from flwr.cli.config_utils import (
|
|
26
26
|
process_loaded_project_config,
|
27
27
|
validate_federation_in_project_config,
|
28
28
|
)
|
29
|
-
from flwr.common.
|
29
|
+
from flwr.common.typing import UserAuthLoginDetails
|
30
30
|
from flwr.proto.exec_pb2 import ( # pylint: disable=E0611
|
31
31
|
GetLoginDetailsRequest,
|
32
32
|
GetLoginDetailsResponse,
|
@@ -64,7 +64,7 @@ def login( # pylint: disable=R0914
|
|
64
64
|
login_response: GetLoginDetailsResponse = stub.GetLoginDetails(login_request)
|
65
65
|
|
66
66
|
# Get the auth plugin
|
67
|
-
auth_type = login_response.
|
67
|
+
auth_type = login_response.auth_type
|
68
68
|
auth_plugin = try_obtain_cli_auth_plugin(app, federation, auth_type)
|
69
69
|
if auth_plugin is None:
|
70
70
|
typer.secho(
|
@@ -75,7 +75,14 @@ def login( # pylint: disable=R0914
|
|
75
75
|
raise typer.Exit(code=1)
|
76
76
|
|
77
77
|
# Login
|
78
|
-
|
78
|
+
details = UserAuthLoginDetails(
|
79
|
+
auth_type=login_response.auth_type,
|
80
|
+
device_code=login_response.device_code,
|
81
|
+
verification_uri_complete=login_response.verification_uri_complete,
|
82
|
+
expires_in=login_response.expires_in,
|
83
|
+
interval=login_response.interval,
|
84
|
+
)
|
85
|
+
credentials = auth_plugin.login(details, stub)
|
79
86
|
|
80
87
|
# Store the tokens
|
81
|
-
auth_plugin.store_tokens(
|
88
|
+
auth_plugin.store_tokens(credentials)
|
{flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/cli/utils.py
RENAMED
@@ -223,19 +223,19 @@ def try_obtain_cli_auth_plugin(
|
|
223
223
|
config_path = get_user_auth_config_path(root_dir, federation)
|
224
224
|
|
225
225
|
# Load the config file if it exists
|
226
|
-
|
226
|
+
json_file: dict[str, Any] = {}
|
227
227
|
if config_path.exists():
|
228
228
|
with config_path.open("r", encoding="utf-8") as file:
|
229
|
-
|
229
|
+
json_file = json.load(file)
|
230
230
|
# This is the case when the user auth is not enabled
|
231
231
|
elif auth_type is None:
|
232
232
|
return None
|
233
233
|
|
234
234
|
# Get the auth type from the config if not provided
|
235
235
|
if auth_type is None:
|
236
|
-
if AUTH_TYPE not in
|
236
|
+
if AUTH_TYPE not in json_file:
|
237
237
|
return None
|
238
|
-
auth_type =
|
238
|
+
auth_type = json_file[AUTH_TYPE]
|
239
239
|
|
240
240
|
# Retrieve auth plugin class and instantiate it
|
241
241
|
try:
|
@@ -36,7 +36,9 @@ from flwr.proto.fleet_pb2 import ( # pylint: disable=E0611
|
|
36
36
|
CreateNodeRequest,
|
37
37
|
DeleteNodeRequest,
|
38
38
|
PingRequest,
|
39
|
+
PullMessagesRequest,
|
39
40
|
PullTaskInsRequest,
|
41
|
+
PushMessagesRequest,
|
40
42
|
PushTaskResRequest,
|
41
43
|
)
|
42
44
|
from flwr.proto.run_pb2 import GetRunRequest # pylint: disable=E0611
|
@@ -52,6 +54,8 @@ Request = Union[
|
|
52
54
|
GetRunRequest,
|
53
55
|
PingRequest,
|
54
56
|
GetFabRequest,
|
57
|
+
PullMessagesRequest,
|
58
|
+
PushMessagesRequest,
|
55
59
|
]
|
56
60
|
|
57
61
|
|
@@ -129,6 +133,8 @@ class AuthenticateClientInterceptor(grpc.UnaryUnaryClientInterceptor): # type:
|
|
129
133
|
GetRunRequest,
|
130
134
|
PingRequest,
|
131
135
|
GetFabRequest,
|
136
|
+
PullMessagesRequest,
|
137
|
+
PushMessagesRequest,
|
132
138
|
),
|
133
139
|
):
|
134
140
|
if self.shared_secret is None:
|
@@ -40,8 +40,12 @@ from flwr.proto.fleet_pb2 import ( # pylint: disable=E0611
|
|
40
40
|
DeleteNodeResponse,
|
41
41
|
PingRequest,
|
42
42
|
PingResponse,
|
43
|
+
PullMessagesRequest,
|
44
|
+
PullMessagesResponse,
|
43
45
|
PullTaskInsRequest,
|
44
46
|
PullTaskInsResponse,
|
47
|
+
PushMessagesRequest,
|
48
|
+
PushMessagesResponse,
|
45
49
|
PushTaskResRequest,
|
46
50
|
PushTaskResResponse,
|
47
51
|
)
|
@@ -132,12 +136,24 @@ class GrpcAdapter:
|
|
132
136
|
"""."""
|
133
137
|
return self._send_and_receive(request, PullTaskInsResponse, **kwargs)
|
134
138
|
|
139
|
+
def PullMessages( # pylint: disable=C0103
|
140
|
+
self, request: PullMessagesRequest, **kwargs: Any
|
141
|
+
) -> PullMessagesResponse:
|
142
|
+
"""."""
|
143
|
+
return self._send_and_receive(request, PullMessagesResponse, **kwargs)
|
144
|
+
|
135
145
|
def PushTaskRes( # pylint: disable=C0103
|
136
146
|
self, request: PushTaskResRequest, **kwargs: Any
|
137
147
|
) -> PushTaskResResponse:
|
138
148
|
"""."""
|
139
149
|
return self._send_and_receive(request, PushTaskResResponse, **kwargs)
|
140
150
|
|
151
|
+
def PushMessages( # pylint: disable=C0103
|
152
|
+
self, request: PushMessagesRequest, **kwargs: Any
|
153
|
+
) -> PushMessagesResponse:
|
154
|
+
"""."""
|
155
|
+
return self._send_and_receive(request, PushMessagesResponse, **kwargs)
|
156
|
+
|
141
157
|
def GetRun( # pylint: disable=C0103
|
142
158
|
self, request: GetRunRequest, **kwargs: Any
|
143
159
|
) -> GetRunResponse:
|
@@ -18,26 +18,31 @@
|
|
18
18
|
from abc import ABC, abstractmethod
|
19
19
|
from collections.abc import Sequence
|
20
20
|
from pathlib import Path
|
21
|
-
from typing import
|
21
|
+
from typing import Optional, Union
|
22
22
|
|
23
23
|
from flwr.proto.exec_pb2_grpc import ExecStub
|
24
24
|
|
25
|
+
from ..typing import UserAuthCredentials, UserAuthLoginDetails
|
26
|
+
|
25
27
|
|
26
28
|
class ExecAuthPlugin(ABC):
|
27
29
|
"""Abstract Flower Auth Plugin class for ExecServicer.
|
28
30
|
|
29
31
|
Parameters
|
30
32
|
----------
|
31
|
-
|
32
|
-
|
33
|
+
user_auth_config_path : Path
|
34
|
+
Path to the YAML file containing the authentication configuration.
|
33
35
|
"""
|
34
36
|
|
35
37
|
@abstractmethod
|
36
|
-
def __init__(
|
38
|
+
def __init__(
|
39
|
+
self,
|
40
|
+
user_auth_config_path: Path,
|
41
|
+
):
|
37
42
|
"""Abstract constructor."""
|
38
43
|
|
39
44
|
@abstractmethod
|
40
|
-
def get_login_details(self) ->
|
45
|
+
def get_login_details(self) -> Optional[UserAuthLoginDetails]:
|
41
46
|
"""Get the login details."""
|
42
47
|
|
43
48
|
@abstractmethod
|
@@ -47,7 +52,7 @@ class ExecAuthPlugin(ABC):
|
|
47
52
|
"""Validate authentication tokens in the provided metadata."""
|
48
53
|
|
49
54
|
@abstractmethod
|
50
|
-
def get_auth_tokens(self,
|
55
|
+
def get_auth_tokens(self, device_code: str) -> Optional[UserAuthCredentials]:
|
51
56
|
"""Get authentication tokens."""
|
52
57
|
|
53
58
|
@abstractmethod
|
@@ -62,50 +67,55 @@ class CliAuthPlugin(ABC):
|
|
62
67
|
|
63
68
|
Parameters
|
64
69
|
----------
|
65
|
-
|
66
|
-
|
70
|
+
credentials_path : Path
|
71
|
+
Path to the user's authentication credentials file.
|
67
72
|
"""
|
68
73
|
|
69
74
|
@staticmethod
|
70
75
|
@abstractmethod
|
71
76
|
def login(
|
72
|
-
login_details:
|
77
|
+
login_details: UserAuthLoginDetails,
|
73
78
|
exec_stub: ExecStub,
|
74
|
-
) ->
|
75
|
-
"""Authenticate the user
|
79
|
+
) -> UserAuthCredentials:
|
80
|
+
"""Authenticate the user and retrieve authentication credentials.
|
76
81
|
|
77
82
|
Parameters
|
78
83
|
----------
|
79
|
-
login_details :
|
80
|
-
|
84
|
+
login_details : UserAuthLoginDetails
|
85
|
+
An object containing the user's login details.
|
81
86
|
exec_stub : ExecStub
|
82
|
-
|
87
|
+
A stub for executing RPC calls to the server.
|
83
88
|
|
84
89
|
Returns
|
85
90
|
-------
|
86
|
-
|
87
|
-
|
88
|
-
in JSON format.
|
91
|
+
UserAuthCredentials
|
92
|
+
The authentication credentials obtained after login.
|
89
93
|
"""
|
90
94
|
|
91
95
|
@abstractmethod
|
92
|
-
def __init__(self,
|
96
|
+
def __init__(self, credentials_path: Path):
|
93
97
|
"""Abstract constructor."""
|
94
98
|
|
95
99
|
@abstractmethod
|
96
|
-
def store_tokens(self,
|
97
|
-
"""Store authentication tokens
|
100
|
+
def store_tokens(self, credentials: UserAuthCredentials) -> None:
|
101
|
+
"""Store authentication tokens to the `credentials_path`.
|
98
102
|
|
99
|
-
The
|
100
|
-
at `
|
103
|
+
The credentials, including tokens, will be saved as a JSON file
|
104
|
+
at `credentials_path`.
|
101
105
|
"""
|
102
106
|
|
103
107
|
@abstractmethod
|
104
108
|
def load_tokens(self) -> None:
|
105
|
-
"""Load authentication tokens from the
|
109
|
+
"""Load authentication tokens from the `credentials_path`."""
|
106
110
|
|
107
111
|
@abstractmethod
|
108
112
|
def write_tokens_to_metadata(
|
109
113
|
self, metadata: Sequence[tuple[str, Union[str, bytes]]]
|
110
114
|
) -> Sequence[tuple[str, Union[str, bytes]]]:
|
111
115
|
"""Write authentication tokens to the provided metadata."""
|
116
|
+
|
117
|
+
@abstractmethod
|
118
|
+
def read_tokens_from_metadata(
|
119
|
+
self, metadata: Sequence[tuple[str, Union[str, bytes]]]
|
120
|
+
) -> Optional[UserAuthCredentials]:
|
121
|
+
"""Read authentication tokens from the provided metadata."""
|
{flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/constant.py
RENAMED
@@ -114,6 +114,8 @@ MAX_RETRY_DELAY = 20 # Maximum delay duration between two consecutive retries.
|
|
114
114
|
# Constants for user authentication
|
115
115
|
CREDENTIALS_DIR = ".credentials"
|
116
116
|
AUTH_TYPE = "auth_type"
|
117
|
+
ACCESS_TOKEN_KEY = "access_token"
|
118
|
+
REFRESH_TOKEN_KEY = "refresh_token"
|
117
119
|
|
118
120
|
|
119
121
|
class MessageType:
|
{flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/common/typing.py
RENAMED
@@ -266,3 +266,23 @@ class InvalidRunStatusException(BaseException):
|
|
266
266
|
def __init__(self, message: str) -> None:
|
267
267
|
super().__init__(message)
|
268
268
|
self.message = message
|
269
|
+
|
270
|
+
|
271
|
+
# OIDC user authentication types
|
272
|
+
@dataclass
|
273
|
+
class UserAuthLoginDetails:
|
274
|
+
"""User authentication login details."""
|
275
|
+
|
276
|
+
auth_type: str
|
277
|
+
device_code: str
|
278
|
+
verification_uri_complete: str
|
279
|
+
expires_in: int
|
280
|
+
interval: int
|
281
|
+
|
282
|
+
|
283
|
+
@dataclass
|
284
|
+
class UserAuthCredentials:
|
285
|
+
"""User authentication tokens."""
|
286
|
+
|
287
|
+
access_token: str
|
288
|
+
refresh_token: str
|
{flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/exec_pb2.py
RENAMED
@@ -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\"\x18\n\x16GetLoginDetailsRequest\"\
|
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\"\x18\n\x16GetLoginDetailsRequest\"\x8a\x01\n\x17GetLoginDetailsResponse\x12\x11\n\tauth_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\x32\xe5\x03\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\x12\\\n\x0fGetLoginDetails\x12\".flwr.proto.GetLoginDetailsRequest\x1a#.flwr.proto.GetLoginDetailsResponse\"\x00\x12V\n\rGetAuthTokens\x12 .flwr.proto.GetAuthTokensRequest\x1a!.flwr.proto.GetAuthTokensResponse\"\x00\x62\x06proto3')
|
22
22
|
|
23
23
|
_globals = globals()
|
24
24
|
_builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
|
@@ -29,12 +29,6 @@ if _descriptor._USE_C_DESCRIPTORS == False:
|
|
29
29
|
_globals['_STARTRUNREQUEST_OVERRIDECONFIGENTRY']._serialized_options = b'8\001'
|
30
30
|
_globals['_LISTRUNSRESPONSE_RUNDICTENTRY']._options = None
|
31
31
|
_globals['_LISTRUNSRESPONSE_RUNDICTENTRY']._serialized_options = b'8\001'
|
32
|
-
_globals['_GETLOGINDETAILSRESPONSE_LOGINDETAILSENTRY']._options = None
|
33
|
-
_globals['_GETLOGINDETAILSRESPONSE_LOGINDETAILSENTRY']._serialized_options = b'8\001'
|
34
|
-
_globals['_GETAUTHTOKENSREQUEST_AUTHDETAILSENTRY']._options = None
|
35
|
-
_globals['_GETAUTHTOKENSREQUEST_AUTHDETAILSENTRY']._serialized_options = b'8\001'
|
36
|
-
_globals['_GETAUTHTOKENSRESPONSE_AUTHTOKENSENTRY']._options = None
|
37
|
-
_globals['_GETAUTHTOKENSRESPONSE_AUTHTOKENSENTRY']._serialized_options = b'8\001'
|
38
32
|
_globals['_STARTRUNREQUEST']._serialized_start=138
|
39
33
|
_globals['_STARTRUNREQUEST']._serialized_end=389
|
40
34
|
_globals['_STARTRUNREQUEST_OVERRIDECONFIGENTRY']._serialized_start=316
|
@@ -54,21 +48,15 @@ if _descriptor._USE_C_DESCRIPTORS == False:
|
|
54
48
|
_globals['_GETLOGINDETAILSREQUEST']._serialized_start=784
|
55
49
|
_globals['_GETLOGINDETAILSREQUEST']._serialized_end=808
|
56
50
|
_globals['_GETLOGINDETAILSRESPONSE']._serialized_start=811
|
57
|
-
_globals['_GETLOGINDETAILSRESPONSE']._serialized_end=
|
58
|
-
_globals['
|
59
|
-
_globals['
|
60
|
-
_globals['
|
61
|
-
_globals['
|
62
|
-
_globals['
|
63
|
-
_globals['
|
64
|
-
_globals['
|
65
|
-
_globals['
|
66
|
-
_globals['
|
67
|
-
_globals['
|
68
|
-
_globals['_STOPRUNREQUEST']._serialized_start=1268
|
69
|
-
_globals['_STOPRUNREQUEST']._serialized_end=1300
|
70
|
-
_globals['_STOPRUNRESPONSE']._serialized_start=1302
|
71
|
-
_globals['_STOPRUNRESPONSE']._serialized_end=1336
|
72
|
-
_globals['_EXEC']._serialized_start=1339
|
73
|
-
_globals['_EXEC']._serialized_end=1824
|
51
|
+
_globals['_GETLOGINDETAILSRESPONSE']._serialized_end=949
|
52
|
+
_globals['_GETAUTHTOKENSREQUEST']._serialized_start=951
|
53
|
+
_globals['_GETAUTHTOKENSREQUEST']._serialized_end=994
|
54
|
+
_globals['_GETAUTHTOKENSRESPONSE']._serialized_start=996
|
55
|
+
_globals['_GETAUTHTOKENSRESPONSE']._serialized_end=1064
|
56
|
+
_globals['_STOPRUNREQUEST']._serialized_start=1066
|
57
|
+
_globals['_STOPRUNREQUEST']._serialized_end=1098
|
58
|
+
_globals['_STOPRUNRESPONSE']._serialized_start=1100
|
59
|
+
_globals['_STOPRUNRESPONSE']._serialized_end=1134
|
60
|
+
_globals['_EXEC']._serialized_start=1137
|
61
|
+
_globals['_EXEC']._serialized_end=1622
|
74
62
|
# @@protoc_insertion_point(module_scope)
|
{flwr_nightly-1.15.0.dev20250107 → flwr_nightly-1.15.0.dev20250109}/src/py/flwr/proto/exec_pb2.pyi
RENAMED
@@ -143,77 +143,50 @@ global___GetLoginDetailsRequest = GetLoginDetailsRequest
|
|
143
143
|
|
144
144
|
class GetLoginDetailsResponse(google.protobuf.message.Message):
|
145
145
|
DESCRIPTOR: google.protobuf.descriptor.Descriptor
|
146
|
-
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
) -> None: ...
|
157
|
-
def ClearField(self, field_name: typing_extensions.Literal["key",b"key","value",b"value"]) -> None: ...
|
158
|
-
|
159
|
-
LOGIN_DETAILS_FIELD_NUMBER: builtins.int
|
160
|
-
@property
|
161
|
-
def login_details(self) -> google.protobuf.internal.containers.ScalarMap[typing.Text, typing.Text]: ...
|
146
|
+
AUTH_TYPE_FIELD_NUMBER: builtins.int
|
147
|
+
DEVICE_CODE_FIELD_NUMBER: builtins.int
|
148
|
+
VERIFICATION_URI_COMPLETE_FIELD_NUMBER: builtins.int
|
149
|
+
EXPIRES_IN_FIELD_NUMBER: builtins.int
|
150
|
+
INTERVAL_FIELD_NUMBER: builtins.int
|
151
|
+
auth_type: typing.Text
|
152
|
+
device_code: typing.Text
|
153
|
+
verification_uri_complete: typing.Text
|
154
|
+
expires_in: builtins.int
|
155
|
+
interval: builtins.int
|
162
156
|
def __init__(self,
|
163
157
|
*,
|
164
|
-
|
158
|
+
auth_type: typing.Text = ...,
|
159
|
+
device_code: typing.Text = ...,
|
160
|
+
verification_uri_complete: typing.Text = ...,
|
161
|
+
expires_in: builtins.int = ...,
|
162
|
+
interval: builtins.int = ...,
|
165
163
|
) -> None: ...
|
166
|
-
def ClearField(self, field_name: typing_extensions.Literal["
|
164
|
+
def ClearField(self, field_name: typing_extensions.Literal["auth_type",b"auth_type","device_code",b"device_code","expires_in",b"expires_in","interval",b"interval","verification_uri_complete",b"verification_uri_complete"]) -> None: ...
|
167
165
|
global___GetLoginDetailsResponse = GetLoginDetailsResponse
|
168
166
|
|
169
167
|
class GetAuthTokensRequest(google.protobuf.message.Message):
|
170
168
|
DESCRIPTOR: google.protobuf.descriptor.Descriptor
|
171
|
-
|
172
|
-
|
173
|
-
KEY_FIELD_NUMBER: builtins.int
|
174
|
-
VALUE_FIELD_NUMBER: builtins.int
|
175
|
-
key: typing.Text
|
176
|
-
value: typing.Text
|
177
|
-
def __init__(self,
|
178
|
-
*,
|
179
|
-
key: typing.Text = ...,
|
180
|
-
value: typing.Text = ...,
|
181
|
-
) -> None: ...
|
182
|
-
def ClearField(self, field_name: typing_extensions.Literal["key",b"key","value",b"value"]) -> None: ...
|
183
|
-
|
184
|
-
AUTH_DETAILS_FIELD_NUMBER: builtins.int
|
185
|
-
@property
|
186
|
-
def auth_details(self) -> google.protobuf.internal.containers.ScalarMap[typing.Text, typing.Text]: ...
|
169
|
+
DEVICE_CODE_FIELD_NUMBER: builtins.int
|
170
|
+
device_code: typing.Text
|
187
171
|
def __init__(self,
|
188
172
|
*,
|
189
|
-
|
173
|
+
device_code: typing.Text = ...,
|
190
174
|
) -> None: ...
|
191
|
-
def ClearField(self, field_name: typing_extensions.Literal["
|
175
|
+
def ClearField(self, field_name: typing_extensions.Literal["device_code",b"device_code"]) -> None: ...
|
192
176
|
global___GetAuthTokensRequest = GetAuthTokensRequest
|
193
177
|
|
194
178
|
class GetAuthTokensResponse(google.protobuf.message.Message):
|
195
179
|
DESCRIPTOR: google.protobuf.descriptor.Descriptor
|
196
|
-
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
key: typing.Text
|
201
|
-
value: typing.Text
|
202
|
-
def __init__(self,
|
203
|
-
*,
|
204
|
-
key: typing.Text = ...,
|
205
|
-
value: typing.Text = ...,
|
206
|
-
) -> None: ...
|
207
|
-
def ClearField(self, field_name: typing_extensions.Literal["key",b"key","value",b"value"]) -> None: ...
|
208
|
-
|
209
|
-
AUTH_TOKENS_FIELD_NUMBER: builtins.int
|
210
|
-
@property
|
211
|
-
def auth_tokens(self) -> google.protobuf.internal.containers.ScalarMap[typing.Text, typing.Text]: ...
|
180
|
+
ACCESS_TOKEN_FIELD_NUMBER: builtins.int
|
181
|
+
REFRESH_TOKEN_FIELD_NUMBER: builtins.int
|
182
|
+
access_token: typing.Text
|
183
|
+
refresh_token: typing.Text
|
212
184
|
def __init__(self,
|
213
185
|
*,
|
214
|
-
|
186
|
+
access_token: typing.Text = ...,
|
187
|
+
refresh_token: typing.Text = ...,
|
215
188
|
) -> None: ...
|
216
|
-
def ClearField(self, field_name: typing_extensions.Literal["
|
189
|
+
def ClearField(self, field_name: typing_extensions.Literal["access_token",b"access_token","refresh_token",b"refresh_token"]) -> None: ...
|
217
190
|
global___GetAuthTokensResponse = GetAuthTokensResponse
|
218
191
|
|
219
192
|
class StopRunRequest(google.protobuf.message.Message):
|
@@ -0,0 +1,69 @@
|
|
1
|
+
# -*- coding: utf-8 -*-
|
2
|
+
# Generated by the protocol buffer compiler. DO NOT EDIT!
|
3
|
+
# source: flwr/proto/fleet.proto
|
4
|
+
# Protobuf Python Version: 4.25.0
|
5
|
+
"""Generated protocol buffer code."""
|
6
|
+
from google.protobuf import descriptor as _descriptor
|
7
|
+
from google.protobuf import descriptor_pool as _descriptor_pool
|
8
|
+
from google.protobuf import symbol_database as _symbol_database
|
9
|
+
from google.protobuf.internal import builder as _builder
|
10
|
+
# @@protoc_insertion_point(imports)
|
11
|
+
|
12
|
+
_sym_db = _symbol_database.Default()
|
13
|
+
|
14
|
+
|
15
|
+
from flwr.proto import node_pb2 as flwr_dot_proto_dot_node__pb2
|
16
|
+
from flwr.proto import task_pb2 as flwr_dot_proto_dot_task__pb2
|
17
|
+
from flwr.proto import run_pb2 as flwr_dot_proto_dot_run__pb2
|
18
|
+
from flwr.proto import fab_pb2 as flwr_dot_proto_dot_fab__pb2
|
19
|
+
from flwr.proto import message_pb2 as flwr_dot_proto_dot_message__pb2
|
20
|
+
|
21
|
+
|
22
|
+
DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x16\x66lwr/proto/fleet.proto\x12\nflwr.proto\x1a\x15\x66lwr/proto/node.proto\x1a\x15\x66lwr/proto/task.proto\x1a\x14\x66lwr/proto/run.proto\x1a\x14\x66lwr/proto/fab.proto\x1a\x18\x66lwr/proto/message.proto\"*\n\x11\x43reateNodeRequest\x12\x15\n\rping_interval\x18\x01 \x01(\x01\"4\n\x12\x43reateNodeResponse\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\"3\n\x11\x44\x65leteNodeRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\"\x14\n\x12\x44\x65leteNodeResponse\"D\n\x0bPingRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\x12\x15\n\rping_interval\x18\x02 \x01(\x01\"\x1f\n\x0cPingResponse\x12\x0f\n\x07success\x18\x01 \x01(\x08\"F\n\x12PullTaskInsRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\x12\x10\n\x08task_ids\x18\x02 \x03(\t\"k\n\x13PullTaskInsResponse\x12(\n\treconnect\x18\x01 \x01(\x0b\x32\x15.flwr.proto.Reconnect\x12*\n\rtask_ins_list\x18\x02 \x03(\x0b\x32\x13.flwr.proto.TaskIns\"`\n\x12PushTaskResRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\x12*\n\rtask_res_list\x18\x02 \x03(\x0b\x32\x13.flwr.proto.TaskRes\"\xae\x01\n\x13PushTaskResResponse\x12(\n\treconnect\x18\x01 \x01(\x0b\x32\x15.flwr.proto.Reconnect\x12=\n\x07results\x18\x02 \x03(\x0b\x32,.flwr.proto.PushTaskResResponse.ResultsEntry\x1a.\n\x0cResultsEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12\r\n\x05value\x18\x02 \x01(\r:\x02\x38\x01\"J\n\x13PullMessagesRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\x12\x13\n\x0bmessage_ids\x18\x02 \x03(\t\"l\n\x14PullMessagesResponse\x12(\n\treconnect\x18\x01 \x01(\x0b\x32\x15.flwr.proto.Reconnect\x12*\n\rmessages_list\x18\x02 \x03(\x0b\x32\x13.flwr.proto.Message\"a\n\x13PushMessagesRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\x12*\n\rmessages_list\x18\x02 \x03(\x0b\x32\x13.flwr.proto.Message\"\xb0\x01\n\x14PushMessagesResponse\x12(\n\treconnect\x18\x01 \x01(\x0b\x32\x15.flwr.proto.Reconnect\x12>\n\x07results\x18\x02 \x03(\x0b\x32-.flwr.proto.PushMessagesResponse.ResultsEntry\x1a.\n\x0cResultsEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12\r\n\x05value\x18\x02 \x01(\r:\x02\x38\x01\"\x1e\n\tReconnect\x12\x11\n\treconnect\x18\x01 \x01(\x04\x32\xb6\x05\n\x05\x46leet\x12M\n\nCreateNode\x12\x1d.flwr.proto.CreateNodeRequest\x1a\x1e.flwr.proto.CreateNodeResponse\"\x00\x12M\n\nDeleteNode\x12\x1d.flwr.proto.DeleteNodeRequest\x1a\x1e.flwr.proto.DeleteNodeResponse\"\x00\x12;\n\x04Ping\x12\x17.flwr.proto.PingRequest\x1a\x18.flwr.proto.PingResponse\"\x00\x12P\n\x0bPullTaskIns\x12\x1e.flwr.proto.PullTaskInsRequest\x1a\x1f.flwr.proto.PullTaskInsResponse\"\x00\x12S\n\x0cPullMessages\x12\x1f.flwr.proto.PullMessagesRequest\x1a .flwr.proto.PullMessagesResponse\"\x00\x12P\n\x0bPushTaskRes\x12\x1e.flwr.proto.PushTaskResRequest\x1a\x1f.flwr.proto.PushTaskResResponse\"\x00\x12S\n\x0cPushMessages\x12\x1f.flwr.proto.PushMessagesRequest\x1a .flwr.proto.PushMessagesResponse\"\x00\x12\x41\n\x06GetRun\x12\x19.flwr.proto.GetRunRequest\x1a\x1a.flwr.proto.GetRunResponse\"\x00\x12\x41\n\x06GetFab\x12\x19.flwr.proto.GetFabRequest\x1a\x1a.flwr.proto.GetFabResponse\"\x00\x62\x06proto3')
|
23
|
+
|
24
|
+
_globals = globals()
|
25
|
+
_builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
|
26
|
+
_builder.BuildTopDescriptorsAndMessages(DESCRIPTOR, 'flwr.proto.fleet_pb2', _globals)
|
27
|
+
if _descriptor._USE_C_DESCRIPTORS == False:
|
28
|
+
DESCRIPTOR._options = None
|
29
|
+
_globals['_PUSHTASKRESRESPONSE_RESULTSENTRY']._options = None
|
30
|
+
_globals['_PUSHTASKRESRESPONSE_RESULTSENTRY']._serialized_options = b'8\001'
|
31
|
+
_globals['_PUSHMESSAGESRESPONSE_RESULTSENTRY']._options = None
|
32
|
+
_globals['_PUSHMESSAGESRESPONSE_RESULTSENTRY']._serialized_options = b'8\001'
|
33
|
+
_globals['_CREATENODEREQUEST']._serialized_start=154
|
34
|
+
_globals['_CREATENODEREQUEST']._serialized_end=196
|
35
|
+
_globals['_CREATENODERESPONSE']._serialized_start=198
|
36
|
+
_globals['_CREATENODERESPONSE']._serialized_end=250
|
37
|
+
_globals['_DELETENODEREQUEST']._serialized_start=252
|
38
|
+
_globals['_DELETENODEREQUEST']._serialized_end=303
|
39
|
+
_globals['_DELETENODERESPONSE']._serialized_start=305
|
40
|
+
_globals['_DELETENODERESPONSE']._serialized_end=325
|
41
|
+
_globals['_PINGREQUEST']._serialized_start=327
|
42
|
+
_globals['_PINGREQUEST']._serialized_end=395
|
43
|
+
_globals['_PINGRESPONSE']._serialized_start=397
|
44
|
+
_globals['_PINGRESPONSE']._serialized_end=428
|
45
|
+
_globals['_PULLTASKINSREQUEST']._serialized_start=430
|
46
|
+
_globals['_PULLTASKINSREQUEST']._serialized_end=500
|
47
|
+
_globals['_PULLTASKINSRESPONSE']._serialized_start=502
|
48
|
+
_globals['_PULLTASKINSRESPONSE']._serialized_end=609
|
49
|
+
_globals['_PUSHTASKRESREQUEST']._serialized_start=611
|
50
|
+
_globals['_PUSHTASKRESREQUEST']._serialized_end=707
|
51
|
+
_globals['_PUSHTASKRESRESPONSE']._serialized_start=710
|
52
|
+
_globals['_PUSHTASKRESRESPONSE']._serialized_end=884
|
53
|
+
_globals['_PUSHTASKRESRESPONSE_RESULTSENTRY']._serialized_start=838
|
54
|
+
_globals['_PUSHTASKRESRESPONSE_RESULTSENTRY']._serialized_end=884
|
55
|
+
_globals['_PULLMESSAGESREQUEST']._serialized_start=886
|
56
|
+
_globals['_PULLMESSAGESREQUEST']._serialized_end=960
|
57
|
+
_globals['_PULLMESSAGESRESPONSE']._serialized_start=962
|
58
|
+
_globals['_PULLMESSAGESRESPONSE']._serialized_end=1070
|
59
|
+
_globals['_PUSHMESSAGESREQUEST']._serialized_start=1072
|
60
|
+
_globals['_PUSHMESSAGESREQUEST']._serialized_end=1169
|
61
|
+
_globals['_PUSHMESSAGESRESPONSE']._serialized_start=1172
|
62
|
+
_globals['_PUSHMESSAGESRESPONSE']._serialized_end=1348
|
63
|
+
_globals['_PUSHMESSAGESRESPONSE_RESULTSENTRY']._serialized_start=838
|
64
|
+
_globals['_PUSHMESSAGESRESPONSE_RESULTSENTRY']._serialized_end=884
|
65
|
+
_globals['_RECONNECT']._serialized_start=1350
|
66
|
+
_globals['_RECONNECT']._serialized_end=1380
|
67
|
+
_globals['_FLEET']._serialized_start=1383
|
68
|
+
_globals['_FLEET']._serialized_end=2077
|
69
|
+
# @@protoc_insertion_point(module_scope)
|