decisionserver64-https-s2i.json 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522
  1. {
  2. "kind": "Template",
  3. "apiVersion": "v1",
  4. "metadata": {
  5. "annotations": {
  6. "description": "Application template for Red Hat JBoss BRMS 6.4 decision server HTTPS applications built using S2I.",
  7. "iconClass": "icon-decisionserver",
  8. "tags": "decisionserver,jboss",
  9. "version": "1.4.7",
  10. "openshift.io/display-name": "JBoss BRMS 6.4 decision server (with https)",
  11. "openshift.io/provider-display-name": "Red Hat, Inc.",
  12. "description": "An example BRMS decision server application. For more information about using this template, see https://github.com/jboss-openshift/application-templates.",
  13. "template.openshift.io/long-description": "This template defines resources needed to develop Red Hat JBoss BRMS 6.4 decision server, including a build configuration, application deployment configuration and secured using https.",
  14. "template.openshift.io/documentation-url": "https://access.redhat.com/documentation/en/red-hat-jboss-brms/",
  15. "template.openshift.io/support-url": "https://access.redhat.com"
  16. },
  17. "name": "decisionserver64-https-s2i"
  18. },
  19. "labels": {
  20. "template": "decisionserver64-https-s2i",
  21. "xpaas": "1.4.7"
  22. },
  23. "message": "A new BRMS application with SSL support has been created in your project. The username/password for accessing the KIE Server REST or JMS interface is ${KIE_SERVER_USER}/${KIE_SERVER_PASSWORD}. Please be sure to create the \"decisionserver-service-account\" service account and the secret named \"${HTTPS_SECRET}\" containing the ${HTTPS_KEYSTORE} file used for serving secure content.",
  24. "parameters": [
  25. {
  26. "displayName": "KIE Container Deployment",
  27. "description": "The KIE Container deployment configuration in format: containerId=groupId:artifactId:version|c2=g2:a2:v2",
  28. "name": "KIE_CONTAINER_DEPLOYMENT",
  29. "value": "decisionserver-hellorules=org.openshift.quickstarts:decisionserver-hellorules:1.3.0.Final",
  30. "required": false
  31. },
  32. {
  33. "displayName": "KIE Server Protocol",
  34. "description": "The protocol to access the KIE Server REST interface.",
  35. "name": "KIE_SERVER_PROTOCOL",
  36. "value": "https",
  37. "required": false
  38. },
  39. {
  40. "displayName": "KIE Server Port",
  41. "description": "The port to access the KIE Server REST interface.",
  42. "name": "KIE_SERVER_PORT",
  43. "value": "8443",
  44. "required": false
  45. },
  46. {
  47. "displayName": "KIE Server Username",
  48. "description": "The user name to access the KIE Server REST or JMS interface.",
  49. "name": "KIE_SERVER_USER",
  50. "value": "kieserver",
  51. "required": false
  52. },
  53. {
  54. "displayName": "KIE Server Password",
  55. "description": "The password to access the KIE Server REST or JMS interface. Must be different than username; must not be root, admin, or administrator; must contain at least 8 characters, 1 alphabetic character(s), 1 digit(s), and 1 non-alphanumeric symbol(s).",
  56. "name": "KIE_SERVER_PASSWORD",
  57. "from": "[a-zA-Z]{6}[0-9]{1}!",
  58. "generate": "expression",
  59. "required": false
  60. },
  61. {
  62. "displayName": "Application Name",
  63. "description": "The name for the application.",
  64. "name": "APPLICATION_NAME",
  65. "value": "kie-app",
  66. "required": true
  67. },
  68. {
  69. "displayName": "Custom http Route Hostname",
  70. "description": "Custom hostname for http service route. Leave blank for default hostname, e.g.: <application-name>-<project>.<default-domain-suffix>",
  71. "name": "HOSTNAME_HTTP",
  72. "value": "",
  73. "required": false
  74. },
  75. {
  76. "displayName": "Custom https Route Hostname",
  77. "description": "Custom hostname for https service route. Leave blank for default hostname, e.g.: secure-<application-name>-<project>.<default-domain-suffix>",
  78. "name": "HOSTNAME_HTTPS",
  79. "value": "",
  80. "required": false
  81. },
  82. {
  83. "displayName": "Git Repository URL",
  84. "description": "Git source URI for application",
  85. "name": "SOURCE_REPOSITORY_URL",
  86. "value": "https://github.com/jboss-openshift/openshift-quickstarts.git",
  87. "required": true
  88. },
  89. {
  90. "displayName": "Git Reference",
  91. "description": "Git branch/tag reference",
  92. "name": "SOURCE_REPOSITORY_REF",
  93. "value": "1.3",
  94. "required": false
  95. },
  96. {
  97. "displayName": "Context Directory",
  98. "description": "Path within Git project to build; empty for root project directory.",
  99. "name": "CONTEXT_DIR",
  100. "value": "decisionserver/hellorules",
  101. "required": false
  102. },
  103. {
  104. "displayName": "Queues",
  105. "description": "Queue names",
  106. "name": "HORNETQ_QUEUES",
  107. "value": "",
  108. "required": false
  109. },
  110. {
  111. "displayName": "Topics",
  112. "description": "Topic names",
  113. "name": "HORNETQ_TOPICS",
  114. "value": "",
  115. "required": false
  116. },
  117. {
  118. "displayName": "Server Keystore Secret Name",
  119. "description": "The name of the secret containing the keystore file",
  120. "name": "HTTPS_SECRET",
  121. "value": "decisionserver-app-secret",
  122. "required": true
  123. },
  124. {
  125. "displayName": "Server Keystore Filename",
  126. "description": "The name of the keystore file within the secret",
  127. "name": "HTTPS_KEYSTORE",
  128. "value": "keystore.jks",
  129. "required": false
  130. },
  131. {
  132. "displayName": "Server Certificate Name",
  133. "description": "The name associated with the server certificate",
  134. "name": "HTTPS_NAME",
  135. "value": "jboss",
  136. "required": false
  137. },
  138. {
  139. "displayName": "Server Keystore Password",
  140. "description": "The password for the keystore and certificate",
  141. "name": "HTTPS_PASSWORD",
  142. "value": "mykeystorepass",
  143. "required": false
  144. },
  145. {
  146. "displayName": "HornetQ Password",
  147. "description": "HornetQ cluster admin password",
  148. "name": "HORNETQ_CLUSTER_PASSWORD",
  149. "from": "[a-zA-Z0-9]{8}",
  150. "generate": "expression",
  151. "required": true
  152. },
  153. {
  154. "displayName": "Github Webhook Secret",
  155. "description": "GitHub trigger secret",
  156. "name": "GITHUB_WEBHOOK_SECRET",
  157. "from": "[a-zA-Z0-9]{8}",
  158. "generate": "expression",
  159. "required": true
  160. },
  161. {
  162. "displayName": "Generic Webhook Secret",
  163. "description": "Generic build trigger secret",
  164. "name": "GENERIC_WEBHOOK_SECRET",
  165. "from": "[a-zA-Z0-9]{8}",
  166. "generate": "expression",
  167. "required": true
  168. },
  169. {
  170. "displayName": "ImageStream Namespace",
  171. "description": "Namespace in which the ImageStreams for Red Hat Middleware images are installed. These ImageStreams are normally installed in the openshift namespace. You should only need to modify this if you've installed the ImageStreams in a different namespace/project.",
  172. "name": "IMAGE_STREAM_NAMESPACE",
  173. "value": "openshift",
  174. "required": true
  175. },
  176. {
  177. "displayName": "Maven mirror URL",
  178. "description": "Maven mirror to use for S2I builds",
  179. "name": "MAVEN_MIRROR_URL",
  180. "value": "",
  181. "required": false
  182. },
  183. {
  184. "description": "List of directories from which archives will be copied into the deployment folder. If unspecified, all archives in /target will be copied.",
  185. "name": "ARTIFACT_DIR",
  186. "value": "",
  187. "required": false
  188. }
  189. ],
  190. "objects": [
  191. {
  192. "kind": "Service",
  193. "apiVersion": "v1",
  194. "spec": {
  195. "ports": [
  196. {
  197. "port": 8080,
  198. "targetPort": 8080
  199. }
  200. ],
  201. "selector": {
  202. "deploymentConfig": "${APPLICATION_NAME}"
  203. }
  204. },
  205. "metadata": {
  206. "name": "${APPLICATION_NAME}",
  207. "labels": {
  208. "application": "${APPLICATION_NAME}"
  209. },
  210. "annotations": {
  211. "description": "The web server's http port."
  212. }
  213. }
  214. },
  215. {
  216. "kind": "Service",
  217. "apiVersion": "v1",
  218. "spec": {
  219. "ports": [
  220. {
  221. "port": 8443,
  222. "targetPort": 8443
  223. }
  224. ],
  225. "selector": {
  226. "deploymentConfig": "${APPLICATION_NAME}"
  227. }
  228. },
  229. "metadata": {
  230. "name": "secure-${APPLICATION_NAME}",
  231. "labels": {
  232. "application": "${APPLICATION_NAME}"
  233. },
  234. "annotations": {
  235. "description": "The web server's https port."
  236. }
  237. }
  238. },
  239. {
  240. "kind": "Route",
  241. "apiVersion": "v1",
  242. "id": "${APPLICATION_NAME}-http",
  243. "metadata": {
  244. "name": "${APPLICATION_NAME}",
  245. "labels": {
  246. "application": "${APPLICATION_NAME}"
  247. },
  248. "annotations": {
  249. "description": "Route for application's http service."
  250. }
  251. },
  252. "spec": {
  253. "host": "${HOSTNAME_HTTP}",
  254. "to": {
  255. "name": "${APPLICATION_NAME}"
  256. }
  257. }
  258. },
  259. {
  260. "kind": "Route",
  261. "apiVersion": "v1",
  262. "id": "${APPLICATION_NAME}-https",
  263. "metadata": {
  264. "name": "secure-${APPLICATION_NAME}",
  265. "labels": {
  266. "application": "${APPLICATION_NAME}"
  267. },
  268. "annotations": {
  269. "description": "Route for application's https service."
  270. }
  271. },
  272. "spec": {
  273. "host": "${HOSTNAME_HTTPS}",
  274. "to": {
  275. "name": "secure-${APPLICATION_NAME}"
  276. },
  277. "tls": {
  278. "termination": "passthrough"
  279. }
  280. }
  281. },
  282. {
  283. "kind": "ImageStream",
  284. "apiVersion": "v1",
  285. "metadata": {
  286. "name": "${APPLICATION_NAME}",
  287. "labels": {
  288. "application": "${APPLICATION_NAME}"
  289. }
  290. }
  291. },
  292. {
  293. "kind": "BuildConfig",
  294. "apiVersion": "v1",
  295. "metadata": {
  296. "name": "${APPLICATION_NAME}",
  297. "labels": {
  298. "application": "${APPLICATION_NAME}"
  299. }
  300. },
  301. "spec": {
  302. "source": {
  303. "type": "Git",
  304. "git": {
  305. "uri": "${SOURCE_REPOSITORY_URL}",
  306. "ref": "${SOURCE_REPOSITORY_REF}"
  307. },
  308. "contextDir": "${CONTEXT_DIR}"
  309. },
  310. "strategy": {
  311. "type": "Source",
  312. "sourceStrategy": {
  313. "env": [
  314. {
  315. "name": "KIE_CONTAINER_DEPLOYMENT",
  316. "value": "${KIE_CONTAINER_DEPLOYMENT}"
  317. },
  318. {
  319. "name": "MAVEN_MIRROR_URL",
  320. "value": "${MAVEN_MIRROR_URL}"
  321. },
  322. {
  323. "name": "ARTIFACT_DIR",
  324. "value": "${ARTIFACT_DIR}"
  325. }
  326. ],
  327. "forcePull": true,
  328. "from": {
  329. "kind": "ImageStreamTag",
  330. "namespace": "${IMAGE_STREAM_NAMESPACE}",
  331. "name": "jboss-decisionserver64-openshift:1.1"
  332. }
  333. }
  334. },
  335. "output": {
  336. "to": {
  337. "kind": "ImageStreamTag",
  338. "name": "${APPLICATION_NAME}:latest"
  339. }
  340. },
  341. "triggers": [
  342. {
  343. "type": "GitHub",
  344. "github": {
  345. "secret": "${GITHUB_WEBHOOK_SECRET}"
  346. }
  347. },
  348. {
  349. "type": "Generic",
  350. "generic": {
  351. "secret": "${GENERIC_WEBHOOK_SECRET}"
  352. }
  353. },
  354. {
  355. "type": "ImageChange",
  356. "imageChange": {}
  357. },
  358. {
  359. "type": "ConfigChange"
  360. }
  361. ]
  362. }
  363. },
  364. {
  365. "kind": "DeploymentConfig",
  366. "apiVersion": "v1",
  367. "metadata": {
  368. "name": "${APPLICATION_NAME}",
  369. "labels": {
  370. "application": "${APPLICATION_NAME}"
  371. }
  372. },
  373. "spec": {
  374. "strategy": {
  375. "type": "Recreate"
  376. },
  377. "triggers": [
  378. {
  379. "type": "ImageChange",
  380. "imageChangeParams": {
  381. "automatic": true,
  382. "containerNames": [
  383. "${APPLICATION_NAME}"
  384. ],
  385. "from": {
  386. "kind": "ImageStream",
  387. "name": "${APPLICATION_NAME}"
  388. }
  389. }
  390. },
  391. {
  392. "type": "ConfigChange"
  393. }
  394. ],
  395. "replicas": 1,
  396. "selector": {
  397. "deploymentConfig": "${APPLICATION_NAME}"
  398. },
  399. "template": {
  400. "metadata": {
  401. "name": "${APPLICATION_NAME}",
  402. "labels": {
  403. "deploymentConfig": "${APPLICATION_NAME}",
  404. "application": "${APPLICATION_NAME}"
  405. }
  406. },
  407. "spec": {
  408. "serviceAccountName": "decisionserver-service-account",
  409. "terminationGracePeriodSeconds": 60,
  410. "containers": [
  411. {
  412. "name": "${APPLICATION_NAME}",
  413. "image": "${APPLICATION_NAME}",
  414. "imagePullPolicy": "Always",
  415. "volumeMounts": [
  416. {
  417. "name": "decisionserver-keystore-volume",
  418. "mountPath": "/etc/decisionserver-secret-volume",
  419. "readOnly": true
  420. }
  421. ],
  422. "livenessProbe": {
  423. "exec": {
  424. "command": [
  425. "/bin/bash",
  426. "-c",
  427. "/opt/eap/bin/livenessProbe.sh"
  428. ]
  429. }
  430. },
  431. "readinessProbe": {
  432. "exec": {
  433. "command": [
  434. "/bin/bash",
  435. "-c",
  436. "/opt/eap/bin/readinessProbe.sh"
  437. ]
  438. }
  439. },
  440. "ports": [
  441. {
  442. "name": "jolokia",
  443. "containerPort": 8778,
  444. "protocol": "TCP"
  445. },
  446. {
  447. "name": "http",
  448. "containerPort": 8080,
  449. "protocol": "TCP"
  450. },
  451. {
  452. "name": "https",
  453. "containerPort": 8443,
  454. "protocol": "TCP"
  455. }
  456. ],
  457. "env": [
  458. {
  459. "name": "KIE_CONTAINER_DEPLOYMENT",
  460. "value": "${KIE_CONTAINER_DEPLOYMENT}"
  461. },
  462. {
  463. "name": "KIE_SERVER_PROTOCOL",
  464. "value": "${KIE_SERVER_PROTOCOL}"
  465. },
  466. {
  467. "name": "KIE_SERVER_PORT",
  468. "value": "${KIE_SERVER_PORT}"
  469. },
  470. {
  471. "name": "KIE_SERVER_USER",
  472. "value": "${KIE_SERVER_USER}"
  473. },
  474. {
  475. "name": "KIE_SERVER_PASSWORD",
  476. "value": "${KIE_SERVER_PASSWORD}"
  477. },
  478. {
  479. "name": "HTTPS_KEYSTORE_DIR",
  480. "value": "/etc/decisionserver-secret-volume"
  481. },
  482. {
  483. "name": "HTTPS_KEYSTORE",
  484. "value": "${HTTPS_KEYSTORE}"
  485. },
  486. {
  487. "name": "HTTPS_NAME",
  488. "value": "${HTTPS_NAME}"
  489. },
  490. {
  491. "name": "HTTPS_PASSWORD",
  492. "value": "${HTTPS_PASSWORD}"
  493. },
  494. {
  495. "name": "HORNETQ_CLUSTER_PASSWORD",
  496. "value": "${HORNETQ_CLUSTER_PASSWORD}"
  497. },
  498. {
  499. "name": "HORNETQ_QUEUES",
  500. "value": "${HORNETQ_QUEUES}"
  501. },
  502. {
  503. "name": "HORNETQ_TOPICS",
  504. "value": "${HORNETQ_TOPICS}"
  505. }
  506. ]
  507. }
  508. ],
  509. "volumes": [
  510. {
  511. "name": "decisionserver-keystore-volume",
  512. "secret": {
  513. "secretName": "${HTTPS_SECRET}"
  514. }
  515. }
  516. ]
  517. }
  518. }
  519. }
  520. }
  521. ]
  522. }