From: John Mulligan Date: Fri, 26 May 2023 19:06:40 +0000 (-0400) Subject: cephadm: add fetch_tcp_ports function for getting processed ports X-Git-Tag: v19.0.0~982^2~19 X-Git-Url: http://git-server-git.apps.pok.os.sepia.ceph.com/?a=commitdiff_plain;h=3a8b1af46ccac6ab7f6fbd64a336443afec0282d;p=ceph.git cephadm: add fetch_tcp_ports function for getting processed ports The cephadm cli can pass ports as either a string containing space separated port numbers or, in the newer method, a (JSON) list of ints. The fetch_tcp_ports function abstracts away the handling of these input forms. Signed-off-by: John Mulligan --- diff --git a/src/cephadm/cephadm.py b/src/cephadm/cephadm.py index d0332f1900a3..06d8161a4ae8 100755 --- a/src/cephadm/cephadm.py +++ b/src/cephadm/cephadm.py @@ -3067,6 +3067,17 @@ def fetch_configs(ctx: CephadmContext) -> Dict[str, str]: return {} +def fetch_tcp_ports(ctx: CephadmContext) -> List[int]: + """Return a list of tcp ports, as integers, stored on the given ctx. + """ + ports = getattr(ctx, 'tcp_ports', None) + if ports is None: + return [] + if isinstance(ports, str): + return list(map(int, ports.split())) + return ports + + def get_config_and_keyring(ctx): # type: (CephadmContext) -> Tuple[Optional[str], Optional[str]] config = None