flwr-nightly 1.10.0.dev20240705__py3-none-any.whl → 1.10.0.dev20240708__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.

Potentially problematic release.


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

Files changed (37) hide show
  1. flwr/client/app.py +9 -6
  2. flwr/client/grpc_adapter_client/connection.py +2 -1
  3. flwr/client/grpc_client/connection.py +2 -1
  4. flwr/client/grpc_rere_client/connection.py +9 -3
  5. flwr/client/rest_client/connection.py +10 -4
  6. flwr/common/config.py +75 -2
  7. flwr/common/context.py +8 -2
  8. flwr/common/logger.py +13 -0
  9. flwr/common/typing.py +1 -0
  10. flwr/proto/common_pb2.py +24 -0
  11. flwr/proto/common_pb2.pyi +7 -0
  12. flwr/proto/common_pb2_grpc.py +4 -0
  13. flwr/proto/common_pb2_grpc.pyi +4 -0
  14. flwr/proto/driver_pb2.py +23 -19
  15. flwr/proto/driver_pb2.pyi +18 -1
  16. flwr/proto/exec_pb2.py +15 -11
  17. flwr/proto/exec_pb2.pyi +19 -1
  18. flwr/proto/run_pb2.py +11 -7
  19. flwr/proto/run_pb2.pyi +19 -1
  20. flwr/server/driver/grpc_driver.py +77 -139
  21. flwr/server/run_serverapp.py +20 -12
  22. flwr/server/superlink/driver/driver_servicer.py +5 -1
  23. flwr/server/superlink/state/in_memory_state.py +10 -2
  24. flwr/server/superlink/state/sqlite_state.py +22 -7
  25. flwr/server/superlink/state/state.py +7 -2
  26. flwr/simulation/app.py +39 -24
  27. flwr/simulation/ray_transport/ray_client_proxy.py +15 -7
  28. flwr/simulation/run_simulation.py +1 -1
  29. flwr/superexec/app.py +1 -0
  30. flwr/superexec/deployment.py +16 -5
  31. flwr/superexec/exec_servicer.py +4 -1
  32. flwr/superexec/executor.py +2 -3
  33. {flwr_nightly-1.10.0.dev20240705.dist-info → flwr_nightly-1.10.0.dev20240708.dist-info}/METADATA +1 -1
  34. {flwr_nightly-1.10.0.dev20240705.dist-info → flwr_nightly-1.10.0.dev20240708.dist-info}/RECORD +37 -33
  35. {flwr_nightly-1.10.0.dev20240705.dist-info → flwr_nightly-1.10.0.dev20240708.dist-info}/LICENSE +0 -0
  36. {flwr_nightly-1.10.0.dev20240705.dist-info → flwr_nightly-1.10.0.dev20240708.dist-info}/WHEEL +0 -0
  37. {flwr_nightly-1.10.0.dev20240705.dist-info → flwr_nightly-1.10.0.dev20240708.dist-info}/entry_points.txt +0 -0
@@ -44,16 +44,22 @@ class RayActorClientProxy(ClientProxy):
44
44
  """Flower client proxy which delegates work using Ray."""
45
45
 
46
46
  def __init__(
47
- self, client_fn: ClientFnExt, cid: str, actor_pool: VirtualClientEngineActorPool
47
+ self,
48
+ client_fn: ClientFnExt,
49
+ node_id: int,
50
+ partition_id: int,
51
+ actor_pool: VirtualClientEngineActorPool,
48
52
  ):
49
- super().__init__(cid)
53
+ super().__init__(cid=str(node_id))
54
+ self.node_id = node_id
55
+ self.partition_id = partition_id
50
56
 
51
57
  def _load_app() -> ClientApp:
52
58
  return ClientApp(client_fn=client_fn)
53
59
 
54
60
  self.app_fn = _load_app
55
61
  self.actor_pool = actor_pool
56
- self.proxy_state = NodeState(partition_id=int(self.cid))
62
+ self.proxy_state = NodeState(partition_id=self.partition_id)
57
63
 
58
64
  def _submit_job(self, message: Message, timeout: Optional[float]) -> Message:
59
65
  """Sumbit a message to the ActorPool."""
@@ -67,11 +73,13 @@ class RayActorClientProxy(ClientProxy):
67
73
 
68
74
  try:
69
75
  self.actor_pool.submit_client_job(
70
- lambda a, a_fn, mssg, cid, state: a.run.remote(a_fn, mssg, cid, state),
71
- (self.app_fn, message, self.cid, state),
76
+ lambda a, a_fn, mssg, partition_id, state: a.run.remote(
77
+ a_fn, mssg, partition_id, state
78
+ ),
79
+ (self.app_fn, message, str(self.partition_id), state),
72
80
  )
73
81
  out_mssg, updated_context = self.actor_pool.get_client_result(
74
- self.cid, timeout
82
+ str(self.partition_id), timeout
75
83
  )
76
84
 
77
85
  # Update state
@@ -103,7 +111,7 @@ class RayActorClientProxy(ClientProxy):
103
111
  message_id="",
104
112
  group_id=str(group_id) if group_id is not None else "",
105
113
  src_node_id=0,
106
- dst_node_id=int(self.cid),
114
+ dst_node_id=self.node_id,
107
115
  reply_to_message="",
108
116
  ttl=timeout if timeout else DEFAULT_TTL,
109
117
  message_type=message_type,
@@ -209,7 +209,7 @@ def _main_loop(
209
209
  serverapp_th = None
210
210
  try:
211
211
  # Create run (with empty fab_id and fab_version)
212
- run_id_ = state_factory.state().create_run("", "")
212
+ run_id_ = state_factory.state().create_run("", "", {})
213
213
 
214
214
  if run_id:
215
215
  _override_run_id(state_factory, run_id_to_replace=run_id_, run_id=run_id)
flwr/superexec/app.py CHANGED
@@ -77,6 +77,7 @@ def _parse_args_run_superexec() -> argparse.ArgumentParser:
77
77
  parser.add_argument(
78
78
  "executor",
79
79
  help="For example: `deployment:exec` or `project.package.module:wrapper.exec`.",
80
+ default="flwr.superexec.deployment:executor",
80
81
  )
81
82
  parser.add_argument(
82
83
  "--address",
@@ -17,7 +17,7 @@
17
17
  import subprocess
18
18
  import sys
19
19
  from logging import ERROR, INFO
20
- from typing import Optional
20
+ from typing import Dict, Optional
21
21
 
22
22
  from typing_extensions import override
23
23
 
@@ -53,18 +53,29 @@ class DeploymentEngine(Executor):
53
53
  )
54
54
  self.stub = DriverStub(channel)
55
55
 
56
- def _create_run(self, fab_id: str, fab_version: str) -> int:
56
+ def _create_run(
57
+ self,
58
+ fab_id: str,
59
+ fab_version: str,
60
+ override_config: Dict[str, str],
61
+ ) -> int:
57
62
  if self.stub is None:
58
63
  self._connect()
59
64
 
60
65
  assert self.stub is not None
61
66
 
62
- req = CreateRunRequest(fab_id=fab_id, fab_version=fab_version)
67
+ req = CreateRunRequest(
68
+ fab_id=fab_id,
69
+ fab_version=fab_version,
70
+ override_config=override_config,
71
+ )
63
72
  res = self.stub.CreateRun(request=req)
64
73
  return int(res.run_id)
65
74
 
66
75
  @override
67
- def start_run(self, fab_file: bytes) -> Optional[RunTracker]:
76
+ def start_run(
77
+ self, fab_file: bytes, override_config: Dict[str, str]
78
+ ) -> Optional[RunTracker]:
68
79
  """Start run using the Flower Deployment Engine."""
69
80
  try:
70
81
  # Install FAB to flwr dir
@@ -79,7 +90,7 @@ class DeploymentEngine(Executor):
79
90
  )
80
91
 
81
92
  # Call SuperLink to create run
82
- run_id: int = self._create_run(fab_id, fab_version)
93
+ run_id: int = self._create_run(fab_id, fab_version, override_config)
83
94
  log(INFO, "Created run %s", str(run_id))
84
95
 
85
96
  # Start ServerApp
@@ -45,7 +45,10 @@ class ExecServicer(exec_pb2_grpc.ExecServicer):
45
45
  """Create run ID."""
46
46
  log(INFO, "ExecServicer.StartRun")
47
47
 
48
- run = self.executor.start_run(request.fab_file)
48
+ run = self.executor.start_run(
49
+ request.fab_file,
50
+ dict(request.override_config.items()),
51
+ )
49
52
 
50
53
  if run is None:
51
54
  log(ERROR, "Executor failed to start run")
@@ -17,7 +17,7 @@
17
17
  from abc import ABC, abstractmethod
18
18
  from dataclasses import dataclass
19
19
  from subprocess import Popen
20
- from typing import Optional
20
+ from typing import Dict, Optional
21
21
 
22
22
 
23
23
  @dataclass
@@ -33,8 +33,7 @@ class Executor(ABC):
33
33
 
34
34
  @abstractmethod
35
35
  def start_run(
36
- self,
37
- fab_file: bytes,
36
+ self, fab_file: bytes, override_config: Dict[str, str]
38
37
  ) -> Optional[RunTracker]:
39
38
  """Start a run using the given Flower FAB ID and version.
40
39
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: flwr-nightly
3
- Version: 1.10.0.dev20240705
3
+ Version: 1.10.0.dev20240708
4
4
  Summary: Flower: A Friendly Federated Learning Framework
5
5
  Home-page: https://flower.ai
6
6
  License: Apache-2.0
@@ -53,17 +53,17 @@ flwr/cli/run/__init__.py,sha256=oCd6HmQDx-sqver1gecgx-uMA38BLTSiiKpl7RGNceg,789
53
53
  flwr/cli/run/run.py,sha256=WsOknYnwm_iD-s6jAHxjGKbm0PgV3VZdQ04v6s4nPQY,4449
54
54
  flwr/cli/utils.py,sha256=l65Ul0YsSBPuypk0uorAtEDmLEYiUrzpCXi6zCg9mJ4,4506
55
55
  flwr/client/__init__.py,sha256=wzJZsYJIHf_8-PMzvfbinyzzjgh1UP1vLrAw2_yEbKI,1345
56
- flwr/client/app.py,sha256=NiueYu7-_2_qwb2GYnp-Lzk39gkgeNN9I36psNbjl2U,24784
56
+ flwr/client/app.py,sha256=J4O5tyOP0LDOJgaXFEli97aSbE5dy8hIirRndAUlL0k,24887
57
57
  flwr/client/client.py,sha256=Vp9UkOkoHdNfn6iMYZsj_5m_GICiFfUlKEVaLad-YhM,8183
58
58
  flwr/client/client_app.py,sha256=cvY-km3JEOWKxUio4xvksNFBk2FQQXliUfQTlDty71w,9648
59
59
  flwr/client/dpfedavg_numpy_client.py,sha256=ylZ-LpBIKmL1HCiS8kq4pkp2QGalc8rYEzDHdRG3VRQ,7435
60
60
  flwr/client/grpc_adapter_client/__init__.py,sha256=QyNWIbsq9DpyMk7oemiO1P3TBFfkfkctnJ1JoAkTl3s,742
61
- flwr/client/grpc_adapter_client/connection.py,sha256=kUObTsJ_4OwxE4tvIlWwn_iSWk2snjLWMo19tqdXo1s,3841
61
+ flwr/client/grpc_adapter_client/connection.py,sha256=jxwWnqppwpwI7c5xtGRwbiyDKRLdMP4Y6YLAwTypfeY,3864
62
62
  flwr/client/grpc_client/__init__.py,sha256=LsnbqXiJhgQcB0XzAlUQgPx011Uf7Y7yabIC1HxivJ8,735
63
- flwr/client/grpc_client/connection.py,sha256=NGPFSq98wBXpVXZlei6jlg679nL07GDwyQ4z37AzoGc,9279
63
+ flwr/client/grpc_client/connection.py,sha256=5KZ1AhKJiJsMgLoAwsyN83k8hu_XWaRbUb-ATR1RvF0,9302
64
64
  flwr/client/grpc_rere_client/__init__.py,sha256=MK-oSoV3kwUEQnIwl0GN4OpiHR7eLOrMA8ikunET130,752
65
65
  flwr/client/grpc_rere_client/client_interceptor.py,sha256=sYPEznuQPdy2BPDlvM9FK0ZRRucb4NfwUee1Z_mN82E,4954
66
- flwr/client/grpc_rere_client/connection.py,sha256=MazJNpMkatxXXcmkwNCWfCzCqMXW-nOBpvEh-hdUNEw,10157
66
+ flwr/client/grpc_rere_client/connection.py,sha256=ieIOBSrrjWVZflbLdb6KMehzs-aOdvIhcTTtfgQbT5I,10292
67
67
  flwr/client/grpc_rere_client/grpc_adapter.py,sha256=woljH8yr1pyLH4W4Azogyy7Nafn6y9DHBnDCIIVKwCw,4711
68
68
  flwr/client/heartbeat.py,sha256=cx37mJBH8LyoIN4Lks85wtqT1mnU5GulQnr4pGCvAq0,2404
69
69
  flwr/client/message_handler/__init__.py,sha256=QxxQuBNpFPTHx3KiUNvQSlqMKlEnbRR1kFfc1KVje08,719
@@ -81,22 +81,22 @@ flwr/client/node_state.py,sha256=z4ol2a20wvspTkn53q24Gnt-1csZRR8JjWnk4A_-Agk,192
81
81
  flwr/client/node_state_tests.py,sha256=fadnOTT3VAuzzs_UAbOukcuyx-oQPv2lBq92qTuUecw,2212
82
82
  flwr/client/numpy_client.py,sha256=u76GWAdHmJM88Agm2EgLQSvO8Jnk225mJTk-_TmPjFE,10283
83
83
  flwr/client/rest_client/__init__.py,sha256=5KGlp7pjc1dhNRkKlaNtUfQmg8wrRFh9lS3P3uRS-7Q,735
84
- flwr/client/rest_client/connection.py,sha256=vw264e67jq7kgqgqHLvgXFbQwoHll2yET9XKzJkXtnM,11957
84
+ flwr/client/rest_client/connection.py,sha256=nowX8_TMnaiIhBMU5f60sIOkvcS3DHOHBT_YrvCnxnw,12096
85
85
  flwr/client/supernode/__init__.py,sha256=SUhWOzcgXRNXk1V9UgB5-FaWukqqrOEajVUHEcPkwyQ,865
86
86
  flwr/client/supernode/app.py,sha256=WuTp0vt2ILyKHOCl9OUtFfdlUExt-eEUy9SOFVlJAEw,14857
87
87
  flwr/client/typing.py,sha256=RJGVF64Z0nqW-qmdFuFaY4Jig3dMUFgNhFi-5dq-8-I,1069
88
88
  flwr/common/__init__.py,sha256=4cBLNNnNTwHDnL_HCxhU5ILCSZ6fYh3A_aMBtlvHTVw,3721
89
89
  flwr/common/address.py,sha256=wRu1Luezx1PWadwV9OA_KNko01oVvbRnPqfzaDn8QOk,1882
90
- flwr/common/config.py,sha256=afI57MxKWrLzrh0rlrSxnAlMCI7crgnllouAKxznWLY,2628
90
+ flwr/common/config.py,sha256=GTmXfeCi6Xt1CTUzg8TUshOHVv2vP8X8e6uCcLBWoX4,5024
91
91
  flwr/common/constant.py,sha256=qNmxEV3_pOO7MeTAA9qwIh4KoCPStcX3Gm8GRPIRx_4,2890
92
- flwr/common/context.py,sha256=j894PRbqybFSw4Shw8DFMleDx3SUYTbtNk5xLFyNHGw,1790
92
+ flwr/common/context.py,sha256=uJ9lr-XIjFmp24vBAAOcwxXKGVZIaUzjOMD0G56V4h8,1887
93
93
  flwr/common/date.py,sha256=OcQuwpb2HxcblTqYm6H223ufop5UZw5N_fzalbpOVzY,891
94
94
  flwr/common/differential_privacy.py,sha256=WZWrL7C9XaB9l9NDkLDI5PvM7jwcoTTFu08ZVG8-M5Q,6113
95
95
  flwr/common/differential_privacy_constants.py,sha256=c7b7tqgvT7yMK0XN9ndiTBs4mQf6d3qk6K7KBZGlV4Q,1074
96
96
  flwr/common/dp.py,sha256=SZ3MtJKpjxUeQeyb2pqWSF0S_h9rZtCGYPToIxqcNj8,2004
97
97
  flwr/common/exit_handlers.py,sha256=2Nt0wLhc17KQQsLPFSRAjjhUiEFfJK6tNozdGiIY4Fs,2812
98
98
  flwr/common/grpc.py,sha256=_9838_onFLx7W6_lakUN35ziKpdcKp7fA-0jE0EhcEQ,2460
99
- flwr/common/logger.py,sha256=bFu4eOychVwwYwaaCtxQ85dmx8gUtvwp6fRk-GefXHk,7107
99
+ flwr/common/logger.py,sha256=2WW8xV49EHNTBGQP9N83ekYYLVgzjtxLYCM-m0UXwgw,7426
100
100
  flwr/common/message.py,sha256=QmFYYXA-3e9M8tGO-3NPyAI8yvdmcpdYaA_noR1DE88,13194
101
101
  flwr/common/object_ref.py,sha256=PQR0tztVOkD1nn_uGuNz4bHm7z4fwsosTsUKvWIGF5Y,6506
102
102
  flwr/common/parameter.py,sha256=-bFAUayToYDF50FZGrBC1hQYJCQDtB2bbr3ZuVLMtdE,2095
@@ -120,19 +120,23 @@ flwr/common/secure_aggregation/secaggplus_constants.py,sha256=9MF-oQh62uD7rt9VeN
120
120
  flwr/common/secure_aggregation/secaggplus_utils.py,sha256=3VssKgYF7HQIkSpROnEUoYWVt47p12PE_Rj4nYqqg04,3221
121
121
  flwr/common/serde.py,sha256=Yn83kbSf9vJndTa5ldL4DR_bL_wy_bD4lTlD3ZbB658,22250
122
122
  flwr/common/telemetry.py,sha256=IGzOp87BYReCj5bEoZS6zDSKH0aXsmhMvhHx8fdC1v0,7948
123
- flwr/common/typing.py,sha256=q1RtnEtI2jX9VGT12_ECM3euMIcjmwh1Pd1tVrYf6i8,4483
123
+ flwr/common/typing.py,sha256=2ilsaLfuQ0Okrj6PDaqzIyYiLr8RoKZiFyNUhYTvIv4,4519
124
124
  flwr/common/version.py,sha256=W1ntylR04xkCP6zeSet6sRtBn7P1cje2lOqBJgYBjJY,1349
125
125
  flwr/proto/__init__.py,sha256=hbY7JYakwZwCkYgCNlmHdc8rtvfoJbAZLalMdc--CGc,683
126
- flwr/proto/driver_pb2.py,sha256=xqEN0UxFAUl1h_S_tP8SQShNYSJt_oSdb1npMn5KfL0,3394
127
- flwr/proto/driver_pb2.pyi,sha256=uTcjWrMsNojfSYrXaXyYmXaB4E8PL5drYs2MuMgN5R8,5016
126
+ flwr/proto/common_pb2.py,sha256=uBZV8af4kxDDhJ8rAsGTHI9Iy9tIbPhsscIVXyVa5Jg,913
127
+ flwr/proto/common_pb2.pyi,sha256=XbFvpZvvrS7QcH5AFXfpRGl4hQvhd3QdKO6x0oTlCCU,165
128
+ flwr/proto/common_pb2_grpc.py,sha256=1oboBPFxaTEXt9Aw7EAj8gXHDCNMhZD2VXqocC9l_gk,159
129
+ flwr/proto/common_pb2_grpc.pyi,sha256=ff2TSiLVnG6IVQcTGzb2DIH3XRSoAvAo_RMcvbMFyc0,76
130
+ flwr/proto/driver_pb2.py,sha256=uatMt8OjAw27Fe3v4OEK1Vll3sqGAulzVJmWvXnkfyY,3911
131
+ flwr/proto/driver_pb2.pyi,sha256=tzOuzI_Pv7m35F6lMzUp4vFu1iD_kZBTXG75dm74NNk,5824
128
132
  flwr/proto/driver_pb2_grpc.py,sha256=lEaiX6MAHC-GzGSh0S6949jrYyBEB0ox6hWQgw1iOdQ,8887
129
133
  flwr/proto/driver_pb2_grpc.pyi,sha256=__NCO_mAPMZt3_X_6CUIwWzOm7TmRfghoSs6syEsyAo,2425
130
134
  flwr/proto/error_pb2.py,sha256=LarjKL90LbwkXKlhzNrDssgl4DXcvIPve8NVCXHpsKA,1084
131
135
  flwr/proto/error_pb2.pyi,sha256=ZNH4HhJTU_KfMXlyCeg8FwU-fcUYxTqEmoJPtWtHikc,734
132
136
  flwr/proto/error_pb2_grpc.py,sha256=1oboBPFxaTEXt9Aw7EAj8gXHDCNMhZD2VXqocC9l_gk,159
133
137
  flwr/proto/error_pb2_grpc.pyi,sha256=ff2TSiLVnG6IVQcTGzb2DIH3XRSoAvAo_RMcvbMFyc0,76
134
- flwr/proto/exec_pb2.py,sha256=eA1VsoMtSAtBI8uWhEiM_xO_5bY9H-TZkrwFbDgzM-8,1909
135
- flwr/proto/exec_pb2.pyi,sha256=eQ262F1-bvE60BthMh4rQOWKCRw_E4J4FEnHXtabIlc,1929
138
+ flwr/proto/exec_pb2.py,sha256=zMOZVuPqKuDfaaDBUyjYlxNBHc1XFykFwuweLTfJEhM,2419
139
+ flwr/proto/exec_pb2.pyi,sha256=we99SGJLBu7oYZp-ZkLE42gL-YSWtCis11zSdnXoWoI,2780
136
140
  flwr/proto/exec_pb2_grpc.py,sha256=faAN19XEMP8GTKrcIU6jvlWkN44n2KiUsZh_OG0sYcg,4072
137
141
  flwr/proto/exec_pb2_grpc.pyi,sha256=VrFhT1Um3Nb8UC2YqnR9GIiM-Yyx0FqaxVOWljh-G_w,1208
138
142
  flwr/proto/fab_pb2.py,sha256=k1L3z4L3pJGRIUmgt609xUe-UAtSKFwT0C7wXnb12IY,1427
@@ -155,8 +159,8 @@ flwr/proto/recordset_pb2.py,sha256=un8L0kvBcgFXQIiQweOseeIJBjlOozUvQY9uTQ42Dqo,6
155
159
  flwr/proto/recordset_pb2.pyi,sha256=NPzCJWAj1xLWzeZ_xZ6uaObQjQfWGnnqlLtn4J-SoFY,14161
156
160
  flwr/proto/recordset_pb2_grpc.py,sha256=1oboBPFxaTEXt9Aw7EAj8gXHDCNMhZD2VXqocC9l_gk,159
157
161
  flwr/proto/recordset_pb2_grpc.pyi,sha256=ff2TSiLVnG6IVQcTGzb2DIH3XRSoAvAo_RMcvbMFyc0,76
158
- flwr/proto/run_pb2.py,sha256=4URYh86fdnvlZKslj4vyqssLD9Ngq81LPauMmISn5wg,1470
159
- flwr/proto/run_pb2.pyi,sha256=gskE1cHfre7n8FEMwSzG7BlFkcDH5JjSx2CrBT5__Dk,1815
162
+ flwr/proto/run_pb2.py,sha256=813Vt7cgaAyecLaHLjf7fQCW36tYS7L-mBkJfAUxIl4,1920
163
+ flwr/proto/run_pb2.pyi,sha256=Jahn2HBPIaVIe5xM_P24hnxQSLB3yDmn0QGr3Jz8gbs,2666
160
164
  flwr/proto/run_pb2_grpc.py,sha256=1oboBPFxaTEXt9Aw7EAj8gXHDCNMhZD2VXqocC9l_gk,159
161
165
  flwr/proto/run_pb2_grpc.pyi,sha256=ff2TSiLVnG6IVQcTGzb2DIH3XRSoAvAo_RMcvbMFyc0,76
162
166
  flwr/proto/task_pb2.py,sha256=6-HLTXleiG65fhlLZdvwEW30Bcgm46KO7E1NfLrl4NI,2472
@@ -180,10 +184,10 @@ flwr/server/compat/legacy_context.py,sha256=D2s7PvQoDnTexuRmf1uG9Von7GUj4Qqyr7qL
180
184
  flwr/server/criterion.py,sha256=ypbAexbztzGUxNen9RCHF91QeqiEQix4t4Ih3E-42MM,1061
181
185
  flwr/server/driver/__init__.py,sha256=bikRv6CjTwSvYh7tf10gziU5o2YotOWhhftz2tr3KDc,886
182
186
  flwr/server/driver/driver.py,sha256=NT_yaeit7_kZEIsCEqOWPID1GrVD3ywH4xZ2wtIh5lM,5217
183
- flwr/server/driver/grpc_driver.py,sha256=Lbsxj5EHp_I1NVkUoKBcUc6ZifBeQ8OOYUsNfxsjA18,12269
187
+ flwr/server/driver/grpc_driver.py,sha256=4Azmzq4RWzcLbOqBBEF-I78krWVWZ6bT0U42S25zMvY,9659
184
188
  flwr/server/driver/inmemory_driver.py,sha256=RcK94_NtjGZ4aZDIscnU7A3Uv1u8jGx29-xcbjQvZTM,6444
185
189
  flwr/server/history.py,sha256=bBOHKyX1eQONIsUx4EUU-UnAk1i0EbEl8ioyMq_UWQ8,5063
186
- flwr/server/run_serverapp.py,sha256=-tgV2GJFmKeA1r0RT9Vubh6RXOAvlfCn9Jdz81i5OI4,8850
190
+ flwr/server/run_serverapp.py,sha256=d4kFybZBiPqUkPKusU_Nmzq6nPzds6nwt67BvndDlGQ,9142
187
191
  flwr/server/server.py,sha256=wsXsxMZ9SQ0B42nBnUlcV83NJPycgrgg5bFwcQ4BYBE,17821
188
192
  flwr/server/server_app.py,sha256=Re5Y9ftXlBRJXYHY_8TrNWsjyOUCPC5F_93H0xiZDhI,4400
189
193
  flwr/server/server_config.py,sha256=CZaHVAsMvGLjpWVcLPkiYxgJN4xfIyAiUrCI3fETKY4,1349
@@ -214,7 +218,7 @@ flwr/server/strategy/strategy.py,sha256=g6VoIFogEviRub6G4QsKdIp6M_Ek6GhBhqcdNx5u
214
218
  flwr/server/superlink/__init__.py,sha256=8tHYCfodUlRD8PCP9fHgvu8cz5N31A2QoRVL0jDJ15E,707
215
219
  flwr/server/superlink/driver/__init__.py,sha256=_JaRW-FdyikHc7souUrnk3mwTGViraEJCeUBY_M_ocs,712
216
220
  flwr/server/superlink/driver/driver_grpc.py,sha256=wMqYVeDwIc_FEfQPbCzd9p1YyIcjwiFUMX4QZjGSx5k,1932
217
- flwr/server/superlink/driver/driver_servicer.py,sha256=LdMQ-CzgXT7gQgkxUB1sghml3VAnRBrpifVbOEBvSeI,5347
221
+ flwr/server/superlink/driver/driver_servicer.py,sha256=SY7YPr7GeHnN_bv6drXnfd8n3PztKBde96ixE_ua2VM,5433
218
222
  flwr/server/superlink/fleet/__init__.py,sha256=76od-HhYjOUoZFLFDFCFnNHI4JLAmaXQEAyp7LWlQpc,711
219
223
  flwr/server/superlink/fleet/grpc_adapter/__init__.py,sha256=spBQQJeYz8zPOBOfyMLv87kqWPASGB73AymcLXdFaYA,742
220
224
  flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py,sha256=K4LkOsVzIdsR7Py_9cfo6CR-bDocpP15ktHTc2UnJ9k,4957
@@ -236,9 +240,9 @@ flwr/server/superlink/fleet/vce/backend/backend.py,sha256=LJsKl7oixVvptcG98Rd9ej
236
240
  flwr/server/superlink/fleet/vce/backend/raybackend.py,sha256=dwaebZfzvzlvjkMflH5hJ19-Sszvxt0AWwIEGk9BliU,7495
237
241
  flwr/server/superlink/fleet/vce/vce_api.py,sha256=skPxli2QKTn-zElEt7lak5Q4N5v8NZB-EeROKac2bAs,12387
238
242
  flwr/server/superlink/state/__init__.py,sha256=Gj2OTFLXvA-mAjBvwuKDM3rDrVaQPcIoybSa2uskMTE,1003
239
- flwr/server/superlink/state/in_memory_state.py,sha256=5bkz3oqbpPymhorCtbicxQg31RJC0vT4AT-o0Ex0LRQ,12895
240
- flwr/server/superlink/state/sqlite_state.py,sha256=tDE6fWVMwkXugy6ri75K-H5TXs-2MuBaVpFi9kKX01c,28680
241
- flwr/server/superlink/state/state.py,sha256=Ap-TzFPWTRd0a4uCq0XhE-jDPfPbzGvQEDskVOpCt98,8037
243
+ flwr/server/superlink/state/in_memory_state.py,sha256=fb-f4RGiqXON0DC7aSEMNuNIjH406BhBYrNNX5Kza2g,13061
244
+ flwr/server/superlink/state/sqlite_state.py,sha256=dO374mTkvhWQSiwbqwUXVnAYHev-j2mHaX9v8wFmmMA,29044
245
+ flwr/server/superlink/state/state.py,sha256=mwvYPLK_udk4-yV8Q2MLX5FfTlgLG0P9biyyOZGibRY,8115
242
246
  flwr/server/superlink/state/state_factory.py,sha256=Fo8pBQ1WWrVJK5TOEPZ_zgJE69_mfTGjTO6czh6571o,2021
243
247
  flwr/server/superlink/state/utils.py,sha256=155ngcaSePy7nD8X4LHgpuVok6fcH5_CPNRiFAbLWDA,2407
244
248
  flwr/server/typing.py,sha256=2zSG-KuDAgwFPuzgVjTLDaEqJ8gXXGqFR2RD-qIk730,913
@@ -252,20 +256,20 @@ flwr/server/workflow/secure_aggregation/__init__.py,sha256=3XlgDOjD_hcukTGl6Bc1B
252
256
  flwr/server/workflow/secure_aggregation/secagg_workflow.py,sha256=wpAkYPId0nfK6SgpUAtsCni4_MQLd-uqJ81tUKu3xlI,5838
253
257
  flwr/server/workflow/secure_aggregation/secaggplus_workflow.py,sha256=BRqhlnVe8CYNoUvb_KCfRXay02NTT6a-pCrMaOqAxGc,29038
254
258
  flwr/simulation/__init__.py,sha256=9x8OCkK3jpFAPJB1aeEMOddz6V58bExQPtwE8Z3q-RY,1359
255
- flwr/simulation/app.py,sha256=MKqAQAw93VmH5ILWWXu7UFxp3qzWrBV-oxKZNZus010,14420
259
+ flwr/simulation/app.py,sha256=8NDXoQ8oC11khXIGnydrsUh5JfaH7c2Fwzix8vDFK1I,15144
256
260
  flwr/simulation/ray_transport/__init__.py,sha256=wzcEEwUUlulnXsg6raCA1nGpP3LlAQDtJ8zNkCXcVbA,734
257
261
  flwr/simulation/ray_transport/ray_actor.py,sha256=bu6gEnbHYtlUxLtzjzpEUtvkQDRzl1PVMjJuCDZvfgQ,19196
258
- flwr/simulation/ray_transport/ray_client_proxy.py,sha256=jpdNk1Du67e2Y1mw14ciMRHuctOPUIN28vYJjObGXEY,6726
262
+ flwr/simulation/ray_transport/ray_client_proxy.py,sha256=zGLVebfwFhBo1CAqEQ0MtW-fPG8ark3e4n6OksFGch4,6954
259
263
  flwr/simulation/ray_transport/utils.py,sha256=TYdtfg1P9VfTdLMOJlifInGpxWHYs9UfUqIv2wfkRLA,2392
260
- flwr/simulation/run_simulation.py,sha256=m2FK0LzLSOR2HC94XDowLLwvHuIhaV6q78HsT_MKLMU,16858
264
+ flwr/simulation/run_simulation.py,sha256=7dlpFtviRsD7TncoWEqwsdZ758JQbc0Sxvxlw1mkuMg,16862
261
265
  flwr/superexec/__init__.py,sha256=9h94ogLxi6eJ3bUuJYq3E3pApThSabTPiSmPAGlTkHE,800
262
- flwr/superexec/app.py,sha256=kCCsCo51_peIMmKc4-tmiN5qO29cPqZOqqs-QVH0oA4,6097
263
- flwr/superexec/deployment.py,sha256=yWIhS8rozuDo_jQ-Uw-RX_9-Lsn3Pb2uqe7OZYjXSQ0,3733
266
+ flwr/superexec/app.py,sha256=dm0o3O6dlsk8hZHondat5QWrBh9UfKzHxn4dVrqwiRk,6151
267
+ flwr/superexec/deployment.py,sha256=xv5iQWuaMeeL0XE5KMLWq3gRU4lvsGu1-_oPIXi5x9E,3955
264
268
  flwr/superexec/exec_grpc.py,sha256=u-rztpOleqSGqgvNE-ZLw1HchNsBHU1-eB3m52GZ0pQ,1852
265
- flwr/superexec/exec_servicer.py,sha256=qf8CT4RLXnY8omOy75kwfsWmMnfTD42B4ENTh5S-BCY,2120
266
- flwr/superexec/executor.py,sha256=GouXCY2LiZ-ffsOoZ_z-fh4JwbzMmhTl-gwpWFgGWTY,1688
267
- flwr_nightly-1.10.0.dev20240705.dist-info/LICENSE,sha256=z8d0m5b2O9McPEK1xHG_dWgUBT6EfBDz6wA0F7xSPTA,11358
268
- flwr_nightly-1.10.0.dev20240705.dist-info/METADATA,sha256=LPV7BWANCuST_QSPiCC52orzDQep7FtPp2ch1vGSpoU,15614
269
- flwr_nightly-1.10.0.dev20240705.dist-info/WHEEL,sha256=FMvqSimYX_P7y0a7UY-_Mc83r5zkBZsCYPm7Lr0Bsq4,88
270
- flwr_nightly-1.10.0.dev20240705.dist-info/entry_points.txt,sha256=7qBQcA-bDGDxnJmLd9FYqglFQubjCNqyg9M8a-lukps,336
271
- flwr_nightly-1.10.0.dev20240705.dist-info/RECORD,,
269
+ flwr/superexec/exec_servicer.py,sha256=4R1f_9v0vly_bXpIYaXAeV1tO5LAy1AYygGGGNZmlQk,2194
270
+ flwr/superexec/executor.py,sha256=TMQMMf-vv0htlv6v-eEBI67J1WL3Yz7dp_Fm1lgMEyU,1718
271
+ flwr_nightly-1.10.0.dev20240708.dist-info/LICENSE,sha256=z8d0m5b2O9McPEK1xHG_dWgUBT6EfBDz6wA0F7xSPTA,11358
272
+ flwr_nightly-1.10.0.dev20240708.dist-info/METADATA,sha256=PTCizQrpDKKp9_ZqsxqP7APWdLMwsRk31PKfU-8QKgk,15614
273
+ flwr_nightly-1.10.0.dev20240708.dist-info/WHEEL,sha256=FMvqSimYX_P7y0a7UY-_Mc83r5zkBZsCYPm7Lr0Bsq4,88
274
+ flwr_nightly-1.10.0.dev20240708.dist-info/entry_points.txt,sha256=7qBQcA-bDGDxnJmLd9FYqglFQubjCNqyg9M8a-lukps,336
275
+ flwr_nightly-1.10.0.dev20240708.dist-info/RECORD,,