From 7f1796bd31d29309330d52884dc8461fe6cae1aa Mon Sep 17 00:00:00 2001 From: lars Date: Tue, 3 Oct 2023 14:58:51 -0500 Subject: [PATCH] Add Branch Name param --- deploy/portainer/.env | 4 +-- deploy/portainer/deploy.py | 54 +++++++++++++------------------------- 2 files changed, 20 insertions(+), 38 deletions(-) diff --git a/deploy/portainer/.env b/deploy/portainer/.env index 948fad3..5ac62d2 100644 --- a/deploy/portainer/.env +++ b/deploy/portainer/.env @@ -4,6 +4,6 @@ PORTAINER_EP=CICD-runner GITEA_API_KEY=f449c74ec7f04e54fe1e481eae43492b34cea406 DEPLOY_REPO_URL=https://dvgit.privatedns.org/lars/DeployTests DEPLOY_REF=refs/heads/main +DEPLOY_BRANCH=main DEPLOY_HOST=dvdemo.privatedns.org -DEPLOY_PROJECT=ManualDeployTests -DEPLOY_NAME=ManualDeploy \ No newline at end of file +DEPLOY_PROJECT=ManualDeployTests \ No newline at end of file diff --git a/deploy/portainer/deploy.py b/deploy/portainer/deploy.py index c64d9f8..caa0d54 100644 --- a/deploy/portainer/deploy.py +++ b/deploy/portainer/deploy.py @@ -20,8 +20,8 @@ required_env_vars = { 'GITEA_API_KEY': 'API-Key to access Gitea instance', 'DEPLOY_REPO_URL': 'The repository URL to deploy', 'DEPLOY_REF': 'The git ref to deploy', + 'DEPLOY_BRANCH': 'The branch to deploy' 'DEPLOY_HOST': 'The host name under which the deployment will be reachable', - 'DEPLOY_NAME': 'Custom name to use as the deployment name', } # Try getting all arguments from (in order): 1 command line, 2 .env file, 3 Environment @@ -44,26 +44,14 @@ if not_parsed: parser.print_help() sys.exit(1) -# Deploy variables to substitute in portainer deploy template -deploy_variables = {key: getattr(args, key) for key in - ['DEPLOY_REPO_URL', 'DEPLOY_HOST', 'DEPLOY_NAME', 'DEPLOY_REF'] -} -deploy_variables['DEPLOY_WEBHOOK'] = str(uuid.uuid4()) - -portainer=args.PORTAINER -portainer_api_key=args.PORTAINER_API_KEY -portainer_ep=args.PORTAINER_EP -gitea_api_key=args.GITEA_API_KEY -deploy_repo=deploy_variables['DEPLOY_REPO_URL'] -deploy_webhook=deploy_variables['DEPLOY_WEBHOOK'] -deploy_ref=deploy_variables['DEPLOY_REF'] +deploy_webhook = str(uuid.uuid4()) ### Find CICD-runner portainer environment endpointId ### portainer_headers = { 'Content-Type': 'application/json', - 'X-API-Key': portainer_api_key, + 'X-API-Key': args.PORTAINER_API_KEY } -endpoint_url = f'{portainer}/api/endpoints' +endpoint_url = f'{args.PORTAINER}/api/endpoints' json_endpoints = None try: response = requests.get(endpoint_url, headers=portainer_headers) @@ -75,13 +63,13 @@ except requests.exceptions.RequestException as err: endpoint_id = None for endpoint in json_endpoints: - if endpoint["Name"] == portainer_ep: + if endpoint["Name"] == args.PORTAINER_EP: endpoint_id = endpoint["Id"] break if endpoint_id is None: - raise Exception(f'Portainer endpoint \'{portainer_ep}\' not found.') + raise Exception(f'Portainer endpoint \'{args.PORTAINER_EP}\' not found.') else: - print(f'Found portainer endpoint \'{portainer_ep}\' has id: \'{endpoint_id}\'.') + print(f'Found portainer endpoint \'{args.PORTAINER_EP}\' has id: \'{endpoint_id}\'.') ### Template substitution for the portainer stack deployment ### @@ -90,31 +78,31 @@ portainer_deploy_payload = { "deploy/portainer/portainer_deploy.docker-compose.yml" ], "autoUpdate": { - "webhook": f"{deploy_variables['DEPLOY_WEBHOOK']}" + "webhook": deploy_webhook }, "composeFile": "docker-compose.yml", "env": [ { "name": "HOST", - "value": f"{deploy_variables['DEPLOY_HOST']}" + "value": args.DEPLOY_HOST }, { "name": "COMPOSE_PROJECT_NAME", - "value": f"{deploy_variables['DEPLOY_NAME']}" + "value": args.DEPLOY_BRANCH } ], "fromAppTemplate": False, - "name": f"{deploy_variables['DEPLOY_NAME']}", + "name": args.DEPLOY_BRANCH, "repositoryAuthentication": True, "repositoryUsername": "cicd", "repositoryPassword": "gJ6@$7ZjWGyV4%i", - "repositoryReferenceName": f"{deploy_variables['DEPLOY_REF']}", - "repositoryURL": f"{deploy_variables['DEPLOY_REPO_URL']}", + "repositoryReferenceName": args.DEPLOY_REF, + "repositoryURL": args.DEPLOY_REPO_URL, "tlsskipVerify": False } ### Deploy to portainer ### -deploy_url = f'{portainer}/api/stacks/create/standalone/repository?endpointId={endpoint_id}' +deploy_url = f'{args.PORTAINER}/api/stacks/create/standalone/repository?endpointId={endpoint_id}' try: response = requests.post(deploy_url, headers=portainer_headers, json=portainer_deploy_payload) response.raise_for_status() # Raise HTTPError for bad requests @@ -127,27 +115,21 @@ except requests.exceptions.RequestException as err: repo_url = urlparse(deploy_repo) gitea = f"{repo_url.scheme}://{repo_url.netloc}" repo_path = repo_url.path -repo_parts = repo_path.strip('/').split('/') -owner = repo_parts[0] -repo = repo_parts[1] - -ref_parts = deploy_ref.strip('/').split('/') -branch = ref_parts[-1] webhook_payload = { "type": "gitea", - "branch_filter": f"{branch}", + "branch_filter": f"{args.DEPLOY_BRANCH}", "config": { - "url": f"{portainer}/api/stacks/webhooks/{deploy_webhook}", + "url": f"{args.PORTAINER}/api/stacks/webhooks/{deploy_webhook}", "content_type": "json" }, "events": ["push"], # You can specify other events as needed "active": True } -webhook_url = f'{gitea}/api/v1/repos/{owner}/{repo}/hooks' +webhook_url = f'{gitea}/api/v1/repos/{repo_path}/hooks' webhook_headers = { - "Authorization": f"token {gitea_api_key}" + "Authorization": f"token {args.GITEA_API_KEY}" } try: response = requests.post(webhook_url, headers=webhook_headers, json=webhook_payload)