Compare commits
No commits in common. "d6e0d933d8c181b08599db3264446a7458fdca43" and "09c4d9537680e31c60262f8a1452dbc6a1d84d37" have entirely different histories.
d6e0d933d8
...
09c4d95376
|
|
@ -1,8 +1,5 @@
|
||||||
import subprocess
|
import subprocess
|
||||||
import http.client
|
|
||||||
import json
|
|
||||||
import os
|
import os
|
||||||
from base64 import b64encode
|
|
||||||
|
|
||||||
REMOVE_PATHS = [
|
REMOVE_PATHS = [
|
||||||
{% if cookiecutter.open_source_license == "Proprietary" %} "LICENSE", {% endif %}
|
{% if cookiecutter.open_source_license == "Proprietary" %} "LICENSE", {% endif %}
|
||||||
|
|
@ -44,69 +41,6 @@ def get_secret(secret_name: str):
|
||||||
"please enter you gitea api token:"
|
"please enter you gitea api token:"
|
||||||
)
|
)
|
||||||
|
|
||||||
def get_new_gitea_token(
|
|
||||||
connection: http.client.HTTPSConnection, new_token_name: str, user: str, token: str
|
|
||||||
) -> str:
|
|
||||||
auth = b64encode(f"{user}:{token}".encode("utf-8")).decode("ascii")
|
|
||||||
connection.request(
|
|
||||||
"POST",
|
|
||||||
f"/api/v1/users/{user}/tokens",
|
|
||||||
json.dumps(
|
|
||||||
{
|
|
||||||
"name": new_token_name,
|
|
||||||
}
|
|
||||||
),
|
|
||||||
{
|
|
||||||
"Authorization": f"Basic {auth}",
|
|
||||||
"content-type": "application/json",
|
|
||||||
},
|
|
||||||
)
|
|
||||||
response = connection.getresponse()
|
|
||||||
status = response.status
|
|
||||||
if status != 201:
|
|
||||||
print(
|
|
||||||
f"\033[38;2;255;0;0mInvalid response from gitea while creating a new token: {status} ({response.reason})\033[0m"
|
|
||||||
)
|
|
||||||
print(response.read())
|
|
||||||
exit(1)
|
|
||||||
data = json.load(response)
|
|
||||||
return data["sha1"]
|
|
||||||
|
|
||||||
def push_woodpecker_secret(
|
|
||||||
connection: http.client.HTTPSConnection,
|
|
||||||
repo: str,
|
|
||||||
secret_name: str,
|
|
||||||
secret: str,
|
|
||||||
woodpecker_token: str,
|
|
||||||
images: list[str] | None = None
|
|
||||||
):
|
|
||||||
if images is None: images = []
|
|
||||||
connection.request(
|
|
||||||
"POST",
|
|
||||||
f"/api/repos/{repo}/secrets",
|
|
||||||
json.dumps(
|
|
||||||
{
|
|
||||||
"name": secret_name,
|
|
||||||
"value": secret,
|
|
||||||
"image": images,
|
|
||||||
"event": ["push", "tag"],
|
|
||||||
}
|
|
||||||
),
|
|
||||||
{
|
|
||||||
"Authorization": f"Bearer {woodpecker_token}",
|
|
||||||
"content-type": "application/json",
|
|
||||||
},
|
|
||||||
)
|
|
||||||
response = connection.getresponse()
|
|
||||||
status = response.status
|
|
||||||
if status != 200:
|
|
||||||
print(
|
|
||||||
f"\033[38;2;255;0;0mInvalid response from woodpecker when sending a new secret: {status} ({response.reason})\033[0m"
|
|
||||||
)
|
|
||||||
print(response.read())
|
|
||||||
exit(1)
|
|
||||||
response.read()
|
|
||||||
|
|
||||||
|
|
||||||
if {{cookiecutter.generate_gitea_project}}:
|
if {{cookiecutter.generate_gitea_project}}:
|
||||||
try:
|
try:
|
||||||
|
|
@ -114,9 +48,9 @@ if {{cookiecutter.generate_gitea_project}}:
|
||||||
except ModuleNotFoundError:
|
except ModuleNotFoundError:
|
||||||
print("module `giteapy` is not availabled, repository not created")
|
print("module `giteapy` is not availabled, repository not created")
|
||||||
exit()
|
exit()
|
||||||
GITEA_API_KEY = get_secret("Gitea Token")
|
API_KEY = get_secret("Gitea Token")
|
||||||
configuration = giteapy.Configuration()
|
configuration = giteapy.Configuration()
|
||||||
configuration.api_key["access_token"] = GITEA_API_KEY
|
configuration.api_key["access_token"] = API_KEY
|
||||||
client = giteapy.ApiClient(configuration)
|
client = giteapy.ApiClient(configuration)
|
||||||
client.configuration.host = "{{ cookiecutter.gitea_url }}/api/v1"
|
client.configuration.host = "{{ cookiecutter.gitea_url }}/api/v1"
|
||||||
api_instance = giteapy.UserApi(client)
|
api_instance = giteapy.UserApi(client)
|
||||||
|
|
@ -127,6 +61,10 @@ if {{cookiecutter.generate_gitea_project}}:
|
||||||
|
|
||||||
|
|
||||||
if {{cookiecutter.generate_gitea_project}} and {{cookiecutter.configure_ci}}:
|
if {{cookiecutter.generate_gitea_project}} and {{cookiecutter.configure_ci}}:
|
||||||
|
import http.client
|
||||||
|
|
||||||
|
# import json
|
||||||
|
|
||||||
api_instance = giteapy.RepositoryApi(client)
|
api_instance = giteapy.RepositoryApi(client)
|
||||||
options = giteapy.AddCollaboratorOption("read")
|
options = giteapy.AddCollaboratorOption("read")
|
||||||
api_instance.repo_add_collaborator(
|
api_instance.repo_add_collaborator(
|
||||||
|
|
@ -135,18 +73,16 @@ if {{cookiecutter.generate_gitea_project}} and {{cookiecutter.configure_ci}}:
|
||||||
"{{ cookiecutter.woodpecker_gitea_user }}",
|
"{{ cookiecutter.woodpecker_gitea_user }}",
|
||||||
body=options,
|
body=options,
|
||||||
)
|
)
|
||||||
connection_gitea = http.client.HTTPSConnection("git.pains-perdus.fr")
|
|
||||||
GITEA_API_KEY = get_new_gitea_token(connection_gitea, "CI {{ cookiecutter.git_user }}/{{ cookiecutter.project_slug }}", "{{ cookiecutter.git_user }}", GITEA_API_KEY)
|
API_KEY = get_secret("Woodpecker Token")
|
||||||
WOODPECKER_API_KEY = get_secret("Woodpecker Token")
|
|
||||||
WOODPECKER_SERVER = "{{ cookiecutter.woodpecker_server }}".removeprefix("https://")
|
WOODPECKER_SERVER = "{{ cookiecutter.woodpecker_server }}".removeprefix("https://")
|
||||||
origin = "{{ cookiecutter.git_origin }}"
|
origin = "{{ cookiecutter.git_origin }}"
|
||||||
repo = "/".join(origin.removesuffix(".git").split(":")[-1].split("/")[-2:])
|
repo = "/".join(origin.removesuffix(".git").split(":")[-1].split("/")[-2:])
|
||||||
|
|
||||||
connection = http.client.HTTPSConnection(WOODPECKER_SERVER)
|
connection = http.client.HTTPSConnection(WOODPECKER_SERVER)
|
||||||
connection.request(
|
connection.request(
|
||||||
"GET",
|
"GET",
|
||||||
"/api/user/repos?all=true&flush=true",
|
"/api/user/repos?all=true&flush=true",
|
||||||
headers={"Authorization": f"Bearer {WOODPECKER_API_KEY}"},
|
headers={"Authorization": f"Bearer {API_KEY}"},
|
||||||
)
|
)
|
||||||
response = connection.getresponse()
|
response = connection.getresponse()
|
||||||
status = response.status
|
status = response.status
|
||||||
|
|
@ -161,7 +97,7 @@ if {{cookiecutter.generate_gitea_project}} and {{cookiecutter.configure_ci}}:
|
||||||
"POST",
|
"POST",
|
||||||
f"/api/repos/{repo}",
|
f"/api/repos/{repo}",
|
||||||
headers={
|
headers={
|
||||||
"Authorization": f"Bearer {WOODPECKER_API_KEY}",
|
"Authorization": f"Bearer {API_KEY}",
|
||||||
"referer": f"https://{WOODPECKER_SERVER}/repo/add",
|
"referer": f"https://{WOODPECKER_SERVER}/repo/add",
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
@ -171,16 +107,7 @@ if {{cookiecutter.generate_gitea_project}} and {{cookiecutter.configure_ci}}:
|
||||||
print(
|
print(
|
||||||
f"\033[38;2;255;0;0mInvalid response from woodpecker while linking repo: {status} ({response.reason})\033[0m"
|
f"\033[38;2;255;0;0mInvalid response from woodpecker while linking repo: {status} ({response.reason})\033[0m"
|
||||||
)
|
)
|
||||||
print(response.read())
|
|
||||||
exit(1)
|
exit(1)
|
||||||
response.read()
|
|
||||||
push_woodpecker_secret(
|
|
||||||
connection,
|
|
||||||
repo,
|
|
||||||
"gitea_token",
|
|
||||||
GITEA_API_KEY,
|
|
||||||
WOODPECKER_API_KEY
|
|
||||||
)
|
|
||||||
|
|
||||||
if {{cookiecutter.generate_gitea_project}}:
|
if {{cookiecutter.generate_gitea_project}}:
|
||||||
subprocess.call(["git", "remote", "add", "origin", "{{ cookiecutter.git_origin }}"])
|
subprocess.call(["git", "remote", "add", "origin", "{{ cookiecutter.git_origin }}"])
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue