@rancher/shell 0.1.1 → 0.1.3

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 (294) hide show
  1. package/assets/translations/en-us.yaml +33 -769
  2. package/assets/translations/zh-hans.yaml +153 -781
  3. package/components/ActionMenu.vue +3 -3
  4. package/components/CodeMirror.vue +6 -8
  5. package/components/CommunityLinks.vue +1 -1
  6. package/components/ContainerResourceLimit.vue +14 -0
  7. package/components/ExplorerMembers.vue +123 -0
  8. package/components/ExplorerProjectsNamespaces.vue +405 -0
  9. package/components/GrafanaDashboard.vue +17 -2
  10. package/components/LocaleSelector.vue +81 -0
  11. package/components/PromptModal.vue +2 -3
  12. package/components/ResourceList/index.vue +1 -1
  13. package/components/ResourceTable.vue +3 -6
  14. package/components/SingleClusterInfo.vue +1 -1
  15. package/components/SortableTable/index.vue +23 -20
  16. package/components/SortableTable/selection.js +1 -0
  17. package/components/auth/AzureWarning.vue +5 -1
  18. package/components/auth/Principal.vue +1 -1
  19. package/components/auth/RoleDetailEdit.vue +32 -12
  20. package/components/fleet/FleetRepos.vue +0 -2
  21. package/components/form/NameNsDescription.vue +4 -6
  22. package/components/form/NodeScheduling.vue +1 -1
  23. package/components/form/ResourceTabs/index.vue +27 -18
  24. package/components/form/WorkloadPorts.vue +1 -1
  25. package/components/formatter/ClusterLink.vue +13 -0
  26. package/components/formatter/PodImages.vue +11 -1
  27. package/components/formatter/RKETemplateName.vue +37 -0
  28. package/components/formatter/WorkloadHealthScale.vue +1 -1
  29. package/components/nav/Header.vue +9 -9
  30. package/components/nav/NamespaceFilter.vue +7 -4
  31. package/components/nav/TopLevelMenu.vue +6 -43
  32. package/components/nav/WindowManager/ContainerLogs.vue +1 -1
  33. package/config/product/harvester-manager.js +64 -2
  34. package/config/product/manager.js +9 -0
  35. package/config/settings.js +17 -71
  36. package/config/table-headers.js +0 -1
  37. package/config/types.js +8 -26
  38. package/core/plugin-routes.ts +34 -22
  39. package/core/plugin.ts +15 -3
  40. package/core/plugins-loader.js +2 -0
  41. package/core/plugins.js +79 -36
  42. package/core/types.ts +7 -1
  43. package/creators/app/tsconfig.json +6 -1
  44. package/creators/pkg/init +3 -0
  45. package/creators/pkg/tsconfig.json +7 -2
  46. package/detail/provisioning.cattle.io.cluster.vue +23 -0
  47. package/detail/workload/index.vue +11 -5
  48. package/{components/dialog → dialog}/AddClusterMemberDialog.vue +0 -0
  49. package/{components/dialog → dialog}/AddCustomBadgeDialog.vue +0 -0
  50. package/{components/dialog → dialog}/AddProjectMemberDialog.vue +0 -0
  51. package/{components/dialog → dialog}/AddonConfigConfirmationDialog.vue +0 -0
  52. package/{components/dialog → dialog}/DrainNode.vue +0 -0
  53. package/{components/dialog → dialog}/ForceMachineRemoveDialog.vue +0 -0
  54. package/{components/dialog → dialog}/GenericPrompt.vue +0 -0
  55. package/{components/dialog → dialog}/RollbackWorkloadDialog.vue +0 -0
  56. package/{components/dialog → dialog}/RotateCertificatesDialog.vue +0 -0
  57. package/{components/dialog → dialog}/RotateEncryptionKeyDialog.vue +0 -0
  58. package/{components/dialog → dialog}/SaveAsRKETemplateDialog.vue +0 -0
  59. package/{components/dialog → dialog}/ScaleMachineDownDialog.vue +0 -0
  60. package/edit/auth/azuread.vue +20 -1
  61. package/edit/cloudcredential.vue +7 -1
  62. package/edit/management.cattle.io.project.vue +2 -2
  63. package/edit/namespace.vue +17 -10
  64. package/edit/networking.k8s.io.ingress/index.vue +2 -1
  65. package/edit/persistentvolumeclaim.vue +33 -2
  66. package/edit/provisioning.cattle.io.cluster/CustomCommand.vue +1 -1
  67. package/edit/provisioning.cattle.io.cluster/MachinePool.vue +34 -6
  68. package/edit/provisioning.cattle.io.cluster/index.vue +1 -1
  69. package/edit/provisioning.cattle.io.cluster/rke2.vue +21 -6
  70. package/edit/service.vue +1 -1
  71. package/edit/workload/index.vue +363 -15
  72. package/edit/workload/mixins/workload.js +62 -7
  73. package/edit/workload/storage/persistentVolumeClaim/persistentvolumeclaim.vue +1 -0
  74. package/layouts/default.vue +52 -27
  75. package/layouts/error.vue +5 -1
  76. package/layouts/home.vue +6 -2
  77. package/list/harvesterhci.io.management.cluster.vue +74 -33
  78. package/list/namespace.vue +3 -5
  79. package/list/provisioning.cattle.io.cluster.vue +6 -0
  80. package/machine-config/amazonec2.vue +2 -0
  81. package/machine-config/harvester.vue +96 -49
  82. package/middleware/authenticated.js +56 -52
  83. package/mixins/brand.js +3 -4
  84. package/mixins/create-edit-view/impl.js +0 -8
  85. package/mixins/form-validation.js +1 -1
  86. package/mixins/resource-fetch.js +3 -1
  87. package/models/chart.js +1 -1
  88. package/models/cluster/node.js +12 -1
  89. package/models/fleet.cattle.io.bundle.js +26 -19
  90. package/models/harvesterhci.io.management.cluster.js +194 -5
  91. package/models/management.cattle.io.cluster.js +1 -1
  92. package/models/management.cattle.io.clusterroletemplatebinding.js +9 -0
  93. package/models/management.cattle.io.globalrole.js +0 -19
  94. package/models/management.cattle.io.project.js +23 -2
  95. package/models/management.cattle.io.roletemplate.js +2 -21
  96. package/models/namespace.js +19 -3
  97. package/models/pod.js +19 -2
  98. package/models/provisioning.cattle.io.cluster.js +71 -0
  99. package/models/service.js +5 -1
  100. package/models/workload.js +4 -243
  101. package/models/workload.service.js +314 -0
  102. package/nuxt.config.js +14 -12
  103. package/package.json +3 -3
  104. package/pages/auth/login.vue +11 -2
  105. package/pages/auth/setup.vue +1 -1
  106. package/pages/c/_cluster/_product/members/index.vue +3 -93
  107. package/pages/c/_cluster/_product/projectsnamespaces.vue +6 -403
  108. package/pages/c/_cluster/apps/charts/install.vue +0 -6
  109. package/pages/c/_cluster/settings/performance.vue +19 -16
  110. package/pages/fail-whale.vue +1 -10
  111. package/pages/index.vue +18 -4
  112. package/pages/plugins.vue +2 -2
  113. package/pages/prefs.vue +8 -6
  114. package/pkg/auto-import.js +44 -7
  115. package/pkg/dynamic-plugin-loader.js +28 -0
  116. package/pkg/import.js +2 -2
  117. package/pkg/model-loader-require.lib.js +3 -0
  118. package/pkg/vue.config.js +9 -6
  119. package/plugins/console.js +10 -5
  120. package/plugins/dashboard-store/actions.js +8 -3
  121. package/plugins/dashboard-store/getters.js +7 -2
  122. package/plugins/dashboard-store/model-loader-require.js +12 -0
  123. package/plugins/dashboard-store/model-loader.js +4 -1
  124. package/plugins/dashboard-store/resource-class.js +10 -3
  125. package/plugins/steve/actions.js +1 -1
  126. package/plugins/steve/index.js +6 -4
  127. package/plugins/steve/steve-description-class.js +32 -0
  128. package/plugins/steve/subscribe.js +34 -23
  129. package/rancher-components/Banner/Banner.vue +2 -2
  130. package/rancher-components/Form/Checkbox/Checkbox.test.ts +77 -0
  131. package/rancher-components/Form/Checkbox/Checkbox.vue +12 -2
  132. package/rancher-components/Form/LabeledInput/LabeledInput.test.ts +0 -2
  133. package/rancher-components/Form/LabeledInput/LabeledInput.vue +2 -0
  134. package/rancher-components/Form/Radio/RadioButton.vue +14 -1
  135. package/rancher-components/Form/ToggleSwitch/ToggleSwitch.test.ts +107 -0
  136. package/{components/form → rancher-components/Form/ToggleSwitch}/ToggleSwitch.vue +18 -8
  137. package/rancher-components/Form/ToggleSwitch/index.ts +1 -0
  138. package/rancher-components/Form/index.ts +1 -0
  139. package/scripts/build-pkg.sh +48 -2
  140. package/scripts/drone-build-pkg.sh +31 -0
  141. package/scripts/publish-shell.sh +10 -11
  142. package/scripts/serve-pkgs +17 -10
  143. package/scripts/test-plugins-build.sh +18 -1
  144. package/store/catalog.js +3 -1
  145. package/store/i18n.js +16 -11
  146. package/store/index.js +4 -181
  147. package/store/prefs.js +30 -2
  148. package/store/type-map.js +16 -29
  149. package/types/{index.d.ts → rancher/index.d.ts} +0 -0
  150. package/utils/cluster.js +1 -1
  151. package/utils/custom-validators.js +1 -12
  152. package/utils/dynamic-importer.js +1 -1
  153. package/utils/validators/setting.js +0 -35
  154. package/components/FilterLabel.vue +0 -254
  155. package/components/HarvesterUpgradeProgressBarList.vue +0 -109
  156. package/components/VMConsoleBar.vue +0 -87
  157. package/components/dialog/harvester/AddHotplugModal.vue +0 -159
  158. package/components/dialog/harvester/BackupModal.vue +0 -117
  159. package/components/dialog/harvester/CloneTemplate.vue +0 -125
  160. package/components/dialog/harvester/EjectCDROMDialog.vue +0 -157
  161. package/components/dialog/harvester/ExportImageDialog.vue +0 -152
  162. package/components/dialog/harvester/MaintenanceDialog.vue +0 -94
  163. package/components/dialog/harvester/MigrationDialog.vue +0 -154
  164. package/components/dialog/harvester/RestoreDialog.vue +0 -153
  165. package/components/dialog/harvester/SupportBundle.vue +0 -217
  166. package/components/dialog/harvester/UnplugVolume.vue +0 -108
  167. package/components/form/SerialConsole/index.vue +0 -267
  168. package/components/formatter/AttachVMWithName.vue +0 -46
  169. package/components/formatter/CloudInitType.vue +0 -27
  170. package/components/formatter/HarvesterBackupTargetValidation.vue +0 -43
  171. package/components/formatter/HarvesterCPUUsed.vue +0 -122
  172. package/components/formatter/HarvesterDiskState.vue +0 -66
  173. package/components/formatter/HarvesterHostName.vue +0 -66
  174. package/components/formatter/HarvesterIpAddress.vue +0 -90
  175. package/components/formatter/HarvesterMemoryUsed.vue +0 -140
  176. package/components/formatter/HarvesterMigrationState.vue +0 -85
  177. package/components/formatter/HarvesterNodeName.vue +0 -49
  178. package/components/formatter/HarvesterStorageUsed.vue +0 -194
  179. package/components/formatter/HarvesterVmState.vue +0 -123
  180. package/components/nav/HarvesterUpgrade.vue +0 -232
  181. package/components/novnc/NovncConsole.vue +0 -93
  182. package/components/novnc/NovncConsoleItem.vue +0 -89
  183. package/components/novnc/NovncConsoleWrapper.vue +0 -243
  184. package/config/harvester-map.js +0 -44
  185. package/config/harvester-table-headers.js +0 -27
  186. package/config/product/harvester.js +0 -305
  187. package/detail/harvesterhci.io.host/HarvesterHostBasic.vue +0 -364
  188. package/detail/harvesterhci.io.host/HarvesterHostDisk.vue +0 -200
  189. package/detail/harvesterhci.io.host/HarvesterHostNetwork.vue +0 -89
  190. package/detail/harvesterhci.io.host/VirtualMachineInstance.vue +0 -134
  191. package/detail/harvesterhci.io.host/index.vue +0 -243
  192. package/detail/harvesterhci.io.virtualmachinebackup/index.vue +0 -221
  193. package/detail/harvesterhci.io.virtualmachineimage.vue +0 -118
  194. package/detail/kubevirt.io.virtualmachine/VirtualMachineTabs/VirtualMachineBasics.vue +0 -279
  195. package/detail/kubevirt.io.virtualmachine/VirtualMachineTabs/VirtualMachineEvents.vue +0 -75
  196. package/detail/kubevirt.io.virtualmachine/VirtualMachineTabs/VirtualMachineKeypairs.vue +0 -114
  197. package/detail/kubevirt.io.virtualmachine/VirtualMachineTabs/VirtualMachineMigration.vue +0 -79
  198. package/detail/kubevirt.io.virtualmachine/index.vue +0 -213
  199. package/edit/harvesterhci.io.cloudtemplate.vue +0 -123
  200. package/edit/harvesterhci.io.host/HarvesterDisk.vue +0 -262
  201. package/edit/harvesterhci.io.host/index.vue +0 -533
  202. package/edit/harvesterhci.io.keypair.vue +0 -112
  203. package/edit/harvesterhci.io.managedchart/index.vue +0 -25
  204. package/edit/harvesterhci.io.managedchart/rancher-monitoring.vue +0 -172
  205. package/edit/harvesterhci.io.networkattachmentdefinition.vue +0 -210
  206. package/edit/harvesterhci.io.setting/additional-ca.vue +0 -36
  207. package/edit/harvesterhci.io.setting/backup-target.vue +0 -182
  208. package/edit/harvesterhci.io.setting/http-proxy.vue +0 -79
  209. package/edit/harvesterhci.io.setting/index.vue +0 -201
  210. package/edit/harvesterhci.io.setting/overcommit-config.vue +0 -94
  211. package/edit/harvesterhci.io.setting/ssl-certificates.vue +0 -117
  212. package/edit/harvesterhci.io.setting/ssl-parameters.vue +0 -161
  213. package/edit/harvesterhci.io.setting/support-bundle-image.vue +0 -134
  214. package/edit/harvesterhci.io.setting/support-bundle-namespaces.vue +0 -73
  215. package/edit/harvesterhci.io.setting/vip-pools.vue +0 -244
  216. package/edit/harvesterhci.io.setting/vm-force-reset-policy.vue +0 -81
  217. package/edit/harvesterhci.io.virtualmachinebackup.vue +0 -256
  218. package/edit/harvesterhci.io.virtualmachineimage.vue +0 -364
  219. package/edit/harvesterhci.io.virtualmachinetemplateversion.vue +0 -340
  220. package/edit/harvesterhci.io.volume.vue +0 -195
  221. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/AccessCredentialsUsers.vue +0 -190
  222. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/index.vue +0 -212
  223. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/type/basicAuth.vue +0 -94
  224. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/type/sshkey.vue +0 -85
  225. package/edit/kubevirt.io.virtualmachine/VirtualMachineCloudConfig/DataTemplate.vue +0 -153
  226. package/edit/kubevirt.io.virtualmachine/VirtualMachineCloudConfig/index.vue +0 -279
  227. package/edit/kubevirt.io.virtualmachine/VirtualMachineCpuMemory.vue +0 -113
  228. package/edit/kubevirt.io.virtualmachine/VirtualMachineNetwork/__tests__/HarvesterEditNetwork.test.ts +0 -41
  229. package/edit/kubevirt.io.virtualmachine/VirtualMachineNetwork/base.vue +0 -281
  230. package/edit/kubevirt.io.virtualmachine/VirtualMachineNetwork/index.vue +0 -142
  231. package/edit/kubevirt.io.virtualmachine/VirtualMachineReserved.vue +0 -54
  232. package/edit/kubevirt.io.virtualmachine/VirtualMachineSSHKey.vue +0 -256
  233. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/index.vue +0 -391
  234. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditContainer.test.ts +0 -40
  235. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditExisting.test.ts +0 -102
  236. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditVMImage.test.ts +0 -117
  237. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditVolume.test.ts +0 -74
  238. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/container.vue +0 -132
  239. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/existing.vue +0 -303
  240. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/vmImage.vue +0 -285
  241. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/volume.vue +0 -188
  242. package/edit/kubevirt.io.virtualmachine/index.vue +0 -642
  243. package/edit/network.harvesterhci.io.clusternetwork/index.vue +0 -19
  244. package/edit/network.harvesterhci.io.clusternetwork/vlan.vue +0 -134
  245. package/edit/workload/types/Deployment.vue +0 -377
  246. package/edit/workload/types/Generic.vue +0 -295
  247. package/list/harvesterhci.io.cloudtemplate.vue +0 -78
  248. package/list/harvesterhci.io.dashboard/HarvesterUpgrade.vue +0 -211
  249. package/list/harvesterhci.io.dashboard/UpgradeInfo.vue +0 -40
  250. package/list/harvesterhci.io.dashboard/index.vue +0 -752
  251. package/list/harvesterhci.io.host/index.vue +0 -186
  252. package/list/harvesterhci.io.networkattachmentdefinition.vue +0 -167
  253. package/list/harvesterhci.io.setting.vue +0 -241
  254. package/list/harvesterhci.io.virtualmachinebackup.vue +0 -172
  255. package/list/harvesterhci.io.virtualmachineimage.vue +0 -80
  256. package/list/harvesterhci.io.virtualmachinetemplateversion.vue +0 -173
  257. package/list/harvesterhci.io.volume.vue +0 -122
  258. package/list/kubevirt.io.virtualmachine.vue +0 -193
  259. package/mixins/harvester-vm/impl.js +0 -267
  260. package/mixins/harvester-vm/index.js +0 -1357
  261. package/models/harvester/configmap.js +0 -32
  262. package/models/harvester/harvesterhci.io.blockdevice.js +0 -55
  263. package/models/harvester/harvesterhci.io.keypair.js +0 -12
  264. package/models/harvester/harvesterhci.io.setting.js +0 -127
  265. package/models/harvester/harvesterhci.io.supportbundle.js +0 -35
  266. package/models/harvester/harvesterhci.io.upgrade.js +0 -226
  267. package/models/harvester/harvesterhci.io.virtualmachinebackup.js +0 -116
  268. package/models/harvester/harvesterhci.io.virtualmachineimage.js +0 -255
  269. package/models/harvester/harvesterhci.io.virtualmachinerestore.js +0 -43
  270. package/models/harvester/harvesterhci.io.virtualmachinetemplate.js +0 -69
  271. package/models/harvester/harvesterhci.io.virtualmachinetemplateversion.js +0 -227
  272. package/models/harvester/k8s.cni.cncf.io.networkattachmentdefinition.js +0 -32
  273. package/models/harvester/kubevirt.io.virtualmachine.js +0 -850
  274. package/models/harvester/kubevirt.io.virtualmachineinstance.js +0 -142
  275. package/models/harvester/management.cattle.io.managedchart.js +0 -191
  276. package/models/harvester/management.cattle.io.setting.js +0 -40
  277. package/models/harvester/network.harvesterhci.io.clusternetwork.js +0 -100
  278. package/models/harvester/network.harvesterhci.io.nodenetwork.js +0 -34
  279. package/models/harvester/node.js +0 -255
  280. package/models/harvester/persistentvolumeclaim.js +0 -166
  281. package/models/harvester/pod.js +0 -185
  282. package/pages/c/_cluster/harvester/airgapupgrade/index.vue +0 -309
  283. package/pages/c/_cluster/harvester/console/_uid/serial.vue +0 -51
  284. package/pages/c/_cluster/harvester/console/_uid/vnc.vue +0 -52
  285. package/pages/c/_cluster/harvester/index.vue +0 -24
  286. package/pages/c/_cluster/harvester/support/index.vue +0 -154
  287. package/pkg/model-loader.lib.js +0 -3
  288. package/plugins/lookup.js +0 -50
  289. package/promptRemove/kubevirt.io.virtualmachine.vue +0 -164
  290. package/store/harvester-common.js +0 -126
  291. package/utils/validators/vm-datavolumes.js +0 -38
  292. package/utils/validators/vm-image.js +0 -32
  293. package/utils/validators/vm.js +0 -221
  294. package/yarn-error.log +0 -196
@@ -1,200 +0,0 @@
1
- <script>
2
- import LabelValue from '@shell/components/LabelValue';
3
- import { BadgeState } from '@components/BadgeState';
4
- import { Banner } from '@components/Banner';
5
-
6
- export default {
7
- components: {
8
- LabelValue,
9
- BadgeState,
10
- Banner,
11
- },
12
-
13
- props: {
14
- value: {
15
- type: Object,
16
- default: () => {
17
- return {};
18
- },
19
- },
20
- disks: {
21
- type: Array,
22
- default: () => [],
23
- },
24
- mode: {
25
- type: String,
26
- default: 'edit',
27
- },
28
- },
29
- data() {
30
- return {};
31
- },
32
- computed: {
33
- allowSchedulingOptions() {
34
- return [{
35
- label: this.t('generic.enabled'),
36
- value: true,
37
- }, {
38
- label: this.t('generic.disabled'),
39
- value: false,
40
- }];
41
- },
42
-
43
- evictionRequestedOptions() {
44
- return [{
45
- label: this.t('generic.yes'),
46
- value: true,
47
- }, {
48
- label: this.t('generic.no'),
49
- value: false,
50
- }];
51
- },
52
-
53
- readyCondiction() {
54
- return this.value?.conditions?.Ready || {};
55
- },
56
-
57
- schedulableCondiction() {
58
- return this.value?.conditions?.Schedulable || {};
59
- },
60
-
61
- provisionPhase() {
62
- return this.value?.blockDevice?.provisionPhase || {};
63
- },
64
-
65
- mountedMessage() {
66
- const state = this.value?.blockDevice?.metadata?.state || {};
67
-
68
- if (state?.error) {
69
- return state?.message;
70
- } else {
71
- return '';
72
- }
73
- },
74
- },
75
- methods: {
76
- update() {
77
- this.$emit('input', this.value);
78
- },
79
-
80
- canEditPath(value) {
81
- if (this.mountedMessage) {
82
- return true;
83
- }
84
-
85
- if (value.isNew && !!value.originPath) {
86
- return true;
87
- }
88
-
89
- return false;
90
- },
91
- },
92
- };
93
- </script>
94
-
95
- <template>
96
- <div class="disk" @input="update">
97
- <div class="mt-30" />
98
- <Banner
99
- v-if="mountedMessage"
100
- color="error"
101
- :label="mountedMessage"
102
- />
103
- <div v-if="!value.isNew">
104
- <div class="row">
105
- <div class="col span-12">
106
- <div class="pull-right">
107
- Conditions:
108
- <BadgeState
109
- v-tooltip="readyCondiction.message"
110
- :color="readyCondiction.status === 'True' ? 'bg-success' : 'bg-error' "
111
- :icon="readyCondiction.status === 'True' ? 'icon-checkmark' : 'icon-warning' "
112
- label="Ready"
113
- class="mr-10 ml-10 state"
114
- />
115
- <BadgeState
116
- v-tooltip="schedulableCondiction.message"
117
- :color="schedulableCondiction.status === 'True' ? 'bg-success' : 'bg-error' "
118
- :icon="schedulableCondiction.status === 'True' ? 'icon-checkmark' : 'icon-warning' "
119
- label="Schedulable"
120
- class="mr-10 state"
121
- />
122
- <BadgeState
123
- v-if="provisionPhase.label"
124
- :color="provisionPhase.color"
125
- :icon="provisionPhase.icon"
126
- :label="provisionPhase.label"
127
- class="mr-10 state"
128
- />
129
- </div>
130
- </div>
131
- </div>
132
- <div v-if="!value.isNew" class="row mt-30">
133
- <div class="col span-4">
134
- <LabelValue
135
- name="Storage Available"
136
- :value="value.storageAvailable"
137
- />
138
- </div>
139
- <div class="col span-4">
140
- <LabelValue
141
- name="Storage Scheduled"
142
- :value="value.storageScheduled"
143
- />
144
- </div>
145
- <div class="col span-4">
146
- <LabelValue
147
- name="Storage Max"
148
- :value="value.storageMaximum"
149
- />
150
- </div>
151
- </div>
152
- <hr class="mt-10" />
153
- </div>
154
- <div class="row mt-10">
155
- <div class="col span-4">
156
- <LabelValue
157
- :name="t('generic.name')"
158
- :value="value.displayName"
159
- />
160
- </div>
161
- <div class="col span-4">
162
- <LabelValue
163
- :name="t('harvester.host.disk.path.label')"
164
- :value="value.path"
165
- />
166
- </div>
167
- </div>
168
- </div>
169
- </template>
170
-
171
- <style lang="scss" scoped>
172
- .close {
173
- top: 10px;
174
- right: 10px;
175
- padding:0;
176
- position: absolute;
177
- }
178
-
179
- .disk {
180
- position: relative;
181
-
182
- .secret-name {
183
- height: $input-height;
184
- }
185
-
186
- &:not(:last-of-type) {
187
- padding-bottom: 10px;
188
- margin-bottom: 30px;
189
- }
190
- }
191
-
192
- .flex {
193
- display: flex;
194
- justify-content: space-between;
195
- }
196
-
197
- .badge-state {
198
- padding: 2px 5px;
199
- }
200
- </style>
@@ -1,89 +0,0 @@
1
- <script>
2
- import LabelValue from '@shell/components/LabelValue';
3
- import InputOrDisplay from '@shell/components/InputOrDisplay';
4
- import { _CREATE } from '@shell/config/query-params';
5
-
6
- export default {
7
- name: 'HarvesterHostNetwork',
8
-
9
- components: {
10
- LabelValue,
11
- InputOrDisplay,
12
- },
13
-
14
- props: {
15
- value: {
16
- type: Object,
17
- required: true,
18
- },
19
-
20
- mode: {
21
- type: String,
22
- default: _CREATE,
23
- },
24
- },
25
- };
26
- </script>
27
-
28
- <template>
29
- <div>
30
- <div class="row">
31
- <div class="col span-6">
32
- <LabelValue
33
- :name="t('generic.name')"
34
- :value="value.name"
35
- />
36
- </div>
37
- <div class="col span-6">
38
- <LabelValue
39
- :name="t('tableHeaders.state')"
40
- :value="value.state"
41
- />
42
- </div>
43
- </div>
44
- <div class="row mt-10">
45
- <div class="col span-6">
46
- <LabelValue
47
- :name="t('tableHeaders.type')"
48
- :value="value.type"
49
- />
50
- </div>
51
- <div class="col span-6">
52
- <LabelValue
53
- :name="t('harvester.fields.macAddress')"
54
- :value="value.mac"
55
- />
56
- </div>
57
- </div>
58
- <div class="row mt-10">
59
- <div class="col span-6">
60
- <InputOrDisplay
61
- :name="t('harvester.fields.ipv4Address')"
62
- :value="value.ipv4Address"
63
- :mode="mode"
64
- >
65
- <template #value>
66
- <ul>
67
- <li v-for="a in value.ipv4Address" :key="a">
68
- {{ a }}
69
- </li>
70
- </ul>
71
- </template>
72
- </InputOrDisplay>
73
- </div>
74
- <div
75
- v-if="value.promiscuous === 'true'"
76
- class="col span-6"
77
- >
78
- <LabelValue
79
- :name="t('harvester.fields.promiscuous')"
80
- :value="value.promiscuous"
81
- >
82
- <template #value>
83
- {{ value.promiscuous === 'true' ? t('generic.yes') : t('generic.no') }}
84
- </template>
85
- </LabelValue>
86
- </div>
87
- </div>
88
- </div>
89
- </template>
@@ -1,134 +0,0 @@
1
- <script>
2
- import { STATE, AGE, NAME } from '@shell/config/table-headers';
3
- import SortableTable from '@shell/components/SortableTable';
4
- import Loading from '@shell/components/Loading';
5
- import HarvesterVmState from '@shell/components/formatter/HarvesterVmState';
6
- import { allHash } from '@shell/utils/promise';
7
- import { HCI } from '@shell/config/types';
8
- import { HOSTNAME } from '@shell/config/labels-annotations';
9
-
10
- export default {
11
- name: 'InstanceNode',
12
-
13
- components: {
14
- SortableTable,
15
- Loading,
16
- HarvesterVmState,
17
- },
18
-
19
- props: {
20
- node: {
21
- type: Object,
22
- required: true,
23
- },
24
- },
25
-
26
- async fetch() {
27
- const hash = await allHash({
28
- vms: this.$store.dispatch('harvester/findAll', { type: HCI.VM }),
29
- vmis: this.$store.dispatch('harvester/findAll', { type: HCI.VMI }),
30
- allNodeNetwork: this.$store.dispatch('harvester/findAll', { type: HCI.NODE_NETWORK }),
31
- allClusterNetwork: this.$store.dispatch('harvester/findAll', { type: HCI.CLUSTER_NETWORK }),
32
- });
33
- const instanceMap = {};
34
-
35
- (hash.vmis || []).forEach((vmi) => {
36
- const vmiUID = vmi?.metadata?.ownerReferences?.[0]?.uid;
37
-
38
- if (vmiUID) {
39
- instanceMap[vmiUID] = vmi;
40
- }
41
- });
42
-
43
- this.allNodeNetwork = hash.allNodeNetwork;
44
- this.allClusterNetwork = hash.allClusterNetwork;
45
- this.rows = hash.vms.filter((row) => {
46
- return instanceMap[row.metadata?.uid]?.status?.nodeName === this.node?.metadata?.labels?.[HOSTNAME];
47
- });
48
- },
49
-
50
- data() {
51
- return {
52
- rows: [],
53
- allNodeNetwork: [],
54
- allClusterNetwork: []
55
- };
56
- },
57
-
58
- computed: {
59
- headers() {
60
- return [
61
- STATE,
62
- NAME,
63
- {
64
- name: 'vmCPU',
65
- labelKey: 'tableHeaders.cpu',
66
- sort: 'vmCPU',
67
- search: false,
68
- value: 'spec.template.spec.domain.cpu.cores',
69
- width: 120
70
- },
71
- {
72
- name: 'vmRAM',
73
- labelKey: 'glance.memory',
74
- sort: 'vmRAM',
75
- search: false,
76
- value: 'spec.template.spec.domain.resources.limits.memory',
77
- width: 120
78
- },
79
- {
80
- name: 'ip',
81
- label: 'IP Address',
82
- labelKey: 'harvester.tableHeaders.vm.ipAddress',
83
- value: 'id',
84
- formatter: 'HarvesterIpAddress'
85
- },
86
- {
87
- ...AGE,
88
- sort: 'metadata.creationTimestamp:desc',
89
- }
90
- ];
91
- },
92
- },
93
-
94
- methods: {}
95
- };
96
- </script>
97
-
98
- <template>
99
- <Loading v-if="$fetchState.pending" />
100
- <div v-else id="host-instances" class="row">
101
- <div class="col span-12">
102
- <SortableTable
103
- v-bind="$attrs"
104
- :headers="headers"
105
- default-sort-by="age"
106
- :rows="rows"
107
- key-field="_key"
108
- v-on="$listeners"
109
- >
110
- <template slot="cell:state" slot-scope="scope" class="state-col">
111
- <div class="state">
112
- <HarvesterVmState class="vmstate" :row="scope.row" :all-node-network="allNodeNetwork" :all-cluster-network="allClusterNetwork" />
113
- </div>
114
- </template>
115
- </Sortabletable>
116
- </div>
117
- </div>
118
- </template>
119
-
120
- <style lang="scss" scoped>
121
- #host-instances {
122
- ::v-deep thead th {
123
- vertical-align: middle;
124
- }
125
-
126
- ::v-deep .state {
127
- display: flex;
128
-
129
- .vmstate {
130
- margin-right: 6px;
131
- }
132
- }
133
- }
134
- </style>
@@ -1,243 +0,0 @@
1
- <script>
2
- import Tabbed from '@shell/components/Tabbed';
3
- import Tab from '@shell/components/Tabbed/Tab';
4
- import metricPoller from '@shell/mixins/metric-poller';
5
- import {
6
- METRIC, NODE, HCI, LONGHORN, POD
7
- } from '@shell/config/types';
8
- import { allHash } from '@shell/utils/promise';
9
- import { formatSi } from '@shell/utils/units';
10
- import ArrayListGrouped from '@shell/components/form/ArrayListGrouped';
11
- import { findBy } from '@shell/utils/array';
12
- import { clone } from '@shell/utils/object';
13
- import Basic from './HarvesterHostBasic';
14
- import Instance from './VirtualMachineInstance';
15
- import Disk from './HarvesterHostDisk';
16
- import Network from './HarvesterHostNetwork';
17
-
18
- export default {
19
- name: 'DetailHost',
20
-
21
- components: {
22
- Tabbed,
23
- Tab,
24
- Basic,
25
- Instance,
26
- ArrayListGrouped,
27
- Disk,
28
- Network,
29
- },
30
- mixins: [metricPoller],
31
-
32
- props: {
33
- value: {
34
- type: Object,
35
- required: true,
36
- },
37
- },
38
-
39
- async fetch() {
40
- const inStore = this.$store.getters['currentProduct'].inStore;
41
-
42
- const hash = {
43
- nodes: this.$store.dispatch('harvester/findAll', { type: NODE }),
44
- pods: this.$store.dispatch(`${ inStore }/findAll`, { type: POD }),
45
- };
46
-
47
- if (this.$store.getters['harvester/schemaFor'](HCI.NODE_NETWORK)) {
48
- hash.hostNetworks = this.$store.dispatch('harvester/findAll', { type: HCI.NODE_NETWORK });
49
- }
50
-
51
- if (this.$store.getters['harvester/schemaFor'](HCI.BLOCK_DEVICE)) {
52
- hash.blockDevices = this.$store.dispatch('harvester/findAll', { type: HCI.BLOCK_DEVICE });
53
- }
54
-
55
- if (this.$store.getters['harvester/schemaFor'](LONGHORN.NODES)) {
56
- hash.longhornNodes = this.$store.dispatch('harvester/findAll', { type: LONGHORN.NODES });
57
- }
58
-
59
- const res = await allHash(hash);
60
- const hostNetworkResource = (res.hostNetworks || []).find( O => this.value.id === O.attachNodeName);
61
-
62
- this.loadMetrics();
63
-
64
- if (hostNetworkResource) {
65
- this.hostNetworkResource = hostNetworkResource;
66
- }
67
-
68
- const blockDevices = this.$store.getters[`${ inStore }/all`](HCI.BLOCK_DEVICE);
69
- const provisionedBlockDevices = blockDevices.filter((d) => {
70
- const provisioned = d?.spec?.fileSystem?.provisioned;
71
- const isCurrentNode = d?.spec?.nodeName === this.value.id;
72
- const isLonghornMounted = findBy(this.longhornDisks, 'name', d.metadata.name);
73
-
74
- return provisioned && isCurrentNode && !isLonghornMounted;
75
- })
76
- .map((d) => {
77
- return {
78
- isNew: true,
79
- name: d?.metadata?.name,
80
- originPath: d?.spec?.fileSystem?.mountPoint,
81
- path: d?.spec?.fileSystem?.mountPoint,
82
- blockDevice: d,
83
- displayName: d?.displayName,
84
- forceFormatted: d?.spec?.fileSystem?.forceFormatted || false,
85
- };
86
- });
87
-
88
- const disks = [...this.longhornDisks, ...provisionedBlockDevices];
89
-
90
- this.disks = disks;
91
- this.newDisks = clone(disks);
92
- },
93
-
94
- data() {
95
- return {
96
- metrics: null,
97
- mode: 'view',
98
- hostNetworkResource: null,
99
- newDisks: [],
100
- disks: [],
101
- };
102
- },
103
-
104
- computed: {
105
- longhornDisks() {
106
- const inStore = this.$store.getters['currentProduct'].inStore;
107
- const longhornNode = this.$store.getters[`${ inStore }/byId`](LONGHORN.NODES, `longhorn-system/${ this.value.id }`);
108
- const diskStatus = longhornNode?.status?.diskStatus || {};
109
- const diskSpec = longhornNode?.spec?.disks || {};
110
-
111
- const formatOptions = {
112
- increment: 1024,
113
- minExponent: 3,
114
- maxExponent: 3,
115
- maxPrecision: 2,
116
- suffix: 'iB',
117
- };
118
-
119
- const longhornDisks = Object.keys(diskStatus).map((key) => {
120
- const blockDevice = this.$store.getters[`${ inStore }/byId`](HCI.BLOCK_DEVICE, `longhorn-system/${ key }`);
121
-
122
- return {
123
- ...diskStatus[key],
124
- ...diskSpec?.[key],
125
- name: key,
126
- isNew: false,
127
- storageReserved: formatSi(diskSpec[key]?.storageReserved, formatOptions),
128
- storageAvailable: formatSi(diskStatus[key]?.storageAvailable, formatOptions),
129
- storageMaximum: formatSi(diskStatus[key]?.storageMaximum, formatOptions),
130
- storageScheduled: formatSi(diskStatus[key]?.storageScheduled, formatOptions),
131
- blockDevice,
132
- displayName: blockDevice?.displayName || key,
133
- forceFormatted: blockDevice?.spec?.fileSystem?.forceFormatted || false,
134
- };
135
- });
136
-
137
- return longhornDisks;
138
- },
139
-
140
- network() {
141
- const inStore = this.$store.getters['currentProduct'].inStore;
142
- const networks = this.$store.getters[`${ inStore }/all`](HCI.NODE_NETWORK);
143
-
144
- return findBy(networks, 'spec.nodeName', this.value.id) || {};
145
- },
146
-
147
- networkLinks() {
148
- const networkLinkStatus = this.network?.status?.networkLinkStatus || {};
149
-
150
- const out = Object.keys(networkLinkStatus).map((key) => {
151
- const obj = networkLinkStatus[key] || {};
152
-
153
- return {
154
- ...obj,
155
- name: key,
156
- promiscuous: obj.promiscuous ? 'true' : 'false',
157
- };
158
- });
159
-
160
- return out;
161
- },
162
-
163
- hasBlockDevicesSchema() {
164
- return !!this.$store.getters['harvester/schemaFor'](HCI.BLOCK_DEVICE);
165
- },
166
-
167
- hasHostNetworksSchema() {
168
- return !!this.$store.getters['harvester/schemaFor'](HCI.NODE_NETWORK);
169
- }
170
- },
171
-
172
- methods: {
173
- async loadMetrics() {
174
- const schema = this.$store.getters['harvester/schemaFor'](METRIC.NODE);
175
-
176
- if (schema) {
177
- this.metrics = await this.$store.dispatch('harvester/find', {
178
- type: METRIC.NODE,
179
- id: this.value.id,
180
- opt: { force: true, watch: false }
181
- });
182
-
183
- this.$forceUpdate();
184
- }
185
- },
186
-
187
- }
188
- };
189
- </script>
190
-
191
- <template>
192
- <div>
193
- <Tabbed v-bind="$attrs" class="mt-15" :side-tabs="true">
194
- <Tab name="basics" :label="t('harvester.host.tabs.basics')" :weight="4" class="bordered-table">
195
- <Basic v-model="value" :metrics="metrics" :mode="mode" :host-network-resource="hostNetworkResource" />
196
- </Tab>
197
- <Tab name="instance" :label="t('harvester.host.tabs.instance')" :weight="3" class="bordered-table">
198
- <Instance :node="value" />
199
- </Tab>
200
- <Tab
201
- v-if="hasHostNetworksSchema"
202
- name="network"
203
- :label="t('harvester.host.tabs.network')"
204
- :weight="2"
205
- class="bordered-table"
206
- >
207
- <ArrayListGrouped
208
- v-model="networkLinks"
209
- :mode="mode"
210
- :can-remove="false"
211
- >
212
- <template #default="props">
213
- <Network
214
- :value="props.row.value"
215
- :mode="mode"
216
- />
217
- </template>
218
- </ArrayListGrouped>
219
- </Tab>
220
- <Tab
221
- v-if="hasBlockDevicesSchema"
222
- name="disk"
223
- :weight="1"
224
- :label="t('harvester.host.tabs.disk')"
225
- >
226
- <ArrayListGrouped
227
- v-model="newDisks"
228
- :mode="mode"
229
- :can-remove="false"
230
- >
231
- <template #default="props">
232
- <Disk
233
- v-model="props.row.value"
234
- class="mb-20"
235
- :mode="mode"
236
- :disks="disks"
237
- />
238
- </template>
239
- </ArrayListGrouped>
240
- </Tab>
241
- </Tabbed>
242
- </div>
243
- </template>