uawdijnntqw1x1x1
IP : 216.73.216.136
Hostname : dhandapanilive
Kernel : Linux dhandapanilive 5.15.0-139-generic #149~20.04.1-Ubuntu SMP Wed Apr 16 08:29:56 UTC 2025 x86_64
Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
OS : Linux
PATH:
/
var
/
..
/
lib
/
ubuntu-advantage
/
patch_status_json.py
/
/
#!/usr/bin/env python3 """ Patch status.json file to avoid tracebacks for non-root from `ua status` Between 27.1 and 27.2 status.json broke schema key backward-compatibility. Running `ua status` as non-root users does not generate a new status.json with the updated status.json schema so the logic which renders ua status information will traceback on KeyErrors. Since we haven't introduced official schema versioning in UA client yet, this patch is a stop-gap until official schema version handling is delivered. """ import copy import json import logging from uaclient.cli import setup_logging from uaclient import util def patch_status_json_schema_0_1(status_file: str): """Patch incompatible status.json file schema to align with version 0.1.""" setup_logging(logging.INFO, logging.DEBUG) content = util.load_file(status_file) try: status = json.loads(content, cls=util.DatetimeAwareJSONDecoder) except ValueError as e: logging.debug( "Unable to patch /var/lib/ubuntu-advantage/status.json: %s", str(e) ) return new_status = copy.deepcopy(status) if float(status.get("_schema_version", 0)) >= 0.1: return # Already have version 0.1 from daily PPA logging.debug("Patching /var/lib/ubuntu-advantage/status.json schema") new_status["_schema_version"] = "0.1" new_status["account"] = { "name": new_status.pop("account", ""), "id": new_status.pop("account-id", ""), } new_status["contract"] = { "tech_support_level": new_status.pop("techSupportLevel", "n/a"), "name": new_status.pop("subscription", ""), "id": new_status.pop("subscription-id", ""), } if "configStatus" in new_status: new_status["execution_status"] = new_status.pop("configStatus") if "configStatusDetails" in new_status: new_status["execution_details"] = new_status.pop("configStatusDetails") try: status_content = json.dumps( new_status, cls=util.DatetimeAwareJSONEncoder ) except ValueError as e: logging.debug( "Unable to patch /var/lib/ubuntu-advantage/status.json: {}".format( str(e) ) ) util.write_file(status_file, status_content) if __name__ == "__main__": patch_status_json_schema_0_1( status_file="/var/lib/ubuntu-advantage/status.json" )
/var/../lib/ubuntu-advantage/patch_status_json.py