mirror of
https://github.com/certd/certd.git
synced 2026-04-24 12:27:25 +08:00
perf: 新网互联支持查询域名列表
This commit is contained in:
@@ -1,8 +1,8 @@
|
|||||||
import { IsAccess, AccessInput, BaseAccess } from '@certd/pipeline';
|
import { AccessInput, BaseAccess, IsAccess, PageSearch } from '@certd/pipeline';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 这个注解将注册一个授权配置
|
管理页面地址:https://www.dns.com.cn/login/toLogin.do
|
||||||
* 在certd的后台管理系统中,用户可以选择添加此类型的授权
|
是否有API接口,接口地址:https://api.bizcn.com/rrpservices
|
||||||
*/
|
*/
|
||||||
@IsAccess({
|
@IsAccess({
|
||||||
name: 'xinnetconnect',
|
name: 'xinnetconnect',
|
||||||
@@ -38,6 +38,23 @@ export class XinnetConnectAccess extends BaseAccess {
|
|||||||
password = '';
|
password = '';
|
||||||
|
|
||||||
|
|
||||||
|
async getDomainList(req: PageSearch): Promise<any> {
|
||||||
|
let bodyXml =`
|
||||||
|
<limit>${req.pageSize}</limit>
|
||||||
|
<offset>${req.pageNo}</offset>
|
||||||
|
`
|
||||||
|
if(req.searchKey){
|
||||||
|
bodyXml += `<domainname>${req.searchKey}</domainname>`
|
||||||
|
}
|
||||||
|
|
||||||
|
const res = await this.doRequest({
|
||||||
|
url: "/domainService",
|
||||||
|
bodyXml: bodyXml,
|
||||||
|
service: "getDomainList",
|
||||||
|
})
|
||||||
|
return res
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
async addDnsRecord(req: {domain:string,hostRecord:string, value:string, type:string}): Promise<any> {
|
async addDnsRecord(req: {domain:string,hostRecord:string, value:string, type:string}): Promise<any> {
|
||||||
const { domain,hostRecord, value, type } = req;
|
const { domain,hostRecord, value, type } = req;
|
||||||
@@ -125,15 +142,19 @@ export class XinnetConnectAccess extends BaseAccess {
|
|||||||
|
|
||||||
// 提取返回结果
|
// 提取返回结果
|
||||||
const soapBody = result['soap:Envelope']['soap:Body'];
|
const soapBody = result['soap:Envelope']['soap:Body'];
|
||||||
const addDnsRecordResponse = soapBody["ns1:addDnsRecordResponse"];
|
const keys = Object.keys(soapBody);
|
||||||
console.log(addDnsRecordResponse)
|
if (keys.length === 0) {
|
||||||
|
throw new Error('SOAP响应体为空');
|
||||||
|
}
|
||||||
|
const addDnsRecordResponse = soapBody[keys[0]];
|
||||||
|
this.ctx.logger.info(addDnsRecordResponse)
|
||||||
const resultData = addDnsRecordResponse.response.result;
|
const resultData = addDnsRecordResponse.response.result;
|
||||||
|
|
||||||
const res = {
|
const res = {
|
||||||
code: resultData.$.code,
|
code: resultData.$.code,
|
||||||
msg: resultData.msg
|
msg: resultData.msg
|
||||||
}
|
}
|
||||||
console.log('操作结果:', res);
|
this.ctx.logger.info('操作结果:', res);
|
||||||
|
|
||||||
if (res.code != "200") {
|
if (res.code != "200") {
|
||||||
throw new Error(res.msg + " code:" + res.code);
|
throw new Error(res.msg + " code:" + res.code);
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
import { AbstractDnsProvider, CreateRecordOptions, IsDnsProvider, RemoveRecordOptions } from "@certd/plugin-cert";
|
import { PageRes, PageSearch } from "@certd/pipeline";
|
||||||
|
import { AbstractDnsProvider, CreateRecordOptions, DomainRecord, IsDnsProvider, RemoveRecordOptions } from "@certd/plugin-cert";
|
||||||
import { XinnetConnectAccess } from "./access.js";
|
import { XinnetConnectAccess } from "./access.js";
|
||||||
|
|
||||||
|
|
||||||
@@ -62,6 +63,21 @@ export class XinnetConnectDnsProvider extends AbstractDnsProvider<XinnetConnectR
|
|||||||
await this.access.delDnsRecord(record)
|
await this.access.delDnsRecord(record)
|
||||||
this.logger.info(`删除域名解析成功:fullRecord=${fullRecord}`);
|
this.logger.info(`删除域名解析成功:fullRecord=${fullRecord}`);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async getDomainListPage(req: PageSearch): Promise<PageRes<DomainRecord>> {
|
||||||
|
const res = await this.access.getDomainList(req)
|
||||||
|
let list = res.domainlist || []
|
||||||
|
list = list.map(item => ({
|
||||||
|
domain: item.domain,
|
||||||
|
id: item.domain,
|
||||||
|
}))
|
||||||
|
return {
|
||||||
|
pageNo: req.pageNo,
|
||||||
|
pageSize: req.pageSize,
|
||||||
|
total: res.total || 0,
|
||||||
|
list,
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//实例化这个provider,将其自动注册到系统中
|
//实例化这个provider,将其自动注册到系统中
|
||||||
|
|||||||
Reference in New Issue
Block a user