Skip to content

Commit

Permalink
cephadm-boostrap: add new boostrap parameters
Browse files Browse the repository at this point in the history
Added a list of boostrap parameters related to IBM call home
and HW monitoring feature only available downstream

Fixes: https://bugzilla.redhat.com/show_bug.cgi?id=2246266

Signed-off-by: Teoman ONAY <tonay@ibm.com>
(cherry picked from commit faa7b2f)
  • Loading branch information
asm0deuz authored and mergify[bot] committed Feb 15, 2024
1 parent aae65e1 commit 3a04013
Showing 1 changed file with 41 additions and 19 deletions.
60 changes: 41 additions & 19 deletions library/cephadm_bootstrap.py
Original file line number Diff line number Diff line change
Expand Up @@ -158,9 +158,13 @@ def run_module() -> None:
backward_compat = dict(
dashboard=dict(type='bool', required=False, remove_in_version='4.0.0'),
firewalld=dict(type='bool', required=False, remove_in_version='4.0.0'),
monitoring=dict(type='bool', required=False, remove_in_version='4.0.0'),
monitoring=dict(type='bool',
required=False,
remove_in_version='4.0.0'),
pull=dict(type='bool', required=False, remove_in_version='4.0.0'),
dashboard_password=dict(type='str', required=False, no_log=True), # noqa: E501
dashboard_password=dict(type='str',
required=False,
no_log=True),
dashboard_user=dict(type='str', required=False),
)

Expand All @@ -169,6 +173,20 @@ def run_module() -> None:
image=dict(type='str', required=False),
)

cephadm_bootstrap_downstream_only = dict(
call_home_config=dict(type='str', required=False),
call_home_icn=dict(type='str', required=False),
ceph_call_home_contact_email=dict(type='str', required=False),
ceph_call_home_contact_first_name=dict(type='str', required=False),
ceph_call_home_contact_last_name=dict(type='str', required=False),
ceph_call_home_contact_phone=dict(type='str', required=False),
ceph_call_home_country_code=dict(type='str', required=False),
deploy_cephadm_agent=dict(type='bool', required=False),
enable_ibm_call_home=dict(type='bool', required=False),
enable_storage_insights=dict(type='bool', required=False),
storage_insights_config=dict(type='str', required=False),
)

cephadm_bootstrap_params = dict(
allow_fqdn_hostname=dict(type='bool', required=False, default=False),
allow_mismatched_release=dict(type='bool', required=False),
Expand All @@ -180,7 +198,9 @@ def run_module() -> None:
dashboard_key=dict(type='str', required=False),
dashboard_password_noupdate=dict(type='bool', required=False),
fsid=dict(type='str', required=False),
initial_dashboard_password=dict(type='str', required=False, no_log=True), # noqa: E501
initial_dashboard_password=dict(type='str',
required=False,
no_log=True),
initial_dashboard_user=dict(type='str', required=False),
log_to_file=dict(type='bool', required=False),
mgr_id=dict(type='str', required=False),
Expand Down Expand Up @@ -216,6 +236,7 @@ def run_module() -> None:
ssh_user=dict(type='str', required=False),
ssl_dashboard_port=dict(type='str', required=False),
with_centralized_logging=dict(type='bool', required=False),
**cephadm_bootstrap_downstream_only,
)

module = AnsibleModule(
Expand All @@ -242,17 +263,23 @@ def run_module() -> None:

startd = datetime.datetime.now()

cmd = ['cephadm']
cmd: list[str] = []
data_dir = '/var/lib/ceph'
ceph_conf = 'ceph.conf'
ceph_keyring = 'ceph.client.admin.keyring'
ceph_pubkey = 'ceph.pub'

def extend_append(key: str, parameters: dict) -> None:
if parameters[key]['type'] == 'bool':
cmd.append('--' + k.replace('_', '-'))
else:
cmd.extend(['--' + k.replace('_', '-'), module.params.get(k)])
def extend_append(command: str, params: dict) -> list:
cmd: list[str] = []
cmd.append(command)
for k in params:
if module.params.get(k):
if params[k]['type'] == 'bool':
cmd.append('--' + k.replace('_', '-'))
else:
cmd.extend(['--' + k.replace('_', '-'),
module.params.get(k)])
return cmd

if fsid:
if os.path.exists(os.path.join(data_dir, fsid)):
Expand Down Expand Up @@ -282,15 +309,10 @@ def extend_append(key: str, parameters: dict) -> None:
changed=False
)

for k in cephadm_params:
if module.params.get(k):
extend_append(k, cephadm_params)

cmd.extend(['bootstrap'])

for k in cephadm_bootstrap_params:
if module.params.get(k):
extend_append(k, cephadm_bootstrap_params)
# Build cephadm with parameters
cmd = extend_append('cephadm', cephadm_params)
# Extends with boostrap parameters
cmd.extend(extend_append('bootstrap', cephadm_bootstrap_params))

# keep backward compatibility
for k in backward_compat:
Expand All @@ -311,7 +333,7 @@ def extend_append(key: str, parameters: dict) -> None:
cmd.extend(['--dashboard-user',
module.params.get('dashboard_user'),
'--dashboard-password',
module.params.get('dashboard_password'), # noqa: E501
module.params.get('dashboard_password'),
])
else:
if '--skip-dashboard' not in cmd:
Expand Down

0 comments on commit 3a04013

Please sign in to comment.