ScriptCollection 3.5.10__py3-none-any.whl → 3.5.13__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- ScriptCollection/Executables.py +358 -348
- ScriptCollection/GeneralUtilities.py +873 -869
- ScriptCollection/ProgramRunnerBase.py +47 -47
- ScriptCollection/ProgramRunnerEpew.py +122 -122
- ScriptCollection/ProgramRunnerPopen.py +51 -51
- ScriptCollection/ScriptCollectionCore.py +1811 -1782
- ScriptCollection/TasksForCommonProjectStructure.py +2617 -2617
- ScriptCollection/UpdateCertificates.py +126 -126
- {ScriptCollection-3.5.10.dist-info → ScriptCollection-3.5.13.dist-info}/METADATA +1 -1
- ScriptCollection-3.5.13.dist-info/RECORD +16 -0
- {ScriptCollection-3.5.10.dist-info → ScriptCollection-3.5.13.dist-info}/WHEEL +1 -1
- {ScriptCollection-3.5.10.dist-info → ScriptCollection-3.5.13.dist-info}/entry_points.txt +1 -0
- ScriptCollection-3.5.10.dist-info/RECORD +0 -16
- {ScriptCollection-3.5.10.dist-info → ScriptCollection-3.5.13.dist-info}/top_level.txt +0 -0
| @@ -1,126 +1,126 @@ | |
| 1 | 
            -
            import os
         | 
| 2 | 
            -
            from pathlib import Path
         | 
| 3 | 
            -
            import traceback
         | 
| 4 | 
            -
            from shutil import copyfile
         | 
| 5 | 
            -
            from .ScriptCollectionCore import ScriptCollectionCore
         | 
| 6 | 
            -
            from .GeneralUtilities import GeneralUtilities
         | 
| 7 | 
            -
             | 
| 8 | 
            -
             | 
| 9 | 
            -
            class CertificateUpdater:
         | 
| 10 | 
            -
             | 
| 11 | 
            -
                __domains: list[str]
         | 
| 12 | 
            -
                __email: str
         | 
| 13 | 
            -
             | 
| 14 | 
            -
                __current_folder = os.path.dirname(os.path.abspath(__file__))
         | 
| 15 | 
            -
                __repository_folder = GeneralUtilities.resolve_relative_path(f"..{os.path.sep}..{os.path.sep}..{os.path.sep}", __current_folder)
         | 
| 16 | 
            -
                __letsencrypt_folder = GeneralUtilities.resolve_relative_path(f"..{os.path.sep}..{os.path.sep}Volumes{os.path.sep}letsencrypt", __current_folder)
         | 
| 17 | 
            -
                __letsencrypt_live_folder = os.path.join(__letsencrypt_folder, "live")
         | 
| 18 | 
            -
                __letsencrypt_archive_folder = os.path.join(__letsencrypt_folder, "archive")
         | 
| 19 | 
            -
                __log_folder = GeneralUtilities.resolve_relative_path(f"Logs{os.path.sep}Overhead", __repository_folder)
         | 
| 20 | 
            -
                __sc = ScriptCollectionCore()
         | 
| 21 | 
            -
                __line = "___________________________________________________________________"
         | 
| 22 | 
            -
             | 
| 23 | 
            -
                def __init__(self, domains: list[str], email: str):
         | 
| 24 | 
            -
                    self.__domains = domains
         | 
| 25 | 
            -
                    self.__email = email
         | 
| 26 | 
            -
             | 
| 27 | 
            -
                @GeneralUtilities.check_arguments
         | 
| 28 | 
            -
                def __get_latest_index_by_domain(self, domain: str) -> int:
         | 
| 29 | 
            -
                    result = self.__get_latest_index_by_filelist(GeneralUtilities.get_all_files_of_folder(os.path.join(self.__letsencrypt_archive_folder, domain)))
         | 
| 30 | 
            -
                    GeneralUtilities.write_message_to_stdout(f"Debug: Latest found existing number for domain {domain}: {result}")
         | 
| 31 | 
            -
                    return result
         | 
| 32 | 
            -
             | 
| 33 | 
            -
                @GeneralUtilities.check_arguments
         | 
| 34 | 
            -
                def __get_latest_index_by_filelist(self, filenames: list) -> int:
         | 
| 35 | 
            -
                    print("files:")
         | 
| 36 | 
            -
                    print(filenames)
         | 
| 37 | 
            -
                    filenames = [Path(os.path.basename(file)).stem for file in filenames]
         | 
| 38 | 
            -
                    print(filenames)
         | 
| 39 | 
            -
                    filenames = [file for file in filenames if file.startswith("privkey")]
         | 
| 40 | 
            -
                    print(filenames)
         | 
| 41 | 
            -
                    numbers = [int(file[len("privkey"):]) for file in filenames]
         | 
| 42 | 
            -
                    # numbers=[]
         | 
| 43 | 
            -
                    # print([os.path.basename(file) for file in filenames])
         | 
| 44 | 
            -
                    result = max(numbers)
         | 
| 45 | 
            -
                    return result
         | 
| 46 | 
            -
             | 
| 47 | 
            -
                @GeneralUtilities.check_arguments
         | 
| 48 | 
            -
                def __replace_symlink_by_file(self, domain: str, filename: str, index: int) -> None:
         | 
| 49 | 
            -
                    # ".../live/example.com/cert.pem" is a symlink but should replaced by a copy of ".../archive/example.com/cert.42pem"
         | 
| 50 | 
            -
                    archive_file = os.path.join(self.__letsencrypt_archive_folder, domain, filename+str(index)+".pem")
         | 
| 51 | 
            -
                    live_folder = os.path.join(self.__letsencrypt_live_folder, domain)
         | 
| 52 | 
            -
                    live_filename = filename+".pem"
         | 
| 53 | 
            -
                    live_file = os.path.join(live_folder, live_filename)
         | 
| 54 | 
            -
                    self.__sc.run_program("rm", live_filename, live_folder)
         | 
| 55 | 
            -
                    copyfile(archive_file, live_file)
         | 
| 56 | 
            -
             | 
| 57 | 
            -
                @GeneralUtilities.check_arguments
         | 
| 58 | 
            -
                def __replace_file_by_symlink(self, domain: str, filename: str, index: int) -> None:
         | 
| 59 | 
            -
                    # new ".../live/example.com/cert.pem" is a file but should replaced by a symlink which points to ".../archive/example.com/cert42.pem"
         | 
| 60 | 
            -
                    live_folder = os.path.join(self.__letsencrypt_live_folder, domain)
         | 
| 61 | 
            -
                    live_filename = filename+".pem"
         | 
| 62 | 
            -
                    self.__sc.run_program("rm", live_filename, live_folder)
         | 
| 63 | 
            -
                    self.__sc.run_program("ln", f"-s ../../archive/{domain}/{filename+str(index)}.pem {live_filename}", live_folder)
         | 
| 64 | 
            -
             | 
| 65 | 
            -
                @GeneralUtilities.check_arguments
         | 
| 66 | 
            -
                def __replace_symlinks_by_files(self, domain):
         | 
| 67 | 
            -
                    index = self.__get_latest_index_by_domain(domain)
         | 
| 68 | 
            -
                    self.__replace_symlink_by_file(domain, "cert", index)
         | 
| 69 | 
            -
                    self.__replace_symlink_by_file(domain, "chain", index)
         | 
| 70 | 
            -
                    self.__replace_symlink_by_file(domain, "fullchain", index)
         | 
| 71 | 
            -
                    self.__replace_symlink_by_file(domain, "privkey", index)
         | 
| 72 | 
            -
             | 
| 73 | 
            -
                @GeneralUtilities.check_arguments
         | 
| 74 | 
            -
                def __replace_files_by_symlinks(self, domain):
         | 
| 75 | 
            -
                    index = self.__get_latest_index_by_domain(domain)
         | 
| 76 | 
            -
                    self.__replace_file_by_symlink(domain, "cert", index)
         | 
| 77 | 
            -
                    self.__replace_file_by_symlink(domain, "chain", index)
         | 
| 78 | 
            -
                    self.__replace_file_by_symlink(domain, "fullchain", index)
         | 
| 79 | 
            -
                    self.__replace_file_by_symlink(domain, "privkey", index)
         | 
| 80 | 
            -
             | 
| 81 | 
            -
                @GeneralUtilities.check_arguments
         | 
| 82 | 
            -
                def update_certificate_managed_by_docker_and_letsencrypt(self) -> None:
         | 
| 83 | 
            -
                    GeneralUtilities.write_message_to_stdout("current_folder:")
         | 
| 84 | 
            -
                    GeneralUtilities.write_message_to_stdout(self.__current_folder)
         | 
| 85 | 
            -
                    GeneralUtilities.write_message_to_stdout("letsencrypt_folder:")
         | 
| 86 | 
            -
                    GeneralUtilities.write_message_to_stdout(self.__letsencrypt_folder)
         | 
| 87 | 
            -
                    GeneralUtilities.write_message_to_stdout("letsencrypt_live_folder:")
         | 
| 88 | 
            -
                    GeneralUtilities.write_message_to_stdout(self.__letsencrypt_live_folder)
         | 
| 89 | 
            -
                    GeneralUtilities.write_message_to_stdout("letsencrypt_archive_folder:")
         | 
| 90 | 
            -
                    GeneralUtilities.write_message_to_stdout(self.__letsencrypt_archive_folder)
         | 
| 91 | 
            -
                    GeneralUtilities.write_message_to_stdout("log_folder:")
         | 
| 92 | 
            -
                    GeneralUtilities.write_message_to_stdout(self.__log_folder)
         | 
| 93 | 
            -
             | 
| 94 | 
            -
                    GeneralUtilities.write_message_to_stdout(self.__line+self.__line)
         | 
| 95 | 
            -
                    GeneralUtilities.write_message_to_stdout("Updating certificates")
         | 
| 96 | 
            -
                    self.__sc.git_commit(self.__current_folder, "Saved current changes")
         | 
| 97 | 
            -
                    for domain in self.__domains:
         | 
| 98 | 
            -
                        try:
         | 
| 99 | 
            -
                            GeneralUtilities.write_message_to_stdout(self.__line)
         | 
| 100 | 
            -
                            GeneralUtilities.write_message_to_stdout(f"Process domain {domain}")
         | 
| 101 | 
            -
                            certificate_for_domain_already_exists = os.path.isfile(f"{self.__letsencrypt_folder}/renewal/{domain}.conf")
         | 
| 102 | 
            -
                            if certificate_for_domain_already_exists:
         | 
| 103 | 
            -
                                GeneralUtilities.write_message_to_stdout(f"Update certificate for domain {domain}")
         | 
| 104 | 
            -
                                self.__replace_files_by_symlinks(domain)
         | 
| 105 | 
            -
                            else:
         | 
| 106 | 
            -
                                GeneralUtilities.write_message_to_stdout(f"Create certificate for domain {domain}")
         | 
| 107 | 
            -
                            certbot_container_name = "r2_updatecertificates_certbot"
         | 
| 108 | 
            -
                            dockerargument = f"run --name {certbot_container_name} --volume {self.__letsencrypt_folder}:/etc/letsencrypt"
         | 
| 109 | 
            -
                            dockerargument = dockerargument+f" --volume {self.__log_folder}:/var/log/letsencrypt -p 80:80 certbot/certbot:latest"
         | 
| 110 | 
            -
                            certbotargument = f"--standalone --email {self.__email} --agree-tos --force-renewal --rsa-key-size 4096 --non-interactive --no-eff-email --domain {domain}"
         | 
| 111 | 
            -
                            if (certificate_for_domain_already_exists):
         | 
| 112 | 
            -
                                self.__sc.run_program("docker", f"{dockerargument} certonly --no-random-sleep-on-renew {certbotargument}",                                          self.__current_folder, throw_exception_if_exitcode_is_not_zero=True)
         | 
| 113 | 
            -
                                self.__replace_symlinks_by_files(domain)
         | 
| 114 | 
            -
                            else:
         | 
| 115 | 
            -
                                self.__sc.run_program("docker", f"{dockerargument} certonly --cert-name {domain} {certbotargument}",                                          self.__current_folder, throw_exception_if_exitcode_is_not_zero=True)
         | 
| 116 | 
            -
                        except Exception as exception:
         | 
| 117 | 
            -
                            GeneralUtilities.write_exception_to_stderr_with_traceback(exception, traceback, "Error while updating certificate")
         | 
| 118 | 
            -
                        finally:
         | 
| 119 | 
            -
                            try:
         | 
| 120 | 
            -
                                self.__sc.run_program("docker", f"container rm {certbot_container_name}", self.__current_folder, throw_exception_if_exitcode_is_not_zero=True)
         | 
| 121 | 
            -
                            except Exception as exception:
         | 
| 122 | 
            -
                                GeneralUtilities.write_exception_to_stderr_with_traceback(exception, traceback, "Error while removing container")
         | 
| 123 | 
            -
             | 
| 124 | 
            -
                    GeneralUtilities.write_message_to_stdout("Commit changes...")
         | 
| 125 | 
            -
                    self.__sc.git_commit(self.__repository_folder, "Executed certificate-update-process")
         | 
| 126 | 
            -
                    GeneralUtilities.write_message_to_stdout("Finished certificate-update-process")
         | 
| 1 | 
            +
            import os
         | 
| 2 | 
            +
            from pathlib import Path
         | 
| 3 | 
            +
            import traceback
         | 
| 4 | 
            +
            from shutil import copyfile
         | 
| 5 | 
            +
            from .ScriptCollectionCore import ScriptCollectionCore
         | 
| 6 | 
            +
            from .GeneralUtilities import GeneralUtilities
         | 
| 7 | 
            +
             | 
| 8 | 
            +
             | 
| 9 | 
            +
            class CertificateUpdater:
         | 
| 10 | 
            +
             | 
| 11 | 
            +
                __domains: list[str]
         | 
| 12 | 
            +
                __email: str
         | 
| 13 | 
            +
             | 
| 14 | 
            +
                __current_folder = os.path.dirname(os.path.abspath(__file__))
         | 
| 15 | 
            +
                __repository_folder = GeneralUtilities.resolve_relative_path(f"..{os.path.sep}..{os.path.sep}..{os.path.sep}", __current_folder)
         | 
| 16 | 
            +
                __letsencrypt_folder = GeneralUtilities.resolve_relative_path(f"..{os.path.sep}..{os.path.sep}Volumes{os.path.sep}letsencrypt", __current_folder)
         | 
| 17 | 
            +
                __letsencrypt_live_folder = os.path.join(__letsencrypt_folder, "live")
         | 
| 18 | 
            +
                __letsencrypt_archive_folder = os.path.join(__letsencrypt_folder, "archive")
         | 
| 19 | 
            +
                __log_folder = GeneralUtilities.resolve_relative_path(f"Logs{os.path.sep}Overhead", __repository_folder)
         | 
| 20 | 
            +
                __sc = ScriptCollectionCore()
         | 
| 21 | 
            +
                __line = "___________________________________________________________________"
         | 
| 22 | 
            +
             | 
| 23 | 
            +
                def __init__(self, domains: list[str], email: str):
         | 
| 24 | 
            +
                    self.__domains = domains
         | 
| 25 | 
            +
                    self.__email = email
         | 
| 26 | 
            +
             | 
| 27 | 
            +
                @GeneralUtilities.check_arguments
         | 
| 28 | 
            +
                def __get_latest_index_by_domain(self, domain: str) -> int:
         | 
| 29 | 
            +
                    result = self.__get_latest_index_by_filelist(GeneralUtilities.get_all_files_of_folder(os.path.join(self.__letsencrypt_archive_folder, domain)))
         | 
| 30 | 
            +
                    GeneralUtilities.write_message_to_stdout(f"Debug: Latest found existing number for domain {domain}: {result}")
         | 
| 31 | 
            +
                    return result
         | 
| 32 | 
            +
             | 
| 33 | 
            +
                @GeneralUtilities.check_arguments
         | 
| 34 | 
            +
                def __get_latest_index_by_filelist(self, filenames: list) -> int:
         | 
| 35 | 
            +
                    print("files:")
         | 
| 36 | 
            +
                    print(filenames)
         | 
| 37 | 
            +
                    filenames = [Path(os.path.basename(file)).stem for file in filenames]
         | 
| 38 | 
            +
                    print(filenames)
         | 
| 39 | 
            +
                    filenames = [file for file in filenames if file.startswith("privkey")]
         | 
| 40 | 
            +
                    print(filenames)
         | 
| 41 | 
            +
                    numbers = [int(file[len("privkey"):]) for file in filenames]
         | 
| 42 | 
            +
                    # numbers=[]
         | 
| 43 | 
            +
                    # print([os.path.basename(file) for file in filenames])
         | 
| 44 | 
            +
                    result = max(numbers)
         | 
| 45 | 
            +
                    return result
         | 
| 46 | 
            +
             | 
| 47 | 
            +
                @GeneralUtilities.check_arguments
         | 
| 48 | 
            +
                def __replace_symlink_by_file(self, domain: str, filename: str, index: int) -> None:
         | 
| 49 | 
            +
                    # ".../live/example.com/cert.pem" is a symlink but should replaced by a copy of ".../archive/example.com/cert.42pem"
         | 
| 50 | 
            +
                    archive_file = os.path.join(self.__letsencrypt_archive_folder, domain, filename+str(index)+".pem")
         | 
| 51 | 
            +
                    live_folder = os.path.join(self.__letsencrypt_live_folder, domain)
         | 
| 52 | 
            +
                    live_filename = filename+".pem"
         | 
| 53 | 
            +
                    live_file = os.path.join(live_folder, live_filename)
         | 
| 54 | 
            +
                    self.__sc.run_program("rm", live_filename, live_folder)
         | 
| 55 | 
            +
                    copyfile(archive_file, live_file)
         | 
| 56 | 
            +
             | 
| 57 | 
            +
                @GeneralUtilities.check_arguments
         | 
| 58 | 
            +
                def __replace_file_by_symlink(self, domain: str, filename: str, index: int) -> None:
         | 
| 59 | 
            +
                    # new ".../live/example.com/cert.pem" is a file but should replaced by a symlink which points to ".../archive/example.com/cert42.pem"
         | 
| 60 | 
            +
                    live_folder = os.path.join(self.__letsencrypt_live_folder, domain)
         | 
| 61 | 
            +
                    live_filename = filename+".pem"
         | 
| 62 | 
            +
                    self.__sc.run_program("rm", live_filename, live_folder)
         | 
| 63 | 
            +
                    self.__sc.run_program("ln", f"-s ../../archive/{domain}/{filename+str(index)}.pem {live_filename}", live_folder)
         | 
| 64 | 
            +
             | 
| 65 | 
            +
                @GeneralUtilities.check_arguments
         | 
| 66 | 
            +
                def __replace_symlinks_by_files(self, domain):
         | 
| 67 | 
            +
                    index = self.__get_latest_index_by_domain(domain)
         | 
| 68 | 
            +
                    self.__replace_symlink_by_file(domain, "cert", index)
         | 
| 69 | 
            +
                    self.__replace_symlink_by_file(domain, "chain", index)
         | 
| 70 | 
            +
                    self.__replace_symlink_by_file(domain, "fullchain", index)
         | 
| 71 | 
            +
                    self.__replace_symlink_by_file(domain, "privkey", index)
         | 
| 72 | 
            +
             | 
| 73 | 
            +
                @GeneralUtilities.check_arguments
         | 
| 74 | 
            +
                def __replace_files_by_symlinks(self, domain):
         | 
| 75 | 
            +
                    index = self.__get_latest_index_by_domain(domain)
         | 
| 76 | 
            +
                    self.__replace_file_by_symlink(domain, "cert", index)
         | 
| 77 | 
            +
                    self.__replace_file_by_symlink(domain, "chain", index)
         | 
| 78 | 
            +
                    self.__replace_file_by_symlink(domain, "fullchain", index)
         | 
| 79 | 
            +
                    self.__replace_file_by_symlink(domain, "privkey", index)
         | 
| 80 | 
            +
             | 
| 81 | 
            +
                @GeneralUtilities.check_arguments
         | 
| 82 | 
            +
                def update_certificate_managed_by_docker_and_letsencrypt(self) -> None:
         | 
| 83 | 
            +
                    GeneralUtilities.write_message_to_stdout("current_folder:")
         | 
| 84 | 
            +
                    GeneralUtilities.write_message_to_stdout(self.__current_folder)
         | 
| 85 | 
            +
                    GeneralUtilities.write_message_to_stdout("letsencrypt_folder:")
         | 
| 86 | 
            +
                    GeneralUtilities.write_message_to_stdout(self.__letsencrypt_folder)
         | 
| 87 | 
            +
                    GeneralUtilities.write_message_to_stdout("letsencrypt_live_folder:")
         | 
| 88 | 
            +
                    GeneralUtilities.write_message_to_stdout(self.__letsencrypt_live_folder)
         | 
| 89 | 
            +
                    GeneralUtilities.write_message_to_stdout("letsencrypt_archive_folder:")
         | 
| 90 | 
            +
                    GeneralUtilities.write_message_to_stdout(self.__letsencrypt_archive_folder)
         | 
| 91 | 
            +
                    GeneralUtilities.write_message_to_stdout("log_folder:")
         | 
| 92 | 
            +
                    GeneralUtilities.write_message_to_stdout(self.__log_folder)
         | 
| 93 | 
            +
             | 
| 94 | 
            +
                    GeneralUtilities.write_message_to_stdout(self.__line+self.__line)
         | 
| 95 | 
            +
                    GeneralUtilities.write_message_to_stdout("Updating certificates")
         | 
| 96 | 
            +
                    self.__sc.git_commit(self.__current_folder, "Saved current changes")
         | 
| 97 | 
            +
                    for domain in self.__domains:
         | 
| 98 | 
            +
                        try:
         | 
| 99 | 
            +
                            GeneralUtilities.write_message_to_stdout(self.__line)
         | 
| 100 | 
            +
                            GeneralUtilities.write_message_to_stdout(f"Process domain {domain}")
         | 
| 101 | 
            +
                            certificate_for_domain_already_exists = os.path.isfile(f"{self.__letsencrypt_folder}/renewal/{domain}.conf")
         | 
| 102 | 
            +
                            if certificate_for_domain_already_exists:
         | 
| 103 | 
            +
                                GeneralUtilities.write_message_to_stdout(f"Update certificate for domain {domain}")
         | 
| 104 | 
            +
                                self.__replace_files_by_symlinks(domain)
         | 
| 105 | 
            +
                            else:
         | 
| 106 | 
            +
                                GeneralUtilities.write_message_to_stdout(f"Create certificate for domain {domain}")
         | 
| 107 | 
            +
                            certbot_container_name = "r2_updatecertificates_certbot"
         | 
| 108 | 
            +
                            dockerargument = f"run --name {certbot_container_name} --volume {self.__letsencrypt_folder}:/etc/letsencrypt"
         | 
| 109 | 
            +
                            dockerargument = dockerargument+f" --volume {self.__log_folder}:/var/log/letsencrypt -p 80:80 certbot/certbot:latest"
         | 
| 110 | 
            +
                            certbotargument = f"--standalone --email {self.__email} --agree-tos --force-renewal --rsa-key-size 4096 --non-interactive --no-eff-email --domain {domain}"
         | 
| 111 | 
            +
                            if (certificate_for_domain_already_exists):
         | 
| 112 | 
            +
                                self.__sc.run_program("docker", f"{dockerargument} certonly --no-random-sleep-on-renew {certbotargument}",                                          self.__current_folder, throw_exception_if_exitcode_is_not_zero=True)
         | 
| 113 | 
            +
                                self.__replace_symlinks_by_files(domain)
         | 
| 114 | 
            +
                            else:
         | 
| 115 | 
            +
                                self.__sc.run_program("docker", f"{dockerargument} certonly --cert-name {domain} {certbotargument}",                                          self.__current_folder, throw_exception_if_exitcode_is_not_zero=True)
         | 
| 116 | 
            +
                        except Exception as exception:
         | 
| 117 | 
            +
                            GeneralUtilities.write_exception_to_stderr_with_traceback(exception, traceback, "Error while updating certificate")
         | 
| 118 | 
            +
                        finally:
         | 
| 119 | 
            +
                            try:
         | 
| 120 | 
            +
                                self.__sc.run_program("docker", f"container rm {certbot_container_name}", self.__current_folder, throw_exception_if_exitcode_is_not_zero=True)
         | 
| 121 | 
            +
                            except Exception as exception:
         | 
| 122 | 
            +
                                GeneralUtilities.write_exception_to_stderr_with_traceback(exception, traceback, "Error while removing container")
         | 
| 123 | 
            +
             | 
| 124 | 
            +
                    GeneralUtilities.write_message_to_stdout("Commit changes...")
         | 
| 125 | 
            +
                    self.__sc.git_commit(self.__repository_folder, "Executed certificate-update-process")
         | 
| 126 | 
            +
                    GeneralUtilities.write_message_to_stdout("Finished certificate-update-process")
         | 
| @@ -0,0 +1,16 @@ | |
| 1 | 
            +
            ScriptCollection/Executables.py,sha256=msAlVLjgrxCxW-5Uu7Gk8NI1CNQLK2i6TjNR1fppaCY,19535
         | 
| 2 | 
            +
            ScriptCollection/GeneralUtilities.py,sha256=1Q5ML9RwwS5e1mZPuJps3Z3ceVCGF5taFhh0GEG6MlY,35167
         | 
| 3 | 
            +
            ScriptCollection/ProcessesRunner.py,sha256=3mu4ZxzZleQo0Op6o9EYTCFiJfb6kx5ov2YfZfT89mU,1395
         | 
| 4 | 
            +
            ScriptCollection/ProgramRunnerBase.py,sha256=7QAjoqOz6XPmJH19F2k-Z1fFQB_uZnPFvn-T54IJcHQ,2324
         | 
| 5 | 
            +
            ScriptCollection/ProgramRunnerEpew.py,sha256=C2Rs3YWOWWWJct7XmKphp5CF1tf0j4Fp-ljV2drLTfs,6349
         | 
| 6 | 
            +
            ScriptCollection/ProgramRunnerPopen.py,sha256=ECx35Yz-MKPeoRa_42Bsq8qmbHd13I40vXUJSpZPrI4,3475
         | 
| 7 | 
            +
            ScriptCollection/RPStream.py,sha256=NRRHL3YSP3D9MuAV2jB_--0KUKCsvJGxeKnxgrRZ9kY,1545
         | 
| 8 | 
            +
            ScriptCollection/ScriptCollectionCore.py,sha256=cWn10QGcBDP4C6u5TtzGYn6OiYV5OpY8BRkeNGQo00w,97421
         | 
| 9 | 
            +
            ScriptCollection/TasksForCommonProjectStructure.py,sha256=-QxOB01yFHrcPpTNnDA0GY0rv9McvQ95DZ3PNHRCrFE,184090
         | 
| 10 | 
            +
            ScriptCollection/UpdateCertificates.py,sha256=Eynbgu7k9jLxApP2D_8Il77B6BFjJap6K7oTeEAZYbk,7790
         | 
| 11 | 
            +
            ScriptCollection/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
         | 
| 12 | 
            +
            ScriptCollection-3.5.13.dist-info/METADATA,sha256=LxH_9vYMJRCIrEukh8lc02T6npy78tCjQTrpaOtYB1A,7680
         | 
| 13 | 
            +
            ScriptCollection-3.5.13.dist-info/WHEEL,sha256=ixB2d4u7mugx_bCBycvM9OzZ5yD7NmPXFRtKlORZS2Y,91
         | 
| 14 | 
            +
            ScriptCollection-3.5.13.dist-info/entry_points.txt,sha256=Jz1pyS3Q6lqpuOWVHogt00jGwrpcHYtPrHGY0_Ltjbo,2227
         | 
| 15 | 
            +
            ScriptCollection-3.5.13.dist-info/top_level.txt,sha256=hY2hOVH0V0Ce51WB76zKkIWTUNwMUdHo4XDkR2vYVwg,17
         | 
| 16 | 
            +
            ScriptCollection-3.5.13.dist-info/RECORD,,
         | 
| @@ -3,6 +3,7 @@ scbuildcodeunit = ScriptCollection.Executables:BuildCodeUnit | |
| 3 3 | 
             
            scbuildcodeunits = ScriptCollection.Executables:BuildCodeUnits
         | 
| 4 4 | 
             
            scbuildcodeunitsc = ScriptCollection.Executables:BuildCodeUnitsC
         | 
| 5 5 | 
             
            sccalculatebitcoinblockhash = ScriptCollection.Executables:CalculateBitcoinBlockHash
         | 
| 6 | 
            +
            scchangefileextension = ScriptCollection.Executables:ChangeFileExtensions
         | 
| 6 7 | 
             
            scchangehashofprogram = ScriptCollection.Executables:ChangeHashOfProgram
         | 
| 7 8 | 
             
            sccreateemptyfilewithspecificsize = ScriptCollection.Executables:CreateEmptyFileWithSpecificSize
         | 
| 8 9 | 
             
            sccreatehashofallfiles = ScriptCollection.Executables:CreateHashOfAllFiles
         | 
| @@ -1,16 +0,0 @@ | |
| 1 | 
            -
            ScriptCollection/Executables.py,sha256=0I_yTMX-mkbgatm8O7Pvtv2rG5Ep4C0iqUYDL92hINE,19241
         | 
| 2 | 
            -
            ScriptCollection/GeneralUtilities.py,sha256=urvslHJx_ptJgzGjRoc4KKyFtPYWvs2ifLD_MKACnxg,35810
         | 
| 3 | 
            -
            ScriptCollection/ProcessesRunner.py,sha256=3mu4ZxzZleQo0Op6o9EYTCFiJfb6kx5ov2YfZfT89mU,1395
         | 
| 4 | 
            -
            ScriptCollection/ProgramRunnerBase.py,sha256=W4MaDroJHARRtcvPkBC2AS_qgDSRIqOkMvGyycZjtPk,2371
         | 
| 5 | 
            -
            ScriptCollection/ProgramRunnerEpew.py,sha256=lx_jR3W8KavBpZo44u2FrOca_EWWgUb3_w_YKGRrAyM,6471
         | 
| 6 | 
            -
            ScriptCollection/ProgramRunnerPopen.py,sha256=5QFplojwfGS8_WdYrg5nE6__QFB5iaMA0EP8OGfgPoY,3526
         | 
| 7 | 
            -
            ScriptCollection/RPStream.py,sha256=NRRHL3YSP3D9MuAV2jB_--0KUKCsvJGxeKnxgrRZ9kY,1545
         | 
| 8 | 
            -
            ScriptCollection/ScriptCollectionCore.py,sha256=TZQ1Z2mo9FcqzddxmFnFvJ01clasE4dFN5DQuIKlpVY,97563
         | 
| 9 | 
            -
            ScriptCollection/TasksForCommonProjectStructure.py,sha256=Wk7nAbSI1BevltSmWRC4CKtKH3XsavpVM5PHaCiTlRQ,186707
         | 
| 10 | 
            -
            ScriptCollection/UpdateCertificates.py,sha256=lfmVuify-Fqq-vGJusDDUsJVhA-rVLwW2Jx9iLwmkBo,7916
         | 
| 11 | 
            -
            ScriptCollection/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
         | 
| 12 | 
            -
            ScriptCollection-3.5.10.dist-info/METADATA,sha256=V0RkV2wEdYxh9fFHQSmSYh-yaSvDkhTKyw5VQaCZVr8,7680
         | 
| 13 | 
            -
            ScriptCollection-3.5.10.dist-info/WHEEL,sha256=R0nc6qTxuoLk7ShA2_Y-UWkN8ZdfDBG2B6Eqpz2WXbs,91
         | 
| 14 | 
            -
            ScriptCollection-3.5.10.dist-info/entry_points.txt,sha256=dwvB9HRGvqst5xlYIGmmwuFN7lBKhxvndmnNrQOfu8w,2153
         | 
| 15 | 
            -
            ScriptCollection-3.5.10.dist-info/top_level.txt,sha256=hY2hOVH0V0Ce51WB76zKkIWTUNwMUdHo4XDkR2vYVwg,17
         | 
| 16 | 
            -
            ScriptCollection-3.5.10.dist-info/RECORD,,
         | 
| 
            File without changes
         |