BackupStorageCreate.vue 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. <template>
  2. <base-dialog @cancel="cancelDialog">
  3. <div slot="header">{{this.params.title}}</div>
  4. <div slot="body">
  5. <a-form :form="form.fc" v-bind="formItemLayout">
  6. <a-form-item :label="$t('storage.text_55', [$t('dictionary.domain')])">
  7. <domain-select v-if="isAdminMode && l3PermissionEnable" v-decorator="decorators.project_domain" />
  8. <template v-else> {{userInfo.domain.name}} </template>
  9. </a-form-item>
  10. <a-form-item :label="$t('common.name')">
  11. <a-input
  12. v-decorator="decorators.name"
  13. :placeholder="$t('common.tips.input', [$t('common.name')])" />
  14. </a-form-item>
  15. <a-form-item :label="$t('common.description')">
  16. <a-input
  17. v-decorator="decorators.description"
  18. :placeholder="$t('common.tips.optional_input', [$t('common.description')])" />
  19. </a-form-item>
  20. <a-form-item :label="$t('storage.text_38')">
  21. <a-radio-group v-decorator="decorators.storage_type" @change="onStorageTypeChange">
  22. <a-radio-button v-for="obj in STORAGE_TYPES" :key="obj.key" :value="obj.key">{{ obj.value }}</a-radio-button>
  23. </a-radio-group>
  24. </a-form-item>
  25. <a-form-item label="NFS Host" v-if="isNfs">
  26. <a-input :placeholder="$t('storage.host.input.place_holder')" v-decorator="decorators.nfs_host" />
  27. </a-form-item>
  28. <a-form-item label="NFS Shared Dir" v-if="isNfs">
  29. <a-input :placeholder="$t('storage.path.input.place_holder')" v-decorator="decorators.nfs_shared_dir" />
  30. </a-form-item>
  31. <a-form-item label="Bucket URL" v-if="isObjectStorage">
  32. <a-input :placeholder="$t('storage.url.input.place_holder')" v-decorator="decorators.object_bucket_url" />
  33. </a-form-item>
  34. <a-form-item label="Access Key" v-if="isObjectStorage">
  35. <a-input :placeholder="$t('storage.access_key.input.place_holder')" v-decorator="decorators.object_access_key" />
  36. </a-form-item>
  37. <a-form-item label="Secret" v-if="isObjectStorage">
  38. <a-input-password :placeholder="$t('storage.access_secret.input.place_holder')" v-decorator="decorators.object_secret" />
  39. </a-form-item>
  40. <a-form-item label="Signing Version" v-if="isObjectStorage">
  41. <a-radio-group v-decorator="decorators.object_sign_ver">
  42. <a-radio-button value="">{{ $t('common_712') }}</a-radio-button>
  43. <a-radio-button value="v2">V2</a-radio-button>
  44. <a-radio-button value="v4">V4</a-radio-button>
  45. </a-radio-group>
  46. </a-form-item>
  47. <a-form-item :label="$t('storage.capacity')" v-show="false">
  48. <a-input-number :min="0" v-decorator="decorators.capacity_mb" /> GB
  49. </a-form-item>
  50. <a-form-item label="Public Bucket URL" v-if="isObjectStorage">
  51. <a-input :placeholder="$t('storage.url.input.place_holder')" v-decorator="decorators.object_bucket_url_ext" />
  52. </a-form-item>
  53. </a-form>
  54. </div>
  55. <div slot="footer">
  56. <a-button type="primary" @click="handleConfirm" :loading="loading">{{ $t("dialog.ok") }}</a-button>
  57. <a-button @click="cancelDialog">{{ $t('dialog.cancel') }}</a-button>
  58. </div>
  59. </base-dialog>
  60. </template>
  61. <script>
  62. import { mapGetters } from 'vuex'
  63. import DialogMixin from '@/mixins/dialog'
  64. import WindowsMixin from '@/mixins/windows'
  65. import DomainSelect from '@/sections/DomainSelect'
  66. import { REGEXP } from '@/utils/validate'
  67. export default {
  68. name: 'BackupStorageCreateDialog',
  69. components: {
  70. DomainSelect,
  71. },
  72. mixins: [WindowsMixin, DialogMixin],
  73. data () {
  74. return {
  75. loading: false,
  76. STORAGE_TYPES: [
  77. {
  78. key: 'nfs',
  79. value: 'NFS',
  80. },
  81. {
  82. key: 'object',
  83. value: this.$t('storage.object_storage'),
  84. },
  85. ],
  86. form: {
  87. fc: this.$form.createForm(this),
  88. },
  89. formItemLayout: {
  90. wrapperCol: {
  91. span: 20,
  92. },
  93. labelCol: {
  94. span: 4,
  95. },
  96. },
  97. storage_type: 'nfs',
  98. }
  99. },
  100. computed: {
  101. ...mapGetters(['isAdminMode', 'userInfo', 'l3PermissionEnable']),
  102. decorators () {
  103. const hostCheckValid = (rule, value, _callback) => {
  104. let isValid = true
  105. if (!value || value === '') isValid = false
  106. const parts = value.split(',')
  107. if (parts.some(part => {
  108. const trimmedPart = part.trim()
  109. return !REGEXP.IPv4.regexp.test(trimmedPart) && !REGEXP.IPv6.regexp.test(trimmedPart)
  110. })) {
  111. isValid = false
  112. }
  113. return isValid ? _callback() : _callback(new Error(this.$t('storage.host.input.place_holder')))
  114. }
  115. return {
  116. project_domain: [
  117. 'project_domain',
  118. {
  119. initialValue: this.userInfo.projectDomainId,
  120. },
  121. ],
  122. name: [
  123. 'name',
  124. {
  125. validateFirst: true,
  126. rules: [
  127. { required: true, message: this.$t('storage.text_56') },
  128. { validator: this.$validate('blockStorageName') },
  129. ],
  130. },
  131. ],
  132. description: [
  133. 'description',
  134. ],
  135. storage_type: [
  136. 'storage_type',
  137. {
  138. initialValue: 'nfs',
  139. },
  140. ],
  141. nfs_host: [
  142. 'nfs_host',
  143. {
  144. validateFirst: true,
  145. rules: [
  146. { required: true, validator: hostCheckValid, trigger: 'blur' },
  147. ],
  148. },
  149. ],
  150. nfs_shared_dir: [
  151. 'nfs_shared_dir',
  152. {
  153. rules: [
  154. { required: true, message: this.$t('storage.nfs_shared_dir.validate.prompt'), trigger: 'blur' },
  155. ],
  156. },
  157. ],
  158. object_bucket_url: [
  159. 'object_bucket_url',
  160. {
  161. validateFirst: true,
  162. rules: [
  163. { required: true, message: this.$t('storage.object_bucket_url.validate.prompt'), trigger: 'blur' },
  164. ],
  165. },
  166. ],
  167. object_access_key: [
  168. 'object_access_key',
  169. {
  170. rules: [
  171. { required: true, message: this.$t('storage.object_access_key.validate.prompt'), trigger: 'blur' },
  172. ],
  173. },
  174. ],
  175. object_secret: [
  176. 'object_secret',
  177. {
  178. rules: [
  179. { required: true, message: this.$t('storage.object_secret.validate.prompt'), trigger: 'blur' },
  180. ],
  181. },
  182. ],
  183. object_sign_ver: [
  184. 'object_sign_ver',
  185. {
  186. initialValue: '',
  187. },
  188. ],
  189. capacity_mb: [
  190. 'capacity_mb',
  191. {
  192. initialValue: 0,
  193. },
  194. ],
  195. object_bucket_url_ext: [
  196. 'object_bucket_url_ext',
  197. {
  198. validateFirst: true,
  199. rules: [
  200. { required: false, message: this.$t('storage.object_bucket_url_ext.validate.prompt'), trigger: 'blur' },
  201. ],
  202. },
  203. ],
  204. }
  205. },
  206. isNfs () {
  207. return this.storage_type === 'nfs'
  208. },
  209. isObjectStorage () {
  210. return this.storage_type === 'object'
  211. },
  212. },
  213. methods: {
  214. async handleConfirm () {
  215. const manager = new this.$Manager('backupstorages')
  216. try {
  217. const values = await this.form.fc.validateFields(Object.keys(this.decorators))
  218. await manager.create({ data: { ...values, capacity_mb: values.capacity_mb * 1024 } })
  219. this.cancelDialog()
  220. this.params.refresh && this.params.refresh()
  221. } catch (error) {
  222. throw error
  223. }
  224. },
  225. onStorageTypeChange (e) {
  226. console.log(e, e.target.value)
  227. this.storage_type = e.target.value
  228. },
  229. },
  230. }
  231. </script>