* feat: rewrite chat context (#3176) * feat: add app auto execute (#3115) * feat: add app auto execute * auto exec configtion * chatting animation * change icon * fix * fix * fix link * feat: add chat context to all chatbox * perf: loading ui --------- Co-authored-by: heheer <heheer@sealos.io> * app auto exec (#3179) * add chat records loaded state (#3184) * perf: chat store reset storage (#3186) * perf: chat store reset storage * perf: auto exec code * chore: workflow ui (#3175) * chore: workflow ui * fix * change icon color config * change popover to mymenu * 4.8.14 test (#3189) * update doc * fix: token check * perf: icon button * update doc * feat: share page support configuration Whether to allow the original view (#3194) * update doc * perf: fix index (#3206) * perf: i18n * perf: Add service entry (#3226) * 4.8.14 test (#3228) * fix: ai log * fix: text splitter * fix: reference unselect & user form description & simple to advance (#3229) * fix: reference unselect & user form description & simple to advance * change abort position * perf * perf: code (#3232) * perf: code * update doc * fix: create btn permission (#3233) * update doc * fix: refresh chatbox listener * perf: check invalid reference * perf: check invalid reference * update doc * fix: ui props --------- Co-authored-by: heheer <heheer@sealos.io>
77 lines
2.4 KiB
TypeScript
77 lines
2.4 KiB
TypeScript
import { POST } from '@fastgpt/service/common/api/plusRequest';
|
|
import type {
|
|
AuthOutLinkChatProps,
|
|
AuthOutLinkLimitProps,
|
|
AuthOutLinkInitProps,
|
|
AuthOutLinkResponse
|
|
} from '@fastgpt/global/support/outLink/api.d';
|
|
import { ShareChatAuthProps } from '@fastgpt/global/support/permission/chat';
|
|
import { authOutLinkValid } from '@fastgpt/service/support/permission/publish/authLink';
|
|
import { getUserChatInfoAndAuthTeamPoints } from '@/service/support/permission/auth/team';
|
|
import { AuthUserTypeEnum } from '@fastgpt/global/support/permission/constant';
|
|
import { OutLinkErrEnum } from '@fastgpt/global/common/error/code/outLink';
|
|
import { OutLinkSchema } from '@fastgpt/global/support/outLink/type';
|
|
|
|
export function authOutLinkInit(data: AuthOutLinkInitProps): Promise<AuthOutLinkResponse> {
|
|
if (!global.feConfigs?.isPlus) return Promise.resolve({ uid: data.outLinkUid });
|
|
return POST<AuthOutLinkResponse>('/support/outLink/authInit', data);
|
|
}
|
|
export function authOutLinkChatLimit(data: AuthOutLinkLimitProps): Promise<AuthOutLinkResponse> {
|
|
if (!global.feConfigs?.isPlus) return Promise.resolve({ uid: data.outLinkUid });
|
|
return POST<AuthOutLinkResponse>('/support/outLink/authChatStart', data);
|
|
}
|
|
|
|
export const authOutLink = async ({
|
|
shareId,
|
|
outLinkUid
|
|
}: ShareChatAuthProps): Promise<{
|
|
uid: string;
|
|
appId: string;
|
|
outLinkConfig: OutLinkSchema;
|
|
}> => {
|
|
if (!outLinkUid) {
|
|
return Promise.reject(OutLinkErrEnum.linkUnInvalid);
|
|
}
|
|
const result = await authOutLinkValid({ shareId });
|
|
|
|
const { uid } = await authOutLinkInit({
|
|
outLinkUid,
|
|
tokenUrl: result.outLinkConfig.limit?.hookUrl
|
|
});
|
|
|
|
return {
|
|
...result,
|
|
uid
|
|
};
|
|
};
|
|
|
|
export async function authOutLinkChatStart({
|
|
shareId,
|
|
ip,
|
|
outLinkUid,
|
|
question
|
|
}: AuthOutLinkChatProps & {
|
|
shareId: string;
|
|
}) {
|
|
// get outLink and app
|
|
const { outLinkConfig, appId } = await authOutLinkValid({ shareId });
|
|
|
|
// check ai points and chat limit
|
|
const [{ user }, { uid }] = await Promise.all([
|
|
getUserChatInfoAndAuthTeamPoints(outLinkConfig.tmbId),
|
|
authOutLinkChatLimit({ outLink: outLinkConfig, ip, outLinkUid, question })
|
|
]);
|
|
|
|
return {
|
|
sourceName: outLinkConfig.name,
|
|
teamId: outLinkConfig.teamId,
|
|
tmbId: outLinkConfig.tmbId,
|
|
authType: AuthUserTypeEnum.token,
|
|
responseDetail: outLinkConfig.responseDetail,
|
|
showNodeStatus: outLinkConfig.showNodeStatus,
|
|
user,
|
|
appId,
|
|
uid
|
|
};
|
|
}
|