Skip to content

Commit

Permalink
fix: WebDav 端口去掉必填校验 (#3617)
Browse files Browse the repository at this point in the history
  • Loading branch information
ssongliu authored Jan 15, 2024
1 parent 33910f7 commit be6b58b
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 10 deletions.
8 changes: 6 additions & 2 deletions backend/utils/cloud_storage/client/webdav.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,12 +15,16 @@ type webDAVClient struct {

func NewWebDAVClient(vars map[string]interface{}) (*webDAVClient, error) {
address := loadParamFromVars("address", true, vars)
port := loadParamFromVars("port", false, vars)
port := loadParamFromVars("port", true, vars)
password := loadParamFromVars("password", true, vars)
username := loadParamFromVars("username", true, vars)
bucket := loadParamFromVars("bucket", true, vars)

client := gowebdav.NewClient(fmt.Sprintf("%s:%s", address, port), username, password)
url := fmt.Sprintf("%s:%s", address, port)
if len(port) == 0 {
url = address
}
client := gowebdav.NewClient(url, username, password)
if err := client.Connect(); err != nil {
return nil, err
}
Expand Down
24 changes: 16 additions & 8 deletions frontend/src/views/setting/backup-account/webdav/index.vue
Original file line number Diff line number Diff line change
Expand Up @@ -24,12 +24,8 @@
</template>
</el-input>
</el-form-item>
<el-form-item :label="$t('commons.table.port')" prop="varsJson.port" :rules="[Rules.port]">
<el-input-number
:min="0"
:max="65535"
v-model.number="webdavData.rowData!.varsJson['port']"
/>
<el-form-item :label="$t('commons.table.port')" prop="varsJson.port" :rules="[portRule]">
<el-input-number v-model.number="webdavData.rowData!.varsJson['port']" />
</el-form-item>
<el-form-item
:label="$t('commons.login.username')"
Expand Down Expand Up @@ -71,15 +67,15 @@
</template>

<script lang="ts" setup>
import { ref } from 'vue';
import { reactive, ref } from 'vue';
import { Rules } from '@/global/form-rules';
import i18n from '@/lang';
import { ElForm } from 'element-plus';
import { Backup } from '@/api/interface/backup';
import DrawerHeader from '@/components/drawer-header/index.vue';
import { addBackup, editBackup } from '@/api/modules/setting';
import { MsgSuccess } from '@/utils/message';
import { spliceHttp, splitHttp } from '@/utils/util';
import { checkPort, spliceHttp, splitHttp } from '@/utils/util';
const loading = ref(false);
type FormInstance = InstanceType<typeof ElForm>;
Expand All @@ -97,6 +93,18 @@ const drawerVisible = ref(false);
const webdavData = ref<DialogProps>({
title: '',
});
const portRule = reactive({ validator: checkportRule, trigger: 'blur', type: 'number' });
function checkportRule(rule: any, value: any, callback: any) {
if (value !== undefined && value !== null) {
if (checkPort(value)) {
return callback(new Error(i18n.global.t('commons.rule.port')));
}
}
callback();
}
const acceptParams = (params: DialogProps): void => {
webdavData.value = params;
if (webdavData.value.title === 'edit') {
Expand Down

0 comments on commit be6b58b

Please sign in to comment.