diff --git a/docs/guide/qa/index.md b/docs/guide/qa/index.md
index 7c5050dc..b2b882d7 100644
--- a/docs/guide/qa/index.md
+++ b/docs/guide/qa/index.md
@@ -35,3 +35,7 @@ networks:
- subnet: 2001:db8::/64
```
+
+## 3. SSL_CERT_NOT_MATCH_DOMAIN_ERROR
+部署证书任务报类似 `SSL_CERT_NOT_MATCH_DOMAIN_ERROR`错误
+这是由于当前流水线的证书域名与要部署的目标站点的域名不匹配导致的,在申请证书任务中,增加目标站点域名,重新运行流水线即可
\ No newline at end of file
diff --git a/packages/ui/certd-client/index.html b/packages/ui/certd-client/index.html
index f6398595..1740a304 100644
--- a/packages/ui/certd-client/index.html
+++ b/packages/ui/certd-client/index.html
@@ -7,17 +7,6 @@
Loading
-
diff --git a/packages/ui/certd-client/public/iframe.js b/packages/ui/certd-client/public/iframe.js
deleted file mode 100644
index 22bfaf74..00000000
--- a/packages/ui/certd-client/public/iframe.js
+++ /dev/null
@@ -1,151 +0,0 @@
-function embedChatbot() {
- const chatBtnId = "fastgpt-chatbot-button";
- const chatWindowId = "fastgpt-chatbot-window";
- const script = document.getElementById("chatbot-iframe");
- const botSrc = script?.getAttribute("data-bot-src");
- const defaultOpen = script?.getAttribute("data-default-open") === "true";
- const canDrag = script?.getAttribute("data-drag") === "true";
- const MessageIcon =
- script?.getAttribute("data-open-icon") ||
- ``;
- const CloseIcon =
- script?.getAttribute("data-close-icon") ||
- "";
-
- if (!botSrc) {
- console.error(`Can't find appid`);
- return;
- }
- if (document.getElementById(chatBtnId)) {
- return;
- }
-
- const ChatBtn = document.createElement("div");
- ChatBtn.id = chatBtnId;
- ChatBtn.style.cssText = "position: fixed; bottom: 30px; right: 60px; width: 40px; height: 40px; cursor: pointer; z-index: 2147483647; transition: 0;";
-
- const ChatBtnDiv = document.createElement("img");
- ChatBtnDiv.src = defaultOpen ? CloseIcon : MessageIcon;
- ChatBtnDiv.setAttribute("width", "100%");
- ChatBtnDiv.setAttribute("height", "100%");
- ChatBtnDiv.draggable = false;
-
- const parent = document.createElement("div");
- const iframe = document.createElement("iframe");
- iframe.allow = "*";
- iframe.referrerPolicy = "no-referrer";
- iframe.title = "FastGPT Chat Window";
- parent.id = chatWindowId;
- iframe.src = botSrc;
- parent.style.cssText =
- "border: none; position: fixed; flex-direction: column; justify-content: space-between; box-shadow: rgba(150, 150, 150, 0.2) 0px 10px 30px 0px, rgba(150, 150, 150, 0.2) 0px 0px 0px 1px; width: 375px; height: 667px; max-width: 90vw; max-height: 85vh; border-radius: 0.75rem; display: flex; z-index: 2147483647; overflow: hidden; left: unset; background-color: #F3F4F6;";
- parent.style.visibility = defaultOpen ? "unset" : "hidden";
- iframe.style.cssText = "border: none;width:100%;height:100%";
-
- document.body.appendChild(parent);
- parent.appendChild(iframe);
-
- const tips = document.createElement("div");
- tips.innerText = "内容由AI生成,仅供参考";
- tips.style.cssText = "padding:5px;font-size:10px;display:flex; justify-content:center;border-top: 1px solid #ddd;";
- parent.appendChild(tips);
-
- const observer = new MutationObserver(mutations => {
- mutations.forEach(mutation => {
- if (mutation.type === "attributes" && mutation.attributeName === "data-bot-src") {
- const newBotSrc = script.getAttribute("data-bot-src");
- if (newBotSrc) {
- iframe.src = newBotSrc;
- }
- }
- });
- });
- observer.observe(script, {
- attributes: true,
- attributeFilter: ["data-bot-src"],
- });
-
- let chatBtnDragged = false;
- let chatBtnDown = false;
- let chatBtnMouseX;
- let chatBtnMouseY;
-
- const updateChatWindowPosition = () => {
- const chatWindow = document.getElementById(chatWindowId);
- const btn = ChatBtn.getBoundingClientRect();
- const [vw, vh, ww, wh] = [window.innerWidth, window.innerHeight, chatWindow.offsetWidth, chatWindow.offsetHeight];
-
- let right = 0;
- if (btn.left >= ww) {
- right = vw - btn.left + 10; // 左侧有空间则放在左侧,间距 10
- } else if (vw - btn.right >= ww) {
- right = vw - btn.right - ww - 10; // 右侧有空间则放在右侧
- }
-
- let bottom = Math.max(30, vh - btn.bottom); // 聊天窗口底部和按钮对齐,最少 30
- if (btn.top < wh) {
- bottom = Math.min(bottom, vh - wh - 30); // 确保聊天窗口不超出顶部
- }
-
- chatWindow.style.right = `${right}px`;
- chatWindow.style.bottom = `${bottom}px`;
- };
-
- ChatBtn.addEventListener("click", function () {
- if (chatBtnDragged) {
- chatBtnDragged = false;
- return;
- }
- const chatWindow = document.getElementById(chatWindowId);
-
- if (!chatWindow) return;
- const visibilityVal = chatWindow.style.visibility;
- if (visibilityVal === "hidden") {
- chatWindow.style.visibility = "unset";
- ChatBtnDiv.src = CloseIcon;
- } else {
- chatWindow.style.visibility = "hidden";
- ChatBtnDiv.src = MessageIcon;
- }
- });
-
- ChatBtn.addEventListener("mousedown", e => {
- e.stopPropagation();
- chatBtnMouseX = e.clientX;
- chatBtnMouseY = e.clientY;
- chatBtnDown = true;
-
- ChatBtn.initialRight = parseInt(ChatBtn.style.right) || 60;
- ChatBtn.initialBottom = parseInt(ChatBtn.style.bottom) || 30;
- });
-
- window.addEventListener("mousemove", e => {
- e.stopPropagation();
- if (!canDrag || !chatBtnDown) return;
-
- chatBtnDragged = true;
-
- const deltaX = e.clientX - chatBtnMouseX;
- const deltaY = e.clientY - chatBtnMouseY;
-
- let newRight = ChatBtn.initialRight - deltaX;
- let newBottom = ChatBtn.initialBottom - deltaY;
-
- newRight = Math.max(20, Math.min(window.innerWidth - 60, newRight));
- newBottom = Math.max(30, Math.min(window.innerHeight - 70, newBottom));
-
- ChatBtn.style.right = `${newRight}px`;
- ChatBtn.style.bottom = `${newBottom}px`;
-
- updateChatWindowPosition();
- });
-
- window.addEventListener("mouseup", e => {
- chatBtnDown = false;
- });
-
- ChatBtn.appendChild(ChatBtnDiv);
- document.body.appendChild(ChatBtn);
- updateChatWindowPosition();
-}
-window.addEventListener("load", embedChatbot);
diff --git a/packages/ui/certd-client/src/App.vue b/packages/ui/certd-client/src/App.vue
index d8f9367f..3be8db2d 100644
--- a/packages/ui/certd-client/src/App.vue
+++ b/packages/ui/certd-client/src/App.vue
@@ -74,8 +74,12 @@ const tokenTheme = computed(() => {
// settingStore.init();
const chatBox = ref();
-onMounted(async () => {
- // await util.sleep(5000);
- // await chatBox.value.openChat({ q: "hello" });
-});
+// onMounted(async () => {
+// await util.sleep(2000);
+// await chatBox.value.openChat({ q: "hello" });
+// });
+const openChat = (q: string) => {
+ chatBox.value.openChat({ q });
+};
+provide("fn:ai.open", openChat);
diff --git a/packages/ui/certd-client/src/components/ai/index.vue b/packages/ui/certd-client/src/components/ai/index.vue
index dc9020de..8bd9c85d 100644
--- a/packages/ui/certd-client/src/components/ai/index.vue
+++ b/packages/ui/certd-client/src/components/ai/index.vue
@@ -24,7 +24,7 @@
-
+
+ AI分析
+ 关闭
+ 确定
+
@@ -37,11 +42,15 @@ export default {
props: {},
emits: ["run"],
setup(props: any, ctx: any) {
+ const openAiChat: any = inject("fn:ai.open", (q: string) => {});
const taskModal = ref({
open: false,
onOk() {
taskViewClose();
},
+ onAiChat() {
+ onAiChat();
+ },
cancelText: "关闭",
});
const { isMobile } = usePreferences();
@@ -52,6 +61,22 @@ export default {
return "left";
});
+ function onAiChat() {
+ debugger;
+ const logs = currentHistory.value?.logs[activeKey.value];
+ let logText = "";
+ for (let log of logs) {
+ logText += log + "\n";
+ }
+ const maxLength = 5000;
+ if (logText.length > maxLength) {
+ logText = logText.substring(logText.length - maxLength);
+ }
+ if (openAiChat) {
+ openAiChat(logText);
+ }
+ }
+
const detail = ref({ nodes: [] });
const activeKey = ref();
const currentHistory: Ref | undefined = inject("currentHistory");
diff --git a/packages/ui/certd-client/src/views/sys/console/index.vue b/packages/ui/certd-client/src/views/sys/console/index.vue
index 4651b012..b3afb449 100644
--- a/packages/ui/certd-client/src/views/sys/console/index.vue
+++ b/packages/ui/certd-client/src/views/sys/console/index.vue
@@ -9,7 +9,10 @@
- 管理用户
+
+
+ 管理用户
+
@@ -21,7 +24,10 @@
- 管理流水线
+
+
+ 管理流水线
+
@@ -42,21 +48,23 @@