refactor: 用户第三方平台信息添加校验功能 (#4301)
Co-authored-by: chenjianxing <jianxing.chen@fit2cloud.com>
This commit is contained in:
parent
b0d4e45c58
commit
9154a10a1c
|
@ -10,6 +10,7 @@ import io.metersphere.commons.utils.Pager;
|
|||
import io.metersphere.log.annotation.MsAuditLog;
|
||||
import io.metersphere.track.issue.domain.PlatformUser;
|
||||
import io.metersphere.track.issue.domain.zentao.ZentaoBuild;
|
||||
import io.metersphere.track.request.testcase.AuthUserIssueRequest;
|
||||
import io.metersphere.track.request.testcase.IssuesRequest;
|
||||
import io.metersphere.track.request.testcase.IssuesUpdateRequest;
|
||||
import io.metersphere.track.service.IssuesService;
|
||||
|
@ -59,6 +60,11 @@ public class IssuesController {
|
|||
issuesService.testAuth(orgId, platform);
|
||||
}
|
||||
|
||||
@PostMapping("/user/auth")
|
||||
public void userAuth(@RequestBody AuthUserIssueRequest authUserIssueRequest) {
|
||||
issuesService.userAuth(authUserIssueRequest);
|
||||
}
|
||||
|
||||
@GetMapping("/close/{id}")
|
||||
public void closeLocalIssue(@PathVariable String id) {
|
||||
issuesService.closeLocalIssue(id);
|
||||
|
|
|
@ -2,6 +2,7 @@ package io.metersphere.track.issue;
|
|||
|
||||
import io.metersphere.base.domain.IssuesDao;
|
||||
import io.metersphere.base.domain.Project;
|
||||
import io.metersphere.dto.UserDTO;
|
||||
import io.metersphere.track.dto.DemandDTO;
|
||||
import io.metersphere.track.issue.domain.PlatformUser;
|
||||
import io.metersphere.track.request.testcase.IssuesRequest;
|
||||
|
@ -46,6 +47,11 @@ public interface IssuesPlatform {
|
|||
*/
|
||||
void testAuth();
|
||||
|
||||
/**
|
||||
* 用户信息测试
|
||||
*/
|
||||
void userAuth(UserDTO.PlatformInfo userInfo);
|
||||
|
||||
/**
|
||||
* 获取缺陷平台项目下的相关人员
|
||||
* @return platform user list
|
||||
|
|
|
@ -268,7 +268,18 @@ public class JiraPlatform extends AbstractIssuePlatform {
|
|||
@Override
|
||||
public void testAuth() {
|
||||
setConfig();
|
||||
jiraClientV2.getIssueCreateMetadata();
|
||||
jiraClientV2.auth();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void userAuth(UserDTO.PlatformInfo userInfo) {
|
||||
String config = getPlatformConfig(IssuesManagePlatform.Jira.toString());
|
||||
JiraConfig jiraConfig = JSONObject.parseObject(config, JiraConfig.class);
|
||||
jiraConfig.setAccount(userInfo.getJiraAccount());
|
||||
jiraConfig.setPassword(userInfo.getJiraPassword());
|
||||
validateConfig(jiraConfig);
|
||||
jiraClientV2.setConfig(jiraConfig);
|
||||
jiraClientV2.auth();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -0,0 +1,29 @@
|
|||
package io.metersphere.track.issue;
|
||||
|
||||
import io.metersphere.base.domain.IssuesDao;
|
||||
import io.metersphere.base.domain.Project;
|
||||
import io.metersphere.dto.UserDTO;
|
||||
import io.metersphere.track.issue.domain.PlatformUser;
|
||||
import io.metersphere.track.request.testcase.IssuesRequest;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
public abstract class LocalAbstractPlatform extends AbstractIssuePlatform {
|
||||
|
||||
public LocalAbstractPlatform(IssuesRequest issuesRequest) { super(issuesRequest); }
|
||||
|
||||
@Override
|
||||
public void testAuth() {}
|
||||
|
||||
@Override
|
||||
public void userAuth(UserDTO.PlatformInfo userInfo) {}
|
||||
|
||||
@Override
|
||||
public List<PlatformUser> getPlatformUser() { return null; }
|
||||
|
||||
@Override
|
||||
public void syncIssues(Project project, List<IssuesDao> tapdIssues) {}
|
||||
|
||||
@Override
|
||||
String getProjectId(String projectId) { return null; }
|
||||
}
|
|
@ -2,13 +2,11 @@ package io.metersphere.track.issue;
|
|||
|
||||
import io.metersphere.base.domain.IssuesDao;
|
||||
import io.metersphere.base.domain.IssuesWithBLOBs;
|
||||
import io.metersphere.base.domain.Project;
|
||||
import io.metersphere.commons.constants.IssuesManagePlatform;
|
||||
import io.metersphere.commons.user.SessionUser;
|
||||
import io.metersphere.commons.utils.BeanUtils;
|
||||
import io.metersphere.commons.utils.SessionUtils;
|
||||
import io.metersphere.track.dto.DemandDTO;
|
||||
import io.metersphere.track.issue.domain.PlatformUser;
|
||||
import io.metersphere.track.request.testcase.IssuesRequest;
|
||||
import io.metersphere.track.request.testcase.IssuesUpdateRequest;
|
||||
import org.apache.commons.lang3.StringUtils;
|
||||
|
@ -16,7 +14,7 @@ import org.apache.commons.lang3.StringUtils;
|
|||
import java.util.List;
|
||||
import java.util.UUID;
|
||||
|
||||
public class LocalPlatform extends AbstractIssuePlatform {
|
||||
public class LocalPlatform extends LocalAbstractPlatform {
|
||||
|
||||
protected String key = IssuesManagePlatform.Local.toString();
|
||||
|
||||
|
@ -67,31 +65,4 @@ public class LocalPlatform extends AbstractIssuePlatform {
|
|||
public void deleteIssue(String id) {
|
||||
issuesMapper.deleteByPrimaryKey(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void testAuth() {
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<PlatformUser> getPlatformUser() {
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void syncIssues(Project project, List<IssuesDao> tapdIssues) {
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
String getProjectId(String projectId) {
|
||||
return null;
|
||||
}
|
||||
|
||||
public void closeIssue(String issueId) {
|
||||
IssuesWithBLOBs issues = new IssuesWithBLOBs();
|
||||
issues.setId(issueId);
|
||||
issues.setStatus("closed");
|
||||
issuesMapper.updateByPrimaryKeySelective(issues);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -159,6 +159,11 @@ public class TapdPlatform extends AbstractIssuePlatform {
|
|||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void userAuth(UserDTO.PlatformInfo userInfo) {
|
||||
testAuth();
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<PlatformUser> getPlatformUser() {
|
||||
List<PlatformUser> users = new ArrayList<>();
|
||||
|
|
|
@ -234,6 +234,16 @@ public class ZentaoPlatform extends AbstractIssuePlatform {
|
|||
zentaoClient.login();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void userAuth(UserDTO.PlatformInfo userInfo) {
|
||||
String config = getPlatformConfig(IssuesManagePlatform.Zentao.toString());
|
||||
ZentaoConfig zentaoConfig = JSONObject.parseObject(config, ZentaoConfig.class);
|
||||
zentaoConfig.setAccount(userInfo.getZentaoUserName());
|
||||
zentaoConfig.setPassword(userInfo.getZentaoPassword());
|
||||
zentaoClient.setConfig(zentaoConfig);
|
||||
zentaoClient.login();
|
||||
}
|
||||
|
||||
public ZentaoConfig setConfig() {
|
||||
ZentaoConfig config = getConfig();
|
||||
zentaoClient.setConfig(config);
|
||||
|
|
|
@ -49,9 +49,13 @@ public abstract class JiraAbstractClient extends BaseClient {
|
|||
return (JiraAddIssueResponse) getResultForObject(JiraAddIssueResponse.class, response);
|
||||
}
|
||||
|
||||
public String getIssueCreateMetadata() {
|
||||
ResponseEntity<String> response = restTemplate.exchange(getBaseUrl() + "/issue/createmeta", HttpMethod.GET, getAuthHttpEntity(), String.class);
|
||||
return (String) getResultForObject(String.class, response);
|
||||
public void auth() {
|
||||
try {
|
||||
restTemplate.exchange(getBaseUrl() + "/permissions", HttpMethod.GET, getAuthHttpEntity(), String.class);
|
||||
} catch (Exception e) {
|
||||
LogUtil.error(e.getMessage(), e);
|
||||
MSException.throwException(e.getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
protected HttpEntity<MultiValueMap> getAuthHttpEntity() {
|
||||
|
|
|
@ -56,8 +56,14 @@ public class ZentaoClient extends BaseClient {
|
|||
String sessionId = login();
|
||||
HttpEntity<MultiValueMap<String, Object>> requestEntity = new HttpEntity<>(paramMap, new HttpHeaders());
|
||||
RestTemplate restTemplate = new RestTemplate();
|
||||
ResponseEntity<String> response = restTemplate.exchange(getBaseUrl() + "/api-getModel-bug-create.json?zentaosid=" + sessionId,
|
||||
HttpMethod.POST, requestEntity, String.class);
|
||||
ResponseEntity<String> response = null;
|
||||
try {
|
||||
response = restTemplate.exchange(getBaseUrl() + "/api-getModel-bug-create.json?zentaosid=" + sessionId,
|
||||
HttpMethod.POST, requestEntity, String.class);
|
||||
} catch (Exception e) {
|
||||
LogUtil.error(e.getMessage(), e);
|
||||
MSException.throwException(e.getMessage());
|
||||
}
|
||||
AddIssueResponse addIssueResponse = (AddIssueResponse) getResultForObject(AddIssueResponse.class, response);
|
||||
return JSONObject.parseObject(addIssueResponse.getData(), AddIssueResponse.Issue.class);
|
||||
}
|
||||
|
|
|
@ -0,0 +1,13 @@
|
|||
package io.metersphere.track.request.testcase;
|
||||
|
||||
|
||||
import io.metersphere.dto.UserDTO;
|
||||
import lombok.Getter;
|
||||
import lombok.Setter;
|
||||
|
||||
@Getter
|
||||
@Setter
|
||||
public class AuthUserIssueRequest extends UserDTO.PlatformInfo {
|
||||
private String orgId;
|
||||
private String platform;
|
||||
}
|
|
@ -26,6 +26,7 @@ import io.metersphere.service.ProjectService;
|
|||
import io.metersphere.track.issue.*;
|
||||
import io.metersphere.track.issue.domain.PlatformUser;
|
||||
import io.metersphere.track.issue.domain.zentao.ZentaoBuild;
|
||||
import io.metersphere.track.request.testcase.AuthUserIssueRequest;
|
||||
import io.metersphere.track.request.testcase.IssuesRequest;
|
||||
import io.metersphere.track.request.testcase.IssuesUpdateRequest;
|
||||
import org.apache.commons.collections.CollectionUtils;
|
||||
|
@ -484,4 +485,11 @@ public class IssuesService {
|
|||
public List<IssuesDao> relateList(IssuesRequest request) {
|
||||
return extIssuesMapper.getRelateIssues(request);
|
||||
}
|
||||
|
||||
public void userAuth(AuthUserIssueRequest authUserIssueRequest) {
|
||||
IssuesRequest issuesRequest = new IssuesRequest();
|
||||
issuesRequest.setOrganizationId(authUserIssueRequest.getOrgId());
|
||||
AbstractIssuePlatform abstractPlatform = IssueFactory.createPlatform(authUserIssueRequest.getPlatform(), issuesRequest);
|
||||
abstractPlatform.userAuth(authUserIssueRequest);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -52,6 +52,12 @@
|
|||
{{ $t('organization.integration.link_the_project_now') }}
|
||||
</router-link>
|
||||
</div>
|
||||
<div>
|
||||
3. {{ $t('organization.integration.use_tip_three') }}
|
||||
<router-link :to="{name: 'PersonSetting', params: { open: true }}" style="margin-left: 5px">
|
||||
{{ $t('organization.integration.link_the_info_now') }}
|
||||
</router-link>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
|
|
@ -33,6 +33,12 @@
|
|||
{{ $t('organization.integration.link_the_project_now') }}
|
||||
</router-link>
|
||||
</div>
|
||||
<div>
|
||||
3. {{ $t('organization.integration.use_tip_three') }}
|
||||
<router-link :to="{name: 'PersonSetting', params: { open: true }}" style="margin-left: 5px">
|
||||
{{ $t('organization.integration.link_the_info_now') }}
|
||||
</router-link>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
|
|
@ -36,6 +36,12 @@
|
|||
{{ $t('organization.integration.link_the_project_now') }}
|
||||
</router-link>
|
||||
</div>
|
||||
<div>
|
||||
3. {{ $t('organization.integration.use_tip_three') }}
|
||||
<router-link :to="{name: 'PersonSetting', params: { open: true }}" style="margin-left: 5px">
|
||||
{{ $t('organization.integration.link_the_info_now') }}
|
||||
</router-link>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
|
|
@ -10,6 +10,11 @@
|
|||
<el-input v-model="data.jiraPassword" auto-complete="new-password"
|
||||
:placeholder="$t('organization.integration.input_api_password')" show-password/>
|
||||
</el-form-item>
|
||||
<el-form-item >
|
||||
<el-button type="primary" style="float: right" @click="$emit('auth', 'Jira')" size="mini">
|
||||
{{$t('commons.validate')}}
|
||||
</el-button>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</template>
|
||||
|
||||
|
|
|
@ -34,7 +34,7 @@
|
|||
</el-card>
|
||||
|
||||
<!--Modify personal details-->
|
||||
<el-dialog :close-on-click-modal="false" :title="$t('member.modify_personal_info')" :visible.sync="updateVisible" width="30%"
|
||||
<el-dialog :close-on-click-modal="false" :title="$t('member.modify_personal_info')" :visible.sync="updateVisible" width="40%"
|
||||
:destroy-on-close="true" @close="handleClose">
|
||||
<el-form :model="form" label-position="right" label-width="100px" size="small" :rules="rule"
|
||||
ref="updateUserForm">
|
||||
|
@ -51,9 +51,9 @@
|
|||
<el-input v-model="form.phone" autocomplete="off"/>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
<jira-user-info v-if="hasJira" :data="currentPlatformInfo"/>
|
||||
<tapd-user-info v-if="hasTapd" :data="currentPlatformInfo"/>
|
||||
<zentao-user-info v-if="hasZentao" :data="currentPlatformInfo"/>
|
||||
<jira-user-info @auth="handleAuth" v-if="hasJira" :data="currentPlatformInfo"/>
|
||||
<tapd-user-info @auth="handleAuth" v-if="hasTapd" :data="currentPlatformInfo"/>
|
||||
<zentao-user-info @auth="handleAuth" v-if="hasZentao" :data="currentPlatformInfo"/>
|
||||
<template v-slot:footer>
|
||||
<ms-dialog-footer
|
||||
@cancel="updateVisible = false"
|
||||
|
@ -86,7 +86,7 @@
|
|||
</template>
|
||||
|
||||
<script>
|
||||
import {TokenKey} from "../../../../common/js/constants";
|
||||
import {TokenKey, ZEN_TAO} from "../../../../common/js/constants";
|
||||
import MsDialogFooter from "../../common/components/MsDialogFooter";
|
||||
import {
|
||||
getCurrentOrganizationId,
|
||||
|
@ -276,8 +276,24 @@ export default {
|
|||
let dataList = [];
|
||||
dataList[0] = data;
|
||||
this.tableData = dataList;
|
||||
this.handleRouteOpen();
|
||||
})
|
||||
},
|
||||
handleRouteOpen() {
|
||||
let params = this.$route.params;
|
||||
if (params.open) {
|
||||
this.edit(this.tableData[0]);
|
||||
params.open = false;
|
||||
}
|
||||
},
|
||||
handleAuth(type) {
|
||||
let param = {...this.currentPlatformInfo};
|
||||
param.orgId = getCurrentOrganizationId();
|
||||
param.platform = type
|
||||
this.$parent.result = this.$post("issues/user/auth", param, () => {
|
||||
this.$success(this.$t('organization.integration.verified'));
|
||||
});
|
||||
},
|
||||
handleClose() {
|
||||
this.form = {};
|
||||
this.ruleForm = {};
|
||||
|
|
|
@ -10,6 +10,11 @@
|
|||
<el-form-item :label="'Tapd 昵称'" prop="account">
|
||||
<el-input v-model="data.tapdUserName" :placeholder="$t('organization.integration.input_api_account')"/>
|
||||
</el-form-item>
|
||||
<el-form-item >
|
||||
<el-button type="primary" style="float: right" @click="$emit('auth', 'Tapd')" size="mini">
|
||||
{{$t('commons.validate')}}
|
||||
</el-button>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</template>
|
||||
|
||||
|
|
|
@ -10,6 +10,11 @@
|
|||
<el-input v-model="data.zentaoPassword" auto-complete="new-password"
|
||||
:placeholder="$t('organization.integration.input_api_password')" show-password/>
|
||||
</el-form-item>
|
||||
<el-form-item >
|
||||
<el-button type="primary" style="float: right" @click="$emit('auth', 'Zentao')" size="mini">
|
||||
{{$t('commons.validate')}}
|
||||
</el-button>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</template>
|
||||
|
||||
|
|
|
@ -96,6 +96,7 @@ export default {
|
|||
},
|
||||
{
|
||||
path: 'personsetting',
|
||||
name: 'PersonSetting',
|
||||
component: () => import('@/business/components/settings/personal/PersonSetting'),
|
||||
meta: {person: true, title: 'commons.personal_setting'}
|
||||
},
|
||||
|
|
|
@ -399,7 +399,9 @@ export default {
|
|||
use_tip_jira: 'Jira software server authentication information is account password, Jira software cloud authentication information is account + token (account settings-security-create API token)',
|
||||
use_tip_zentao: 'The account password is a Zentao account with corresponding permissions, and the account needs to have super model calling interface permissions',
|
||||
use_tip_two: 'After saving the Basic Auth account information, you need to manually associate the ID/key and issue template in the MeterSphere project',
|
||||
use_tip_three: 'Add your personal platform account',
|
||||
link_the_project_now: 'Link the project now',
|
||||
link_the_info_now: 'Add now',
|
||||
cancel_edit: 'Cancel edit',
|
||||
cancel_integration: 'Cancel integration',
|
||||
cancel_confirm: 'Confirm cancellation of integration ',
|
||||
|
|
|
@ -397,7 +397,9 @@ export default {
|
|||
use_tip_jira: 'Jira software server 认证信息为 账号密码,Jira software cloud 认证信息为 账号+令牌(账户设置-安全-创建API令牌)',
|
||||
use_tip_zentao: '账号密码为具有相应权限的Zentao账号,账号需要具有 超级model调用接口权限',
|
||||
use_tip_two: '保存 Basic Auth 账号信息后,需要在 MeterSphere 项目中手动关联 ID/key 和缺陷模板',
|
||||
use_tip_three: '添加你的个人平台账号',
|
||||
link_the_project_now: '马上关联项目',
|
||||
link_the_info_now: '马上添加',
|
||||
cancel_edit: '取消编辑',
|
||||
cancel_integration: '取消集成',
|
||||
cancel_confirm: '确认取消集成 ',
|
||||
|
|
|
@ -397,7 +397,9 @@ export default {
|
|||
use_tip_jira: 'Jira software server 認證信息為 賬號密碼,Jira software cloud 認證信息為 賬號+令牌(賬戶設置-安全-創建API令牌)',
|
||||
use_tip_zentao: '賬號密碼為具有相應權限的Zentao賬號,賬號需要具有 超級model調用接口權限',
|
||||
use_tip_two: '保存 Basic Auth 賬號信息後,需要在 MeterSphere 項目中手動關聯 ID/key 和缺陷模板',
|
||||
use_tip_three: '添加你的個人平臺賬號',
|
||||
link_the_project_now: '馬上關聯項目',
|
||||
link_the_info_now: '馬上添加',
|
||||
cancel_edit: '取消編輯',
|
||||
cancel_integration: '取消集成',
|
||||
cancel_confirm: '確認取消集成 ',
|
||||
|
|
Loading…
Reference in New Issue