mirror of
https://github.com/ansible-collections/community.general.git
synced 2026-02-04 07:51:50 +00:00
Sort imports with ruff check --fix (#11400)
Sort imports with ruff check --fix.
(cherry picked from commit 236b9c0e04)
Co-authored-by: Felix Fontein <felix@fontein.de>
228 lines
6.6 KiB
Python
228 lines
6.6 KiB
Python
#!/usr/bin/python
|
|
#
|
|
# Copyright Ansible Team
|
|
# GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
from __future__ import annotations
|
|
|
|
DOCUMENTATION = r"""
|
|
module: github_release
|
|
short_description: Interact with GitHub Releases
|
|
description:
|
|
- Fetch metadata about GitHub Releases.
|
|
extends_documentation_fragment:
|
|
- community.general.attributes
|
|
attributes:
|
|
check_mode:
|
|
support: full
|
|
diff_mode:
|
|
support: none
|
|
options:
|
|
token:
|
|
description:
|
|
- GitHub Personal Access Token for authenticating. Mutually exclusive with O(password).
|
|
type: str
|
|
user:
|
|
description:
|
|
- The GitHub account that owns the repository.
|
|
type: str
|
|
required: true
|
|
password:
|
|
description:
|
|
- The GitHub account password for the user. Mutually exclusive with O(token).
|
|
type: str
|
|
repo:
|
|
description:
|
|
- Repository name.
|
|
type: str
|
|
required: true
|
|
action:
|
|
description:
|
|
- Action to perform.
|
|
type: str
|
|
required: true
|
|
choices: ['latest_release', 'create_release']
|
|
tag:
|
|
description:
|
|
- Tag name when creating a release. Required when using O(action=create_release).
|
|
type: str
|
|
target:
|
|
description:
|
|
- Target of release when creating a release.
|
|
type: str
|
|
name:
|
|
description:
|
|
- Name of release when creating a release.
|
|
type: str
|
|
body:
|
|
description:
|
|
- Description of the release when creating a release.
|
|
type: str
|
|
draft:
|
|
description:
|
|
- Sets if the release is a draft or not. (boolean).
|
|
type: bool
|
|
default: false
|
|
prerelease:
|
|
description:
|
|
- Sets if the release is a prerelease or not. (boolean).
|
|
type: bool
|
|
default: false
|
|
|
|
author:
|
|
- "Adrian Moisey (@adrianmoisey)"
|
|
requirements:
|
|
- "github3.py >= 1.0.0a3"
|
|
"""
|
|
|
|
EXAMPLES = r"""
|
|
- name: Get latest release of a public repository
|
|
community.general.github_release:
|
|
user: ansible
|
|
repo: ansible
|
|
action: latest_release
|
|
|
|
- name: Get latest release of testuseer/testrepo
|
|
community.general.github_release:
|
|
token: tokenabc1234567890
|
|
user: testuser
|
|
repo: testrepo
|
|
action: latest_release
|
|
|
|
- name: Get latest release of test repo using username and password
|
|
community.general.github_release:
|
|
user: testuser
|
|
password: secret123
|
|
repo: testrepo
|
|
action: latest_release
|
|
|
|
- name: Create a new release
|
|
community.general.github_release:
|
|
token: tokenabc1234567890
|
|
user: testuser
|
|
repo: testrepo
|
|
action: create_release
|
|
tag: test
|
|
target: master
|
|
name: My Release
|
|
body: Some description
|
|
"""
|
|
|
|
RETURN = r"""
|
|
tag:
|
|
description: Version of the created/latest release.
|
|
type: str
|
|
returned: success
|
|
sample: 1.1.0
|
|
"""
|
|
|
|
import traceback
|
|
|
|
GITHUB_IMP_ERR = None
|
|
try:
|
|
import github3
|
|
|
|
HAS_GITHUB_API = True
|
|
except ImportError:
|
|
GITHUB_IMP_ERR = traceback.format_exc()
|
|
HAS_GITHUB_API = False
|
|
|
|
from ansible.module_utils.basic import AnsibleModule, missing_required_lib
|
|
|
|
|
|
def main():
|
|
module = AnsibleModule(
|
|
argument_spec=dict(
|
|
repo=dict(required=True),
|
|
user=dict(required=True),
|
|
password=dict(no_log=True),
|
|
token=dict(no_log=True),
|
|
action=dict(required=True, choices=["latest_release", "create_release"]),
|
|
tag=dict(type="str"),
|
|
target=dict(type="str"),
|
|
name=dict(type="str"),
|
|
body=dict(type="str"),
|
|
draft=dict(type="bool", default=False),
|
|
prerelease=dict(type="bool", default=False),
|
|
),
|
|
supports_check_mode=True,
|
|
mutually_exclusive=(("password", "token"),),
|
|
required_if=[("action", "create_release", ["tag"]), ("action", "create_release", ["password", "token"], True)],
|
|
)
|
|
|
|
if not HAS_GITHUB_API:
|
|
module.fail_json(msg=missing_required_lib("github3.py >= 1.0.0a3"), exception=GITHUB_IMP_ERR)
|
|
|
|
repo = module.params["repo"]
|
|
user = module.params["user"]
|
|
password = module.params["password"]
|
|
login_token = module.params["token"]
|
|
action = module.params["action"]
|
|
tag = module.params.get("tag")
|
|
target = module.params.get("target")
|
|
name = module.params.get("name")
|
|
body = module.params.get("body")
|
|
draft = module.params.get("draft")
|
|
prerelease = module.params.get("prerelease")
|
|
|
|
# login to github
|
|
try:
|
|
if password:
|
|
gh_obj = github3.login(user, password=password)
|
|
elif login_token:
|
|
gh_obj = github3.login(token=login_token)
|
|
else:
|
|
gh_obj = github3.GitHub()
|
|
|
|
# GitHub's token formats:
|
|
# - ghp_ - Personal access token (classic)
|
|
# - github_pat_ - Fine-grained personal access token
|
|
# - gho_ - OAuth access token
|
|
# - ghu_ - User access token for a GitHub App
|
|
# - ghs_ - Installation access token for a GitHub App
|
|
# - ghr_ - Refresh token for a GitHub App
|
|
#
|
|
# References:
|
|
# https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/about-authentication-to-github#githubs-token-formats
|
|
#
|
|
# Test if we're actually logged in, but skip this check for some token prefixes
|
|
SKIPPED_TOKEN_PREFIXES = ["ghs_"]
|
|
if password or (login_token and not any(login_token.startswith(prefix) for prefix in SKIPPED_TOKEN_PREFIXES)):
|
|
gh_obj.me()
|
|
except github3.exceptions.AuthenticationFailed as e:
|
|
module.fail_json(
|
|
msg=f"Failed to connect to GitHub: {e}",
|
|
details=f"Please check username and password or token for repository {repo}",
|
|
)
|
|
except github3.exceptions.GitHubError as e:
|
|
module.fail_json(
|
|
msg=f"GitHub API error: {e}", details=f"Please check username and password or token for repository {repo}"
|
|
)
|
|
|
|
repository = gh_obj.repository(user, repo)
|
|
|
|
if not repository:
|
|
module.fail_json(msg=f"Repository {user}/{repo} doesn't exist")
|
|
|
|
if action == "latest_release":
|
|
release = repository.latest_release()
|
|
if release:
|
|
module.exit_json(tag=release.tag_name)
|
|
else:
|
|
module.exit_json(tag=None)
|
|
|
|
if action == "create_release":
|
|
release_exists = repository.release_from_tag(tag)
|
|
if release_exists:
|
|
module.exit_json(changed=False, msg=f"Release for tag {tag} already exists.")
|
|
|
|
release = repository.create_release(tag, target, name, body, draft, prerelease)
|
|
if release:
|
|
module.exit_json(changed=True, tag=release.tag_name)
|
|
else:
|
|
module.exit_json(changed=False, tag=None)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
main()
|