flwr-nightly 1.23.0.dev20250930__py3-none-any.whl → 1.26.0.dev20260121__py3-none-any.whl
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/__init__.py +17 -6
- flwr/app/__init__.py +4 -1
- flwr/app/error.py +2 -2
- flwr/app/exception.py +3 -3
- flwr/app/message_type.py +29 -0
- flwr/app/metadata.py +5 -2
- flwr/app/user_config.py +19 -0
- flwr/cli/app.py +62 -9
- flwr/cli/{new/templates/app/code → app_cmd}/__init__.py +9 -1
- flwr/cli/app_cmd/publish.py +285 -0
- flwr/cli/app_cmd/review.py +262 -0
- flwr/cli/auth_plugin/__init__.py +13 -6
- flwr/cli/auth_plugin/auth_plugin.py +26 -15
- flwr/cli/auth_plugin/noop_auth_plugin.py +101 -0
- flwr/cli/auth_plugin/oidc_cli_plugin.py +52 -32
- flwr/cli/build.py +166 -53
- flwr/cli/{cli_user_auth_interceptor.py → cli_account_auth_interceptor.py} +27 -10
- flwr/cli/config/__init__.py +21 -0
- flwr/cli/config/ls.py +104 -0
- flwr/cli/config_migration.py +300 -0
- flwr/cli/config_utils.py +154 -13
- flwr/cli/constant.py +67 -0
- flwr/cli/{new/templates/app/code/flwr_tune → federation}/__init__.py +8 -1
- flwr/cli/federation/ls.py +361 -0
- flwr/cli/flower_config.py +447 -0
- flwr/cli/install.py +91 -13
- flwr/cli/log.py +65 -36
- flwr/cli/login/login.py +41 -27
- flwr/cli/ls.py +232 -158
- flwr/cli/new/new.py +188 -244
- flwr/cli/pull.py +25 -34
- flwr/cli/run/run.py +106 -74
- flwr/cli/run_utils.py +148 -0
- flwr/cli/stop.py +46 -37
- flwr/cli/supernode/__init__.py +25 -0
- flwr/cli/supernode/ls.py +273 -0
- flwr/cli/supernode/register.py +190 -0
- flwr/cli/supernode/unregister.py +140 -0
- flwr/cli/typing.py +211 -0
- flwr/cli/utils.py +428 -80
- flwr/client/__init__.py +2 -1
- flwr/client/dpfedavg_numpy_client.py +4 -1
- flwr/client/grpc_adapter_client/connection.py +14 -17
- flwr/client/grpc_rere_client/connection.py +73 -43
- flwr/client/grpc_rere_client/grpc_adapter.py +35 -15
- flwr/client/grpc_rere_client/{client_interceptor.py → node_auth_client_interceptor.py} +5 -7
- flwr/client/message_handler/message_handler.py +4 -3
- flwr/client/mod/centraldp_mods.py +1 -1
- flwr/client/mod/localdp_mod.py +1 -1
- flwr/client/mod/secure_aggregation/secaggplus_mod.py +11 -9
- flwr/client/numpy_client.py +1 -1
- flwr/client/rest_client/connection.py +99 -54
- flwr/client/run_info_store.py +6 -6
- flwr/client/typing.py +1 -1
- flwr/clientapp/__init__.py +1 -2
- flwr/{client → clientapp}/client_app.py +11 -11
- flwr/clientapp/mod/centraldp_mods.py +16 -17
- flwr/clientapp/mod/localdp_mod.py +8 -9
- flwr/clientapp/typing.py +1 -1
- flwr/{client/clientapp → clientapp}/utils.py +4 -4
- flwr/common/__init__.py +3 -2
- flwr/common/args.py +3 -4
- flwr/common/config.py +15 -17
- flwr/common/constant.py +56 -28
- flwr/common/context.py +2 -1
- flwr/common/differential_privacy.py +3 -4
- flwr/common/event_log_plugin/event_log_plugin.py +3 -4
- flwr/common/exit/exit.py +16 -3
- flwr/common/exit/exit_code.py +39 -10
- flwr/common/exit/exit_handler.py +6 -2
- flwr/common/exit/signal_handler.py +5 -5
- flwr/common/grpc.py +8 -7
- flwr/common/inflatable_protobuf_utils.py +1 -1
- flwr/common/inflatable_utils.py +48 -31
- flwr/common/logger.py +19 -19
- flwr/common/message.py +5 -5
- flwr/common/object_ref.py +7 -7
- flwr/common/record/array.py +6 -6
- flwr/common/record/arrayrecord.py +18 -21
- flwr/common/record/configrecord.py +3 -3
- flwr/common/record/recorddict.py +5 -5
- flwr/common/record/typeddict.py +9 -2
- flwr/common/recorddict_compat.py +7 -10
- flwr/common/retry_invoker.py +20 -20
- flwr/common/secure_aggregation/crypto/symmetric_encryption.py +1 -89
- flwr/common/secure_aggregation/ndarrays_arithmetic.py +8 -5
- flwr/common/serde.py +22 -11
- flwr/common/serde_utils.py +2 -2
- flwr/common/telemetry.py +10 -6
- flwr/common/typing.py +65 -44
- flwr/compat/client/app.py +45 -47
- flwr/compat/client/grpc_client/connection.py +15 -14
- flwr/compat/common/constant.py +29 -0
- flwr/compat/server/app.py +6 -7
- flwr/proto/appio_pb2.py +13 -3
- flwr/proto/appio_pb2.pyi +134 -65
- flwr/proto/appio_pb2_grpc.py +20 -0
- flwr/proto/appio_pb2_grpc.pyi +27 -0
- flwr/proto/clientappio_pb2.py +17 -7
- flwr/proto/clientappio_pb2.pyi +15 -0
- flwr/proto/clientappio_pb2_grpc.py +206 -40
- flwr/proto/clientappio_pb2_grpc.pyi +168 -53
- flwr/proto/control_pb2.py +72 -40
- flwr/proto/control_pb2.pyi +319 -87
- flwr/proto/control_pb2_grpc.py +339 -28
- flwr/proto/control_pb2_grpc.pyi +209 -37
- flwr/proto/error_pb2.py +13 -3
- flwr/proto/error_pb2.pyi +24 -6
- flwr/proto/error_pb2_grpc.py +20 -0
- flwr/proto/error_pb2_grpc.pyi +27 -0
- flwr/proto/fab_pb2.py +24 -10
- flwr/proto/fab_pb2.pyi +68 -20
- flwr/proto/fab_pb2_grpc.py +20 -0
- flwr/proto/fab_pb2_grpc.pyi +27 -0
- flwr/proto/federation_pb2.py +38 -0
- flwr/proto/federation_pb2.pyi +56 -0
- flwr/proto/federation_pb2_grpc.py +24 -0
- flwr/proto/federation_pb2_grpc.pyi +31 -0
- flwr/proto/fleet_pb2.py +45 -27
- flwr/proto/fleet_pb2.pyi +190 -70
- flwr/proto/fleet_pb2_grpc.py +277 -66
- flwr/proto/fleet_pb2_grpc.pyi +201 -55
- flwr/proto/grpcadapter_pb2.py +14 -4
- flwr/proto/grpcadapter_pb2.pyi +38 -16
- flwr/proto/grpcadapter_pb2_grpc.py +35 -4
- flwr/proto/grpcadapter_pb2_grpc.pyi +38 -7
- flwr/proto/heartbeat_pb2.py +17 -7
- flwr/proto/heartbeat_pb2.pyi +51 -22
- flwr/proto/heartbeat_pb2_grpc.py +20 -0
- flwr/proto/heartbeat_pb2_grpc.pyi +27 -0
- flwr/proto/log_pb2.py +13 -3
- flwr/proto/log_pb2.pyi +34 -11
- flwr/proto/log_pb2_grpc.py +20 -0
- flwr/proto/log_pb2_grpc.pyi +27 -0
- flwr/proto/message_pb2.py +15 -5
- flwr/proto/message_pb2.pyi +154 -86
- flwr/proto/message_pb2_grpc.py +20 -0
- flwr/proto/message_pb2_grpc.pyi +27 -0
- flwr/proto/node_pb2.py +16 -4
- flwr/proto/node_pb2.pyi +77 -4
- flwr/proto/node_pb2_grpc.py +20 -0
- flwr/proto/node_pb2_grpc.pyi +27 -0
- flwr/proto/recorddict_pb2.py +13 -3
- flwr/proto/recorddict_pb2.pyi +184 -107
- flwr/proto/recorddict_pb2_grpc.py +20 -0
- flwr/proto/recorddict_pb2_grpc.pyi +27 -0
- flwr/proto/run_pb2.py +40 -31
- flwr/proto/run_pb2.pyi +158 -84
- flwr/proto/run_pb2_grpc.py +20 -0
- flwr/proto/run_pb2_grpc.pyi +27 -0
- flwr/proto/serverappio_pb2.py +13 -3
- flwr/proto/serverappio_pb2.pyi +32 -8
- flwr/proto/serverappio_pb2_grpc.py +246 -65
- flwr/proto/serverappio_pb2_grpc.pyi +221 -85
- flwr/proto/simulationio_pb2.py +16 -8
- flwr/proto/simulationio_pb2.pyi +15 -0
- flwr/proto/simulationio_pb2_grpc.py +162 -41
- flwr/proto/simulationio_pb2_grpc.pyi +149 -55
- flwr/proto/transport_pb2.py +20 -10
- flwr/proto/transport_pb2.pyi +249 -160
- flwr/proto/transport_pb2_grpc.py +35 -4
- flwr/proto/transport_pb2_grpc.pyi +38 -8
- flwr/server/app.py +175 -128
- flwr/server/client_manager.py +4 -5
- flwr/server/client_proxy.py +10 -11
- flwr/server/compat/app.py +4 -5
- flwr/server/compat/app_utils.py +2 -1
- flwr/server/compat/grid_client_proxy.py +12 -13
- flwr/server/compat/legacy_context.py +3 -4
- flwr/server/fleet_event_log_interceptor.py +2 -1
- flwr/server/grid/grid.py +2 -3
- flwr/server/grid/grpc_grid.py +12 -10
- flwr/server/grid/inmemory_grid.py +4 -4
- flwr/server/run_serverapp.py +2 -3
- flwr/server/server.py +34 -39
- flwr/server/server_app.py +7 -8
- flwr/server/server_config.py +1 -2
- flwr/server/serverapp/app.py +34 -28
- flwr/server/serverapp_components.py +4 -5
- flwr/server/strategy/aggregate.py +9 -8
- flwr/server/strategy/bulyan.py +13 -11
- flwr/server/strategy/dp_adaptive_clipping.py +16 -20
- flwr/server/strategy/dp_fixed_clipping.py +12 -17
- flwr/server/strategy/dpfedavg_adaptive.py +3 -4
- flwr/server/strategy/dpfedavg_fixed.py +6 -10
- flwr/server/strategy/fault_tolerant_fedavg.py +14 -13
- flwr/server/strategy/fedadagrad.py +18 -14
- flwr/server/strategy/fedadam.py +16 -14
- flwr/server/strategy/fedavg.py +16 -17
- flwr/server/strategy/fedavg_android.py +15 -15
- flwr/server/strategy/fedavgm.py +21 -18
- flwr/server/strategy/fedmedian.py +2 -3
- flwr/server/strategy/fedopt.py +11 -10
- flwr/server/strategy/fedprox.py +10 -9
- flwr/server/strategy/fedtrimmedavg.py +12 -11
- flwr/server/strategy/fedxgb_bagging.py +13 -11
- flwr/server/strategy/fedxgb_cyclic.py +6 -6
- flwr/server/strategy/fedxgb_nn_avg.py +4 -4
- flwr/server/strategy/fedyogi.py +16 -14
- flwr/server/strategy/krum.py +12 -11
- flwr/server/strategy/qfedavg.py +16 -15
- flwr/server/strategy/strategy.py +6 -9
- flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py +20 -9
- flwr/server/superlink/fleet/grpc_bidi/flower_service_servicer.py +1 -2
- flwr/server/superlink/fleet/grpc_bidi/grpc_bridge.py +3 -4
- flwr/server/superlink/fleet/grpc_bidi/grpc_client_proxy.py +10 -12
- flwr/server/superlink/fleet/grpc_bidi/grpc_server.py +1 -3
- flwr/server/superlink/fleet/grpc_rere/fleet_servicer.py +136 -42
- flwr/server/superlink/fleet/grpc_rere/{server_interceptor.py → node_auth_server_interceptor.py} +28 -50
- flwr/server/superlink/fleet/message_handler/message_handler.py +141 -51
- flwr/server/superlink/fleet/rest_rere/rest_api.py +54 -33
- flwr/server/superlink/fleet/vce/backend/backend.py +2 -2
- flwr/server/superlink/fleet/vce/backend/raybackend.py +6 -6
- flwr/server/superlink/fleet/vce/vce_api.py +32 -13
- flwr/server/superlink/linkstate/__init__.py +2 -0
- flwr/server/superlink/linkstate/in_memory_linkstate.py +293 -208
- flwr/server/superlink/linkstate/linkstate.py +176 -64
- flwr/server/superlink/linkstate/linkstate_factory.py +24 -6
- flwr/server/superlink/linkstate/sql_linkstate.py +221 -0
- flwr/server/superlink/linkstate/sqlite_linkstate.py +743 -648
- flwr/server/superlink/linkstate/utils.py +11 -62
- flwr/server/superlink/serverappio/serverappio_grpc.py +1 -2
- flwr/server/superlink/serverappio/serverappio_servicer.py +28 -23
- flwr/server/superlink/simulation/simulationio_grpc.py +1 -2
- flwr/server/superlink/simulation/simulationio_servicer.py +19 -14
- flwr/server/superlink/utils.py +4 -6
- flwr/server/typing.py +1 -1
- flwr/server/utils/tensorboard.py +15 -8
- flwr/server/utils/validator.py +2 -3
- flwr/server/workflow/default_workflows.py +7 -6
- flwr/server/workflow/secure_aggregation/secagg_workflow.py +2 -4
- flwr/server/workflow/secure_aggregation/secaggplus_workflow.py +13 -11
- flwr/serverapp/strategy/bulyan.py +16 -15
- flwr/serverapp/strategy/dp_adaptive_clipping.py +12 -11
- flwr/serverapp/strategy/dp_fixed_clipping.py +11 -14
- flwr/serverapp/strategy/fedadagrad.py +10 -11
- flwr/serverapp/strategy/fedadam.py +10 -11
- flwr/serverapp/strategy/fedavg.py +10 -11
- flwr/serverapp/strategy/fedavgm.py +17 -16
- flwr/serverapp/strategy/fedmedian.py +2 -2
- flwr/serverapp/strategy/fedopt.py +10 -11
- flwr/serverapp/strategy/fedprox.py +7 -8
- flwr/serverapp/strategy/fedtrimmedavg.py +9 -9
- flwr/serverapp/strategy/fedxgb_bagging.py +3 -3
- flwr/serverapp/strategy/fedxgb_cyclic.py +10 -10
- flwr/serverapp/strategy/fedyogi.py +9 -11
- flwr/serverapp/strategy/krum.py +7 -7
- flwr/serverapp/strategy/multikrum.py +9 -9
- flwr/serverapp/strategy/qfedavg.py +17 -16
- flwr/serverapp/strategy/strategy.py +6 -9
- flwr/serverapp/strategy/strategy_utils.py +7 -8
- flwr/simulation/app.py +46 -42
- flwr/simulation/legacy_app.py +12 -12
- flwr/simulation/ray_transport/ray_actor.py +11 -12
- flwr/simulation/ray_transport/ray_client_proxy.py +14 -19
- flwr/simulation/run_simulation.py +46 -44
- flwr/simulation/simulationio_connection.py +4 -4
- flwr/{common → supercore}/address.py +1 -37
- flwr/supercore/cli/flower_superexec.py +3 -4
- flwr/supercore/constant.py +69 -0
- flwr/supercore/corestate/corestate.py +24 -3
- flwr/supercore/corestate/in_memory_corestate.py +138 -0
- flwr/supercore/corestate/sql_corestate.py +153 -0
- flwr/supercore/corestate/sqlite_corestate.py +157 -0
- flwr/supercore/credential_store/__init__.py +33 -0
- flwr/supercore/credential_store/credential_store.py +34 -0
- flwr/supercore/credential_store/file_credential_store.py +76 -0
- flwr/{common → supercore}/date.py +0 -11
- flwr/supercore/ffs/disk_ffs.py +1 -2
- flwr/supercore/ffs/ffs.py +1 -2
- flwr/supercore/ffs/ffs_factory.py +1 -2
- flwr/{common → supercore}/heartbeat.py +20 -25
- flwr/supercore/object_store/in_memory_object_store.py +1 -6
- flwr/supercore/object_store/object_store.py +1 -2
- flwr/supercore/object_store/object_store_factory.py +27 -8
- flwr/supercore/object_store/sqlite_object_store.py +253 -0
- flwr/{cli/new/templates/app → supercore/primitives}/__init__.py +1 -1
- flwr/supercore/primitives/asymmetric.py +117 -0
- flwr/supercore/primitives/asymmetric_ed25519.py +175 -0
- flwr/supercore/sql_mixin.py +292 -0
- flwr/supercore/sqlite_mixin.py +156 -0
- flwr/{client/clientapp → supercore/state}/__init__.py +2 -2
- flwr/supercore/state/schema/README.md +125 -0
- flwr/{cli/new/templates → supercore/state/schema}/__init__.py +2 -2
- flwr/supercore/state/schema/corestate_tables.py +36 -0
- flwr/supercore/state/schema/linkstate_tables.py +152 -0
- flwr/supercore/state/schema/objectstore_tables.py +90 -0
- flwr/supercore/superexec/plugin/base_exec_plugin.py +1 -2
- flwr/supercore/superexec/plugin/exec_plugin.py +3 -3
- flwr/supercore/superexec/run_superexec.py +9 -13
- flwr/supercore/utils.py +224 -0
- flwr/superlink/artifact_provider/artifact_provider.py +1 -2
- flwr/superlink/auth_plugin/__init__.py +5 -2
- flwr/superlink/auth_plugin/auth_plugin.py +20 -19
- flwr/superlink/auth_plugin/noop_auth_plugin.py +84 -0
- flwr/superlink/federation/__init__.py +24 -0
- flwr/superlink/federation/federation_manager.py +64 -0
- flwr/superlink/federation/noop_federation_manager.py +71 -0
- flwr/superlink/servicer/control/{control_user_auth_interceptor.py → control_account_auth_interceptor.py} +41 -32
- flwr/superlink/servicer/control/control_event_log_interceptor.py +7 -7
- flwr/superlink/servicer/control/control_grpc.py +20 -17
- flwr/superlink/servicer/control/control_license_interceptor.py +3 -3
- flwr/superlink/servicer/control/control_servicer.py +328 -68
- flwr/supernode/cli/flower_supernode.py +74 -26
- flwr/supernode/nodestate/in_memory_nodestate.py +121 -49
- flwr/supernode/nodestate/nodestate.py +52 -8
- flwr/supernode/nodestate/nodestate_factory.py +7 -4
- flwr/supernode/runtime/run_clientapp.py +43 -24
- flwr/supernode/servicer/clientappio/clientappio_servicer.py +48 -10
- flwr/supernode/start_client_internal.py +185 -57
- {flwr_nightly-1.23.0.dev20250930.dist-info → flwr_nightly-1.26.0.dev20260121.dist-info}/METADATA +10 -11
- flwr_nightly-1.26.0.dev20260121.dist-info/RECORD +411 -0
- flwr/cli/new/templates/app/.gitignore.tpl +0 -163
- flwr/cli/new/templates/app/LICENSE.tpl +0 -202
- flwr/cli/new/templates/app/README.baseline.md.tpl +0 -127
- flwr/cli/new/templates/app/README.flowertune.md.tpl +0 -68
- flwr/cli/new/templates/app/README.md.tpl +0 -37
- flwr/cli/new/templates/app/code/__init__.baseline.py.tpl +0 -1
- flwr/cli/new/templates/app/code/__init__.py.tpl +0 -1
- flwr/cli/new/templates/app/code/__init__.pytorch_legacy_api.py.tpl +0 -1
- flwr/cli/new/templates/app/code/client.baseline.py.tpl +0 -75
- flwr/cli/new/templates/app/code/client.huggingface.py.tpl +0 -93
- flwr/cli/new/templates/app/code/client.jax.py.tpl +0 -71
- flwr/cli/new/templates/app/code/client.mlx.py.tpl +0 -102
- flwr/cli/new/templates/app/code/client.numpy.py.tpl +0 -46
- flwr/cli/new/templates/app/code/client.pytorch.py.tpl +0 -80
- flwr/cli/new/templates/app/code/client.pytorch_legacy_api.py.tpl +0 -55
- flwr/cli/new/templates/app/code/client.sklearn.py.tpl +0 -108
- flwr/cli/new/templates/app/code/client.tensorflow.py.tpl +0 -82
- flwr/cli/new/templates/app/code/client.xgboost.py.tpl +0 -110
- flwr/cli/new/templates/app/code/dataset.baseline.py.tpl +0 -36
- flwr/cli/new/templates/app/code/flwr_tune/client_app.py.tpl +0 -92
- flwr/cli/new/templates/app/code/flwr_tune/dataset.py.tpl +0 -87
- flwr/cli/new/templates/app/code/flwr_tune/models.py.tpl +0 -56
- flwr/cli/new/templates/app/code/flwr_tune/server_app.py.tpl +0 -73
- flwr/cli/new/templates/app/code/flwr_tune/strategy.py.tpl +0 -78
- flwr/cli/new/templates/app/code/model.baseline.py.tpl +0 -66
- flwr/cli/new/templates/app/code/server.baseline.py.tpl +0 -43
- flwr/cli/new/templates/app/code/server.huggingface.py.tpl +0 -42
- flwr/cli/new/templates/app/code/server.jax.py.tpl +0 -39
- flwr/cli/new/templates/app/code/server.mlx.py.tpl +0 -41
- flwr/cli/new/templates/app/code/server.numpy.py.tpl +0 -38
- flwr/cli/new/templates/app/code/server.pytorch.py.tpl +0 -41
- flwr/cli/new/templates/app/code/server.pytorch_legacy_api.py.tpl +0 -31
- flwr/cli/new/templates/app/code/server.sklearn.py.tpl +0 -44
- flwr/cli/new/templates/app/code/server.tensorflow.py.tpl +0 -38
- flwr/cli/new/templates/app/code/server.xgboost.py.tpl +0 -56
- flwr/cli/new/templates/app/code/strategy.baseline.py.tpl +0 -1
- flwr/cli/new/templates/app/code/task.huggingface.py.tpl +0 -98
- flwr/cli/new/templates/app/code/task.jax.py.tpl +0 -57
- flwr/cli/new/templates/app/code/task.mlx.py.tpl +0 -102
- flwr/cli/new/templates/app/code/task.numpy.py.tpl +0 -7
- flwr/cli/new/templates/app/code/task.pytorch.py.tpl +0 -98
- flwr/cli/new/templates/app/code/task.pytorch_legacy_api.py.tpl +0 -111
- flwr/cli/new/templates/app/code/task.sklearn.py.tpl +0 -67
- flwr/cli/new/templates/app/code/task.tensorflow.py.tpl +0 -52
- flwr/cli/new/templates/app/code/task.xgboost.py.tpl +0 -67
- flwr/cli/new/templates/app/code/utils.baseline.py.tpl +0 -1
- flwr/cli/new/templates/app/pyproject.baseline.toml.tpl +0 -146
- flwr/cli/new/templates/app/pyproject.flowertune.toml.tpl +0 -80
- flwr/cli/new/templates/app/pyproject.huggingface.toml.tpl +0 -65
- flwr/cli/new/templates/app/pyproject.jax.toml.tpl +0 -52
- flwr/cli/new/templates/app/pyproject.mlx.toml.tpl +0 -56
- flwr/cli/new/templates/app/pyproject.numpy.toml.tpl +0 -49
- flwr/cli/new/templates/app/pyproject.pytorch.toml.tpl +0 -53
- flwr/cli/new/templates/app/pyproject.pytorch_legacy_api.toml.tpl +0 -53
- flwr/cli/new/templates/app/pyproject.sklearn.toml.tpl +0 -52
- flwr/cli/new/templates/app/pyproject.tensorflow.toml.tpl +0 -53
- flwr/cli/new/templates/app/pyproject.xgboost.toml.tpl +0 -61
- flwr/common/pyproject.py +0 -42
- flwr/supercore/object_store/utils.py +0 -43
- flwr_nightly-1.23.0.dev20250930.dist-info/RECORD +0 -429
- /flwr/{common → supercore}/version.py +0 -0
- {flwr_nightly-1.23.0.dev20250930.dist-info → flwr_nightly-1.26.0.dev20260121.dist-info}/WHEEL +0 -0
- {flwr_nightly-1.23.0.dev20250930.dist-info → flwr_nightly-1.26.0.dev20260121.dist-info}/entry_points.txt +0 -0
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
# =====================================================================
|
|
2
|
-
# For a full TOML configuration guide, check the Flower docs:
|
|
3
|
-
# https://flower.ai/docs/framework/how-to-configure-pyproject-toml.html
|
|
4
|
-
# =====================================================================
|
|
5
|
-
|
|
6
|
-
[build-system]
|
|
7
|
-
requires = ["hatchling"]
|
|
8
|
-
build-backend = "hatchling.build"
|
|
9
|
-
|
|
10
|
-
[project]
|
|
11
|
-
name = "$package_name"
|
|
12
|
-
version = "1.0.0"
|
|
13
|
-
description = ""
|
|
14
|
-
license = "Apache-2.0"
|
|
15
|
-
# Dependencies for your Flower App
|
|
16
|
-
dependencies = [
|
|
17
|
-
"flwr[simulation]>=1.23.0",
|
|
18
|
-
"flwr-datasets[vision]>=0.5.0",
|
|
19
|
-
"torch==2.7.1",
|
|
20
|
-
"torchvision==0.22.1",
|
|
21
|
-
]
|
|
22
|
-
|
|
23
|
-
[tool.hatch.build.targets.wheel]
|
|
24
|
-
packages = ["."]
|
|
25
|
-
|
|
26
|
-
[tool.flwr.app]
|
|
27
|
-
publisher = "$username"
|
|
28
|
-
|
|
29
|
-
# Point to your ServerApp and ClientApp objects
|
|
30
|
-
# Format: "<module>:<object>"
|
|
31
|
-
[tool.flwr.app.components]
|
|
32
|
-
serverapp = "$import_name.server_app:app"
|
|
33
|
-
clientapp = "$import_name.client_app:app"
|
|
34
|
-
|
|
35
|
-
# Custom config values accessible via `context.run_config`
|
|
36
|
-
[tool.flwr.app.config]
|
|
37
|
-
num-server-rounds = 3
|
|
38
|
-
fraction-fit = 0.5
|
|
39
|
-
local-epochs = 1
|
|
40
|
-
|
|
41
|
-
# Default federation to use when running the app
|
|
42
|
-
[tool.flwr.federations]
|
|
43
|
-
default = "local-simulation"
|
|
44
|
-
|
|
45
|
-
# Local simulation federation with 10 virtual SuperNodes
|
|
46
|
-
[tool.flwr.federations.local-simulation]
|
|
47
|
-
options.num-supernodes = 10
|
|
48
|
-
|
|
49
|
-
# Remote federation example for use with SuperLink
|
|
50
|
-
[tool.flwr.federations.remote-federation]
|
|
51
|
-
address = "<SUPERLINK-ADDRESS>:<PORT>"
|
|
52
|
-
insecure = true # Remove this line to enable TLS
|
|
53
|
-
# root-certificates = "<PATH/TO/ca.crt>" # For TLS setup
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
# =====================================================================
|
|
2
|
-
# For a full TOML configuration guide, check the Flower docs:
|
|
3
|
-
# https://flower.ai/docs/framework/how-to-configure-pyproject-toml.html
|
|
4
|
-
# =====================================================================
|
|
5
|
-
|
|
6
|
-
[build-system]
|
|
7
|
-
requires = ["hatchling"]
|
|
8
|
-
build-backend = "hatchling.build"
|
|
9
|
-
|
|
10
|
-
[project]
|
|
11
|
-
name = "$package_name"
|
|
12
|
-
version = "1.0.0"
|
|
13
|
-
description = ""
|
|
14
|
-
license = "Apache-2.0"
|
|
15
|
-
# Dependencies for your Flower App
|
|
16
|
-
dependencies = [
|
|
17
|
-
"flwr[simulation]>=1.23.0",
|
|
18
|
-
"flwr-datasets[vision]>=0.5.0",
|
|
19
|
-
"scikit-learn>=1.6.1",
|
|
20
|
-
]
|
|
21
|
-
|
|
22
|
-
[tool.hatch.build.targets.wheel]
|
|
23
|
-
packages = ["."]
|
|
24
|
-
|
|
25
|
-
[tool.flwr.app]
|
|
26
|
-
publisher = "$username"
|
|
27
|
-
|
|
28
|
-
# Point to your ServerApp and ClientApp objects
|
|
29
|
-
# Format: "<module>:<object>"
|
|
30
|
-
[tool.flwr.app.components]
|
|
31
|
-
serverapp = "$import_name.server_app:app"
|
|
32
|
-
clientapp = "$import_name.client_app:app"
|
|
33
|
-
|
|
34
|
-
# Custom config values accessible via `context.run_config`
|
|
35
|
-
[tool.flwr.app.config]
|
|
36
|
-
num-server-rounds = 3
|
|
37
|
-
penalty = "l2"
|
|
38
|
-
local-epochs = 1
|
|
39
|
-
|
|
40
|
-
# Default federation to use when running the app
|
|
41
|
-
[tool.flwr.federations]
|
|
42
|
-
default = "local-simulation"
|
|
43
|
-
|
|
44
|
-
# Local simulation federation with 10 virtual SuperNodes
|
|
45
|
-
[tool.flwr.federations.local-simulation]
|
|
46
|
-
options.num-supernodes = 10
|
|
47
|
-
|
|
48
|
-
# Remote federation example for use with SuperLink
|
|
49
|
-
[tool.flwr.federations.remote-federation]
|
|
50
|
-
address = "<SUPERLINK-ADDRESS>:<PORT>"
|
|
51
|
-
insecure = true # Remove this line to enable TLS
|
|
52
|
-
# root-certificates = "<PATH/TO/ca.crt>" # For TLS setup
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
# =====================================================================
|
|
2
|
-
# For a full TOML configuration guide, check the Flower docs:
|
|
3
|
-
# https://flower.ai/docs/framework/how-to-configure-pyproject-toml.html
|
|
4
|
-
# =====================================================================
|
|
5
|
-
|
|
6
|
-
[build-system]
|
|
7
|
-
requires = ["hatchling"]
|
|
8
|
-
build-backend = "hatchling.build"
|
|
9
|
-
|
|
10
|
-
[project]
|
|
11
|
-
name = "$package_name"
|
|
12
|
-
version = "1.0.0"
|
|
13
|
-
description = ""
|
|
14
|
-
license = "Apache-2.0"
|
|
15
|
-
# Dependencies for your Flower App
|
|
16
|
-
dependencies = [
|
|
17
|
-
"flwr[simulation]>=1.23.0",
|
|
18
|
-
"flwr-datasets[vision]>=0.5.0",
|
|
19
|
-
"tensorflow>=2.11.1,<2.18.0",
|
|
20
|
-
]
|
|
21
|
-
|
|
22
|
-
[tool.hatch.build.targets.wheel]
|
|
23
|
-
packages = ["."]
|
|
24
|
-
|
|
25
|
-
[tool.flwr.app]
|
|
26
|
-
publisher = "$username"
|
|
27
|
-
|
|
28
|
-
# Point to your ServerApp and ClientApp objects
|
|
29
|
-
# Format: "<module>:<object>"
|
|
30
|
-
[tool.flwr.app.components]
|
|
31
|
-
serverapp = "$import_name.server_app:app"
|
|
32
|
-
clientapp = "$import_name.client_app:app"
|
|
33
|
-
|
|
34
|
-
# Custom config values accessible via `context.run_config`
|
|
35
|
-
[tool.flwr.app.config]
|
|
36
|
-
num-server-rounds = 3
|
|
37
|
-
local-epochs = 1
|
|
38
|
-
batch-size = 32
|
|
39
|
-
verbose = false
|
|
40
|
-
|
|
41
|
-
# Default federation to use when running the app
|
|
42
|
-
[tool.flwr.federations]
|
|
43
|
-
default = "local-simulation"
|
|
44
|
-
|
|
45
|
-
# Local simulation federation with 10 virtual SuperNodes
|
|
46
|
-
[tool.flwr.federations.local-simulation]
|
|
47
|
-
options.num-supernodes = 10
|
|
48
|
-
|
|
49
|
-
# Remote federation example for use with SuperLink
|
|
50
|
-
[tool.flwr.federations.remote-federation]
|
|
51
|
-
address = "<SUPERLINK-ADDRESS>:<PORT>"
|
|
52
|
-
insecure = true # Remove this line to enable TLS
|
|
53
|
-
# root-certificates = "<PATH/TO/ca.crt>" # For TLS setup
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
# =====================================================================
|
|
2
|
-
# For a full TOML configuration guide, check the Flower docs:
|
|
3
|
-
# https://flower.ai/docs/framework/how-to-configure-pyproject-toml.html
|
|
4
|
-
# =====================================================================
|
|
5
|
-
|
|
6
|
-
[build-system]
|
|
7
|
-
requires = ["hatchling"]
|
|
8
|
-
build-backend = "hatchling.build"
|
|
9
|
-
|
|
10
|
-
[project]
|
|
11
|
-
name = "$package_name"
|
|
12
|
-
version = "1.0.0"
|
|
13
|
-
description = ""
|
|
14
|
-
license = "Apache-2.0"
|
|
15
|
-
# Dependencies for your Flower App
|
|
16
|
-
dependencies = [
|
|
17
|
-
"flwr[simulation]>=1.23.0",
|
|
18
|
-
"flwr-datasets>=0.5.0",
|
|
19
|
-
"xgboost>=2.0.0",
|
|
20
|
-
]
|
|
21
|
-
|
|
22
|
-
[tool.hatch.build.targets.wheel]
|
|
23
|
-
packages = ["."]
|
|
24
|
-
|
|
25
|
-
[tool.flwr.app]
|
|
26
|
-
publisher = "$username"
|
|
27
|
-
|
|
28
|
-
[tool.flwr.app.components]
|
|
29
|
-
serverapp = "$import_name.server_app:app"
|
|
30
|
-
clientapp = "$import_name.client_app:app"
|
|
31
|
-
|
|
32
|
-
# Custom config values accessible via `context.run_config`
|
|
33
|
-
[tool.flwr.app.config]
|
|
34
|
-
num-server-rounds = 3
|
|
35
|
-
fraction-train = 0.1
|
|
36
|
-
fraction-evaluate = 0.1
|
|
37
|
-
local-epochs = 1
|
|
38
|
-
|
|
39
|
-
# XGBoost parameters
|
|
40
|
-
params.objective = "binary:logistic"
|
|
41
|
-
params.eta = 0.1 # Learning rate
|
|
42
|
-
params.max-depth = 8
|
|
43
|
-
params.eval-metric = "auc"
|
|
44
|
-
params.nthread = 16
|
|
45
|
-
params.num-parallel-tree = 1
|
|
46
|
-
params.subsample = 1
|
|
47
|
-
params.tree-method = "hist"
|
|
48
|
-
|
|
49
|
-
# Default federation to use when running the app
|
|
50
|
-
[tool.flwr.federations]
|
|
51
|
-
default = "local-simulation"
|
|
52
|
-
|
|
53
|
-
# Local simulation federation with 10 virtual SuperNodes
|
|
54
|
-
[tool.flwr.federations.local-simulation]
|
|
55
|
-
options.num-supernodes = 10
|
|
56
|
-
|
|
57
|
-
# Remote federation example for use with SuperLink
|
|
58
|
-
[tool.flwr.federations.remote-federation]
|
|
59
|
-
address = "<SUPERLINK-ADDRESS>:<PORT>"
|
|
60
|
-
insecure = true # Remove this line to enable TLS
|
|
61
|
-
# root-certificates = "<PATH/TO/ca.crt>" # For TLS setup
|
flwr/common/pyproject.py
DELETED
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
# Copyright 2025 Flower Labs GmbH. All Rights Reserved.
|
|
2
|
-
#
|
|
3
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
4
|
-
# you may not use this file except in compliance with the License.
|
|
5
|
-
# You may obtain a copy of the License at
|
|
6
|
-
#
|
|
7
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
|
8
|
-
#
|
|
9
|
-
# Unless required by applicable law or agreed to in writing, software
|
|
10
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
11
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
|
-
# See the License for the specific language governing permissions and
|
|
13
|
-
# limitations under the License.
|
|
14
|
-
# ==============================================================================
|
|
15
|
-
"""Validates the project's name property."""
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
import re
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
def validate_project_name(name: str) -> bool:
|
|
22
|
-
"""Validate the project name against PEP 621 and PEP 503 specifications.
|
|
23
|
-
|
|
24
|
-
Conventions at a glance:
|
|
25
|
-
- Must be lowercase
|
|
26
|
-
- Must not contain special characters
|
|
27
|
-
- Must use hyphens(recommended) or underscores. No spaces.
|
|
28
|
-
- Recommended to be no more than 40 characters long (But it can be)
|
|
29
|
-
|
|
30
|
-
Parameters
|
|
31
|
-
----------
|
|
32
|
-
name : str
|
|
33
|
-
The project name to validate.
|
|
34
|
-
|
|
35
|
-
Returns
|
|
36
|
-
-------
|
|
37
|
-
bool
|
|
38
|
-
True if the name is valid, False otherwise.
|
|
39
|
-
"""
|
|
40
|
-
if not name or len(name) > 40 or not re.match(r"^[a-z0-9-_]+$", name):
|
|
41
|
-
return False
|
|
42
|
-
return True
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
# Copyright 2025 Flower Labs GmbH. All Rights Reserved.
|
|
2
|
-
#
|
|
3
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
4
|
-
# you may not use this file except in compliance with the License.
|
|
5
|
-
# You may obtain a copy of the License at
|
|
6
|
-
#
|
|
7
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
|
8
|
-
#
|
|
9
|
-
# Unless required by applicable law or agreed to in writing, software
|
|
10
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
11
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
|
-
# See the License for the specific language governing permissions and
|
|
13
|
-
# limitations under the License.
|
|
14
|
-
# ==============================================================================
|
|
15
|
-
"""Utils for ObjectStore."""
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
from typing import Union
|
|
19
|
-
|
|
20
|
-
from flwr.proto.appio_pb2 import PushAppMessagesRequest # pylint: disable=E0611
|
|
21
|
-
from flwr.proto.fleet_pb2 import PushMessagesRequest # pylint: disable=E0611
|
|
22
|
-
|
|
23
|
-
from . import ObjectStore
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
def store_mapping_and_register_objects(
|
|
27
|
-
store: ObjectStore, request: Union[PushAppMessagesRequest, PushMessagesRequest]
|
|
28
|
-
) -> set[str]:
|
|
29
|
-
"""Store Message object to descendants mapping and preregister objects."""
|
|
30
|
-
if not request.messages_list:
|
|
31
|
-
return set()
|
|
32
|
-
objects_to_push: set[str] = set()
|
|
33
|
-
# Get run_id from the first message in the list
|
|
34
|
-
# All messages of a request should in the same run
|
|
35
|
-
run_id = request.messages_list[0].metadata.run_id
|
|
36
|
-
|
|
37
|
-
for object_tree in request.message_object_trees:
|
|
38
|
-
# Preregister
|
|
39
|
-
unavailable_obj_ids = store.preregister(run_id, object_tree)
|
|
40
|
-
# Keep track of objects that need to be pushed
|
|
41
|
-
objects_to_push |= set(unavailable_obj_ids)
|
|
42
|
-
|
|
43
|
-
return objects_to_push
|