flwr-nightly 1.12.0.dev20240930__py3-none-any.whl → 1.12.0.dev20241002__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.
- flwr/client/grpc_rere_client/grpc_adapter.py +14 -3
- flwr/client/supernode/app.py +1 -0
- flwr/common/constant.py +6 -3
- flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py +17 -2
- {flwr_nightly-1.12.0.dev20240930.dist-info → flwr_nightly-1.12.0.dev20241002.dist-info}/METADATA +2 -2
- {flwr_nightly-1.12.0.dev20240930.dist-info → flwr_nightly-1.12.0.dev20241002.dist-info}/RECORD +9 -9
- {flwr_nightly-1.12.0.dev20240930.dist-info → flwr_nightly-1.12.0.dev20241002.dist-info}/LICENSE +0 -0
- {flwr_nightly-1.12.0.dev20240930.dist-info → flwr_nightly-1.12.0.dev20241002.dist-info}/WHEEL +0 -0
- {flwr_nightly-1.12.0.dev20240930.dist-info → flwr_nightly-1.12.0.dev20241002.dist-info}/entry_points.txt +0 -0
|
@@ -24,10 +24,14 @@ from google.protobuf.message import Message as GrpcMessage
|
|
|
24
24
|
|
|
25
25
|
from flwr.common import log
|
|
26
26
|
from flwr.common.constant import (
|
|
27
|
+
GRPC_ADAPTER_METADATA_FLOWER_PACKAGE_NAME_KEY,
|
|
28
|
+
GRPC_ADAPTER_METADATA_FLOWER_PACKAGE_VERSION_KEY,
|
|
27
29
|
GRPC_ADAPTER_METADATA_FLOWER_VERSION_KEY,
|
|
30
|
+
GRPC_ADAPTER_METADATA_MESSAGE_MODULE_KEY,
|
|
31
|
+
GRPC_ADAPTER_METADATA_MESSAGE_QUALNAME_KEY,
|
|
28
32
|
GRPC_ADAPTER_METADATA_SHOULD_EXIT_KEY,
|
|
29
33
|
)
|
|
30
|
-
from flwr.common.version import package_version
|
|
34
|
+
from flwr.common.version import package_name, package_version
|
|
31
35
|
from flwr.proto.fab_pb2 import GetFabRequest, GetFabResponse # pylint: disable=E0611
|
|
32
36
|
from flwr.proto.fleet_pb2 import ( # pylint: disable=E0611
|
|
33
37
|
CreateNodeRequest,
|
|
@@ -62,9 +66,16 @@ class GrpcAdapter:
|
|
|
62
66
|
self, request: GrpcMessage, response_type: type[T], **kwargs: Any
|
|
63
67
|
) -> T:
|
|
64
68
|
# Serialize request
|
|
69
|
+
req_cls = request.__class__
|
|
65
70
|
container_req = MessageContainer(
|
|
66
|
-
metadata={
|
|
67
|
-
|
|
71
|
+
metadata={
|
|
72
|
+
GRPC_ADAPTER_METADATA_FLOWER_PACKAGE_NAME_KEY: package_name,
|
|
73
|
+
GRPC_ADAPTER_METADATA_FLOWER_PACKAGE_VERSION_KEY: package_version,
|
|
74
|
+
GRPC_ADAPTER_METADATA_FLOWER_VERSION_KEY: package_version,
|
|
75
|
+
GRPC_ADAPTER_METADATA_MESSAGE_MODULE_KEY: req_cls.__module__,
|
|
76
|
+
GRPC_ADAPTER_METADATA_MESSAGE_QUALNAME_KEY: req_cls.__qualname__,
|
|
77
|
+
},
|
|
78
|
+
grpc_message_name=req_cls.__qualname__,
|
|
68
79
|
grpc_message_content=request.SerializeToString(),
|
|
69
80
|
)
|
|
70
81
|
|
flwr/client/supernode/app.py
CHANGED
flwr/common/constant.py
CHANGED
|
@@ -60,8 +60,6 @@ PING_MAX_INTERVAL = 1e300
|
|
|
60
60
|
# IDs
|
|
61
61
|
RUN_ID_NUM_BYTES = 8
|
|
62
62
|
NODE_ID_NUM_BYTES = 8
|
|
63
|
-
GRPC_ADAPTER_METADATA_FLOWER_VERSION_KEY = "flower-version"
|
|
64
|
-
GRPC_ADAPTER_METADATA_SHOULD_EXIT_KEY = "should-exit"
|
|
65
63
|
|
|
66
64
|
# Constants for FAB
|
|
67
65
|
APP_DIR = "apps"
|
|
@@ -72,8 +70,13 @@ FLWR_HOME = "FLWR_HOME"
|
|
|
72
70
|
PARTITION_ID_KEY = "partition-id"
|
|
73
71
|
NUM_PARTITIONS_KEY = "num-partitions"
|
|
74
72
|
|
|
75
|
-
|
|
73
|
+
# Constants for keys in `metadata` of `MessageContainer` in `grpc-adapter`
|
|
74
|
+
GRPC_ADAPTER_METADATA_FLOWER_PACKAGE_NAME_KEY = "flower-package-name"
|
|
75
|
+
GRPC_ADAPTER_METADATA_FLOWER_PACKAGE_VERSION_KEY = "flower-package-version"
|
|
76
|
+
GRPC_ADAPTER_METADATA_FLOWER_VERSION_KEY = "flower-version" # Deprecated
|
|
76
77
|
GRPC_ADAPTER_METADATA_SHOULD_EXIT_KEY = "should-exit"
|
|
78
|
+
GRPC_ADAPTER_METADATA_MESSAGE_MODULE_KEY = "grpc-message-module"
|
|
79
|
+
GRPC_ADAPTER_METADATA_MESSAGE_QUALNAME_KEY = "grpc-message-qualname"
|
|
77
80
|
|
|
78
81
|
|
|
79
82
|
class MessageType:
|
|
@@ -21,7 +21,15 @@ from typing import Callable, TypeVar
|
|
|
21
21
|
import grpc
|
|
22
22
|
from google.protobuf.message import Message as GrpcMessage
|
|
23
23
|
|
|
24
|
+
from flwr.common.constant import (
|
|
25
|
+
GRPC_ADAPTER_METADATA_FLOWER_PACKAGE_NAME_KEY,
|
|
26
|
+
GRPC_ADAPTER_METADATA_FLOWER_PACKAGE_VERSION_KEY,
|
|
27
|
+
GRPC_ADAPTER_METADATA_FLOWER_VERSION_KEY,
|
|
28
|
+
GRPC_ADAPTER_METADATA_MESSAGE_MODULE_KEY,
|
|
29
|
+
GRPC_ADAPTER_METADATA_MESSAGE_QUALNAME_KEY,
|
|
30
|
+
)
|
|
24
31
|
from flwr.common.logger import log
|
|
32
|
+
from flwr.common.version import package_name, package_version
|
|
25
33
|
from flwr.proto import grpcadapter_pb2_grpc # pylint: disable=E0611
|
|
26
34
|
from flwr.proto.fab_pb2 import GetFabRequest, GetFabResponse # pylint: disable=E0611
|
|
27
35
|
from flwr.proto.fleet_pb2 import ( # pylint: disable=E0611
|
|
@@ -52,9 +60,16 @@ def _handle(
|
|
|
52
60
|
) -> MessageContainer:
|
|
53
61
|
req = request_type.FromString(msg_container.grpc_message_content)
|
|
54
62
|
res = handler(req)
|
|
63
|
+
res_cls = res.__class__
|
|
55
64
|
return MessageContainer(
|
|
56
|
-
metadata={
|
|
57
|
-
|
|
65
|
+
metadata={
|
|
66
|
+
GRPC_ADAPTER_METADATA_FLOWER_PACKAGE_NAME_KEY: package_name,
|
|
67
|
+
GRPC_ADAPTER_METADATA_FLOWER_PACKAGE_VERSION_KEY: package_version,
|
|
68
|
+
GRPC_ADAPTER_METADATA_FLOWER_VERSION_KEY: package_version,
|
|
69
|
+
GRPC_ADAPTER_METADATA_MESSAGE_MODULE_KEY: res_cls.__module__,
|
|
70
|
+
GRPC_ADAPTER_METADATA_MESSAGE_QUALNAME_KEY: res_cls.__qualname__,
|
|
71
|
+
},
|
|
72
|
+
grpc_message_name=res_cls.__qualname__,
|
|
58
73
|
grpc_message_content=res.SerializeToString(),
|
|
59
74
|
)
|
|
60
75
|
|
{flwr_nightly-1.12.0.dev20240930.dist-info → flwr_nightly-1.12.0.dev20241002.dist-info}/METADATA
RENAMED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.1
|
|
2
2
|
Name: flwr-nightly
|
|
3
|
-
Version: 1.12.0.
|
|
3
|
+
Version: 1.12.0.dev20241002
|
|
4
4
|
Summary: Flower: A Friendly Federated Learning Framework
|
|
5
5
|
Home-page: https://flower.ai
|
|
6
6
|
License: Apache-2.0
|
|
@@ -43,7 +43,7 @@ Requires-Dist: requests (>=2.31.0,<3.0.0) ; extra == "rest"
|
|
|
43
43
|
Requires-Dist: starlette (>=0.31.0,<0.32.0) ; extra == "rest"
|
|
44
44
|
Requires-Dist: tomli (>=2.0.1,<3.0.0)
|
|
45
45
|
Requires-Dist: tomli-w (>=1.0.0,<2.0.0)
|
|
46
|
-
Requires-Dist: typer
|
|
46
|
+
Requires-Dist: typer (>=0.12.5,<0.13.0)
|
|
47
47
|
Requires-Dist: uvicorn[standard] (>=0.23.0,<0.24.0) ; extra == "rest"
|
|
48
48
|
Project-URL: Documentation, https://flower.ai
|
|
49
49
|
Project-URL: Repository, https://github.com/adap/flower
|
{flwr_nightly-1.12.0.dev20240930.dist-info → flwr_nightly-1.12.0.dev20241002.dist-info}/RECORD
RENAMED
|
@@ -77,7 +77,7 @@ flwr/client/grpc_client/connection.py,sha256=WX0cKlV_S19bYYp52z3PYRrtOdGb52ovvFF
|
|
|
77
77
|
flwr/client/grpc_rere_client/__init__.py,sha256=MK-oSoV3kwUEQnIwl0GN4OpiHR7eLOrMA8ikunET130,752
|
|
78
78
|
flwr/client/grpc_rere_client/client_interceptor.py,sha256=q08lIEeJLvvonNOiejNXvmySbPObteGnbDHhEKDmWzE,5380
|
|
79
79
|
flwr/client/grpc_rere_client/connection.py,sha256=tppAfMTV1yLBNmgS0KuvqGUjaecpA7SWbPIITkfEHcY,10960
|
|
80
|
-
flwr/client/grpc_rere_client/grpc_adapter.py,sha256=
|
|
80
|
+
flwr/client/grpc_rere_client/grpc_adapter.py,sha256=sQo0I9T65t97LFGoW_PrmgaTbd18GFgi2DoAI5wQJ4k,5589
|
|
81
81
|
flwr/client/heartbeat.py,sha256=cx37mJBH8LyoIN4Lks85wtqT1mnU5GulQnr4pGCvAq0,2404
|
|
82
82
|
flwr/client/message_handler/__init__.py,sha256=QxxQuBNpFPTHx3KiUNvQSlqMKlEnbRR1kFfc1KVje08,719
|
|
83
83
|
flwr/client/message_handler/message_handler.py,sha256=lwBUvnY21GTK9uZPyxfiAPnGav9ueKo7YmyDpzUU6-Y,6524
|
|
@@ -96,12 +96,12 @@ flwr/client/numpy_client.py,sha256=tqGyhIkeeZQGr65BR03B7TWgx4rW3FA7G2874D8z_VU,1
|
|
|
96
96
|
flwr/client/rest_client/__init__.py,sha256=5KGlp7pjc1dhNRkKlaNtUfQmg8wrRFh9lS3P3uRS-7Q,735
|
|
97
97
|
flwr/client/rest_client/connection.py,sha256=icPDYPaTMWn3bQ9g42VUHEppcIVcBJFGuV3leo7mMpo,12814
|
|
98
98
|
flwr/client/supernode/__init__.py,sha256=SUhWOzcgXRNXk1V9UgB5-FaWukqqrOEajVUHEcPkwyQ,865
|
|
99
|
-
flwr/client/supernode/app.py,sha256=
|
|
99
|
+
flwr/client/supernode/app.py,sha256=it4jm9GATntwmRJNXfIIfsS8bTIRwba94B1uNy0I2TM,11973
|
|
100
100
|
flwr/client/typing.py,sha256=dxoTBnTMfqXr5J7G3y-uNjqxYCddvxhu89spfj4Lm2U,1048
|
|
101
101
|
flwr/common/__init__.py,sha256=TVaoFEJE158aui1TPZQiJCDZX4RNHRyI8I55VC80HhI,3901
|
|
102
102
|
flwr/common/address.py,sha256=7kM2Rqjw86-c8aKwAvrXerWqznnVv4TFJ62aSAeTn10,3017
|
|
103
103
|
flwr/common/config.py,sha256=QjsDEDf4xsx8StJV9I80dYWbBp7aBNrJmTlAeLpQpyw,7567
|
|
104
|
-
flwr/common/constant.py,sha256=
|
|
104
|
+
flwr/common/constant.py,sha256=m2FkF5QzFC_72hFxDioekOHwhilPKCds1axojg77oX8,3606
|
|
105
105
|
flwr/common/context.py,sha256=5Bd9RCrhLkYZOVR7vr97OVhzVBHQkS1fUsYiIKTwpxU,2239
|
|
106
106
|
flwr/common/date.py,sha256=OcQuwpb2HxcblTqYm6H223ufop5UZw5N_fzalbpOVzY,891
|
|
107
107
|
flwr/common/differential_privacy.py,sha256=XwcJ3rWr8S8BZUocc76vLSJAXIf6OHnWkBV6-xlIRuw,6106
|
|
@@ -251,7 +251,7 @@ flwr/server/superlink/ffs/ffs.py,sha256=qLI1UfosJugu2BKOJWqHIhafTm-YiuKqGf3OGWPH
|
|
|
251
251
|
flwr/server/superlink/ffs/ffs_factory.py,sha256=N_eMuUZggotdGiDQ5r_Tf21xsu_ob0e3jyM6ag7d3kk,1490
|
|
252
252
|
flwr/server/superlink/fleet/__init__.py,sha256=76od-HhYjOUoZFLFDFCFnNHI4JLAmaXQEAyp7LWlQpc,711
|
|
253
253
|
flwr/server/superlink/fleet/grpc_adapter/__init__.py,sha256=spBQQJeYz8zPOBOfyMLv87kqWPASGB73AymcLXdFaYA,742
|
|
254
|
-
flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py,sha256=
|
|
254
|
+
flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py,sha256=kE7ejRKR-8rVJsKgvglHn78L2ok6ZJ1Y4frZvgiJvpk,6341
|
|
255
255
|
flwr/server/superlink/fleet/grpc_bidi/__init__.py,sha256=dkSKQMuMTYh1qSnuN87cAPv_mcdLg3f0PqTABHs8gUE,735
|
|
256
256
|
flwr/server/superlink/fleet/grpc_bidi/flower_service_servicer.py,sha256=xbvorZhCHBj0CvFWB7oUeHoY0o750hUkiS0DiTCGHDs,6020
|
|
257
257
|
flwr/server/superlink/fleet/grpc_bidi/grpc_bridge.py,sha256=JkAH_nIZaqe_9kntrg26od_jaz5XdLFuvNMgGu8xk9Q,6485
|
|
@@ -299,8 +299,8 @@ flwr/superexec/exec_grpc.py,sha256=ZPq7EP55Vwj0kRcLVuTCokFqfIgBk-7YmDykZoMKi-c,1
|
|
|
299
299
|
flwr/superexec/exec_servicer.py,sha256=TRpwPVl7eI0Y_xlCY6DmVpAo0yFU1gLwzyIeqFw9pyk,4746
|
|
300
300
|
flwr/superexec/executor.py,sha256=-5J-ZLs-uArro3T2pCq0YQRC65cs18M888nufzdYE4E,2375
|
|
301
301
|
flwr/superexec/simulation.py,sha256=J6pw-RqCSiUed8I_3MasZH4tl57ZmDebPAHNnbb0-vE,7420
|
|
302
|
-
flwr_nightly-1.12.0.
|
|
303
|
-
flwr_nightly-1.12.0.
|
|
304
|
-
flwr_nightly-1.12.0.
|
|
305
|
-
flwr_nightly-1.12.0.
|
|
306
|
-
flwr_nightly-1.12.0.
|
|
302
|
+
flwr_nightly-1.12.0.dev20241002.dist-info/LICENSE,sha256=z8d0m5b2O9McPEK1xHG_dWgUBT6EfBDz6wA0F7xSPTA,11358
|
|
303
|
+
flwr_nightly-1.12.0.dev20241002.dist-info/METADATA,sha256=isayq_Y0Y4YIWJZTfKBRoBdvHjap-0on_rq_1qlKGJE,15548
|
|
304
|
+
flwr_nightly-1.12.0.dev20241002.dist-info/WHEEL,sha256=FMvqSimYX_P7y0a7UY-_Mc83r5zkBZsCYPm7Lr0Bsq4,88
|
|
305
|
+
flwr_nightly-1.12.0.dev20241002.dist-info/entry_points.txt,sha256=WUCbqhLEOzjx_lyATIM0-f0e8kOVaQjzwOvyOxHrMhs,434
|
|
306
|
+
flwr_nightly-1.12.0.dev20241002.dist-info/RECORD,,
|
{flwr_nightly-1.12.0.dev20240930.dist-info → flwr_nightly-1.12.0.dev20241002.dist-info}/LICENSE
RENAMED
|
File without changes
|
{flwr_nightly-1.12.0.dev20240930.dist-info → flwr_nightly-1.12.0.dev20241002.dist-info}/WHEEL
RENAMED
|
File without changes
|
|
File without changes
|