questions.yaml 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279
  1. groups:
  2. - name: pgAdmin Configuration
  3. description: Configure pgAdmin
  4. - name: Network Configuration
  5. description: Configure Network for pgAdmin
  6. - name: Storage Configuration
  7. description: Configure Storage for pgAdmin
  8. - name: Resources Configuration
  9. description: Configure Resources for pgAdmin
  10. portals:
  11. web_portal:
  12. protocols:
  13. - "$kubernetes-resource_configmap_portal_protocol"
  14. host:
  15. - "$kubernetes-resource_configmap_portal_host"
  16. ports:
  17. - "$kubernetes-resource_configmap_portal_port"
  18. path: "$kubernetes-resource_configmap_portal_path"
  19. questions:
  20. - variable: pgadminConfig
  21. label: ""
  22. group: pgAdmin Configuration
  23. schema:
  24. type: dict
  25. attrs:
  26. - variable: adminEmail
  27. label: Admin Email
  28. description: The email address for the pgAdmin admin user.
  29. schema:
  30. type: string
  31. required: true
  32. default: ""
  33. - variable: adminPassword
  34. label: Admin Password
  35. description: The password for the pgAdmin admin user.
  36. schema:
  37. type: string
  38. required: true
  39. private: true
  40. default: ""
  41. - variable: additionalEnvs
  42. label: Additional Environment Variables
  43. description: Configure additional environment variables for pgAdmin.
  44. schema:
  45. type: list
  46. default: []
  47. items:
  48. - variable: env
  49. label: Environment Variable
  50. schema:
  51. type: dict
  52. attrs:
  53. - variable: name
  54. label: Name
  55. schema:
  56. type: string
  57. required: true
  58. - variable: value
  59. label: Value
  60. schema:
  61. type: string
  62. required: true
  63. - variable: pgadminNetwork
  64. label: ""
  65. group: Network Configuration
  66. schema:
  67. type: dict
  68. attrs:
  69. - variable: webPort
  70. label: Web Port
  71. description: The port for the pgAdmin Web UI.
  72. schema:
  73. type: int
  74. default: 30056
  75. min: 9000
  76. max: 65535
  77. required: true
  78. - variable: hostNetwork
  79. label: Host Network
  80. description: |
  81. Bind to the host network. It's recommended to keep this disabled.</br>
  82. schema:
  83. type: boolean
  84. default: false
  85. - variable: certificateID
  86. label: Certificate
  87. description: The certificate to use for pgAdmin
  88. schema:
  89. type: int
  90. "null": true
  91. $ref:
  92. - "definitions/certificate"
  93. - variable: pgadminStorage
  94. label: ""
  95. group: Storage Configuration
  96. schema:
  97. type: dict
  98. attrs:
  99. - variable: config
  100. label: pgAdmin Config Storage
  101. description: The path to store pgAdmin Configuration.
  102. schema:
  103. type: dict
  104. attrs:
  105. - variable: type
  106. label: Type
  107. description: |
  108. ixVolume: Is dataset created automatically by the system.</br>
  109. Host Path: Is a path that already exists on the system.
  110. schema:
  111. type: string
  112. required: true
  113. immutable: true
  114. default: "ixVolume"
  115. enum:
  116. - value: "hostPath"
  117. description: Host Path (Path that already exists on the system)
  118. - value: "ixVolume"
  119. description: ixVolume (Dataset created automatically by the system)
  120. - variable: datasetName
  121. label: Dataset Name
  122. schema:
  123. type: string
  124. show_if: [["type", "=", "ixVolume"]]
  125. required: true
  126. hidden: true
  127. immutable: true
  128. default: "config"
  129. $ref:
  130. - "normalize/ixVolume"
  131. - variable: hostPath
  132. label: Host Path
  133. schema:
  134. type: hostpath
  135. show_if: [["type", "=", "hostPath"]]
  136. required: true
  137. - variable: additionalStorages
  138. label: Additional Storage
  139. description: Additional storage for pgAdmin.
  140. schema:
  141. type: list
  142. default: []
  143. items:
  144. - variable: storageEntry
  145. label: Storage Entry
  146. schema:
  147. type: dict
  148. attrs:
  149. - variable: type
  150. label: Type
  151. description: |
  152. ixVolume: Is dataset created automatically by the system.</br>
  153. Host Path: Is a path that already exists on the system.</br>
  154. SMB Share: Is a SMB share that is mounted to a persistent volume claim.
  155. schema:
  156. type: string
  157. required: true
  158. default: "ixVolume"
  159. immutable: true
  160. enum:
  161. - value: "hostPath"
  162. description: Host Path (Path that already exists on the system)
  163. - value: "ixVolume"
  164. description: ixVolume (Dataset created automatically by the system)
  165. - value: "smb-pv-pvc"
  166. description: SMB Share (Mounts a persistent volume claim to a SMB share)
  167. - variable: mountPath
  168. label: Mount Path
  169. description: The path inside the container to mount the storage.
  170. schema:
  171. type: path
  172. required: true
  173. - variable: hostPath
  174. label: Host Path
  175. description: The host path to use for storage.
  176. schema:
  177. type: hostpath
  178. show_if: [["type", "=", "hostPath"]]
  179. required: true
  180. - variable: datasetName
  181. label: Dataset Name
  182. description: The name of the dataset to use for storage.
  183. schema:
  184. type: string
  185. show_if: [["type", "=", "ixVolume"]]
  186. required: true
  187. immutable: true
  188. default: "storage_entry"
  189. $ref:
  190. - "normalize/ixVolume"
  191. - variable: server
  192. label: Server
  193. description: The server for the SMB share.
  194. schema:
  195. type: string
  196. show_if: [["type", "=", "smb-pv-pvc"]]
  197. required: true
  198. - variable: share
  199. label: Share
  200. description: The share name for the SMB share.
  201. schema:
  202. type: string
  203. show_if: [["type", "=", "smb-pv-pvc"]]
  204. required: true
  205. - variable: domain
  206. label: Domain (Optional)
  207. description: The domain for the SMB share.
  208. schema:
  209. type: string
  210. show_if: [["type", "=", "smb-pv-pvc"]]
  211. - variable: username
  212. label: Username
  213. description: The username for the SMB share.
  214. schema:
  215. type: string
  216. show_if: [["type", "=", "smb-pv-pvc"]]
  217. required: true
  218. - variable: password
  219. label: Password
  220. description: The password for the SMB share.
  221. schema:
  222. type: string
  223. show_if: [["type", "=", "smb-pv-pvc"]]
  224. required: true
  225. private: true
  226. - variable: size
  227. label: Size (in Gi)
  228. description: The size of the volume quota.
  229. schema:
  230. type: int
  231. show_if: [["type", "=", "smb-pv-pvc"]]
  232. required: true
  233. min: 1
  234. default: 1
  235. - variable: resources
  236. group: Resources Configuration
  237. label: ""
  238. schema:
  239. type: dict
  240. attrs:
  241. - variable: limits
  242. label: Limits
  243. schema:
  244. type: dict
  245. attrs:
  246. - variable: cpu
  247. label: CPU
  248. description: CPU limit for pgAdmin.
  249. schema:
  250. type: string
  251. max_length: 6
  252. valid_chars: '^(0\.[1-9]|[1-9][0-9]*)(\.[0-9]|m?)$'
  253. valid_chars_error: |
  254. Valid CPU limit formats are</br>
  255. - Plain Integer - eg. 1</br>
  256. - Float - eg. 0.5</br>
  257. - Milicpu - eg. 500m
  258. default: "4000m"
  259. required: true
  260. - variable: memory
  261. label: Memory
  262. description: Memory limit for pgAdmin.
  263. schema:
  264. type: string
  265. max_length: 12
  266. valid_chars: '^[1-9][0-9]*([EPTGMK]i?|e[0-9]+)?$'
  267. valid_chars_error: |
  268. Valid Memory limit formats are</br>
  269. - Suffixed with E/P/T/G/M/K - eg. 1G</br>
  270. - Suffixed with Ei/Pi/Ti/Gi/Mi/Ki - eg. 1Gi</br>
  271. - Plain Integer in bytes - eg. 1024</br>
  272. - Exponent - eg. 134e6
  273. default: "8Gi"
  274. required: true