Skip to content

Commit

Permalink
rpmbuild, frontend: activate Red Hat subscription on demand
Browse files Browse the repository at this point in the history
Fix #2132
  • Loading branch information
FrostyX committed Sep 30, 2024
1 parent 35a23e6 commit f4120f2
Show file tree
Hide file tree
Showing 4 changed files with 74 additions and 1 deletion.
5 changes: 5 additions & 0 deletions rpmbuild/copr-rpmbuild.yml
Original file line number Diff line number Diff line change
Expand Up @@ -12,3 +12,8 @@
# cute
# multiline
# snippet
#
# Chroots that require active Red Hat subscription
# rhsm:
# - rhel-*
# - epel-*
3 changes: 3 additions & 0 deletions rpmbuild/copr_rpmbuild/config.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,10 @@ class Config:
"""
Configuration class for copr-rpmbuild
"""

def __init__(self):
self.tags_to_mock_snippet = []
self.rhsm = []

def load_config(self):
"""
Expand All @@ -27,3 +29,4 @@ def load_config(self):
pass

self.tags_to_mock_snippet = config_data.get("tags_to_mock_snippet", [])
self.rhsm = config_data.get("rhsm", [])
58 changes: 58 additions & 0 deletions rpmbuild/copr_rpmbuild/rhsm.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
"""
Red Hat Subscription Management
Activating Red Hat subscription may take a lot of time and historically, the
subscription service used to be unreliable, so we should wait for the
subscription only when necessary.
"""

import os
import time
import logging
from subprocess import run, PIPE

Check warning

Code scanning / vcs-diff-lint

Unused run imported from subprocess Warning

Unused run imported from subprocess

Check warning

Code scanning / vcs-diff-lint

Unused PIPE imported from subprocess Warning

Unused PIPE imported from subprocess

Check warning

Code scanning / vcs-diff-lint

subprocess.run imported but unused Warning

subprocess.run imported but unused

Check warning

Code scanning / vcs-diff-lint

subprocess.PIPE imported but unused Warning

subprocess.PIPE imported but unused
from fnmatch import fnmatch


log = logging.getLogger("__main__")


def subscription_required(task, config):
"""
Is subscription required for this task?
"""
for pattern in config.rhsm:
if fnmatch(task["chroot"], pattern):
return True
return False


def active_subscription():
"""
Is subscription active on this system?
"""
# This is not a 100% reliable check that the subscription is active. The
# ideal check would be running `subscription-manager status` and checking
# its exit code but that requires root privileges. This check will break
# in the following corner cases:
# - The system is registered and then halted for a long time and then
# booted again after the entitlement is no longer valid
# - The system is unregistered from the server (but not from the client
# itself), making all the client files stale
return os.path.exists("/etc/pki/consumer/cert.pem")


def wait_for_subscription(timeout=86400):
"""
Wait until this system has an active subscription
"""
start = time.time()
attempt = 1
while True:
log.info("Checking Red Hat subscription (attempt #%s)", attempt)
if active_subscription():
log.info("Red Hat subscription active")
return
if time.time() > start + timeout:
raise RuntimeError("Waiting for Red Hat subscription timeouted!")
time.sleep(30)
attempt += 1
9 changes: 8 additions & 1 deletion rpmbuild/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
import shutil
import pprint
import shlex
from six.moves.urllib.parse import urlparse, urljoin, urlencode

from copr_common.request import SafeRequest, RequestError
from copr_rpmbuild import providers
Expand All @@ -25,7 +26,8 @@
locate_srpm,
package_version,
)
from six.moves.urllib.parse import urlparse, urljoin, urlencode
from copr_rpmbuild.config import Config
from copr_rpmbuild.rhsm import subscription_required, wait_for_subscription

log = logging.getLogger(__name__)
log.setLevel(logging.INFO)
Expand Down Expand Up @@ -256,6 +258,11 @@ def build_rpm(args, config):
task = get_task(args, config, build_config_url_path, task_id)
log_task(task)

copr_rpmbuild_config = Config()
copr_rpmbuild_config.load_config()
if subscription_required(task, copr_rpmbuild_config):
wait_for_subscription()

try:
source_json = {
"clone_url": task["git_repo"],
Expand Down

0 comments on commit f4120f2

Please sign in to comment.