Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Refactor/SK-936 | Clean up certs and remove /add_combiner logic #653

Merged
merged 18 commits into from
Sep 4, 2024
Merged
2 changes: 2 additions & 0 deletions .github/workflows/code-checks.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,8 @@ jobs:
--exclude-dir='flower-client'
--exclude='tests.py'
--exclude='controller_cmd.py'
--exclude='combiner_cmd.py'
--exclude='run_cmd.py'
--exclude='README.rst'
'^[ \t]+(import|from) ' -I .

Expand Down
2 changes: 2 additions & 0 deletions MANIFEST.in
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
include README.rst
include fedn/common/settings-controller.yaml.template
3 changes: 3 additions & 0 deletions config/settings-client.yaml.local.template
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
network_id: fedn-network
discover_host: localhost
discover_port: 8092
31 changes: 31 additions & 0 deletions config/settings-combiner.yaml.local.template
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
network_id: fedn-network

name: combiner
host: localhost
address: localhost
port: 12080
max_clients: 30

cert_path: tmp/server.crt
key_path: tmp/server.key

statestore:
type: MongoDB
mongo_config:
username: fedn_admin
password: password
host: localhost
port: 6534

storage:
storage_type: S3
storage_config:
storage_hostname: localhost
storage_port: 9000
storage_access_key: fedn_admin
storage_secret_key: password
storage_bucket: fedn-models
context_bucket: fedn-context
storage_secure_mode: False


19 changes: 19 additions & 0 deletions config/settings-combiner.yaml.template
Original file line number Diff line number Diff line change
Expand Up @@ -7,4 +7,23 @@ host: combiner
port: 12080
max_clients: 30

statestore:
type: MongoDB
mongo_config:
username: fedn_admin
password: password
host: mongo
port: 6534

storage:
storage_type: S3
storage_config:
storage_hostname: minio
storage_port: 9000
storage_access_key: fedn_admin
storage_secret_key: password
storage_bucket: fedn-models
context_bucket: fedn-context
storage_secure_mode: False


24 changes: 24 additions & 0 deletions config/settings-controller.yaml.local.template
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
network_id: fedn-network
controller:
host: localhost
port: 8092
debug: True

statestore:
type: MongoDB
mongo_config:
username: fedn_admin
password: password
host: localhost
port: 6534

storage:
storage_type: S3
storage_config:
storage_hostname: localhost
storage_port: 9000
storage_access_key: fedn_admin
storage_secret_key: password
storage_bucket: fedn-models
context_bucket: fedn-context
storage_secure_mode: False
2 changes: 2 additions & 0 deletions docker-compose.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,8 @@ services:
environment:
- PYTHONUNBUFFERED=0
- GET_HOSTS_FROM=dns
- STATESTORE_CONFIG=/app/config/settings-combiner.yaml
- MODELSTORAGE_CONFIG=/app/config/settings-combiner.yaml
build:
context: .
args:
Expand Down
4 changes: 2 additions & 2 deletions examples/mnist-pytorch/client/python_env.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,6 @@ build_dependencies:
- setuptools
- wheel
dependencies:
- torch==2.3.1
- torchvision==0.18.1
- torch
- torchvision
- fedn
7 changes: 3 additions & 4 deletions fedn/cli/combiner_cmd.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,17 +3,14 @@
import click
import requests

from fedn.network.combiner.combiner import Combiner

from .main import main
from .shared import CONTROLLER_DEFAULTS, apply_config, get_api_url, get_token, print_response


@main.group("combiner")
@click.pass_context
def combiner_cmd(ctx):
""":param ctx:
"""
""":param ctx:"""
pass


Expand Down Expand Up @@ -60,6 +57,8 @@ def start_cmd(ctx, discoverhost, discoverport, token, name, host, port, fqdn, se
click.echo(f"\nCombiner configuration loaded from file: {init}")
click.echo("Values set in file override defaults and command line arguments...\n")

from fedn.network.combiner.combiner import Combiner

combiner = Combiner(config)
combiner.run()

Expand Down
26 changes: 17 additions & 9 deletions fedn/cli/run_cmd.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,10 @@

import click
import yaml

from fedn.common.exceptions import InvalidClientConfig
from fedn.common.log_config import logger
from fedn.network.clients.client import Client
from fedn.network.combiner.combiner import Combiner
from fedn.utils.dispatcher import Dispatcher, _read_yaml_file

from .client_cmd import validate_client_config
Expand Down Expand Up @@ -40,15 +40,16 @@ def check_helper_config_file(config):
@main.group("run")
@click.pass_context
def run_cmd(ctx):
""":param ctx:
"""
""":param ctx:"""
pass


@run_cmd.command("validate")
@click.option("-p", "--path", required=True, help="Path to package directory containing fedn.yaml")
@click.option("-i", "--input", required=True, help="Path to input model" )
@click.option("-o", "--output", required=True,help="Path to write the output JSON containing validation metrics")
@click.option("-i", "--input", required=True, help="Path to input model")
@click.option("-o", "--output", required=True, help="Path to write the output JSON containing validation metrics")
@click.pass_context
def validate_cmd(ctx, path,input,output):
def validate_cmd(ctx, path, input, output):
"""Execute 'validate' entrypoint in fedn.yaml.

:param ctx:
Expand All @@ -75,12 +76,14 @@ def validate_cmd(ctx, path,input,output):
if dispatcher.python_env_path:
logger.info(f"Removing virtualenv {dispatcher.python_env_path}")
shutil.rmtree(dispatcher.python_env_path)


@run_cmd.command("train")
@click.option("-p", "--path", required=True, help="Path to package directory containing fedn.yaml")
@click.option("-i", "--input", required=True, help="Path to input model parameters" )
@click.option("-o", "--output", required=True,help="Path to write the updated model parameters ")
@click.option("-i", "--input", required=True, help="Path to input model parameters")
@click.option("-o", "--output", required=True, help="Path to write the updated model parameters ")
@click.pass_context
def train_cmd(ctx, path,input,output):
def train_cmd(ctx, path, input, output):
"""Execute 'train' entrypoint in fedn.yaml.

:param ctx:
Expand All @@ -107,6 +110,8 @@ def train_cmd(ctx, path,input,output):
if dispatcher.python_env_path:
logger.info(f"Removing virtualenv {dispatcher.python_env_path}")
shutil.rmtree(dispatcher.python_env_path)


@run_cmd.command("startup")
@click.option("-p", "--path", required=True, help="Path to package directory containing fedn.yaml")
@click.pass_context
Expand Down Expand Up @@ -138,6 +143,7 @@ def startup_cmd(ctx, path):
logger.info(f"Removing virtualenv {dispatcher.python_env_path}")
shutil.rmtree(dispatcher.python_env_path)


@run_cmd.command("build")
@click.option("-p", "--path", required=True, help="Path to package directory containing fedn.yaml")
@click.pass_context
Expand Down Expand Up @@ -320,5 +326,7 @@ def combiner_cmd(ctx, discoverhost, discoverport, token, name, host, port, fqdn,
click.echo(f"\nCombiner configuration loaded from file: {init}")
click.echo("Values set in file override defaults and command line arguments...\n")

from fedn.network.combiner.combiner import Combiner

combiner = Combiner(config)
combiner.run()
40 changes: 19 additions & 21 deletions fedn/common/certificate/certificate.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,24 +9,27 @@


class Certificate:
"""Utility to generate unsigned certificates.

"""
"""Utility to generate unsigned certificates."""

CERT_NAME = "cert.pem"
KEY_NAME = "key.pem"
BITS = 2048

def __init__(self, cwd, name=None, key_name="key.pem", cert_name="cert.pem", create_dirs=True):
try:
os.makedirs(cwd)
except OSError:
logger.info("Directory exists, will store all cert and keys here.")
def __init__(self, name=None, key_path="", cert_path="", create_dirs=False):
if create_dirs:
try:
cwd = os.getcwd()
os.makedirs(cwd)
except OSError:
logger.info("Directory exists, will store all cert and keys here.")
else:
logger.info("Successfully created the directory to store cert and keys in {}".format(cwd))

self.key_path = os.path.join(cwd, "key.pem")
self.cert_path = os.path.join(cwd, "cert.pem")
else:
logger.info("Successfully created the directory to store cert and keys in {}".format(cwd))

self.key_path = os.path.join(cwd, key_name)
self.cert_path = os.path.join(cwd, cert_name)
self.key_path = key_path
self.cert_path = cert_path

if name:
self.name = name
Expand All @@ -36,9 +39,7 @@ def __init__(self, cwd, name=None, key_name="key.pem", cert_name="cert.pem", cre
def gen_keypair(
self,
):
"""Generate keypair.

"""
"""Generate keypair."""
key = crypto.PKey()
key.generate_key(crypto.TYPE_RSA, 2048)
cert = crypto.X509()
Expand Down Expand Up @@ -73,25 +74,22 @@ def set_keypair_raw(self, certificate, privatekey):
certfile.write(crypto.dump_certificate(crypto.FILETYPE_PEM, certificate))

def get_keypair_raw(self):
""":return:
"""
""":return:"""
with open(self.key_path, "rb") as keyfile:
key_buf = keyfile.read()
with open(self.cert_path, "rb") as certfile:
cert_buf = certfile.read()
return copy.deepcopy(cert_buf), copy.deepcopy(key_buf)

def get_key(self):
""":return:
"""
""":return:"""
with open(self.key_path, "rb") as keyfile:
key_buf = keyfile.read()
key = crypto.load_privatekey(crypto.FILETYPE_PEM, key_buf)
return key

def get_cert(self):
""":return:
"""
""":return:"""
with open(self.cert_path, "rb") as certfile:
cert_buf = certfile.read()
cert = crypto.load_certificate(crypto.FILETYPE_PEM, cert_buf)
Expand Down
Loading
Loading