mirror of
https://github.com/certd/certd.git
synced 2026-04-28 07:57:25 +08:00
Compare commits
9 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 5a148aa3b9 | |||
| b4c362da37 | |||
| 575ae164c8 | |||
| a9606bfb4e | |||
| b5ec04723d | |||
| 51cc08411f | |||
| d75034deae | |||
| 4ce23debb6 | |||
| 063706a7bf |
@@ -3,6 +3,13 @@
|
|||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
||||||
|
|
||||||
|
## [1.37.10](https://github.com/certd/certd/compare/v1.37.9...v1.37.10) (2025-11-19)
|
||||||
|
|
||||||
|
### Performance Improvements
|
||||||
|
|
||||||
|
* 优化dokploy 部署插件,配置选择serverId ([c9709f2](https://github.com/certd/certd/commit/c9709f26981c1cc9f71c14babb204329fcae0db5))
|
||||||
|
* 站点证书监控备注输入框改成textarea ([70b603d](https://github.com/certd/certd/commit/70b603d601c34f39148c2ab70c655c51babf563d))
|
||||||
|
|
||||||
## [1.37.9](https://github.com/certd/certd/compare/v1.37.8...v1.37.9) (2025-11-19)
|
## [1.37.9](https://github.com/certd/certd/compare/v1.37.8...v1.37.9) (2025-11-19)
|
||||||
|
|
||||||
### Bug Fixes
|
### Bug Fixes
|
||||||
|
|||||||
@@ -19,9 +19,15 @@ header中传入x-certd-token即可调用开放接口
|
|||||||
4、然后将content和sign分别base64后用.号连接: x-certd-token = base64(content) +"."+base64(sign)
|
4、然后将content和sign分别base64后用.号连接: x-certd-token = base64(content) +"."+base64(sign)
|
||||||
|
|
||||||
|
|
||||||
## 补充说明
|
## 参数
|
||||||
1.证书申请接口支持证书id和域名两种方式获取证书。
|
支持证书id和域名两种方式获取证书。
|
||||||
2.autoApply=true将在没有证书时自动触发申请,申请过程中会提示`正在申请中`,可轮循获取状态,直到证书申请成功。
|
|
||||||
|
## 创建新的证书申请
|
||||||
|
参数autoApply=true,将在没有证书时自动触发申请证书,检查逻辑如下:
|
||||||
|
1. 如果证书仓库里面有,且没有过期,就直接返回证书
|
||||||
|
2. 如果没有或者已过期,就会去找流水线,有就触发流水线执行
|
||||||
|
3. 如果没有流水线,就创建一个流水线,触发运行(`注意:需要提前在域名管理中配置好域名校验方式,否则会申请失败`)
|
||||||
|
4. 再次采用相同参数请求接口,如果在申请过程中,就会提示`正在申请中`,可轮循获取状态,直到证书申请成功。
|
||||||
|
|
||||||
|
|
||||||
## SDK
|
## SDK
|
||||||
|
|||||||
@@ -62,7 +62,7 @@
|
|||||||
| 14.| **威联通-部署证书到威联通** | 部署证书到qnap |
|
| 14.| **威联通-部署证书到威联通** | 部署证书到qnap |
|
||||||
| 15.| **飞牛NAS-部署证书** | |
|
| 15.| **飞牛NAS-部署证书** | |
|
||||||
| 16.| **Proxmox-上传证书到Proxmox** | |
|
| 16.| **Proxmox-上传证书到Proxmox** | |
|
||||||
| 17.| **Dokploy-更新证书** | 自动更新Dokploy证书 |
|
| 17.| **Dokploy-部署server证书** | 自动更新Dokploy server证书 |
|
||||||
## 5. 阿里云
|
## 5. 阿里云
|
||||||
|
|
||||||
| 序号 | 名称 | 说明 |
|
| 序号 | 名称 | 说明 |
|
||||||
|
|||||||
@@ -70,5 +70,5 @@
|
|||||||
"bugs": {
|
"bugs": {
|
||||||
"url": "https://github.com/publishlab/node-acme-client/issues"
|
"url": "https://github.com/publishlab/node-acme-client/issues"
|
||||||
},
|
},
|
||||||
"gitHead": "8bfdef79c48c3151089107ead7134ce4515fd5bc"
|
"gitHead": "eb41a3655fe91af94f1c42a51aaa9122edfcf40e"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -31,9 +31,28 @@ export const directory = {
|
|||||||
sslcom:{
|
sslcom:{
|
||||||
staging: 'https://acme.ssl.com/sslcom-dv-rsa',
|
staging: 'https://acme.ssl.com/sslcom-dv-rsa',
|
||||||
production: 'https://acme.ssl.com/sslcom-dv-rsa',
|
production: 'https://acme.ssl.com/sslcom-dv-rsa',
|
||||||
|
ec: 'https://acme.ssl.com/sslcom-dv-ecc',
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export function getDirectoryUrl(opts) {
|
||||||
|
const {sslProvider, pkType} = opts
|
||||||
|
const list= directory[sslProvider]
|
||||||
|
if (!list) {
|
||||||
|
throw new Error(`sslProvider ${sslProvider} not found`)
|
||||||
|
}
|
||||||
|
let pkTypePrefix = pkType || 'rsa'
|
||||||
|
if (pkType) {
|
||||||
|
pkTypePrefix = pkType.toLowerCase().split("_")[0]
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pkTypePrefix && list[pkTypePrefix]) {
|
||||||
|
return list[pkTypePrefix]
|
||||||
|
}
|
||||||
|
|
||||||
|
return list.production
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Crypto
|
* Crypto
|
||||||
*/
|
*/
|
||||||
|
|||||||
+2
@@ -117,6 +117,8 @@ export const directory: {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export function getDirectoryUrl(opts:{sslProvider:string, pkType: string}): string;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Crypto
|
* Crypto
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -17,6 +17,7 @@
|
|||||||
"compile": "tsc --skipLibCheck --watch"
|
"compile": "tsc --skipLibCheck --watch"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
"async-lock": "^1.4.1",
|
||||||
"axios": "^1.7.2",
|
"axios": "^1.7.2",
|
||||||
"dayjs": "^1.11.7",
|
"dayjs": "^1.11.7",
|
||||||
"http-proxy-agent": "^7.0.2",
|
"http-proxy-agent": "^7.0.2",
|
||||||
@@ -46,5 +47,5 @@
|
|||||||
"tslib": "^2.8.1",
|
"tslib": "^2.8.1",
|
||||||
"typescript": "^5.4.2"
|
"typescript": "^5.4.2"
|
||||||
},
|
},
|
||||||
"gitHead": "8bfdef79c48c3151089107ead7134ce4515fd5bc"
|
"gitHead": "eb41a3655fe91af94f1c42a51aaa9122edfcf40e"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,46 +1,16 @@
|
|||||||
import { logger, utils } from './index.js';
|
// @ts-ignore
|
||||||
|
import AsyncLock from "async-lock";
|
||||||
|
|
||||||
export class Locker {
|
export class Locker {
|
||||||
locked: Record<string, any> = {};
|
private asyncLocker: AsyncLock;
|
||||||
|
|
||||||
async execute(lockStr: string, callback: any) {
|
constructor() {
|
||||||
await this.lock(lockStr);
|
this.asyncLocker = new AsyncLock();
|
||||||
const timeoutId = setTimeout(() => {
|
|
||||||
logger.warn('Lock timeout,自动解锁', lockStr);
|
|
||||||
this.unlock(lockStr);
|
|
||||||
}, 20000);
|
|
||||||
try {
|
|
||||||
return await callback();
|
|
||||||
} finally {
|
|
||||||
clearTimeout(timeoutId);
|
|
||||||
this.unlock(lockStr);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
async lock(str: string) {
|
async execute(lockStr: string, callback: any, options?: { timeout?: number }) {
|
||||||
const isLocked = this.isLocked(str);
|
const timeout = options?.timeout ?? 20000;
|
||||||
if (isLocked) {
|
return this.asyncLocker.acquire(lockStr, callback, { timeout });
|
||||||
let count = 0;
|
|
||||||
while (true) {
|
|
||||||
await utils.sleep(100);
|
|
||||||
if (!this.isLocked(str)) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
count++;
|
|
||||||
if (count > 20) {
|
|
||||||
throw new Error('Lock timeout');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
this.locked[str] = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
unlock(str: string) {
|
|
||||||
delete this.locked[str];
|
|
||||||
}
|
|
||||||
|
|
||||||
isLocked(str: string) {
|
|
||||||
return this.locked[str] ?? false;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,14 @@
|
|||||||
|
import { random } from "lodash-es";
|
||||||
|
import { locker } from "./dist/utils/util.lock.js";
|
||||||
|
|
||||||
|
async function testLocker() {
|
||||||
|
for (let i = 0; i < 10; i++) {
|
||||||
|
await locker.execute("test", async () => {
|
||||||
|
console.log("test", i);
|
||||||
|
await new Promise(resolve => setTimeout(resolve, Math.random() * 1000));
|
||||||
|
throw new Error("test error");
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
await testLocker();
|
||||||
@@ -45,5 +45,5 @@
|
|||||||
"tslib": "^2.8.1",
|
"tslib": "^2.8.1",
|
||||||
"typescript": "^5.4.2"
|
"typescript": "^5.4.2"
|
||||||
},
|
},
|
||||||
"gitHead": "8bfdef79c48c3151089107ead7134ce4515fd5bc"
|
"gitHead": "eb41a3655fe91af94f1c42a51aaa9122edfcf40e"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -24,5 +24,5 @@
|
|||||||
"prettier": "^2.8.8",
|
"prettier": "^2.8.8",
|
||||||
"tslib": "^2.8.1"
|
"tslib": "^2.8.1"
|
||||||
},
|
},
|
||||||
"gitHead": "8bfdef79c48c3151089107ead7134ce4515fd5bc"
|
"gitHead": "eb41a3655fe91af94f1c42a51aaa9122edfcf40e"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -31,5 +31,5 @@
|
|||||||
"tslib": "^2.8.1",
|
"tslib": "^2.8.1",
|
||||||
"typescript": "^5.4.2"
|
"typescript": "^5.4.2"
|
||||||
},
|
},
|
||||||
"gitHead": "8bfdef79c48c3151089107ead7134ce4515fd5bc"
|
"gitHead": "eb41a3655fe91af94f1c42a51aaa9122edfcf40e"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,8 +6,6 @@
|
|||||||
"module": "./dist/bundle.js",
|
"module": "./dist/bundle.js",
|
||||||
"types": "./dist/d/index.d.ts",
|
"types": "./dist/d/index.d.ts",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"test": "cross-env NODE_CONFIG_DIR=./test/config mocha --recursive --require babel-register",
|
|
||||||
"dev": "babel src --out-dir babel -w",
|
|
||||||
"build": "rollup -c ",
|
"build": "rollup -c ",
|
||||||
"dev-build": "npm run build",
|
"dev-build": "npm run build",
|
||||||
"pub": "npm publish"
|
"pub": "npm publish"
|
||||||
@@ -15,7 +13,6 @@
|
|||||||
"author": "",
|
"author": "",
|
||||||
"license": "Apache",
|
"license": "Apache",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"babel-register": "^6.26.0",
|
|
||||||
"buffer": "^5.0.8",
|
"buffer": "^5.0.8",
|
||||||
"create-hash": "^1.1.3",
|
"create-hash": "^1.1.3",
|
||||||
"create-hmac": "^1.1.6",
|
"create-hmac": "^1.1.6",
|
||||||
@@ -30,8 +27,6 @@
|
|||||||
"@rollup/plugin-typescript": "^11.0.0",
|
"@rollup/plugin-typescript": "^11.0.0",
|
||||||
"@typescript-eslint/eslint-plugin": "^8.26.1",
|
"@typescript-eslint/eslint-plugin": "^8.26.1",
|
||||||
"@typescript-eslint/parser": "^8.26.1",
|
"@typescript-eslint/parser": "^8.26.1",
|
||||||
"babel-cli": "^6.26.0",
|
|
||||||
"babel-preset-env": "^1.6.1",
|
|
||||||
"chai": "^4.1.2",
|
"chai": "^4.1.2",
|
||||||
"config": "^1.30.0",
|
"config": "^1.30.0",
|
||||||
"cross-env": "^5.1.4",
|
"cross-env": "^5.1.4",
|
||||||
@@ -61,5 +56,5 @@
|
|||||||
"fetch"
|
"fetch"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"gitHead": "8bfdef79c48c3151089107ead7134ce4515fd5bc"
|
"gitHead": "eb41a3655fe91af94f1c42a51aaa9122edfcf40e"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -32,5 +32,5 @@
|
|||||||
"tslib": "^2.8.1",
|
"tslib": "^2.8.1",
|
||||||
"typescript": "^5.4.2"
|
"typescript": "^5.4.2"
|
||||||
},
|
},
|
||||||
"gitHead": "8bfdef79c48c3151089107ead7134ce4515fd5bc"
|
"gitHead": "eb41a3655fe91af94f1c42a51aaa9122edfcf40e"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -64,5 +64,5 @@
|
|||||||
"typeorm": "^0.3.11",
|
"typeorm": "^0.3.11",
|
||||||
"typescript": "^5.4.2"
|
"typescript": "^5.4.2"
|
||||||
},
|
},
|
||||||
"gitHead": "8bfdef79c48c3151089107ead7134ce4515fd5bc"
|
"gitHead": "eb41a3655fe91af94f1c42a51aaa9122edfcf40e"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -46,5 +46,5 @@
|
|||||||
"typeorm": "^0.3.11",
|
"typeorm": "^0.3.11",
|
||||||
"typescript": "^5.4.2"
|
"typescript": "^5.4.2"
|
||||||
},
|
},
|
||||||
"gitHead": "8bfdef79c48c3151089107ead7134ce4515fd5bc"
|
"gitHead": "eb41a3655fe91af94f1c42a51aaa9122edfcf40e"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -43,5 +43,5 @@
|
|||||||
"tslib": "^2.8.1",
|
"tslib": "^2.8.1",
|
||||||
"typescript": "^5.4.2"
|
"typescript": "^5.4.2"
|
||||||
},
|
},
|
||||||
"gitHead": "8bfdef79c48c3151089107ead7134ce4515fd5bc"
|
"gitHead": "eb41a3655fe91af94f1c42a51aaa9122edfcf40e"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -128,7 +128,7 @@ export class AcmeService {
|
|||||||
await this.saveAccountConfig(email, conf);
|
await this.saveAccountConfig(email, conf);
|
||||||
this.logger.info(`创建新的Accountkey:${email}`);
|
this.logger.info(`创建新的Accountkey:${email}`);
|
||||||
}
|
}
|
||||||
const directoryUrl = acme.directory[this.sslProvider].production;
|
const directoryUrl = acme.getDirectoryUrl({ sslProvider: this.sslProvider, pkType: this.options.privateKeyType });
|
||||||
if (this.options.useMappingProxy) {
|
if (this.options.useMappingProxy) {
|
||||||
urlMapping.enabled = true;
|
urlMapping.enabled = true;
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -35,7 +35,7 @@
|
|||||||
"rimraf": "^5.0.5",
|
"rimraf": "^5.0.5",
|
||||||
"socks": "^2.8.3",
|
"socks": "^2.8.3",
|
||||||
"socks-proxy-agent": "^8.0.4",
|
"socks-proxy-agent": "^8.0.4",
|
||||||
"ssh2": "^1.15.0",
|
"ssh2": "1.17.0",
|
||||||
"strip-ansi": "^7.1.0",
|
"strip-ansi": "^7.1.0",
|
||||||
"tencentcloud-sdk-nodejs": "^4.0.1005"
|
"tencentcloud-sdk-nodejs": "^4.0.1005"
|
||||||
},
|
},
|
||||||
@@ -53,5 +53,5 @@
|
|||||||
"tslib": "^2.8.1",
|
"tslib": "^2.8.1",
|
||||||
"typescript": "^5.4.2"
|
"typescript": "^5.4.2"
|
||||||
},
|
},
|
||||||
"gitHead": "8bfdef79c48c3151089107ead7134ce4515fd5bc"
|
"gitHead": "eb41a3655fe91af94f1c42a51aaa9122edfcf40e"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -19,6 +19,8 @@ RUN apk add --no-cache openjdk8
|
|||||||
WORKDIR /app/
|
WORKDIR /app/
|
||||||
COPY --from=builder /workspace/certd-server/ /app/
|
COPY --from=builder /workspace/certd-server/ /app/
|
||||||
|
|
||||||
|
COPY ./patch/ssh2/*.js /app/node_modules/.pnpm/node_modules/ssh2/lib/protocol/
|
||||||
|
|
||||||
ENV LEGO_VERSION=4.22.2
|
ENV LEGO_VERSION=4.22.2
|
||||||
ENV LEGO_DOWNLOAD_DIR=/app/tools/lego
|
ENV LEGO_DOWNLOAD_DIR=/app/tools/lego
|
||||||
RUN mkdir -p $LEGO_DOWNLOAD_DIR
|
RUN mkdir -p $LEGO_DOWNLOAD_DIR
|
||||||
|
|||||||
@@ -1,7 +1,8 @@
|
|||||||
import { request } from "/src/api/service";
|
import { request } from "/src/api/service";
|
||||||
import { RequestHandleReq } from "/@/components/plugins/lib";
|
import { RequestHandleReq } from "/@/components/plugins/lib";
|
||||||
|
import { AddonTypeDefines } from "./types";
|
||||||
|
|
||||||
export function createAddonApi(opts: { from: any; addonType: string }) {
|
export function createAddonApi(opts: { from: any; addonType: string } = { from: "user", addonType: "" }) {
|
||||||
let apiPrefix = "/addon";
|
let apiPrefix = "/addon";
|
||||||
if (opts.from === "sys") {
|
if (opts.from === "sys") {
|
||||||
apiPrefix = "/sys/addon";
|
apiPrefix = "/sys/addon";
|
||||||
@@ -128,15 +129,6 @@ export function createAddonApi(opts: { from: any; addonType: string }) {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
export const AddonTypeDefines = {
|
|
||||||
captcha: {
|
|
||||||
name: "captcha",
|
|
||||||
title: "验证码",
|
|
||||||
showDefault: false,
|
|
||||||
showTest: false,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export function getAddonTypeDefine(addonType: string) {
|
export function getAddonTypeDefine(addonType: string) {
|
||||||
return AddonTypeDefines[addonType];
|
return AddonTypeDefines[addonType];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -20,7 +20,7 @@ import { addonProvide } from "/@/views/certd/addon/common";
|
|||||||
export default defineComponent({
|
export default defineComponent({
|
||||||
name: "AddonManager",
|
name: "AddonManager",
|
||||||
setup() {
|
setup() {
|
||||||
const api = createAddonApi();
|
const api = createAddonApi({ from: "user", addonType: "" });
|
||||||
addonProvide(api);
|
addonProvide(api);
|
||||||
const { crudBinding, crudRef, crudExpose } = useFs({ createCrudOptions, context: { api } });
|
const { crudBinding, crudRef, crudExpose } = useFs({ createCrudOptions, context: { api } });
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,15 @@
|
|||||||
|
export interface AddonTypeDefine {
|
||||||
|
name: string;
|
||||||
|
title: string;
|
||||||
|
showDefault: boolean;
|
||||||
|
showTest: boolean;
|
||||||
|
}
|
||||||
|
|
||||||
|
export const AddonTypeDefines: Record<string, AddonTypeDefine> = {
|
||||||
|
captcha: {
|
||||||
|
name: "captcha",
|
||||||
|
title: "验证码",
|
||||||
|
showDefault: false,
|
||||||
|
showTest: false,
|
||||||
|
},
|
||||||
|
};
|
||||||
@@ -106,6 +106,7 @@
|
|||||||
"nanoid": "^5.0.7",
|
"nanoid": "^5.0.7",
|
||||||
"node-forge": "^1.3.1",
|
"node-forge": "^1.3.1",
|
||||||
"nodemailer": "^6.9.16",
|
"nodemailer": "^6.9.16",
|
||||||
|
"openid-client": "^6.8.1",
|
||||||
"otplib": "^12.0.1",
|
"otplib": "^12.0.1",
|
||||||
"pg": "^8.12.0",
|
"pg": "^8.12.0",
|
||||||
"psl": "^1.9.0",
|
"psl": "^1.9.0",
|
||||||
|
|||||||
@@ -0,0 +1,30 @@
|
|||||||
|
import { BaseController, Constants } from "@certd/lib-server";
|
||||||
|
import { ALL, Body, Controller, Get, Post, Provide, Query } from "@midwayjs/core";
|
||||||
|
|
||||||
|
/**
|
||||||
|
*/
|
||||||
|
@Provide()
|
||||||
|
@Controller('/api/connect')
|
||||||
|
export class LoginController extends BaseController {
|
||||||
|
|
||||||
|
|
||||||
|
@Get('/login', { summary: Constants.per.guest })
|
||||||
|
public async login(@Query(ALL) body: any) {
|
||||||
|
//构造登录url
|
||||||
|
return this.ok(1);
|
||||||
|
}
|
||||||
|
@Get('/callback', { summary: Constants.per.guest })
|
||||||
|
public async callback(@Query(ALL) body: any) {
|
||||||
|
//处理登录回调
|
||||||
|
return this.ok(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Post('/bind', { summary: Constants.per.guest })
|
||||||
|
public async bind(@Body(ALL) body: any) {
|
||||||
|
const autoRegister = body.autoRegister || false;
|
||||||
|
const bindInfo = body.bind || {};
|
||||||
|
//处理登录回调
|
||||||
|
return this.ok(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,24 @@
|
|||||||
|
export interface OauthProvider {
|
||||||
|
buildLoginUrl: (params: { redirectUri: string }) => string;
|
||||||
|
handleCallback: (params: { code: string; redirectUri: string }) => Promise<{
|
||||||
|
accessToken: string;
|
||||||
|
refreshToken: string;
|
||||||
|
expiresIn: number;
|
||||||
|
idToken: string;
|
||||||
|
scope: string;
|
||||||
|
tokenType: string;
|
||||||
|
}>;
|
||||||
|
bind: (params: {
|
||||||
|
accessToken: string;
|
||||||
|
refreshToken: string;
|
||||||
|
expiresIn: number;
|
||||||
|
idToken: string;
|
||||||
|
scope: string;
|
||||||
|
tokenType: string;
|
||||||
|
bindInfo: any;
|
||||||
|
}) => Promise<{
|
||||||
|
success: boolean;
|
||||||
|
message: string;
|
||||||
|
}>;
|
||||||
|
|
||||||
|
}
|
||||||
File diff suppressed because it is too large
Load Diff
Generated
+92
-1703
File diff suppressed because it is too large
Load Diff
@@ -1 +1 @@
|
|||||||
15:30
|
23:54
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
15:41
|
23:57
|
||||||
|
|||||||
Reference in New Issue
Block a user