Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Allow SSO in Argo Workflows and re-use Dex server from Argo CD deployment #388

Merged
merged 2 commits into from
Jan 15, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion install/roles/automation-hub/defaults/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
# defaults file
infra_monitoring_namespace: skodjob-monitoring
infra_ci_namespace: skodjob-pipelines
infra_workflow_namespace: skodjob-ci
infra_workflows_namespace: skodjob-ci
infra_argo_namespace: skodjob-gitops

openshift_pipelines_namespace: openshift-pipelines
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,7 @@
namespace: "{{ infra_argo_namespace }}"
state: present
verify_ssl: no
src: templates/argo/install/argocd.yaml
template: templates/argo/install/argocd.yaml
apply: true
retries: 20
delay: 5
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
- name: Create {{ infra_workflow_namespace }} namespace on Infra cluster
- name: Create {{ infra_workflows_namespace }} namespace on Infra cluster
kubernetes.core.k8s:
kubeconfig: "{{ kubeconfig_path }}/{{ infra_context_name }}"
verify_ssl: no
Expand All @@ -8,19 +8,19 @@
apiVersion: v1
kind: Namespace
metadata:
name: "{{ infra_workflow_namespace }}"
name: "{{ infra_workflows_namespace }}"
labels:
project: "skodjob"
secret: "cert-manager"
strimzi.io/sync-secrets: "true"

- name: Clean helm releases for workflows
shell: "oc delete secret -l owner=helm -n {{ infra_workflow_namespace }} || true"
shell: "oc delete secret -l owner=helm -n {{ infra_workflows_namespace }} || true"
environment:
KUBECONFIG: "{{ kubeconfig_path }}/{{ infra_context_name }}"

- name: Make default SA admin in {{ infra_workflow_namespace }} namespace
shell: "oc adm policy add-role-to-user admin system:serviceaccount:{{ infra_workflow_namespace }}:default -n {{ infra_workflow_namespace }}"
- name: Make default SA admin in {{ infra_workflows_namespace }} namespace
shell: "oc adm policy add-role-to-user admin system:serviceaccount:{{ infra_workflows_namespace }}:default -n {{ infra_workflows_namespace }}"
environment:
KUBECONFIG: "{{ kubeconfig_path }}/{{ infra_context_name }}"

Expand All @@ -31,10 +31,10 @@

- name: Install Argo Workflow
kubernetes.core.helm:
name: "{{ infra_workflow_namespace }}"
name: "{{ infra_workflows_namespace }}"
kubeconfig: "{{ kubeconfig_path }}/{{ infra_context_name }}"
chart_ref: argo/argo-workflows
release_namespace: "{{ infra_workflow_namespace }}"
release_namespace: "{{ infra_workflows_namespace }}"
create_namespace: True
force: True
wait: True
Expand All @@ -47,23 +47,40 @@
server:
replicas: 3
authModes:
- client
- server
- sso
ingress:
enabled: true
hosts:
- "{{ argo_workflow_url }}"
- "{{ argo_workflows_url }}"
tls:
- secretName: "{{ cm_certificate_secret }}"
hosts:
- "{{ argo_workflow_url }}"
- "{{ argo_workflows_url }}"
# Configuration for SSO - using ArgoCD Dex server that is connected to OpenShift OAuth Proxy
sso:
enabled: true
insecureSkipVerify: false
issuer: "https://{{ argo_cd_url }}/api/dex"
sessionExpiry: 240h
clientId:
name: "{{ argo_workflows_sso_secret_name }}"
key: client-id
clientSecret:
name: "{{ argo_workflows_sso_secret_name }}"
key: client-secret
redirectUrl: "https://{{ argo_workflows_url }}/oauth2/callback"
# RBAC
rbac:
enabled: false
scopes:
- groups

- name: Install Argo Events
kubernetes.core.helm:
name: "{{ infra_workflow_namespace }}-events"
name: "{{ infra_workflows_namespace }}-events"
kubeconfig: "{{ kubeconfig_path }}/{{ infra_context_name }}"
chart_ref: argo/argo-events
release_namespace: "{{ infra_workflow_namespace }}"
release_namespace: "{{ infra_workflows_namespace }}"
create_namespace: True
purge: True
force: True
Expand All @@ -76,7 +93,7 @@
- name: Create EventBus and ServiceAccount
kubernetes.core.k8s:
kubeconfig: "{{ kubeconfig_path }}/{{ infra_context_name }}"
namespace: "{{ infra_workflow_namespace }}"
namespace: "{{ infra_workflows_namespace }}"
state: present
verify_ssl: no
src: "{{ item }}"
Expand All @@ -92,7 +109,7 @@
- name: Wait for EventBus creation
kubernetes.core.k8s_info:
kubeconfig: "{{ kubeconfig_path }}/{{ infra_context_name }}"
namespace: "{{ infra_workflow_namespace }}"
namespace: "{{ infra_workflows_namespace }}"
kind: EventBus
api_version: argoproj.io/v1alpha1
name: skodjob
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@
- "{{ infra_ci_namespace }}"
- "{{ openshift_pipelines_namespace }}"
- "{{ infra_argo_namespace }}"
- "{{ infra_workflow_namespace }}"
- "{{ infra_workflows_namespace }}"

- name: "Create ServiceAccount for remote access on {{ worker.name }}"
kubernetes.core.k8s:
Expand Down Expand Up @@ -70,7 +70,7 @@
loop_control:
loop_var: namespaceName
loop:
- "{{ infra_workflow_namespace }}"
- "{{ infra_workflows_namespace }}"
- "{{ infra_ci_namespace }}"

# TODO - investigate deletion of this
Expand All @@ -95,7 +95,7 @@
loop_var: namespaceName
loop:
- "{{ infra_argo_namespace }}"
- "{{ infra_workflow_namespace }}"
- "{{ infra_workflows_namespace }}"
- "{{ openshift_pipelines_namespace }}"
- "{{ infra_ci_namespace }}"

Expand Down
8 changes: 4 additions & 4 deletions install/roles/automation-hub/tasks/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -95,10 +95,10 @@
tags: [acs, infra, security, never]

- import_tasks: infra-setup/install/install_strimzi.yaml
tags: [infra, ci, workflow, strimzi, never]
tags: [infra, ci, workflows, strimzi, never]

- import_tasks: infra-setup/install/install_argo_workflow.yaml
tags: [infra, ci, workflow, never]
- import_tasks: infra-setup/install/install_argo_workflows.yaml
tags: [infra, ci, workflows, never]

- import_tasks: infra-setup/install/install_links.yaml
tags: [infra, console-link, links, never]
Expand All @@ -123,7 +123,7 @@
tags: [tekton-pipelines, strimzi-infra, never]

- import_tasks: scenario-deployment/workflows/infra-argo-workflows.yaml
tags: [workflow, infra, never]
tags: [workflows, infra, never]

# Teardown
- import_tasks: infra-setup/delete/delete_argo.yaml
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
- name: Create Infra Argo Workflows
kubernetes.core.k8s:
kubeconfig: "{{ kubeconfig_path }}/{{ infra_context_name }}"
namespace: "{{ infra_workflow_namespace }}"
namespace: "{{ infra_workflows_namespace }}"
state: present
template: "{{ item }}"
verify_ssl: no
Expand All @@ -14,7 +14,7 @@
- name: Create EventSources and Sensors
kubernetes.core.k8s:
kubeconfig: "{{ kubeconfig_path }}/{{ infra_context_name }}"
namespace: "{{ infra_workflow_namespace }}"
namespace: "{{ infra_workflows_namespace }}"
state: present
template: "{{ item }}"
verify_ssl: no
Expand All @@ -24,7 +24,7 @@
- name: Wait for EventSources - Deployed
kubernetes.core.k8s_info:
kubeconfig: "{{ kubeconfig_path }}/{{ infra_context_name }}"
namespace: "{{ infra_workflow_namespace }}"
namespace: "{{ infra_workflows_namespace }}"
kind: EventSource
api_version: argoproj.io/v1alpha1
name: "{{ item }}"
Expand All @@ -47,7 +47,7 @@
- name: Wait for EventSources - SourcesProvided
kubernetes.core.k8s_info:
kubeconfig: "{{ kubeconfig_path }}/{{ infra_context_name }}"
namespace: "{{ infra_workflow_namespace }}"
namespace: "{{ infra_workflows_namespace }}"
kind: EventSource
api_version: argoproj.io/v1alpha1
name: "{{ item }}"
Expand All @@ -62,7 +62,7 @@
- name: Wait for Sensors - Deployed
kubernetes.core.k8s_info:
kubeconfig: "{{ kubeconfig_path }}/{{ infra_context_name }}"
namespace: "{{ infra_workflow_namespace }}"
namespace: "{{ infra_workflows_namespace }}"
kind: Sensor
api_version: argoproj.io/v1alpha1
name: "{{ item }}"
Expand All @@ -85,7 +85,7 @@
- name: Wait for Sensors - TriggersProvided
kubernetes.core.k8s_info:
kubeconfig: "{{ kubeconfig_path }}/{{ infra_context_name }}"
namespace: "{{ infra_workflow_namespace }}"
namespace: "{{ infra_workflows_namespace }}"
kind: Sensor
api_version: argoproj.io/v1alpha1
name: "{{ item }}"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ metadata:
owner-name: automation-hub
name: automation-hub-eventsource-svc
spec:
host: "automation-hub-eventsource-svc-{{ infra_workflow_namespace }}.apps.{{ infra_root_domain }}"
host: "automation-hub-eventsource-svc-{{ infra_workflows_namespace }}.apps.{{ infra_root_domain }}"
port:
targetPort: 12000
to:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ spec:
- name: status
value: "{% raw %}{{ workflow.status }}{% endraw %}"
- name: button_url
value: "https://{{ argo_workflow_url }}/workflows/argo/{% raw %}{{ workflow.name }}{% endraw %}"
value: "https://{{ argo_workflows_url }}/workflows/argo/{% raw %}{{ workflow.name }}{% endraw %}"
- name: button_text
value: "Workflow link :argocd:"
- name: url
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ spec:
- name: status
value: "{% raw %}{{ workflow.status }}{% endraw %}"
- name: button_url
value: "https://{{ argo_workflow_url }}/workflows/argo/{% raw %}{{ workflow.name }}{% endraw %}"
value: "https://{{ argo_workflows_url }}/workflows/argo/{% raw %}{{ workflow.name }}{% endraw %}"
- name: button_text
value: "Workflow link :argocd:"
- name: url
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,7 @@ spec:
- name: status
value: "{% raw %}{{ workflow.status }}{% endraw %}"
- name: button_url
value: "https://{{ argo_workflow_url }}/workflows/argo/{% raw %}{{ workflow.name }}{% endraw %}"
value: "https://{{ argo_workflows_url }}/workflows/argo/{% raw %}{{ workflow.name }}{% endraw %}"
- name: button_text
value: "Workflow link :argocd:"
- name: url
Expand Down
31 changes: 31 additions & 0 deletions install/roles/automation-hub/templates/argo/install/argocd.yaml
Original file line number Diff line number Diff line change
@@ -1,3 +1,18 @@
---
# This is a secret used for Dex server to be usable by Argo Workflows
apiVersion: v1
kind: Secret
metadata:
name: argo-workflows-sso
labels:
project: skodjob
app: argo
annotations:
replicator.v1.mittwald.de/replicate-to: "{{ infra_workflows_namespace }}"
data:
client-id: "{{ argo_workflows_client_id }}"
client-secret: "{{ argo_workflows_client_secret }}"
---
apiVersion: argoproj.io/v1beta1
kind: ArgoCD
metadata:
Expand All @@ -6,6 +21,7 @@ metadata:
project: skodjob
spec:
server:
replicas: 3
autoscale:
enabled: true
grpc:
Expand Down Expand Up @@ -90,6 +106,21 @@ spec:
requests:
cpu: 250m
memory: 128Mi
env:
- name: ARGO_WORKFLOWS_SSO_CLIENT_SECRET
valueFrom:
secretKeyRef:
name: "{{ argo_workflows_sso_secret_name }}"
key: client-secret
config: |
# Setting staticClients allows Argo Workflows to use Argo CD's Dex installation for authentication
staticClients:
# This is the OIDC client ID in plaintext
- id: {{ argo_workflows_client_id }}
name: Argo Workflows
redirectURIs:
- https://{{ argo_workflows_url }}/oauth2/callback
secretEnv: ARGO_WORKFLOWS_SSO_CLIENT_SECRET
ha:
enabled: false
resources:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,6 @@ spec:

section: Skodjob
href: >-
https://{{ argo_workflow_url }}
https://{{ argo_workflows_url }}
location: ApplicationMenu
text: Skodjob-CI
Binary file modified install/secrets/clusters.yaml
Binary file not shown.
Loading