2022-08-26 19:08:52 +07:00
|
|
|
#!/usr/bin/env python
|
2022-07-18 03:48:15 +07:00
|
|
|
|
|
|
|
"""
|
|
|
|
Quick and dirty script for things that I can't/don't have time to do properly yet
|
|
|
|
TODO: retire this script
|
|
|
|
"""
|
|
|
|
|
2022-07-23 23:59:29 +07:00
|
|
|
import base64
|
2022-07-18 03:48:15 +07:00
|
|
|
import json
|
|
|
|
import requests
|
2022-07-23 23:59:29 +07:00
|
|
|
import sys
|
2023-02-22 18:33:48 +07:00
|
|
|
import urllib
|
2022-07-18 03:48:15 +07:00
|
|
|
|
2022-07-23 23:59:29 +07:00
|
|
|
from rich.console import Console
|
|
|
|
from kubernetes import client, config
|
2022-07-18 03:48:15 +07:00
|
|
|
|
|
|
|
# https://git.khuedoan.com/user/settings/applications
|
|
|
|
# Doing this properly inside the cluster requires:
|
|
|
|
# - Kubernetes service account
|
|
|
|
# - Vault Kubernetes auth
|
2022-07-23 23:59:29 +07:00
|
|
|
config.load_kube_config(config_file='./metal/kubeconfig.yaml')
|
2022-07-18 03:48:15 +07:00
|
|
|
|
2022-07-23 23:59:29 +07:00
|
|
|
gitea_host = client.NetworkingV1Api().read_namespaced_ingress('gitea', 'gitea').spec.rules[0].host
|
|
|
|
gitea_user = base64.b64decode(client.CoreV1Api().read_namespaced_secret('gitea-admin-secret', 'gitea').data['username']).decode("utf-8")
|
|
|
|
gitea_pass = base64.b64decode(client.CoreV1Api().read_namespaced_secret('gitea-admin-secret', 'gitea').data['password']).decode("utf-8")
|
2023-02-22 18:33:48 +07:00
|
|
|
gitea_url = f"http://{gitea_user}:{urllib.parse.quote_plus(gitea_pass)}@{gitea_host}"
|
2022-07-18 03:48:15 +07:00
|
|
|
|
2022-07-23 23:59:29 +07:00
|
|
|
vault_host = client.NetworkingV1Api().read_namespaced_ingress('vault', 'vault').spec.rules[0].host
|
|
|
|
vault_token = base64.b64decode(client.CoreV1Api().read_namespaced_secret('vault-unseal-keys', 'vault').data['vault-root']).decode("utf-8")
|
|
|
|
vault_url = f"https://{vault_host}"
|
|
|
|
|
2022-07-18 03:48:15 +07:00
|
|
|
|
|
|
|
def create_vault_secret(path: str, data) -> None:
|
|
|
|
requests.post(
|
2022-07-23 23:59:29 +07:00
|
|
|
url=f"{vault_url}/v1/secret/data/{path}",
|
2022-07-18 03:48:15 +07:00
|
|
|
headers={
|
|
|
|
'X-Vault-Token': vault_token
|
|
|
|
},
|
|
|
|
data=json.dumps({
|
|
|
|
'data': data
|
|
|
|
})
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def setup_gitea_access_token(name: str) -> None:
|
|
|
|
current_tokens = requests.get(
|
|
|
|
url=f"{gitea_url}/api/v1/users/{gitea_user}/tokens",
|
|
|
|
).json()
|
|
|
|
|
|
|
|
if not any(token['name'] == name for token in current_tokens):
|
|
|
|
resp = requests.post(
|
|
|
|
url=f"{gitea_url}/api/v1/users/{gitea_user}/tokens",
|
|
|
|
headers={
|
|
|
|
'Content-Type': 'application/json'
|
|
|
|
},
|
|
|
|
data=json.dumps({
|
|
|
|
'name': name
|
|
|
|
})
|
|
|
|
)
|
|
|
|
|
|
|
|
if resp.status_code == 201:
|
|
|
|
create_vault_secret(
|
|
|
|
f"gitea/{name}",
|
|
|
|
{
|
|
|
|
'token': resp.json()['sha1']
|
|
|
|
}
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
print(f"Error creating access token {name} ({resp.status_code})")
|
|
|
|
print(resp.content)
|
|
|
|
sys.exit(1)
|
|
|
|
|
|
|
|
|
|
|
|
def setup_gitea_oauth_app(name: str, redirect_uri: str) -> None:
|
|
|
|
current_apps = requests.get(
|
|
|
|
url=f"{gitea_url}/api/v1/user/applications/oauth2",
|
|
|
|
).json()
|
|
|
|
|
|
|
|
if not any(app['name'] == name for app in current_apps):
|
|
|
|
resp = requests.post(
|
|
|
|
url=f"{gitea_url}/api/v1/user/applications/oauth2",
|
|
|
|
headers={
|
|
|
|
'Content-Type': 'application/json'
|
|
|
|
},
|
|
|
|
data=json.dumps({
|
|
|
|
'name': name,
|
|
|
|
'redirect_uris': [redirect_uri]
|
|
|
|
})
|
|
|
|
)
|
|
|
|
|
|
|
|
if resp.status_code == 201:
|
|
|
|
create_vault_secret(
|
|
|
|
f"gitea/{name}",
|
|
|
|
{
|
|
|
|
'client_id': resp.json()['client_id'],
|
|
|
|
'client_secret': resp.json()['client_secret']
|
|
|
|
}
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
print(f"Error creating OAuth application {name} ({resp.status_code})")
|
|
|
|
print(resp.content)
|
|
|
|
sys.exit(1)
|
|
|
|
|
|
|
|
|
|
|
|
def main() -> None:
|
2022-07-23 23:59:29 +07:00
|
|
|
|
2022-07-18 03:48:15 +07:00
|
|
|
with Console().status("Completing the remaining sorcery"):
|
|
|
|
gitea_access_tokens = [
|
|
|
|
'renovate'
|
|
|
|
]
|
|
|
|
|
|
|
|
gitea_oauth_apps = [
|
2022-07-23 23:59:29 +07:00
|
|
|
{'name': 'dex', 'redirect_uri': f"https://{client.NetworkingV1Api().read_namespaced_ingress('dex', 'dex').spec.rules[0].host}/callback"}
|
2022-07-18 03:48:15 +07:00
|
|
|
]
|
|
|
|
|
|
|
|
for token_name in gitea_access_tokens:
|
|
|
|
setup_gitea_access_token(token_name)
|
|
|
|
|
|
|
|
for app in gitea_oauth_apps:
|
|
|
|
setup_gitea_oauth_app(app['name'], app['redirect_uri'])
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|