@rancher/shell 0.3.0 → 0.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (322) hide show
  1. package/assets/styles/global/_button.scss +5 -1
  2. package/assets/styles/global/_columns.scss +4 -0
  3. package/assets/styles/global/_layout.scss +1 -2
  4. package/assets/styles/global/_select.scss +1 -4
  5. package/assets/styles/themes/_dark.scss +4 -4
  6. package/assets/styles/themes/_light.scss +4 -3
  7. package/assets/styles/themes/_suse.scss +1 -1
  8. package/assets/styles/vendor/vue-select.scss +4 -3
  9. package/assets/translations/en-us.yaml +669 -73
  10. package/assets/translations/zh-hans.yaml +547 -165
  11. package/chart/monitoring/steps/uninstall-v1.vue +2 -2
  12. package/cloud-credential/azure.vue +23 -0
  13. package/cloud-credential/harvester.vue +25 -62
  14. package/cloud-credential/pnap.vue +80 -0
  15. package/components/.DS_Store +0 -0
  16. package/components/AdvancedSection.vue +9 -2
  17. package/components/Alert.vue +2 -2
  18. package/components/ButtonDropdown.vue +0 -2
  19. package/components/ButtonGroup.vue +1 -0
  20. package/components/CollapsibleCard.vue +0 -1
  21. package/components/CruResource.vue +41 -4
  22. package/components/DetailTop.vue +58 -3
  23. package/components/DisableAuthProviderModal.vue +106 -0
  24. package/{rancher-components/components/Utils/DraggableZone → components}/DraggableZone.vue +0 -0
  25. package/components/ExplorerMembers.vue +253 -30
  26. package/components/ExplorerProjectsNamespaces.vue +77 -33
  27. package/components/GrowlManager.vue +3 -3
  28. package/components/IconOrSvg.vue +149 -0
  29. package/components/LogItem.vue +69 -0
  30. package/components/PodSecurityAdmission.vue +302 -0
  31. package/components/PromptModal.vue +1 -0
  32. package/components/ResourceDetail/Masthead.vue +54 -2
  33. package/components/ResourceDetail/index.vue +12 -5
  34. package/components/ResourceList/Masthead.vue +11 -1
  35. package/components/ResourceList/ResourceLoadingIndicator.vue +12 -2
  36. package/components/ResourceList/index.vue +53 -12
  37. package/components/ResourceList/resource-list.config.js +7 -0
  38. package/components/ResourceTable.vue +31 -6
  39. package/components/SimpleBox.vue +1 -1
  40. package/components/SortableTable/THead.vue +15 -5
  41. package/components/SortableTable/index.vue +21 -10
  42. package/components/Tabbed/index.vue +20 -15
  43. package/components/__tests__/.DS_Store +0 -0
  44. package/components/__tests__/AsyncButton.test.ts +140 -0
  45. package/components/__tests__/BackLink.test.ts +33 -0
  46. package/components/__tests__/ButtonGroup.test.ts +124 -0
  47. package/components/__tests__/ClusterBadge.test.ts +32 -0
  48. package/components/__tests__/CollapsibleCard.test.ts +64 -0
  49. package/components/__tests__/ConsumptionGauge.test.ts +88 -0
  50. package/components/__tests__/CruResource.test.ts +3 -2
  51. package/components/__tests__/FixedBanner.test.ts +129 -0
  52. package/components/__tests__/GrowlManager.test.ts +147 -0
  53. package/components/__tests__/NamespaceFilter.test.ts +33 -25
  54. package/components/__tests__/PercentageBar.test.ts +32 -0
  55. package/components/__tests__/PodSecurityAdmission.test.ts +398 -0
  56. package/components/auth/AuthBanner.vue +20 -10
  57. package/components/auth/RoleDetailEdit.vue +26 -17
  58. package/components/auth/SelectPrincipal.vue +36 -5
  59. package/components/form/ArrayList.vue +3 -35
  60. package/components/form/ArrayListGrouped.vue +13 -4
  61. package/components/form/ArrayListSelect.vue +5 -5
  62. package/components/form/Error.vue +8 -0
  63. package/components/form/KeyValue.vue +39 -7
  64. package/components/form/LabeledSelect.vue +5 -2
  65. package/components/form/Labels.vue +46 -16
  66. package/components/form/Members/ClusterPermissionsEditor.vue +17 -17
  67. package/components/form/Members/MembershipEditor.vue +12 -12
  68. package/components/form/NameNsDescription.vue +1 -1
  69. package/components/form/NodeScheduling.vue +1 -1
  70. package/components/form/Probe.vue +3 -3
  71. package/components/form/ResourceQuota/Project.vue +6 -6
  72. package/components/form/ResourceTabs/index.vue +1 -6
  73. package/components/form/Security.vue +7 -6
  74. package/components/form/Select.vue +3 -2
  75. package/components/form/SelectOrCreateAuthSecret.vue +22 -29
  76. package/components/form/ServicePorts.vue +8 -0
  77. package/components/form/WorkloadPorts.vue +7 -1
  78. package/components/form/__tests__/ArrayList.test.ts +74 -0
  79. package/components/form/__tests__/ArrayListGrouped.test.ts +6 -4
  80. package/components/formatter/Checked.vue +1 -1
  81. package/components/formatter/ClusterLink.vue +5 -0
  82. package/components/formatter/IconIsDefault.vue +2 -2
  83. package/components/formatter/InternalExternalIP.vue +11 -8
  84. package/components/formatter/LiveDuration.vue +78 -0
  85. package/components/formatter/WorkloadHealthScale.vue +5 -3
  86. package/components/nav/Header.vue +6 -3
  87. package/components/nav/NamespaceFilter.vue +146 -63
  88. package/components/nav/TopLevelMenu.vue +22 -19
  89. package/components/nav/WindowManager/ContainerLogs.vue +83 -126
  90. package/components/nav/WindowManager/ContainerShell.vue +9 -7
  91. package/components/nav/WindowManager/Window.vue +2 -0
  92. package/components/nav/WindowManager/index.vue +10 -0
  93. package/config/elemental-types.js +9 -0
  94. package/config/features.js +2 -0
  95. package/config/home-links.js +4 -1
  96. package/config/pod-security-admission.ts +82 -0
  97. package/config/product/apps.js +1 -1
  98. package/config/product/auth.js +6 -5
  99. package/config/product/explorer.js +6 -6
  100. package/config/product/fleet.js +1 -1
  101. package/config/product/manager.js +6 -2
  102. package/config/secret.js +0 -1
  103. package/config/settings.ts +26 -9
  104. package/config/table-headers.js +22 -11
  105. package/config/types.js +4 -1
  106. package/content/docs/zh-hans/getting-started.md +113 -137
  107. package/content/docs/zh-hans/whats-new.md +8 -46
  108. package/creators/pkg/package-lock.json +37 -0
  109. package/creators/pkg/package.json +1 -1
  110. package/detail/catalog.cattle.io.app.vue +1 -1
  111. package/detail/pod.vue +1 -1
  112. package/detail/provisioning.cattle.io.cluster.vue +35 -9
  113. package/detail/service.vue +2 -9
  114. package/detail/workload/index.vue +0 -1
  115. package/dialog/AddClusterMemberDialog.vue +22 -28
  116. package/dialog/AddProjectMemberDialog.vue +53 -9
  117. package/dialog/DiagnosticTimingsDialog.vue +8 -7
  118. package/dialog/DrainNode.vue +44 -48
  119. package/dialog/ForceMachineRemoveDialog.vue +5 -7
  120. package/dialog/GenericPrompt.vue +15 -20
  121. package/dialog/RollbackWorkloadDialog.vue +15 -46
  122. package/dialog/RotateCertificatesDialog.vue +5 -7
  123. package/dialog/RotateEncryptionKeyDialog.vue +5 -9
  124. package/dialog/SaveAsRKETemplateDialog.vue +5 -13
  125. package/dialog/ScaleMachineDownDialog.vue +1 -1
  126. package/dialog/ScalePoolDownDialog.vue +121 -0
  127. package/edit/__tests__/management.cattle.io.setting.test.ts +3 -3
  128. package/edit/auth/azuread.vue +16 -16
  129. package/edit/auth/github.vue +8 -0
  130. package/edit/auth/googleoauth.vue +10 -1
  131. package/edit/auth/ldap/index.vue +10 -0
  132. package/edit/auth/oidc.vue +10 -0
  133. package/edit/auth/saml.vue +10 -0
  134. package/edit/autoscaling.horizontalpodautoscaler/index.vue +1 -1
  135. package/edit/cloudcredential.vue +3 -7
  136. package/edit/logging-flow/Match.vue +39 -8
  137. package/edit/logging-flow/index.vue +27 -4
  138. package/edit/management.cattle.io.podsecurityadmissionconfigurationtemplate.vue +107 -0
  139. package/edit/management.cattle.io.project.vue +8 -1
  140. package/edit/management.cattle.io.setting.vue +5 -2
  141. package/edit/management.cattle.io.user.vue +7 -1
  142. package/edit/monitoring.coreos.com.alertmanagerconfig/receiverConfig.vue +23 -7
  143. package/edit/monitoring.coreos.com.alertmanagerconfig/types/email.vue +2 -2
  144. package/edit/monitoring.coreos.com.prometheusrule/GroupRules.vue +14 -6
  145. package/edit/namespace.vue +18 -4
  146. package/edit/networking.k8s.io.ingress/Certificate.vue +1 -0
  147. package/edit/networking.k8s.io.ingress/IngressClass.vue +8 -6
  148. package/edit/networking.k8s.io.ingress/RulePath.vue +12 -6
  149. package/edit/networking.k8s.io.ingress/index.vue +8 -6
  150. package/edit/persistentvolume/index.vue +30 -27
  151. package/edit/persistentvolume/plugins/cephfs.vue +29 -29
  152. package/edit/persistentvolume/plugins/csi.vue +102 -62
  153. package/edit/persistentvolume/plugins/fc.vue +19 -19
  154. package/edit/persistentvolume/plugins/iscsi.vue +45 -45
  155. package/edit/persistentvolume/plugins/rbd.vue +39 -39
  156. package/edit/persistentvolumeclaim.vue +78 -75
  157. package/edit/provisioning.cattle.io.cluster/MachinePool.vue +11 -7
  158. package/edit/provisioning.cattle.io.cluster/RegistryConfigs.vue +10 -1
  159. package/edit/provisioning.cattle.io.cluster/RegistryMirrors.vue +87 -27
  160. package/edit/provisioning.cattle.io.cluster/SelectCredential.vue +3 -6
  161. package/edit/provisioning.cattle.io.cluster/__tests__/rke2.test.ts +93 -0
  162. package/edit/provisioning.cattle.io.cluster/import.vue +1 -1
  163. package/edit/provisioning.cattle.io.cluster/index.vue +29 -6
  164. package/edit/provisioning.cattle.io.cluster/rke2.vue +440 -152
  165. package/edit/secret/index.vue +3 -7
  166. package/edit/service.vue +3 -1
  167. package/edit/storage.k8s.io.storageclass/index.vue +100 -16
  168. package/edit/storage.k8s.io.storageclass/provisioners/driver.harvesterhci.io.vue +114 -0
  169. package/edit/workload/__tests__/index.test.ts +98 -0
  170. package/edit/workload/index.vue +58 -8
  171. package/edit/workload/mixins/workload.js +107 -70
  172. package/edit/workload/storage/ContainerMountPaths.vue +0 -10
  173. package/edit/workload/storage/emptyDir.vue +88 -0
  174. package/edit/workload/storage/ephemeralVolume/index.vue +1 -1
  175. package/edit/workload/storage/index.vue +8 -0
  176. package/edit/workload/storage/persistentVolumeClaim/index.vue +1 -1
  177. package/layouts/default.vue +57 -44
  178. package/list/__tests__/workload.test.ts +5 -2
  179. package/list/catalog.cattle.io.app.vue +1 -0
  180. package/list/cis.cattle.io.clusterscan.vue +1 -0
  181. package/list/fleet.cattle.io.bundle.vue +5 -6
  182. package/list/fleet.cattle.io.cluster.vue +6 -3
  183. package/list/fleet.cattle.io.clusterregistrationtoken.vue +5 -6
  184. package/list/fleet.cattle.io.gitrepo.vue +4 -9
  185. package/list/helm.cattle.io.projecthelmchart.vue +1 -5
  186. package/list/logging.banzaicloud.io.clusterflow.vue +4 -1
  187. package/list/logging.banzaicloud.io.flow.vue +6 -5
  188. package/list/management.cattle.io.cluster.vue +1 -0
  189. package/list/management.cattle.io.feature.vue +3 -4
  190. package/list/management.cattle.io.podsecurityadmissionconfigurationtemplate.vue +47 -0
  191. package/list/management.cattle.io.setting.vue +2 -2
  192. package/list/management.cattle.io.user.vue +4 -10
  193. package/list/monitoring.coreos.com.alertmanagerconfig.vue +2 -7
  194. package/list/node.vue +8 -5
  195. package/list/persistentvolume.vue +3 -3
  196. package/list/persistentvolumeclaim.vue +3 -4
  197. package/list/provisioning.cattle.io.cluster.vue +18 -19
  198. package/list/service.vue +6 -14
  199. package/list/workload.vue +43 -38
  200. package/machine-config/azure.vue +429 -60
  201. package/machine-config/pnap.vue +288 -0
  202. package/mixins/auth-config.js +1 -3
  203. package/mixins/browser-tab-visibility.js +8 -14
  204. package/mixins/chart.js +1 -1
  205. package/mixins/create-edit-view/impl.js +4 -0
  206. package/mixins/create-edit-view/index.js +4 -2
  207. package/mixins/resource-fetch-namespaced.js +98 -0
  208. package/mixins/resource-fetch.js +79 -45
  209. package/mixins/resource-manager.js +1 -23
  210. package/models/apps.controllerrevision.js +7 -0
  211. package/models/apps.daemonset.js +18 -0
  212. package/models/apps.deployment.js +44 -0
  213. package/models/apps.replicaset.js +7 -0
  214. package/models/apps.statefulset.js +18 -0
  215. package/models/batch.job.js +7 -14
  216. package/models/cluster/node.js +10 -2
  217. package/models/cluster.x-k8s.io.machine.js +26 -4
  218. package/models/cluster.x-k8s.io.machinedeployment.js +12 -2
  219. package/models/event.js +7 -0
  220. package/models/logging.banzaicloud.io.flow.js +4 -0
  221. package/models/management.cattle.io.cluster.js +1 -1
  222. package/models/management.cattle.io.clusterroletemplatebinding.js +1 -1
  223. package/models/management.cattle.io.globalrole.js +2 -2
  224. package/models/management.cattle.io.node.js +37 -2
  225. package/models/management.cattle.io.podsecurityadmissionconfigurationtemplate.ts +4 -0
  226. package/models/management.cattle.io.project.js +30 -11
  227. package/models/management.cattle.io.setting.js +1 -1
  228. package/models/management.cattle.io.user.js +37 -1
  229. package/models/namespace.js +42 -5
  230. package/models/persistentvolume.js +14 -2
  231. package/models/pod.js +15 -0
  232. package/models/projectroletemplatebinding.js +7 -0
  233. package/models/provisioning.cattle.io.cluster.js +61 -10
  234. package/models/rke-machine.cattle.io.pnapmachinetemplate.js +15 -0
  235. package/models/service.js +14 -13
  236. package/models/storage.k8s.io.storageclass.js +33 -18
  237. package/models/workload.js +38 -7
  238. package/nuxt.config.js +27 -17
  239. package/package.json +7 -7
  240. package/pages/about.vue +14 -2
  241. package/pages/c/_cluster/apps/charts/index.vue +4 -3
  242. package/pages/c/_cluster/apps/charts/install.vue +59 -22
  243. package/pages/c/_cluster/auth/config/_id.vue +6 -0
  244. package/pages/c/_cluster/auth/config/index.vue +8 -6
  245. package/pages/c/_cluster/auth/group.principal/assign-edit.vue +1 -1
  246. package/pages/c/_cluster/auth/roles/index.vue +1 -1
  247. package/pages/c/_cluster/explorer/index.vue +12 -6
  248. package/pages/c/_cluster/longhorn/index.vue +1 -1
  249. package/pages/c/_cluster/monitoring/alertmanagerconfig/_alertmanagerconfigid/receiver.vue +15 -4
  250. package/pages/c/_cluster/monitoring/index.vue +1 -1
  251. package/pages/c/_cluster/neuvector/index.vue +1 -1
  252. package/pages/c/_cluster/settings/performance.vue +48 -2
  253. package/pages/c/_cluster/uiplugins/PluginInfoPanel.vue +34 -1
  254. package/pages/c/_cluster/uiplugins/index.vue +28 -2
  255. package/pages/diagnostic.vue +5 -4
  256. package/pages/home.vue +105 -30
  257. package/pages/prefs.vue +23 -12
  258. package/pages/rio/mesh.vue +1 -1
  259. package/pkg/dynamic-importer.lib.js +8 -0
  260. package/pkg/vue.config.js +4 -0
  261. package/plugins/dashboard-store/__tests__/mutations.spec.js +406 -0
  262. package/plugins/dashboard-store/actions.js +32 -25
  263. package/plugins/dashboard-store/getters.js +50 -33
  264. package/plugins/dashboard-store/mutations.js +134 -28
  265. package/plugins/dashboard-store/resource-class.js +21 -41
  266. package/plugins/steve/actions.js +30 -0
  267. package/plugins/steve/caches/resourceCache.js +60 -0
  268. package/plugins/steve/getters.js +44 -1
  269. package/plugins/steve/mutations.js +97 -36
  270. package/plugins/steve/resourceWatcher.js +277 -0
  271. package/plugins/steve/schema.utils.js +25 -0
  272. package/plugins/steve/subscribe.js +288 -115
  273. package/plugins/steve/worker/index.js +17 -0
  274. package/plugins/steve/worker/web-worker.advanced.js +302 -0
  275. package/plugins/steve/{web-worker.steve-sub-worker.js → worker/web-worker.basic.js} +3 -44
  276. package/rancher-components/Card/Card.vue +3 -3
  277. package/rancher-components/Form/TextArea/TextAreaAutoGrow.vue +1 -0
  278. package/rancher-components/StringList/StringList.test.ts +45 -420
  279. package/rancher-components/StringList/StringList.vue +1 -10
  280. package/rancher-components/components/Banner/Banner.test.ts +44 -0
  281. package/rancher-components/components/Banner/Banner.vue +129 -61
  282. package/rancher-components/components/Form/Checkbox/Checkbox.test.ts +13 -22
  283. package/rancher-components/components/Form/Checkbox/Checkbox.vue +8 -6
  284. package/rancher-components/components/Form/ToggleSwitch/ToggleSwitch.test.ts +9 -9
  285. package/rancher-components/components/LabeledTooltip/LabeledTooltip.vue +0 -1
  286. package/rancher-components/components/StringList/StringList.test.ts +7 -7
  287. package/rancher-components/components/StringList/StringList.vue +21 -15
  288. package/scripts/test-plugins-build.sh +8 -0
  289. package/static/loading-indicator.html +1 -1
  290. package/store/index.js +54 -3
  291. package/store/plugins.js +0 -17
  292. package/store/pnap.js +128 -0
  293. package/store/prefs.js +4 -2
  294. package/store/type-map.js +55 -13
  295. package/types/pod-security-admission.ts +36 -0
  296. package/types/shell/index.d.ts +496 -396
  297. package/utils/__tests__/object.test.ts +17 -1
  298. package/utils/__tests__/pod-security-admission.test.ts +61 -0
  299. package/utils/async.ts +36 -0
  300. package/utils/color.js +45 -0
  301. package/utils/crypto/browserHashUtils.js +18 -0
  302. package/utils/dynamic-importer.js +8 -0
  303. package/utils/install-redirect.js +1 -1
  304. package/utils/object.js +24 -0
  305. package/utils/pod-security-admission.ts +39 -0
  306. package/utils/socket.js +61 -24
  307. package/utils/string.js +2 -0
  308. package/utils/svg-filter.js +301 -0
  309. package/utils/time.js +49 -0
  310. package/utils/validators/cidr.js +4 -0
  311. package/utils/validators/formRules/__tests__/index.test.ts +23 -3
  312. package/utils/validators/formRules/index.ts +14 -0
  313. package/config/product/harvester-manager.js +0 -162
  314. package/edit/harvesterhci.io.management.cluster.vue +0 -153
  315. package/list/harvesterhci.io.management.cluster.vue +0 -241
  316. package/machine-config/harvester.vue +0 -693
  317. package/models/harvesterhci.io.management.cluster.js +0 -228
  318. package/pages/c/_cluster/harvesterManager/index.vue +0 -24
  319. package/rancher-components/Card/Card.test.ts +0 -39
  320. package/rancher-components/Utils/DraggableZone/DraggableZone.vue +0 -181
  321. package/rancher-components/Utils/DraggableZone/index.ts +0 -1
  322. package/rancher-components/components/Utils/DraggableZone/index.ts +0 -1
@@ -1,693 +0,0 @@
1
- <script>
2
- import isEmpty from 'lodash/isEmpty';
3
- import NodeAffinity from '@shell/components/form/NodeAffinity';
4
- // import PodAffinity from '@shell/components/form/PodAffinity';
5
- import Loading from '@shell/components/Loading';
6
- import CreateEditView from '@shell/mixins/create-edit-view';
7
- import LabeledSelect from '@shell/components/form/LabeledSelect';
8
- import { LabeledInput } from '@components/Form/LabeledInput';
9
- import UnitInput from '@shell/components/form/UnitInput';
10
- import YamlEditor from '@shell/components/YamlEditor';
11
- import { Banner } from '@components/Banner';
12
-
13
- import { get } from '@shell/utils/object';
14
- import { mapGetters } from 'vuex';
15
- import {
16
- HCI,
17
- NAMESPACE,
18
- MANAGEMENT,
19
- CONFIG_MAP,
20
- NORMAN,
21
- NODE
22
- } from '@shell/config/types';
23
- import { base64Decode, base64Encode } from '@shell/utils/crypto';
24
- import { allHashSettled } from '@shell/utils/promise';
25
- import { podAffinity as podAffinityValidator } from '@shell/utils/validators/pod-affinity';
26
- import { stringify, exceptionToErrorsArray } from '@shell/utils/error';
27
- import { HCI as HCI_ANNOTATIONS } from '@shell/config/labels-annotations';
28
-
29
- const STORAGE_NETWORK = 'storage-network.settings.harvesterhci.io';
30
-
31
- export function isReady() {
32
- function getStatusConditionOfType(type, defaultValue = []) {
33
- const conditions = Array.isArray(get(this, 'status.conditions')) ? this.status.conditions : defaultValue;
34
-
35
- return conditions.find( cond => cond.type === type);
36
- }
37
-
38
- const initialized = getStatusConditionOfType.call(this, 'Initialized');
39
- const imported = getStatusConditionOfType.call(this, 'Imported');
40
- const isCompleted = this.status?.progress === 100;
41
-
42
- if ([initialized?.status, imported?.status].includes('False')) {
43
- return false;
44
- } else {
45
- return isCompleted && true;
46
- }
47
- }
48
-
49
- export default {
50
- name: 'ConfigComponentHarvester',
51
-
52
- components: {
53
- Loading, LabeledSelect, LabeledInput, UnitInput, Banner, YamlEditor, NodeAffinity
54
- },
55
-
56
- mixins: [CreateEditView],
57
-
58
- props: {
59
- credentialId: {
60
- type: String,
61
- required: true
62
- },
63
-
64
- uuid: {
65
- type: String,
66
- required: true
67
- },
68
-
69
- disabled: {
70
- type: Boolean,
71
- default: false
72
- },
73
-
74
- poolIndex: {
75
- type: Number,
76
- required: true
77
- },
78
-
79
- machinePools: {
80
- type: Array,
81
- default: () => []
82
- }
83
- },
84
-
85
- async fetch() {
86
- this.errors = [];
87
-
88
- try {
89
- this.credential = await this.$store.dispatch('rancher/find', {
90
- type: NORMAN.CLOUD_CREDENTIAL,
91
- id: this.credentialId
92
- });
93
- const clusterId = get(this.credential, 'decodedData.clusterId');
94
-
95
- const url = `/k8s/clusters/${ clusterId }/v1`;
96
-
97
- const isImportCluster =
98
- this.credential.decodedData.clusterType === 'imported';
99
-
100
- this.isImportCluster = isImportCluster;
101
-
102
- if (clusterId && isImportCluster) {
103
- const res = await allHashSettled({
104
- namespaces: this.$store.dispatch('cluster/request', { url: `${ url }/${ NAMESPACE }s` }),
105
- images: this.$store.dispatch('cluster/request', { url: `${ url }/${ HCI.IMAGE }s` }),
106
- configMaps: this.$store.dispatch('cluster/request', { url: `${ url }/${ CONFIG_MAP }s` }),
107
- networks: this.$store.dispatch('cluster/request', { url: `${ url }/k8s.cni.cncf.io.network-attachment-definitions` }),
108
- });
109
-
110
- for (const key of Object.keys(res)) {
111
- const obj = res[key];
112
-
113
- if (obj.status === 'rejected') {
114
- this.errors.push(stringify(obj.reason));
115
- continue;
116
- }
117
- }
118
-
119
- if (this.errors.length > 0) {
120
- // If an error is reported in the request data, see if it is due to a cluster error
121
- const cluster = await this.$store.dispatch('management/find', {
122
- type: MANAGEMENT.CLUSTER,
123
- id: clusterId
124
- });
125
-
126
- if (cluster.stateDescription && !cluster.isReady) {
127
- this.errors = [cluster.stateDescription];
128
- }
129
- }
130
-
131
- const userDataOptions = [];
132
- const networkDataOptions = [];
133
-
134
- (res.configMaps.value?.data || []).map((O) => {
135
- const cloudTemplate =
136
- O.metadata?.labels?.[HCI_ANNOTATIONS.CLOUD_INIT];
137
-
138
- if (cloudTemplate === 'user') {
139
- userDataOptions.push({
140
- label: O.metadata.name,
141
- value: O.data.cloudInit
142
- });
143
- }
144
-
145
- if (cloudTemplate === 'network') {
146
- networkDataOptions.push({
147
- label: O.metadata.name,
148
- value: O.data.cloudInit
149
- });
150
- }
151
- });
152
-
153
- this.userDataOptions = userDataOptions;
154
- this.networkDataOptions = networkDataOptions;
155
- this.images = res.images.value?.data;
156
- this.networkOptions = (res.networks.value?.data || []).filter(O => O.metadata?.annotations?.[STORAGE_NETWORK] !== 'true').map((O) => {
157
- let value;
158
- let label;
159
-
160
- try {
161
- const config = JSON.parse(O.spec.config);
162
-
163
- const id = config.vlan;
164
-
165
- value = O.id;
166
- label = `${ value } (vlanId=${ id })`;
167
- } catch (err) {}
168
-
169
- return {
170
- label,
171
- value
172
- };
173
- });
174
-
175
- (res.namespaces.value.data || []).forEach(async(namespace) => {
176
- const proxyNamespace = await this.$store.dispatch('cluster/create', namespace);
177
-
178
- if (!proxyNamespace.isSystem && namespace.links.update) {
179
- const value = namespace.metadata.name;
180
- const label = namespace.metadata.name;
181
-
182
- this.namespaces.push(namespace);
183
- this.namespaceOptions.push({
184
- label,
185
- value
186
- });
187
- }
188
- });
189
-
190
- try {
191
- const { data: nodes } = await this.$store.dispatch('cluster/request', { url: `${ url }/${ NODE }s` });
192
-
193
- this.allNodeObjects = nodes;
194
- } catch (err) {
195
- this.allNodeObjects = [];
196
- }
197
- }
198
-
199
- if (isEmpty(this.value.cpuCount)) {
200
- this.value.cpuCount = '2';
201
- }
202
-
203
- if (isEmpty(this.value.memorySize)) {
204
- this.value.memorySize = '4';
205
- }
206
-
207
- if (isEmpty(this.value.diskSize)) {
208
- this.value.diskSize = '40';
209
- }
210
- } catch (e) {
211
- this.errors = exceptionToErrorsArray(e);
212
- }
213
- },
214
-
215
- data() {
216
- let vmAffinity = { affinity: {} };
217
- let userData = '';
218
- let networkData = '';
219
-
220
- if (this.value.vmAffinity) {
221
- vmAffinity = { affinity: JSON.parse(base64Decode(this.value.vmAffinity)) };
222
- }
223
-
224
- if (this.value.userData) {
225
- userData = base64Decode(this.value.userData);
226
- }
227
-
228
- if (this.value.networkData) {
229
- networkData = base64Decode(this.value.networkData);
230
- }
231
-
232
- return {
233
- credential: null,
234
- isImportCluster: false,
235
- vmAffinity,
236
- userData,
237
- networkData,
238
- images: [],
239
- namespaces: [],
240
- namespaceOptions: [],
241
- networkOptions: [],
242
- userDataOptions: [],
243
- networkDataOptions: [],
244
- allNodeObjects: [],
245
- cpuCount: ''
246
- };
247
- },
248
-
249
- computed: {
250
- ...mapGetters({ t: 'i18n/t' }),
251
-
252
- disabledEdit() {
253
- return this.disabled || !!(this.isEdit && this.value.id);
254
- },
255
-
256
- imageOptions: {
257
- get() {
258
- return (this.images || []).filter( (O) => {
259
- return !O.spec.url.endsWith('.iso') && isReady.call(O);
260
- }).sort((a, b) => a.metadata.creationTimestamp > b.metadata.creationTimestamp ? -1 : 1).map( (O) => {
261
- const value = O.id;
262
- const label = `${ O.spec.displayName } (${ value })`;
263
-
264
- return {
265
- label,
266
- value
267
- };
268
- });
269
- },
270
- set(neu) {
271
- this.images = neu;
272
- }
273
- },
274
-
275
- namespaceDisabled() {
276
- return this.disabledEdit || this.poolIndex > 0;
277
- }
278
- },
279
-
280
- watch: {
281
- credentialId() {
282
- if (!this.isEdit) {
283
- this.imageOptions = [];
284
- this.networkOptions = [];
285
- this.namespaces = [];
286
- this.namespaceOptions = [];
287
- this.vmAffinity = { affinity: {} };
288
- this.value.imageName = '';
289
- this.value.networkName = '';
290
- this.value.vmNamespace = '';
291
- this.value.vmAffinity = '';
292
- }
293
-
294
- this.$fetch();
295
- },
296
-
297
- networkData(neu) {
298
- this.$refs.networkYamlEditor.refresh();
299
- this.value.networkData = base64Encode(neu);
300
- },
301
-
302
- userData(neu) {
303
- this.$refs.userDataYamlEditor.refresh();
304
- this.value.userData = base64Encode(neu);
305
- },
306
-
307
- machinePools: {
308
- handler(pools) {
309
- const vmNamespace = pools[0].config.vmNamespace;
310
-
311
- if (this.poolIndex > 0 && this.value.vmNamespace !== vmNamespace) {
312
- this.value.vmNamespace = vmNamespace;
313
- }
314
- },
315
- deep: true
316
- }
317
- },
318
-
319
- methods: {
320
- stringify,
321
-
322
- test() {
323
- const errors = [];
324
-
325
- if (!this.value.cpuCount) {
326
- const message = this.validatorRequiredField(
327
- this.t('cluster.credential.harvester.cpu')
328
- );
329
-
330
- errors.push(message);
331
- }
332
-
333
- if (!this.value.vmNamespace) {
334
- const message = this.validatorRequiredField(
335
- this.t('cluster.credential.harvester.namespace')
336
- );
337
-
338
- errors.push(message);
339
- }
340
-
341
- if (!this.value.memorySize) {
342
- const message = this.validatorRequiredField(
343
- this.t('cluster.credential.harvester.memory')
344
- );
345
-
346
- errors.push(message);
347
- }
348
-
349
- if (!this.value.diskSize) {
350
- const message = this.validatorRequiredField(
351
- this.t('cluster.credential.harvester.disk')
352
- );
353
-
354
- errors.push(message);
355
- }
356
-
357
- if (!this.value.imageName) {
358
- const message = this.validatorRequiredField(
359
- this.t('cluster.credential.harvester.image')
360
- );
361
-
362
- errors.push(message);
363
- }
364
-
365
- if (!this.value.sshUser) {
366
- const message = this.validatorRequiredField(
367
- this.t('cluster.credential.harvester.sshUser')
368
- );
369
-
370
- errors.push(message);
371
- }
372
-
373
- if (!this.value.networkName) {
374
- const message = this.validatorRequiredField(
375
- this.t('cluster.credential.harvester.network')
376
- );
377
-
378
- errors.push(message);
379
- }
380
-
381
- podAffinityValidator(this.vmAffinity.affinity, this.$store.getters, errors);
382
-
383
- return { errors };
384
- },
385
-
386
- validatorRequiredField(key) {
387
- return this.t('validation.required', { key });
388
- },
389
-
390
- valuesChanged(value, type) {
391
- this.value[type] = base64Encode(value);
392
- },
393
-
394
- onOpen() {
395
- this.getVmImage();
396
- },
397
-
398
- async getVmImage() {
399
- try {
400
- const clusterId = get(this.credential, 'decodedData.clusterId');
401
- const url = `/k8s/clusters/${ clusterId }/v1`;
402
-
403
- if (url && this.isImportCluster) {
404
- const res = await this.$store.dispatch('cluster/request', { url: `${ url }/${ HCI.IMAGE }s` });
405
-
406
- this.images = res?.data;
407
- }
408
- } catch (e) {
409
- this.errors = exceptionToErrorsArray(e);
410
- }
411
- },
412
-
413
- updateScheduling(neu) {
414
- const { affinity } = neu;
415
-
416
- if (!affinity.nodeAffinity && !affinity.podAffinity && !affinity.podAntiAffinity) {
417
- this.value.vmAffinity = '';
418
- this.vmAffinity = { affinity: {} };
419
-
420
- return;
421
- }
422
-
423
- this.value.vmAffinity = base64Encode(JSON.stringify(affinity));
424
- this.vmAffinity = neu;
425
- },
426
-
427
- updateNodeScheduling(nodeAffinity) {
428
- if (!this.vmAffinity.affinity) {
429
- Object.assign(this.vmAffinity, { affinity: { nodeAffinity } });
430
- } else {
431
- Object.assign(this.vmAffinity.affinity, { nodeAffinity });
432
- }
433
-
434
- this.updateScheduling(this.vmAffinity);
435
- }
436
- }
437
- };
438
- </script>
439
-
440
- <template>
441
- <div>
442
- <Loading
443
- v-if="$fetchState.pending"
444
- :delayed="true"
445
- />
446
- <div v-else>
447
- <div class="row mt-20">
448
- <div class="col span-6">
449
- <UnitInput
450
- v-model="value.cpuCount"
451
- v-int-number
452
- label-key="cluster.credential.harvester.cpu"
453
- suffix="C"
454
- output-as="string"
455
- required
456
- :mode="mode"
457
- :disabled="disabled"
458
- :placeholder="t('cluster.harvester.machinePool.cpu.placeholder')"
459
- />
460
- </div>
461
-
462
- <div class="col span-6">
463
- <UnitInput
464
- v-model="value.memorySize"
465
- v-int-number
466
- label-key="cluster.credential.harvester.memory"
467
- output-as="string"
468
- suffix="GiB"
469
- :mode="mode"
470
- :disabled="disabled"
471
- required
472
- :placeholder="t('cluster.harvester.machinePool.memory.placeholder')"
473
- />
474
- </div>
475
- </div>
476
-
477
- <div class="row mt-20">
478
- <div class="col span-6">
479
- <UnitInput
480
- v-model="value.diskSize"
481
- v-int-number
482
- label-key="cluster.credential.harvester.disk"
483
- output-as="string"
484
- suffix="GiB"
485
- :mode="mode"
486
- :disabled="disabled"
487
- required
488
- :placeholder="t('cluster.harvester.machinePool.disk.placeholder')"
489
- />
490
- </div>
491
-
492
- <div class="col span-6">
493
- <LabeledSelect
494
- v-if="isImportCluster"
495
- v-model="value.vmNamespace"
496
- :mode="mode"
497
- :options="namespaceOptions"
498
- :searchable="true"
499
- :required="true"
500
- :disabled="namespaceDisabled"
501
- label-key="cluster.credential.harvester.namespace"
502
- :placeholder="
503
- t('cluster.harvester.machinePool.namespace.placeholder')
504
- "
505
- />
506
-
507
- <LabeledInput
508
- v-else
509
- v-model="value.vmNamespace"
510
- label-key="cluster.credential.harvester.namespace"
511
- :required="true"
512
- :mode="mode"
513
- :disabled="namespaceDisabled"
514
- :placeholder="
515
- t('cluster.harvester.machinePool.namespace.placeholder')
516
- "
517
- />
518
- </div>
519
- </div>
520
-
521
- <div
522
- v-if="isImportCluster"
523
- class="row mt-20"
524
- >
525
- <div class="col span-6">
526
- <LabeledSelect
527
- v-model="value.imageName"
528
- :mode="mode"
529
- :options="imageOptions"
530
- :required="true"
531
- :searchable="true"
532
- :disabled="disabled"
533
- label-key="cluster.credential.harvester.image"
534
- :placeholder="t('cluster.harvester.machinePool.image.placeholder')"
535
- @on-open="onOpen"
536
- />
537
- </div>
538
-
539
- <div class="col span-6">
540
- <LabeledSelect
541
- v-model="value.networkName"
542
- :mode="mode"
543
- :options="networkOptions"
544
- :required="true"
545
- :disabled="disabledEdit"
546
- label-key="cluster.credential.harvester.network"
547
- :placeholder="
548
- t('cluster.harvester.machinePool.network.placeholder')
549
- "
550
- />
551
- </div>
552
- </div>
553
-
554
- <div
555
- v-else
556
- class="row mt-20"
557
- >
558
- <div class="col span-6">
559
- <LabeledInput
560
- v-model="value.imageName"
561
- :mode="mode"
562
- :required="true"
563
- :placeholder="t('cluster.credential.harvester.placeholder')"
564
- :disabled="disabledEdit"
565
- label-key="cluster.credential.harvester.image"
566
- />
567
- </div>
568
-
569
- <div class="col span-6">
570
- <LabeledInput
571
- v-model="value.networkName"
572
- :mode="mode"
573
- :required="true"
574
- :placeholder="t('cluster.credential.harvester.placeholder')"
575
- :disabled="disabledEdit"
576
- label-key="cluster.credential.harvester.network"
577
- />
578
- </div>
579
- </div>
580
-
581
- <div class="row mt-20">
582
- <div class="col span-6">
583
- <LabeledInput
584
- v-model="value.sshUser"
585
- label-key="cluster.credential.harvester.sshUser"
586
- :required="true"
587
- :mode="mode"
588
- :disabled="disabled"
589
- :placeholder="
590
- t('cluster.harvester.machinePool.sshUser.placeholder')
591
- "
592
- tooltip-key="cluster.harvester.machinePool.sshUser.toolTip"
593
- />
594
- </div>
595
- </div>
596
-
597
- <portal :to="'advanced-'+uuid">
598
- <h3 class="mt-20">
599
- {{ t("workload.container.titles.nodeScheduling") }}
600
- </h3>
601
- <NodeAffinity
602
- :mode="mode"
603
- :value="vmAffinity.affinity.nodeAffinity"
604
- @input="updateNodeScheduling"
605
- />
606
-
607
- <!-- <h3 class="mt-20">
608
- {{ t("workload.container.titles.podScheduling") }}
609
- </h3>
610
- <PodAffinity
611
- :mode="mode"
612
- :value="vmAffinity"
613
- :nodes="allNodeObjects"
614
- :namespaces="namespaces"
615
- @update="updateScheduling"
616
- /> -->
617
-
618
- <h3 class="mt-20">
619
- {{ t("cluster.credential.harvester.userData.title") }}
620
- </h3>
621
- <div>
622
- <LabeledSelect
623
- v-if="isImportCluster && isCreate"
624
- v-model="userData"
625
- class="mb-10"
626
- :options="userDataOptions"
627
- label-key="cluster.credential.harvester.userData.label"
628
- :mode="mode"
629
- :disabled="disabled"
630
- />
631
-
632
- <YamlEditor
633
- ref="userDataYamlEditor"
634
- :key="userData"
635
- class="yaml-editor mb-20"
636
- :editor-mode="mode === 'view' ? 'VIEW_CODE' : 'EDIT_CODE'"
637
- :value="userData"
638
- :disabled="disabled"
639
- @onInput="valuesChanged($event, 'userData')"
640
- />
641
- </div>
642
-
643
- <h3>{{ t('cluster.credential.harvester.networkData.title') }}</h3>
644
- <div>
645
- <LabeledSelect
646
- v-if="isImportCluster && isCreate"
647
- v-model="networkData"
648
- class="mb-10"
649
- :options="networkDataOptions"
650
- label-key="cluster.credential.harvester.networkData.label"
651
- :mode="mode"
652
- :disabled="disabled"
653
- />
654
-
655
- <YamlEditor
656
- ref="networkYamlEditor"
657
- :key="networkData"
658
- class="yaml-editor mb-10"
659
- :editor-mode="mode === 'view' ? 'VIEW_CODE' : 'EDIT_CODE'"
660
- :value="networkData"
661
- :disabled="disabled"
662
- @onInput="valuesChanged($event, 'networkData')"
663
- />
664
- </div>
665
- </portal>
666
- </div>
667
- <div v-if="errors.length">
668
- <div
669
- v-for="(err, idx) in errors"
670
- :key="idx"
671
- >
672
- <Banner
673
- color="error"
674
- :label="stringify(err.Message || err)"
675
- />
676
- </div>
677
- </div>
678
- </div>
679
- </template>
680
-
681
- <style lang="scss" scoped>
682
- $yaml-height: 200px;
683
-
684
- ::v-deep .yaml-editor {
685
- flex: 1;
686
- min-height: $yaml-height;
687
- & .code-mirror .CodeMirror {
688
- position: initial;
689
- height: auto;
690
- min-height: $yaml-height;
691
- }
692
- }
693
- </style>