Skip to content

Commit

Permalink
feat: Add support for translanting %pre and main body part of kickstart
Browse files Browse the repository at this point in the history
  • Loading branch information
skycastlelily committed Jul 15, 2024
1 parent f1e7590 commit 1d2325b
Show file tree
Hide file tree
Showing 4 changed files with 61 additions and 10 deletions.
37 changes: 29 additions & 8 deletions src/mrack/transformers/beaker.py
Original file line number Diff line number Diff line change
Expand Up @@ -86,26 +86,47 @@ def _get_ks_meta(self, host):

def _construct_ks_append_script(self, ks_append, pubkeys=None):
"""Create ks_appdend from requirements."""
res_ks_list = []
if not ks_append and not pubkeys:
return []

res_ks_append = ["%post"]
if pubkeys:
ks_append += self._allow_ssh_keys(pubkeys)
if isinstance(ks_append, dict):
res_ks_pre = ks_append.get("pre-install")
res_ks = ks_append.get("script")
res_ks_post = ks_append.get("post-install")
if res_ks_pre:
if res_ks_pre.startswith("%pre"):
res_ks_list += [res_ks_pre]
else:
res_ks_list += ["%pre"] + [res_ks_pre] + ["%end"]
if res_ks:
res_ks_list += [res_ks]
if res_ks_post:
if res_ks_post.startswith("%post"):
res_ks_list += [res_ks_post]
else:
res_ks_list += ["%post"] + [res_ks_post] + ["%end"]
else:
res_ks_list = ["%post"]
res_ks_list += ks_append
res_ks_list.append("%end")

res_ks_append += ks_append
if pubkeys:
res_ks_list += ["%post"] + self._allow_ssh_keys(pubkeys) + ["%end"]

res_ks_append.append("%end")
return ["\n".join(res_ks_append)]
return [
"\n".join(res_ks_list),
]

def _allow_ssh_keys(self, pubkeys):
"""Create ssh key content to be injected to xml."""
keys_content = []
keys_content.append("mkdir -p /root/.ssh")
keys_content.append('cat >>/root/.ssh/authorized_keys << "__EOF__"')
keys_content.append("# keys added by mrack:")

for key in set(pubkeys):
keys = list(set(pubkeys))
keys.sort(key=pubkeys.index)
for key in keys:
with open(os.path.expanduser(key), "r", encoding="utf-8") as key_file:
keys_content.append(f"{key_file.read().strip()}")

Expand Down
1 change: 1 addition & 0 deletions tests/unit/data/key_one
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
ssh-rsa key_one_content
1 change: 1 addition & 0 deletions tests/unit/data/key_two
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
ssh-rsa key_two_content
32 changes: 30 additions & 2 deletions tests/unit/test_beaker_transformer.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
from mrack.providers.beaker import BeakerProvider

from .mock_data import MockedBeakerTransformer, provisioning_config
from .utils import get_file_path


class TestBeakerTransformer:
Expand All @@ -19,7 +20,28 @@ class TestBeakerTransformer:
default_tasks = [{"name": "/distribution/dummy", "role": "STANDALONE"}]
default_retention_tag = "audit"
default_product = "[internal]"

key_one = get_file_path("key_one")
key_two = get_file_path("key_two")
raw_maximal_ksappend = (
[
"%pre\npre_dummy\n%end\nscript_dummy\n%post\npost_dummy\n%end",
]
+ [
'%post\nmkdir -p /root/.ssh\ncat >>/root/.ssh/authorized_keys << "__EOF__"',
]
+ [
"# keys added by mrack:\nssh-rsa key_one_content\nssh-rsa key_two_content",
]
+ [
"# end section of keys added by mrack\n__EOF__\nrestorecon -R /root/.ssh",
]
+ [
"chmod go-w /root /root/.ssh /root/.ssh/authorized_keys\n%end",
]
)
maximal_ksappend = [
"\n".join(raw_maximal_ksappend),
]
fedora = {
"name": f"fedora.{domain_name}",
"role": "client",
Expand All @@ -28,6 +50,12 @@ class TestBeakerTransformer:
"restraint_id": 1,
"beaker": {
"ks_meta": "FEDORA_HOST_KS_META",
"ks_append": {
"pre-install": "%pre\npre_dummy\n%end",
"script": "script_dummy",
"post-install": "%post\npost_dummy\n%end",
},
"pubkeys": [key_one, key_two],
"tasks": [
{
"name": "/distribution/check-install",
Expand Down Expand Up @@ -156,7 +184,7 @@ async def create_transformer(self, legacy=False):
"distro": "Fedora-36%",
"variant": "Server",
"ks_meta": "FEDORA_HOST_KS_META",
"ks_append": default_ks_append,
"ks_append": maximal_ksappend,
"whiteboard": default_whiteboard,
"priority": default_prio,
"tasks": [
Expand Down

0 comments on commit 1d2325b

Please sign in to comment.