@dj1029/plugin-smart-sl 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md ADDED
@@ -0,0 +1,11 @@
1
+ # smart-sl
2
+
3
+ This library was generated with [Nx](https://nx.dev).
4
+
5
+ ## Building
6
+
7
+ Run `nx build smart-sl` to build the library.
8
+
9
+ ## Running unit tests
10
+
11
+ Run `nx test smart-sl` to execute the unit tests via [Jest](https://jestjs.io).
@@ -0,0 +1,6 @@
1
+ import { z } from 'zod';
2
+ import { type XpertPlugin } from '@xpert-ai/plugin-sdk';
3
+ declare const ConfigSchema: z.ZodObject<{}, "strip", z.ZodTypeAny, {}, {}>;
4
+ declare const plugin: XpertPlugin<z.infer<typeof ConfigSchema>>;
5
+ export default plugin;
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAexD,QAAA,MAAM,YAAY,gDAAe,CAAC;AAElC,QAAA,MAAM,MAAM,EAAE,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,YAAY,CAAC,CAsCrD,CAAC;AAEF,eAAe,MAAM,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,50 @@
1
+ import { z } from 'zod';
2
+ import { readFileSync } from 'fs';
3
+ import { fileURLToPath } from 'url';
4
+ import { dirname, join } from 'path';
5
+ import { smartBIModule } from './lib/smartBI.module.js';
6
+ import { iconImage } from './lib/types.js';
7
+ const __filename = fileURLToPath(import.meta.url);
8
+ const __dirname = dirname(__filename);
9
+ const packageJson = JSON.parse(readFileSync(join(__dirname, '../package.json'), 'utf8'));
10
+ const ConfigSchema = z.object({});
11
+ const plugin = {
12
+ /** meta:定义插件的基本信息(名字、版本、分类、关键词) */
13
+ meta: {
14
+ name: packageJson.name,
15
+ version: packageJson.version,
16
+ category: 'integration',
17
+ icon: {
18
+ type: 'image',
19
+ value: iconImage
20
+ },
21
+ displayName: 'SmartBI Plugin',
22
+ description: 'Integrate SmartBI functionality',
23
+ keywords: ['SmartBI', 'feishu', 'document source', 'knowledge', 'integration'],
24
+ author: 'dengjin',
25
+ },
26
+ /** 描述插件的配置Schema */
27
+ config: {
28
+ schema: ConfigSchema,
29
+ },
30
+ register(ctx) {
31
+ ctx.logger.log('register SmartBI plugin');
32
+ return {
33
+ module: smartBIModule,
34
+ global: true,
35
+ };
36
+ },
37
+ /** 模块注册完成 */
38
+ async onInit(ctx) {
39
+ ctx.logger.log('lark SmartBI initialized');
40
+ },
41
+ /** 应用启动后(可对外服务) */
42
+ async onStart(ctx) {
43
+ ctx.logger.log('SmartBI plugin started');
44
+ },
45
+ /** 优雅停机后(释放资源) */
46
+ async onStop(ctx) {
47
+ ctx.logger.log('SmartBI plugin stopped');
48
+ },
49
+ };
50
+ export default plugin;
@@ -0,0 +1,7 @@
1
+ export declare class HttpClientService {
2
+ private axiosInstance;
3
+ constructor();
4
+ get(url: string, data?: any): any;
5
+ post(url: string, data?: any): any;
6
+ }
7
+ //# sourceMappingURL=http-client.service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"http-client.service.d.ts","sourceRoot":"","sources":["../../src/lib/http-client.service.ts"],"names":[],"mappings":"AAGA,qBACa,iBAAiB;IAC1B,OAAO,CAAC,aAAa,CAAC;;IAoBtB,GAAG,CAAC,GAAG,EAAE,MAAM,EAAC,IAAI,CAAC,EAAE,GAAG;IAI1B,IAAI,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG;CAI/B"}
@@ -0,0 +1,32 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { Injectable } from '@nestjs/common';
3
+ import axios from 'axios';
4
+ let HttpClientService = class HttpClientService {
5
+ constructor() {
6
+ this.axiosInstance = axios.create({
7
+ baseURL: 'https://www.antsfind.com:449', // 设置基础URL
8
+ timeout: 10000, // 设置超时时间
9
+ headers: { 'Content-Type': 'application/json' }, // 设置默认头信息
10
+ });
11
+ // 添加拦截器(例如,请求和响应拦截)
12
+ this.axiosInstance.interceptors.request.use(config => {
13
+ // 在发送请求之前做些什么,例如设置认证头信息等
14
+ // config.headers['Authorization'] = `Bearer ${process.env.API_TOKEN}`; // 示例:从环境变量获取token
15
+ return config;
16
+ }, error => {
17
+ // 对请求错误做些什么
18
+ return Promise.reject(error);
19
+ });
20
+ }
21
+ get(url, data) {
22
+ return this.axiosInstance.get(url, data);
23
+ }
24
+ post(url, data) {
25
+ return this.axiosInstance.post(url, data);
26
+ }
27
+ };
28
+ HttpClientService = __decorate([
29
+ Injectable(),
30
+ __metadata("design:paramtypes", [])
31
+ ], HttpClientService);
32
+ export { HttpClientService };
@@ -0,0 +1,17 @@
1
+ import { IIntegration, TIntegrationProvider } from '@metad/contracts';
2
+ import { IntegrationStrategy, TIntegrationStrategyParams } from '@xpert-ai/plugin-sdk';
3
+ import { TSmartBIIntegrationConfig } from './types.js';
4
+ import { HttpClientService } from './http-client.service.js';
5
+ export declare class SmartBIIntegrationStrategy implements IntegrationStrategy<TSmartBIIntegrationConfig> {
6
+ private httpClient;
7
+ constructor(httpClient: HttpClientService);
8
+ meta: TIntegrationProvider;
9
+ /**
10
+ * 预留的执行方法,当前未使用
11
+ * @param integration
12
+ * @param payload
13
+ */
14
+ execute(integration: IIntegration, payload: TIntegrationStrategyParams): Promise<any>;
15
+ validateConfig(config: TSmartBIIntegrationConfig): Promise<any>;
16
+ }
17
+ //# sourceMappingURL=integrationStrategy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"integrationStrategy.d.ts","sourceRoot":"","sources":["../../src/lib/integrationStrategy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAA0B,oBAAoB,EAAE,MAAM,kBAAkB,CAAA;AAE7F,OAAO,EAAE,mBAAmB,EAA0B,0BAA0B,EAAE,MAAM,sBAAsB,CAAA;AAC9G,OAAO,EAAyB,yBAAyB,EAAE,MAAM,YAAY,CAAA;AAC7E,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAG7D,qBAEa,0BAA2B,YAAW,mBAAmB,CAAC,yBAAyB,CAAC;IAEjF,OAAO,CAAC,UAAU;gBAAV,UAAU,EAAE,iBAAiB;IAEjD,IAAI,EAAE,oBAAoB,CA6BzB;IAED;;;;OAIG;IACH,OAAO,CAAC,WAAW,EAAE,YAAY,EAAE,OAAO,EAAE,0BAA0B,GAAG,OAAO,CAAC,GAAG,CAAC;IAI/E,cAAc,CAAC,MAAM,EAAC,yBAAyB;CAiBxD"}
@@ -0,0 +1,67 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { IntegrationFeatureEnum } from '@metad/contracts';
3
+ import { Injectable } from '@nestjs/common';
4
+ import { IntegrationStrategyKey } from '@xpert-ai/plugin-sdk';
5
+ import { SmartBIName, iconImage } from './types.js';
6
+ import { HttpClientService } from './http-client.service.js';
7
+ let SmartBIIntegrationStrategy = class SmartBIIntegrationStrategy {
8
+ constructor(httpClient) {
9
+ this.httpClient = httpClient;
10
+ this.meta = {
11
+ name: SmartBIName,
12
+ label: {
13
+ en_US: 'SmartBI',
14
+ zh_Hans: 'SmartBI'
15
+ },
16
+ description: {
17
+ en_US: 'SmartBI is a powerful BI tool',
18
+ zh_Hans: 'SmartBI 是一个强大的 BI 工具'
19
+ },
20
+ avatar: iconImage,
21
+ icon: {
22
+ type: 'image',
23
+ value: iconImage
24
+ },
25
+ schema: {
26
+ type: 'object',
27
+ properties: {
28
+ userName: {
29
+ type: 'string',
30
+ title: 'userName',
31
+ },
32
+ passWord: {
33
+ type: 'string',
34
+ title: 'passWord',
35
+ },
36
+ }
37
+ },
38
+ features: [IntegrationFeatureEnum.SSO, IntegrationFeatureEnum.KNOWLEDGE],
39
+ };
40
+ }
41
+ /**
42
+ * 预留的执行方法,当前未使用
43
+ * @param integration
44
+ * @param payload
45
+ */
46
+ execute(integration, payload) {
47
+ throw new Error('Method not implemented.');
48
+ }
49
+ async validateConfig(config) {
50
+ if (!config) {
51
+ throw new Error("凭证验证失败");
52
+ }
53
+ if (!config.userName) {
54
+ throw new Error('userName is required');
55
+ }
56
+ if (!config.passWord) {
57
+ throw new Error('passWord is required');
58
+ }
59
+ return this.httpClient.post('/login', { username: config.userName, password: config.passWord });
60
+ }
61
+ };
62
+ SmartBIIntegrationStrategy = __decorate([
63
+ Injectable(),
64
+ IntegrationStrategyKey(SmartBIName),
65
+ __metadata("design:paramtypes", [HttpClientService])
66
+ ], SmartBIIntegrationStrategy);
67
+ export { SmartBIIntegrationStrategy };
@@ -0,0 +1,8 @@
1
+ import { SmartBIIntegrationStrategy } from "./integrationStrategy.js";
2
+ import type { IIntegration } from "@metad/contracts";
3
+ export declare class SmartBIController {
4
+ private readonly integrationStrategy;
5
+ constructor(integrationStrategy: SmartBIIntegrationStrategy);
6
+ connect(integration: IIntegration): Promise<IIntegration<any>>;
7
+ }
8
+ //# sourceMappingURL=lark.controller.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lark.controller.d.ts","sourceRoot":"","sources":["../../src/lib/lark.controller.ts"],"names":[],"mappings":"AAEA,OAAO,EAAC,0BAA0B,EAAC,MAAM,0BAA0B,CAAC;AACpE,OAAO,KAAK,EAAC,YAAY,EAAC,MAAM,kBAAkB,CAAC;AAEnD,qBACa,iBAAiB;IACd,OAAO,CAAC,QAAQ,CAAC,mBAAmB;gBAAnB,mBAAmB,EAAE,0BAA0B;IAGtE,OAAO,CAAS,WAAW,EAAE,YAAY;CAWlD"}
@@ -0,0 +1,32 @@
1
+ import { __decorate, __metadata, __param } from "tslib";
2
+ import { Body, Controller, ForbiddenException, Post } from "@nestjs/common";
3
+ import { SmartBIName } from "./types.js";
4
+ import { SmartBIIntegrationStrategy } from "./integrationStrategy.js";
5
+ let SmartBIController = class SmartBIController {
6
+ constructor(integrationStrategy) {
7
+ this.integrationStrategy = integrationStrategy;
8
+ }
9
+ async connect(integration) {
10
+ try {
11
+ console.log("controller ---- test --- integration ---- ", integration);
12
+ const botInfo = await this.integrationStrategy.validateConfig(integration.options);
13
+ return integration;
14
+ }
15
+ catch (err) {
16
+ const errorMessage = "凭证验证失败";
17
+ throw new ForbiddenException(`${errorMessage}: ${err.message}`);
18
+ }
19
+ }
20
+ };
21
+ __decorate([
22
+ Post('test'),
23
+ __param(0, Body()),
24
+ __metadata("design:type", Function),
25
+ __metadata("design:paramtypes", [Object]),
26
+ __metadata("design:returntype", Promise)
27
+ ], SmartBIController.prototype, "connect", null);
28
+ SmartBIController = __decorate([
29
+ Controller(SmartBIName),
30
+ __metadata("design:paramtypes", [SmartBIIntegrationStrategy])
31
+ ], SmartBIController);
32
+ export { SmartBIController };
@@ -0,0 +1,19 @@
1
+ import { IOnPluginBootstrap, IOnPluginDestroy } from '@xpert-ai/plugin-sdk';
2
+ export declare class smartBIModule implements IOnPluginBootstrap, IOnPluginDestroy {
3
+ /**
4
+ * 默认情况下,我们禁用每个事件的附加日志记录,以避免使日志混乱
5
+ * We disable by default additional logging for each event to avoid cluttering the logs
6
+ * */
7
+ private logEnabled;
8
+ /**
9
+ * 在插件初始化时调用。
10
+ * Called when the plugin is being initialized.
11
+ */
12
+ onPluginBootstrap(): void | Promise<void>;
13
+ /**
14
+ * 当插件被销毁时调用。
15
+ * Called when the plugin is being destroyed.
16
+ */
17
+ onPluginDestroy(): void | Promise<void>;
18
+ }
19
+ //# sourceMappingURL=smartBI.module.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"smartBI.module.d.ts","sourceRoot":"","sources":["../../src/lib/smartBI.module.ts"],"names":[],"mappings":"AACA,OAAO,EAAqB,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAK/F,qBAuBa,aAAc,YAAW,kBAAkB,EAAE,gBAAgB;IACtE;;;SAGK;IACL,OAAO,CAAC,UAAU,CAAQ;IAE1B;;;OAGG;IACH,iBAAiB,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAMzC;;;OAGG;IACH,eAAe,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;CAK1C"}
@@ -0,0 +1,58 @@
1
+ var smartBIModule_1;
2
+ import { __decorate } from "tslib";
3
+ import chalk from 'chalk';
4
+ import { XpertServerPlugin } from '@xpert-ai/plugin-sdk';
5
+ import { SmartBIIntegrationStrategy } from './integrationStrategy.js';
6
+ import { SmartBIController } from "./lark.controller.js";
7
+ let smartBIModule = smartBIModule_1 = class smartBIModule {
8
+ constructor() {
9
+ /**
10
+ * 默认情况下,我们禁用每个事件的附加日志记录,以避免使日志混乱
11
+ * We disable by default additional logging for each event to avoid cluttering the logs
12
+ * */
13
+ this.logEnabled = true;
14
+ }
15
+ /**
16
+ * 在插件初始化时调用。
17
+ * Called when the plugin is being initialized.
18
+ */
19
+ onPluginBootstrap() {
20
+ if (this.logEnabled) {
21
+ console.log(chalk.green(`${smartBIModule_1.name} is being bootstrapped...`));
22
+ }
23
+ }
24
+ /**
25
+ * 当插件被销毁时调用。
26
+ * Called when the plugin is being destroyed.
27
+ */
28
+ onPluginDestroy() {
29
+ if (this.logEnabled) {
30
+ console.log(chalk.green(`${smartBIModule_1.name} is being destroyed...`));
31
+ }
32
+ }
33
+ };
34
+ smartBIModule = smartBIModule_1 = __decorate([
35
+ XpertServerPlugin({
36
+ /**
37
+ * 引用其他module
38
+ */
39
+ imports: [],
40
+ /**
41
+ * 在实际中是对应的表 他用的是typeorm来实现的对表的一个ORM映射
42
+ */
43
+ entities: [],
44
+ /**
45
+ * 接口
46
+ */
47
+ controllers: [
48
+ SmartBIController
49
+ ],
50
+ /**
51
+ * 提供的 services 方法
52
+ */
53
+ providers: [
54
+ SmartBIIntegrationStrategy
55
+ ]
56
+ })
57
+ ], smartBIModule);
58
+ export { smartBIModule };
@@ -0,0 +1,7 @@
1
+ export declare const iconImage = "";
2
+ export declare const SmartBIName = "smartBI";
3
+ export type TSmartBIIntegrationConfig = {
4
+ userName: string;
5
+ passWord: string;
6
+ };
7
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/lib/types.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,SAAS,usHAAusH,CAAA;AAC7tH,eAAO,MAAM,WAAW,YAAY,CAAA;AAEpC,MAAM,MAAM,yBAAyB,GAAG;IACpC,QAAQ,EAAE,MAAM,CAAA;IAChB,QAAQ,EAAE,MAAM,CAAA;CACnB,CAAA"}
@@ -0,0 +1,2 @@
1
+ export const iconImage = ``;
2
+ export const SmartBIName = 'smartBI';
package/package.json ADDED
@@ -0,0 +1,35 @@
1
+ {
2
+ "name": "@dj1029/plugin-smart-sl",
3
+ "version": "0.0.2",
4
+ "type": "module",
5
+ "main": "./dist/index.js",
6
+ "module": "./dist/index.js",
7
+ "types": "./dist/index.d.ts",
8
+ "exports": {
9
+ "./package.json": "./package.json",
10
+ ".": {
11
+ "@xpert-plugins-starter/source": "./src/index.ts",
12
+ "types": "./dist/index.d.ts",
13
+ "import": "./dist/index.js",
14
+ "default": "./dist/index.js"
15
+ }
16
+ },
17
+ "files": [
18
+ "dist",
19
+ "!**/*.tsbuildinfo"
20
+ ],
21
+ "dependencies": {
22
+ "@larksuiteoapi/node-sdk": "^1.55.0",
23
+ "tslib": "^2.3.0"
24
+ },
25
+ "peerDependencies": {
26
+ "zod": "3.25.67",
27
+ "@xpert-ai/plugin-sdk": "^3.6.3",
28
+ "i18next": "25.6.0",
29
+ "@metad/contracts": "^3.6.2",
30
+ "@nestjs/common": "^11.1.6",
31
+ "axios": "1.12.2",
32
+ "chalk": "4.1.2",
33
+ "@langchain/core": "0.3.72"
34
+ }
35
+ }