Skip to content

Commit

Permalink
infra deploy pipeline
Browse files Browse the repository at this point in the history
Signed-off-by: Gerd Oberlechner <[email protected]>
  • Loading branch information
geoberle committed Oct 28, 2024
1 parent 49d5e10 commit 15dab67
Show file tree
Hide file tree
Showing 13 changed files with 668 additions and 748 deletions.
581 changes: 238 additions & 343 deletions .github/workflows/aro-hcp-dev-env-cd.yml

Large diffs are not rendered by default.

776 changes: 388 additions & 388 deletions .github/workflows/cs-integration-env-cd.yml

Large diffs are not rendered by default.

3 changes: 3 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,9 @@ fmt: $(GOIMPORTS)
# Infra
#

infra.region:
cd dev-infrastructure && DEPLOY_ENV=$(DEPLOY_ENV) make region

infra.svc:
cd dev-infrastructure && DEPLOY_ENV=$(DEPLOY_ENV) make svc.init

Expand Down
1 change: 1 addition & 0 deletions backend/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ image:
rm -f archive.tar.gz

push: image
az acr login --name ${ARO_HCP_IMAGE_ACR}
docker push ${ARO_HCP_BACKEND_IMAGE}

deploy:
Expand Down
2 changes: 1 addition & 1 deletion config/config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,7 @@ clouds:
clusterServiceImageTag: cf23767
clusterServiceImageRepo: app-sre/uhc-clusters-service
# Shared SVC KV
serviceKeyVaultName: 'aro-hcp-dev-svc-kv'
serviceKeyVaultName: 'aro-hcp-dev-global-kv'
serviceKeyVaultRG: 'global'
serviceKeyVaultRegion: 'westus3'
serviceKeyVaultPrivate: false
Expand Down
1 change: 1 addition & 0 deletions dev-infrastructure/.gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -6,4 +6,5 @@ configurations/acr-svc.bicepparam
configurations/acr-ocp.bicepparam
configurations/acr.bicepparam
configurations/image-sync.bicepparam
configurations/dev-role-assignments.bicepparam
config.mk
19 changes: 14 additions & 5 deletions dev-infrastructure/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ fmt:

lint:
set -e; \
FILES="$$(find . -type f -name "*.bicep*")"; \
FILES="$$(find . -type f -name "*.bicep*" ! -name "*.tmpl.bicepparam")"; \
for file in $$FILES; do \
echo "az bicep lint --file $${file}"; \
az bicep lint --file $$file; \
Expand Down Expand Up @@ -188,7 +188,7 @@ svc.wait:
@./ensure-no-running-deployment.sh $(SVC_RESOURCEGROUP) $(SVC_RG_DEPLOYMENT_NAME)
.PHONY: svc.wait

svc: svc.wait svc.rg cleanup-orphaned-rolebindings region
svc: svc.wait svc.rg cleanup-orphaned-rolebindings
az deployment group create \
--name "svc" \
--resource-group $(SVC_RESOURCEGROUP) \
Expand Down Expand Up @@ -223,7 +223,7 @@ svc.aks.kubeconfigfile:
@echo ${SVC_KUBECONFIG_FILE}
.PHONY: svc.aks.kubeconfigfile

svc.init: svc svc.aks.admin-access svc.aks.kubeconfig svc.enable-aks-metrics
svc.init: region svc svc.aks.admin-access svc.aks.kubeconfig svc.enable-aks-metrics
.PHONY: svc.init

svc.what-if: svc.rg
Expand All @@ -235,6 +235,15 @@ svc.what-if: svc.rg
configurations/svc-cluster.bicepparam
.PHONY: svc.what-if

svc.dev-role-assignments:
@./ensure-no-running-deployment.sh $(SC_RESOURCEGROUP) svc-roleassigns
az deployment group create \
--name svc-roleassigns \
--resource-group "${SC_RESOURCEGROUP}" \
--template-file templates/dev-roleassignments.bicep \
--parameters configurations/dev-role-assignments.bicepparam
--parameters principalID=${PRINCIPAL_ID}

svc.clean:
@if [ "$$(az group exists --name $(SVC_RESOURCEGROUP))" = "true" ]; then \
az group delete -g $(SVC_RESOURCEGROUP); \
Expand All @@ -258,7 +267,7 @@ mgmt.wait:
@./ensure-no-running-deployment.sh $(MGMT_RESOURCEGROUP) $(MGMG_RG_DEPLOYMENT_NAME)
.PHONY: mgmt.wait

mgmt: mgmt.wait mgmt.rg cleanup-orphaned-rolebindings region
mgmt: mgmt.wait mgmt.rg cleanup-orphaned-rolebindings
az deployment group create \
--name $(MGMG_RG_DEPLOYMENT_NAME) \
--resource-group $(MGMT_RESOURCEGROUP) \
Expand Down Expand Up @@ -293,7 +302,7 @@ mgmt.aks.kubeconfigfile:
@echo ${MGMT_KUBECONFIG_FILE}
.PHONY: mgmt.aks.kubeconfigfile

mgmt.init: mgmt mgmt.aks.admin-access mgmt.aks.kubeconfig mgmt.enable-aks-metrics
mgmt.init: region mgmt mgmt.aks.admin-access mgmt.aks.kubeconfig mgmt.enable-aks-metrics
.PHONY: mgmt.init

mgmt.what-if: mgmt.rg
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
using '../templates/dev-roleassignments.bicep'

param aksClusterName = '{{ .aksName }}'
param grantCosmosAccess = true
param cosmosDBName = '{{ .frontendCosmosDBName }}'
param sharedKvNames = ['{{ .serviceKeyVaultName }}']
param sharedKvResourceGroup = '{{ .serviceKeyVaultRG }}'
param principalID = ''
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ param cosmosDBName string = 'replaceme'
param sharedKvNames array = []
param sharedKvResourceGroup string = 'global'
param location string = resourceGroup().location
param githubActionsPrincipalID string
param principalID string

// https://learn.microsoft.com/en-us/azure/aks/manage-azure-rbac#create-role-assignments-for-users-to-access-the-cluster
// Azure Kubernetes Service RBAC Cluster Admin
Expand All @@ -18,7 +18,7 @@ var aksClusterRbacClusterAdminRoleId = subscriptionResourceId(

// Grants Github Actions access to Cosmos data
param cosmosRoleDefinitionId string = '00000000-0000-0000-0000-000000000002'
var cosmosRoleAssignmentId = guid(cosmosRoleDefinitionId, githubActionsPrincipalID, cosmosDbAccount.id)
var cosmosRoleAssignmentId = guid(cosmosRoleDefinitionId, principalID, cosmosDbAccount.id)

// C O S M O S

Expand All @@ -33,10 +33,10 @@ resource cosmosDbAccount 'Microsoft.DocumentDB/databaseAccounts@2023-11-15' exis
// az aks command invoke --resource-group hcp-standalone-mshen --name aro-hcp-cluster-001 --command "kubectl get ns"
resource currentUserAksClusterAdmin 'Microsoft.Authorization/roleAssignments@2022-04-01' = {
scope: aksCluster
name: guid(location, aksClusterName, aksClusterRbacClusterAdminRoleId, githubActionsPrincipalID)
name: guid(location, aksClusterName, aksClusterRbacClusterAdminRoleId, principalID)
properties: {
roleDefinitionId: aksClusterRbacClusterAdminRoleId
principalId: githubActionsPrincipalID
principalId: principalID
}
}

Expand All @@ -45,7 +45,7 @@ resource sqlRoleAssignment 'Microsoft.DocumentDB/databaseAccounts/sqlRoleAssignm
parent: cosmosDbAccount
properties: {
roleDefinitionId: '/${subscription().id}/resourceGroups/${resourceGroup().name}/providers/Microsoft.DocumentDB/databaseAccounts/${cosmosDbAccount.name}/sqlRoleDefinitions/${cosmosRoleDefinitionId}'
principalId: githubActionsPrincipalID
principalId: principalID
scope: cosmosDbAccount.id
}
}
Expand All @@ -59,7 +59,7 @@ module keyVaultAccess '../modules/keyvault/keyvault-secret-access.bicep' = [
params: {
keyVaultName: name
roleName: 'Key Vault Secrets User'
managedIdentityPrincipalId: githubActionsPrincipalID
managedIdentityPrincipalId: principalID
}
}
]
1 change: 1 addition & 0 deletions frontend/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ image:
rm -f archive.tar.gz

push: image
az acr login --name ${ARO_HCP_IMAGE_ACR}
docker push ${ARO_HCP_FRONTEND_IMAGE}

deploy:
Expand Down
1 change: 1 addition & 0 deletions tooling/image-sync/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
config.mk
9 changes: 4 additions & 5 deletions tooling/image-sync/Makefile
Original file line number Diff line number Diff line change
@@ -1,9 +1,8 @@
SHELL = /bin/bash
DEPLOY_ENV ?= personal-dev
$(shell ../templatize.sh $(DEPLOY_ENV) config.tmpl.mk config.mk)
include config.mk
COMMIT = $(shell git rev-parse --short=7 HEAD)$(shell [[ $$(git status --porcelain) = "" ]] || echo -dirty)
CONFIG_PROFILE ?= dev
include ../../dev-infrastructure/configurations/$(CONFIG_PROFILE).mk
ARO_HCP_BASE_IMAGE ?= ${ARO_HCP_IMAGE_ACR}.azurecr.io
ARO_HCP_IMAGE_SYNC_IMAGE ?= $(ARO_HCP_BASE_IMAGE)/image-sync/component-sync

image-sync:
go build -tags=containers_image_openpgp,requirefips .
Expand All @@ -17,10 +16,10 @@ clean:
build-push: image push

image:
cp ../../image-sync/configuration/mvp-image-sync.yml config.yml
docker build --platform="linux/amd64" -f "./Dockerfile" -t ${ARO_HCP_IMAGE_SYNC_IMAGE}:${COMMIT} .

push:
az acr login --name ${ARO_HCP_IMAGE_ACR}
docker tag ${ARO_HCP_IMAGE_SYNC_IMAGE}:${COMMIT} ${ARO_HCP_IMAGE_SYNC_IMAGE}:latest
docker push ${ARO_HCP_IMAGE_SYNC_IMAGE}:${COMMIT}
docker push ${ARO_HCP_IMAGE_SYNC_IMAGE}:latest
Expand Down
2 changes: 2 additions & 0 deletions tooling/image-sync/config.tmpl.mk
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
ARO_HCP_BASE_IMAGE ?= {{ .acrName }}.azurecr.io
ARO_HCP_IMAGE_SYNC_IMAGE ?= $(ARO_HCP_BASE_IMAGE)/{{ .imageSyncImageRepo }}

0 comments on commit 15dab67

Please sign in to comment.