mirror of
https://github.com/ansible-collections/hetzner.hcloud.git
synced 2026-02-04 08:01:49 +00:00
[](https://renovatebot.com) This PR contains the following updates: | Package | Change | Age | Adoption | Passing | Confidence | |---|---|---|---|---|---| | [hcloud](https://togithub.com/hetznercloud/hcloud-python) ([changelog](https://togithub.com/hetznercloud/hcloud-python/blob/main/CHANGELOG.md)) | `1.32.0` -> `1.33.0` | [](https://docs.renovatebot.com/merge-confidence/) | [](https://docs.renovatebot.com/merge-confidence/) | [](https://docs.renovatebot.com/merge-confidence/) | [](https://docs.renovatebot.com/merge-confidence/) | --- ### Release Notes <details> <summary>hetznercloud/hcloud-python (hcloud)</summary> ### [`v1.33.0`](https://togithub.com/hetznercloud/hcloud-python/blob/HEAD/CHANGELOG.md#1330-2023-12-19) [Compare Source](https://togithub.com/hetznercloud/hcloud-python/compare/v1.32.0...v1.33.0) ##### Features - add metrics endpoint for load balancers and servers ([#​331](https://togithub.com/hetznercloud/hcloud-python/issues/331)) ([ee3c54f](ee3c54fd1b)) ##### Bug Fixes - fallback to error code when message is unset ([#​328](https://togithub.com/hetznercloud/hcloud-python/issues/328)) ([1c94153](1c94153d93)) ##### Dependencies - update actions/setup-python action to v5 ([#​335](https://togithub.com/hetznercloud/hcloud-python/issues/335)) ([2ac252d](2ac252d18b)) - update dependency sphinx-rtd-theme to v2 ([#​330](https://togithub.com/hetznercloud/hcloud-python/issues/330)) ([7cc4335](7cc4335cac)) - update pre-commit hook psf/black-pre-commit-mirror to v23.12.0 ([#​338](https://togithub.com/hetznercloud/hcloud-python/issues/338)) ([38e4748](38e4748d3d)) - update pre-commit hook pycqa/isort to v5.13.0 ([#​336](https://togithub.com/hetznercloud/hcloud-python/issues/336)) ([3244cfe](3244cfef2f)) - update pre-commit hook pycqa/isort to v5.13.1 ([#​337](https://togithub.com/hetznercloud/hcloud-python/issues/337)) ([020a0ef](020a0eff6b)) - update pre-commit hook pycqa/isort to v5.13.2 ([#​339](https://togithub.com/hetznercloud/hcloud-python/issues/339)) ([b46df8c](b46df8cbb2)) </details> --- ### Configuration 📅 **Schedule**: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined). 🚦 **Automerge**: Disabled by config. Please merge this manually once you are satisfied. ♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox. 🔕 **Ignore**: Close this PR and you won't be reminded about this update again. --- - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box --- This PR has been generated by [Mend Renovate](https://www.mend.io/free-developer-tools/renovate/). View repository job log [here](https://developer.mend.io/github/ansible-collections/hetzner.hcloud). <!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzNy4xMDMuMSIsInVwZGF0ZWRJblZlciI6IjM3LjEwMy4xIiwidGFyZ2V0QnJhbmNoIjoibWFpbiJ9--> --------- Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> Co-authored-by: jo <ljonas@riseup.net>
114 lines
3.4 KiB
Python
Executable file
114 lines
3.4 KiB
Python
Executable file
#!/usr/bin/env python3
|
|
|
|
"""
|
|
Fetch and bundles the hcloud package inside the collection.
|
|
|
|
Fetch the desired version `HCLOUD_VERSION` from https://github.com/hetznercloud/hcloud-python
|
|
`HCLOUD_SOURCE_URL` using git, apply some code modifications to comply with ansible,
|
|
move the modified files at the vendor location `HCLOUD_VENDOR_PATH`.
|
|
"""
|
|
|
|
from __future__ import annotations
|
|
|
|
import logging
|
|
import re
|
|
from argparse import ArgumentParser
|
|
from pathlib import Path
|
|
from shutil import move, rmtree
|
|
from subprocess import check_call
|
|
from tempfile import TemporaryDirectory
|
|
from textwrap import dedent
|
|
|
|
logger = logging.getLogger("vendor")
|
|
|
|
HCLOUD_SOURCE_URL = "https://github.com/hetznercloud/hcloud-python"
|
|
HCLOUD_VERSION = "v1.33.0"
|
|
HCLOUD_VENDOR_PATH = "plugins/module_utils/vendor/hcloud"
|
|
|
|
|
|
def apply_code_modifications(source_path: Path):
|
|
# The ansible galaxy-importer consider __version___.py to be an invalid filename in module_utils/
|
|
# Move the __version__.py file to _version.py
|
|
move(source_path / "__version__.py", source_path / "_version.py")
|
|
|
|
for file in source_path.rglob("*.py"):
|
|
content = file.read_text()
|
|
content_orig = content
|
|
|
|
# Move the __version__.py file to _version.py
|
|
content = re.sub(
|
|
r"from .__version__ import VERSION",
|
|
r"from ._version import VERSION",
|
|
content,
|
|
)
|
|
|
|
# Wrap requests imports
|
|
content = re.sub(
|
|
r"import requests",
|
|
dedent(
|
|
r"""
|
|
try:
|
|
import requests
|
|
except ImportError:
|
|
requests = None
|
|
"""
|
|
).strip(),
|
|
content,
|
|
)
|
|
|
|
# Wrap dateutil imports
|
|
content = re.sub(
|
|
r"from dateutil.parser import isoparse",
|
|
dedent(
|
|
r"""
|
|
try:
|
|
from dateutil.parser import isoparse
|
|
except ImportError:
|
|
isoparse = None
|
|
"""
|
|
).strip(),
|
|
content,
|
|
)
|
|
|
|
# Remove requests.Response typings
|
|
content = re.sub(
|
|
r": requests\.Response",
|
|
r"",
|
|
content,
|
|
)
|
|
|
|
if content != content_orig:
|
|
logger.info("Applied code modifications on %s", file)
|
|
|
|
file.write_text(content)
|
|
|
|
|
|
def main(check: bool = False) -> int:
|
|
with TemporaryDirectory() as tmp_dir:
|
|
tmp_dir_path = Path(tmp_dir)
|
|
logger.info("Created temporary directory %s", tmp_dir_path)
|
|
|
|
check_call(["git", "clone", "--depth=1", "--branch", HCLOUD_VERSION, HCLOUD_SOURCE_URL, tmp_dir_path])
|
|
logger.info("Cloned the source files in %s", tmp_dir_path)
|
|
|
|
apply_code_modifications(tmp_dir_path / "hcloud")
|
|
logger.info("Applied code modifications on the source files")
|
|
|
|
rmtree(HCLOUD_VENDOR_PATH)
|
|
move(tmp_dir_path / "hcloud", HCLOUD_VENDOR_PATH)
|
|
logger.info("Bundled the modified sources files in the collection")
|
|
|
|
if check:
|
|
check_call(["git", "diff", "--exit-code", "--", HCLOUD_VENDOR_PATH])
|
|
|
|
return 0
|
|
|
|
|
|
if __name__ == "__main__":
|
|
logging.basicConfig(level=logging.INFO, format="%(levelname)-8s: %(message)s")
|
|
|
|
parser = ArgumentParser()
|
|
parser.add_argument("--check", action="store_true", default=False)
|
|
args = parser.parse_args()
|
|
|
|
raise SystemExit(main(check=args.check))
|