-
Notifications
You must be signed in to change notification settings - Fork 0
/
template.yaml
224 lines (217 loc) · 7.85 KB
/
template.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
apiVersion: scaffolder.backstage.io/v1beta3
kind: Template
metadata:
name: dev-builds-quarkus-stssc-template
title: Dev Branch Builds - Securing a Quarkus Service Software Supply Chain
description: Create a simple microservice built on a trusted software supply chain
tags:
- recommended
- java
- quarkus
- maven
spec:
owner: rhdh
type: service
parameters:
- title: Provide Information for Application
required:
- component_id
- java_package_name
properties:
component_id:
title: Name
type: string
description: Unique name of the component
default: my-quarkus-app
ui:field: EntityNamePicker
maxLength: 14
group_id:
title: Group Id
type: string
default: redhat.janus
description: Maven Group Id
artifact_id:
title: Artifact Id
type: string
default: quarkus-app
description: Maven Artifact Id
java_package_name:
title: Java Package Name
default: org.redhat.janus
type: string
description: Name for the java package. eg (com.redhat.blah)
description:
title: Description
type: string
description: Help others understand what this website is for.
default: A cool quarkus app
- title: Provide Image Registry Information
required:
- image_registry
properties:
image_registry:
title: Image Registry
type: string
enum:
- Openshift
- Quay
dependencies:
image_registry:
oneOf:
- properties:
image_registry:
enum:
- Openshift
image_host:
title: Image Host
type: string
description: Host for storing image
default: image-registry.openshift-image-registry.svc:5000
image_tag:
title: Image Tag
default: latest
type: string
description: Build Image tag
- properties:
image_registry:
enum:
- Quay
image_host:
title: Image Host
type: string
description: Quay host from TAP demo
default: quay-644wl.apps.cluster-644wl.sandbox1016.opentlc.com
image_organization:
title: Organization
type: string
description: Name of the Quay Organization
default: quayadmin
image_tag:
title: Image Tag
default: latest
type: string
description: Build Image tag
- title: Cluster Information
required:
- cluster
properties:
cluster:
title: Application Cluster url
type: string
description: Cluster URL from TAP demo.
default: apps.cluster-644wl.sandbox1016.opentlc.com
- title: Application repository Information
required:
- repo
properties:
repo:
title: Repository Location
type: object
properties:
host:
title: Repo Host
type: string
description: Update the correct gitlab URL from TAP demo.
default: gitlab-gitlab.apps.cluster-644wl.sandbox1016.opentlc.com
owner:
title: Repo Owner
type: string
description: Your SCM host organization/group
default: development
enum:
- development
verify_commits:
title: Verify Commits
type: string
description: Verify Git repository commits using Red Hat’s Trusted Artifact Signer (TAS) service
default: disabled
enum:
- enabled
- disabled
steps:
- id: template
name: Fetch Skeleton + Template
action: fetch:template
input:
url: ./skeleton
copyWithoutTemplating:
- .github/workflows/*
values:
component_id: ${{ parameters.component_id }}
description: ${{ parameters.description }}
namespace: ${{ parameters.component_id }}-dev
group_id: ${{ parameters.group_id }}
artifact_id: ${{ parameters.artifact_id }}
java_package_name: ${{ parameters.java_package_name }}
owner: ${{ user.entity.metadata.name }}
cluster: .${{ parameters.cluster }}
host: ${{ parameters.repo.host }}
destination: ${{ parameters.repo.owner }}/${{ parameters.component_id }}
quay_destination: ${{ parameters.image_organization}}/${{ parameters.component_id }}
port: 8080
verify_commits: ${{ parameters.repo.verify_commits }}
- id: publish
name: Publish
action: publish:gitlab
input:
repoUrl: "${{ parameters.repo.host }}?owner=${{ parameters.repo.owner }}&repo=${{parameters.component_id}}"
repoVisibility: public
- id: register
name: Register
action: catalog:register
input:
repoContentsUrl: ${{ steps.publish.output.repoContentsUrl }}
catalogInfoPath: "/catalog-info.yaml"
- id: template-gitops-deployment
name: Generating Deployment Resources
action: fetch:template
input:
url: ./manifests
copyWithoutTemplating: []
values:
gitlab_project_id: ${{ steps.publish.output.projectId }}
host: ${{ parameters.repo.host }}
component_id: ${{ parameters.component_id }}
description: ${{ parameters.description }}
destination: https://${{ parameters.repo.host }}/${{ parameters.repo.owner }}/${{parameters.component_id}}-gitops.git
source_repository: https://${{ parameters.repo.host }}/${{ parameters.repo.owner }}/${{parameters.component_id}}.git
repository_name: ${{parameters.component_id}}
git_owner: ${{ parameters.repo.owner }}
cluster: .${{ parameters.cluster }}
namespace: ${{ parameters.component_id }}-dev
image_registry: ${{ parameters.image_registry }}
image_host: ${{ parameters.image_host }}
image_organization: ${{ parameters.image_organization }}
image_name: ${{ parameters.component_id }}
image_tag: ${{ parameters.image_tag }}
port: 8080
repository_host: ${{ parameters.repo.host }}
deployment_name: quarkus-template
user: ${{ user.entity.metadata.name }}
verify_commits: ${{ parameters.repo.verify_commits }}
targetPath: ./tenant-gitops
- id: publish-gitops
name: Publishing to Resource Repository
action: publish:gitlab
input:
repoUrl: "${{ parameters.repo.host }}?owner=${{ parameters.repo.owner }}&repo=${{parameters.component_id}}-gitops"
title: gitops resources for ${{ parameters.component_id }}
description: gitops resources for ${{ parameters.component_id }}
sourcePath: ./tenant-gitops
repoVisibility: public
- id: create-argocd-resources
name: Create ArgoCD Resources
action: argocd:create-resources
input:
appName: ${{ parameters.component_id }}-bootstrap
argoInstance: main
namespace: janus-argocd
repoUrl: https://${{ parameters.repo.host }}/${{ parameters.repo.owner }}/${{ parameters.component_id }}-gitops.git
path: 'argocd/'
output:
links:
- title: Source Code Repository
url: ${{ steps.publish.output.remoteUrl }}
- title: Open Component in catalog
icon: catalog
entityRef: ${{ steps.register.output.entityRef }}