@seatable/mcp-seatable 0.9.5
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/.env.example +11 -0
- package/LICENSE +21 -0
- package/README.md +302 -0
- package/bin/seatable-mcp.cjs +20 -0
- package/dist/auth/tokenValidator.d.ts +10 -0
- package/dist/auth/tokenValidator.d.ts.map +1 -0
- package/dist/auth/tokenValidator.js +55 -0
- package/dist/auth/tokenValidator.js.map +1 -0
- package/dist/config/env.d.ts +67 -0
- package/dist/config/env.d.ts.map +1 -0
- package/dist/config/env.js +105 -0
- package/dist/config/env.js.map +1 -0
- package/dist/errors.d.ts +8 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/errors.js +28 -0
- package/dist/errors.js.map +1 -0
- package/dist/http/httpServer.d.ts +7 -0
- package/dist/http/httpServer.d.ts.map +1 -0
- package/dist/http/httpServer.js +211 -0
- package/dist/http/httpServer.js.map +1 -0
- package/dist/http/sseServer.d.ts +11 -0
- package/dist/http/sseServer.d.ts.map +1 -0
- package/dist/http/sseServer.js +154 -0
- package/dist/http/sseServer.js.map +1 -0
- package/dist/index.d.ts +13 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +86 -0
- package/dist/index.js.map +1 -0
- package/dist/logger.d.ts +5 -0
- package/dist/logger.d.ts.map +1 -0
- package/dist/logger.js +34 -0
- package/dist/logger.js.map +1 -0
- package/dist/mcp/server.d.ts +52 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +222 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/tools/addRow.d.ts +3 -0
- package/dist/mcp/tools/addRow.d.ts.map +1 -0
- package/dist/mcp/tools/addRow.js +23 -0
- package/dist/mcp/tools/addRow.js.map +1 -0
- package/dist/mcp/tools/addSelectOption.d.ts +3 -0
- package/dist/mcp/tools/addSelectOption.d.ts.map +1 -0
- package/dist/mcp/tools/addSelectOption.js +27 -0
- package/dist/mcp/tools/addSelectOption.js.map +1 -0
- package/dist/mcp/tools/appendRows.d.ts +3 -0
- package/dist/mcp/tools/appendRows.d.ts.map +1 -0
- package/dist/mcp/tools/appendRows.js +27 -0
- package/dist/mcp/tools/appendRows.js.map +1 -0
- package/dist/mcp/tools/attachFileToRow.d.ts +3 -0
- package/dist/mcp/tools/attachFileToRow.d.ts.map +1 -0
- package/dist/mcp/tools/attachFileToRow.js +42 -0
- package/dist/mcp/tools/attachFileToRow.js.map +1 -0
- package/dist/mcp/tools/bulkSetSelectOptions.d.ts +3 -0
- package/dist/mcp/tools/bulkSetSelectOptions.d.ts.map +1 -0
- package/dist/mcp/tools/bulkSetSelectOptions.js +49 -0
- package/dist/mcp/tools/bulkSetSelectOptions.js.map +1 -0
- package/dist/mcp/tools/deleteRow.d.ts +3 -0
- package/dist/mcp/tools/deleteRow.d.ts.map +1 -0
- package/dist/mcp/tools/deleteRow.js +22 -0
- package/dist/mcp/tools/deleteRow.js.map +1 -0
- package/dist/mcp/tools/echoArgs.d.ts +3 -0
- package/dist/mcp/tools/echoArgs.d.ts.map +1 -0
- package/dist/mcp/tools/echoArgs.js +14 -0
- package/dist/mcp/tools/echoArgs.js.map +1 -0
- package/dist/mcp/tools/findRows.d.ts +9 -0
- package/dist/mcp/tools/findRows.d.ts.map +1 -0
- package/dist/mcp/tools/findRows.js +255 -0
- package/dist/mcp/tools/findRows.js.map +1 -0
- package/dist/mcp/tools/getRow.d.ts +3 -0
- package/dist/mcp/tools/getRow.d.ts.map +1 -0
- package/dist/mcp/tools/getRow.js +18 -0
- package/dist/mcp/tools/getRow.js.map +1 -0
- package/dist/mcp/tools/getSchema.d.ts +3 -0
- package/dist/mcp/tools/getSchema.d.ts.map +1 -0
- package/dist/mcp/tools/getSchema.js +16 -0
- package/dist/mcp/tools/getSchema.js.map +1 -0
- package/dist/mcp/tools/linkRows.d.ts +3 -0
- package/dist/mcp/tools/linkRows.d.ts.map +1 -0
- package/dist/mcp/tools/linkRows.js +23 -0
- package/dist/mcp/tools/linkRows.js.map +1 -0
- package/dist/mcp/tools/listBases.d.ts +3 -0
- package/dist/mcp/tools/listBases.d.ts.map +1 -0
- package/dist/mcp/tools/listBases.js +16 -0
- package/dist/mcp/tools/listBases.js.map +1 -0
- package/dist/mcp/tools/listCollaborators.d.ts +3 -0
- package/dist/mcp/tools/listCollaborators.d.ts.map +1 -0
- package/dist/mcp/tools/listCollaborators.js +16 -0
- package/dist/mcp/tools/listCollaborators.js.map +1 -0
- package/dist/mcp/tools/listRows.d.ts +3 -0
- package/dist/mcp/tools/listRows.d.ts.map +1 -0
- package/dist/mcp/tools/listRows.js +20 -0
- package/dist/mcp/tools/listRows.js.map +1 -0
- package/dist/mcp/tools/listTables.d.ts +3 -0
- package/dist/mcp/tools/listTables.d.ts.map +1 -0
- package/dist/mcp/tools/listTables.js +19 -0
- package/dist/mcp/tools/listTables.js.map +1 -0
- package/dist/mcp/tools/manageColumns.d.ts +3 -0
- package/dist/mcp/tools/manageColumns.d.ts.map +1 -0
- package/dist/mcp/tools/manageColumns.js +44 -0
- package/dist/mcp/tools/manageColumns.js.map +1 -0
- package/dist/mcp/tools/manageTables.d.ts +3 -0
- package/dist/mcp/tools/manageTables.d.ts.map +1 -0
- package/dist/mcp/tools/manageTables.js +36 -0
- package/dist/mcp/tools/manageTables.js.map +1 -0
- package/dist/mcp/tools/pingSeatable.d.ts +3 -0
- package/dist/mcp/tools/pingSeatable.d.ts.map +1 -0
- package/dist/mcp/tools/pingSeatable.js +37 -0
- package/dist/mcp/tools/pingSeatable.js.map +1 -0
- package/dist/mcp/tools/querySql.d.ts +3 -0
- package/dist/mcp/tools/querySql.d.ts.map +1 -0
- package/dist/mcp/tools/querySql.js +28 -0
- package/dist/mcp/tools/querySql.js.map +1 -0
- package/dist/mcp/tools/searchRows.d.ts +3 -0
- package/dist/mcp/tools/searchRows.d.ts.map +1 -0
- package/dist/mcp/tools/searchRows.js +18 -0
- package/dist/mcp/tools/searchRows.js.map +1 -0
- package/dist/mcp/tools/types.d.ts +90 -0
- package/dist/mcp/tools/types.d.ts.map +1 -0
- package/dist/mcp/tools/types.js +2 -0
- package/dist/mcp/tools/types.js.map +1 -0
- package/dist/mcp/tools/unlinkRows.d.ts +3 -0
- package/dist/mcp/tools/unlinkRows.d.ts.map +1 -0
- package/dist/mcp/tools/unlinkRows.js +23 -0
- package/dist/mcp/tools/unlinkRows.js.map +1 -0
- package/dist/mcp/tools/updateRow.d.ts +3 -0
- package/dist/mcp/tools/updateRow.d.ts.map +1 -0
- package/dist/mcp/tools/updateRow.js +32 -0
- package/dist/mcp/tools/updateRow.js.map +1 -0
- package/dist/mcp/tools/uploadFile.d.ts +3 -0
- package/dist/mcp/tools/uploadFile.d.ts.map +1 -0
- package/dist/mcp/tools/uploadFile.js +29 -0
- package/dist/mcp/tools/uploadFile.js.map +1 -0
- package/dist/mcp/tools/upsertRows.d.ts +3 -0
- package/dist/mcp/tools/upsertRows.d.ts.map +1 -0
- package/dist/mcp/tools/upsertRows.js +55 -0
- package/dist/mcp/tools/upsertRows.js.map +1 -0
- package/dist/ratelimit/connectionCounter.d.ts +11 -0
- package/dist/ratelimit/connectionCounter.d.ts.map +1 -0
- package/dist/ratelimit/connectionCounter.js +27 -0
- package/dist/ratelimit/connectionCounter.js.map +1 -0
- package/dist/ratelimit/index.d.ts +27 -0
- package/dist/ratelimit/index.d.ts.map +1 -0
- package/dist/ratelimit/index.js +50 -0
- package/dist/ratelimit/index.js.map +1 -0
- package/dist/ratelimit/rateLimiter.d.ts +18 -0
- package/dist/ratelimit/rateLimiter.d.ts.map +1 -0
- package/dist/ratelimit/rateLimiter.js +54 -0
- package/dist/ratelimit/rateLimiter.js.map +1 -0
- package/dist/schema/generic.d.ts +126 -0
- package/dist/schema/generic.d.ts.map +1 -0
- package/dist/schema/generic.js +45 -0
- package/dist/schema/generic.js.map +1 -0
- package/dist/schema/jsonSchemaToZod.d.ts +3 -0
- package/dist/schema/jsonSchemaToZod.d.ts.map +1 -0
- package/dist/schema/jsonSchemaToZod.js +53 -0
- package/dist/schema/jsonSchemaToZod.js.map +1 -0
- package/dist/schema/map.d.ts +3 -0
- package/dist/schema/map.d.ts.map +1 -0
- package/dist/schema/map.js +92 -0
- package/dist/schema/map.js.map +1 -0
- package/dist/schema/validate.d.ts +15 -0
- package/dist/schema/validate.d.ts.map +1 -0
- package/dist/schema/validate.js +170 -0
- package/dist/schema/validate.js.map +1 -0
- package/dist/seatable/client.d.ts +106 -0
- package/dist/seatable/client.d.ts.map +1 -0
- package/dist/seatable/client.js +378 -0
- package/dist/seatable/client.js.map +1 -0
- package/dist/seatable/clientRegistry.d.ts +11 -0
- package/dist/seatable/clientRegistry.d.ts.map +1 -0
- package/dist/seatable/clientRegistry.js +33 -0
- package/dist/seatable/clientRegistry.js.map +1 -0
- package/dist/seatable/contextualClient.d.ts +92 -0
- package/dist/seatable/contextualClient.d.ts.map +1 -0
- package/dist/seatable/contextualClient.js +42 -0
- package/dist/seatable/contextualClient.js.map +1 -0
- package/dist/seatable/mockClient.d.ts +68 -0
- package/dist/seatable/mockClient.d.ts.map +1 -0
- package/dist/seatable/mockClient.js +115 -0
- package/dist/seatable/mockClient.js.map +1 -0
- package/dist/seatable/tokenManager.d.ts +28 -0
- package/dist/seatable/tokenManager.d.ts.map +1 -0
- package/dist/seatable/tokenManager.js +92 -0
- package/dist/seatable/tokenManager.js.map +1 -0
- package/dist/seatable/types.d.ts +22 -0
- package/dist/seatable/types.d.ts.map +1 -0
- package/dist/seatable/types.js +3 -0
- package/dist/seatable/types.js.map +1 -0
- package/dist/seatable/utils.d.ts +7 -0
- package/dist/seatable/utils.d.ts.map +1 -0
- package/dist/seatable/utils.js +25 -0
- package/dist/seatable/utils.js.map +1 -0
- package/package.json +94 -0
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
import { ListRowsResponse, SeaTableRow, SeaTableTable } from './types.js';
|
|
3
|
+
export interface SeaTableClientConfig {
|
|
4
|
+
serverUrl: string;
|
|
5
|
+
apiToken: string;
|
|
6
|
+
timeoutMs?: number;
|
|
7
|
+
}
|
|
8
|
+
declare const ListRowsQuerySchema: z.ZodObject<{
|
|
9
|
+
table: z.ZodString;
|
|
10
|
+
page: z.ZodDefault<z.ZodNumber>;
|
|
11
|
+
page_size: z.ZodDefault<z.ZodNumber>;
|
|
12
|
+
view: z.ZodOptional<z.ZodString>;
|
|
13
|
+
}, "strip", z.ZodTypeAny, {
|
|
14
|
+
table: string;
|
|
15
|
+
page: number;
|
|
16
|
+
page_size: number;
|
|
17
|
+
view?: string | undefined;
|
|
18
|
+
}, {
|
|
19
|
+
table: string;
|
|
20
|
+
page?: number | undefined;
|
|
21
|
+
page_size?: number | undefined;
|
|
22
|
+
view?: string | undefined;
|
|
23
|
+
}>;
|
|
24
|
+
export type ListRowsQuery = z.infer<typeof ListRowsQuerySchema>;
|
|
25
|
+
export declare class SeaTableClient {
|
|
26
|
+
private readonly tokenManager;
|
|
27
|
+
private readonly limiter;
|
|
28
|
+
private readonly serverUrl;
|
|
29
|
+
private readonly apiToken;
|
|
30
|
+
private readonly timeoutMs;
|
|
31
|
+
private http?;
|
|
32
|
+
private initialized;
|
|
33
|
+
private initializing?;
|
|
34
|
+
constructor(config: SeaTableClientConfig);
|
|
35
|
+
private ensureInitialized;
|
|
36
|
+
private init;
|
|
37
|
+
private request;
|
|
38
|
+
getMetadata(): Promise<any>;
|
|
39
|
+
listTables(): Promise<SeaTableTable[]>;
|
|
40
|
+
listRows(query: {
|
|
41
|
+
table: string;
|
|
42
|
+
page?: number;
|
|
43
|
+
page_size?: number;
|
|
44
|
+
view?: string;
|
|
45
|
+
}): Promise<ListRowsResponse>;
|
|
46
|
+
getRow(table: string, rowId: string): Promise<SeaTableRow>;
|
|
47
|
+
addRow(table: string, row: Record<string, unknown>): Promise<SeaTableRow>;
|
|
48
|
+
updateRow(table: string, rowId: string, row: Record<string, unknown>): Promise<any>;
|
|
49
|
+
deleteRow(table: string, rowId: string): Promise<{
|
|
50
|
+
success: boolean;
|
|
51
|
+
}>;
|
|
52
|
+
searchRows(table: string, query: Record<string, unknown>): Promise<ListRowsResponse>;
|
|
53
|
+
querySql(sql: string, parameters?: any[]): Promise<{
|
|
54
|
+
metadata: any;
|
|
55
|
+
results: any[];
|
|
56
|
+
}>;
|
|
57
|
+
listCollaborators(): Promise<Array<{
|
|
58
|
+
email: string;
|
|
59
|
+
name: string;
|
|
60
|
+
}>>;
|
|
61
|
+
private resolveLinkColumn;
|
|
62
|
+
createLinks(args: {
|
|
63
|
+
table: string;
|
|
64
|
+
linkColumn: string;
|
|
65
|
+
pairs: Array<{
|
|
66
|
+
fromRowId: string;
|
|
67
|
+
toRowId: string;
|
|
68
|
+
}>;
|
|
69
|
+
}): Promise<any>;
|
|
70
|
+
deleteLinks(args: {
|
|
71
|
+
table: string;
|
|
72
|
+
linkColumn: string;
|
|
73
|
+
pairs: Array<{
|
|
74
|
+
fromRowId: string;
|
|
75
|
+
toRowId: string;
|
|
76
|
+
}>;
|
|
77
|
+
}): Promise<any>;
|
|
78
|
+
addColumnOptions(args: {
|
|
79
|
+
table: string;
|
|
80
|
+
column: string;
|
|
81
|
+
options: Array<{
|
|
82
|
+
name: string;
|
|
83
|
+
color?: string;
|
|
84
|
+
textColor?: string;
|
|
85
|
+
}>;
|
|
86
|
+
}): Promise<any>;
|
|
87
|
+
uploadFile(args: {
|
|
88
|
+
table: string;
|
|
89
|
+
column: string;
|
|
90
|
+
rowId: string;
|
|
91
|
+
fileName: string;
|
|
92
|
+
fileData: string;
|
|
93
|
+
replace?: boolean;
|
|
94
|
+
}): Promise<{
|
|
95
|
+
file_name: string;
|
|
96
|
+
file_size: number;
|
|
97
|
+
asset_url: string;
|
|
98
|
+
column_type: string;
|
|
99
|
+
}>;
|
|
100
|
+
}
|
|
101
|
+
/** Create a client from environment variables (selfhosted mode). */
|
|
102
|
+
export declare function createClientFromEnv(): SeaTableClient;
|
|
103
|
+
/** Create a client from a provided API token (managed mode). Server URL from env. */
|
|
104
|
+
export declare function createClientFromToken(apiToken: string): SeaTableClient;
|
|
105
|
+
export {};
|
|
106
|
+
//# sourceMappingURL=client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../src/seatable/client.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,378 @@
|
|
|
1
|
+
import axios from 'axios';
|
|
2
|
+
import axiosRetry from 'axios-retry';
|
|
3
|
+
import Bottleneck from 'bottleneck';
|
|
4
|
+
import { z } from 'zod';
|
|
5
|
+
import { getEnv } from '../config/env.js';
|
|
6
|
+
import { toCodedAxiosError } from '../errors.js';
|
|
7
|
+
import { logger } from '../logger.js';
|
|
8
|
+
import { TokenManager } from './tokenManager.js';
|
|
9
|
+
import { logAxiosError } from './utils.js';
|
|
10
|
+
const ListRowsQuerySchema = z.object({
|
|
11
|
+
table: z.string(),
|
|
12
|
+
page: z.number().int().min(1).default(1),
|
|
13
|
+
page_size: z.number().int().min(1).max(1000).default(100),
|
|
14
|
+
view: z.string().optional(),
|
|
15
|
+
});
|
|
16
|
+
export class SeaTableClient {
|
|
17
|
+
tokenManager;
|
|
18
|
+
limiter;
|
|
19
|
+
serverUrl;
|
|
20
|
+
apiToken;
|
|
21
|
+
timeoutMs;
|
|
22
|
+
http;
|
|
23
|
+
initialized = false;
|
|
24
|
+
initializing;
|
|
25
|
+
constructor(config) {
|
|
26
|
+
this.serverUrl = config.serverUrl.replace(/\/$/, '');
|
|
27
|
+
this.apiToken = config.apiToken;
|
|
28
|
+
this.timeoutMs = config.timeoutMs ?? 30000;
|
|
29
|
+
this.tokenManager = new TokenManager({
|
|
30
|
+
serverUrl: this.serverUrl,
|
|
31
|
+
apiToken: config.apiToken,
|
|
32
|
+
timeoutMs: config.timeoutMs,
|
|
33
|
+
});
|
|
34
|
+
this.limiter = new Bottleneck({ maxConcurrent: 1, minTime: 200 }); // 5 RPS
|
|
35
|
+
logger.info({ msg: `SeaTableClient constructor, serverUrl: ${this.serverUrl}` });
|
|
36
|
+
}
|
|
37
|
+
// --- Lazy initialization ---
|
|
38
|
+
async ensureInitialized() {
|
|
39
|
+
if (this.initialized)
|
|
40
|
+
return;
|
|
41
|
+
if (!this.initializing)
|
|
42
|
+
this.initializing = this.init();
|
|
43
|
+
await this.initializing;
|
|
44
|
+
}
|
|
45
|
+
async init() {
|
|
46
|
+
// Trigger token exchange to get base token + dtable_uuid
|
|
47
|
+
await this.tokenManager.getToken();
|
|
48
|
+
const baseUuid = this.tokenManager.getDtableUuid();
|
|
49
|
+
if (!baseUuid) {
|
|
50
|
+
throw new Error('Cannot determine base UUID. Ensure the token exchange returns dtable_uuid.');
|
|
51
|
+
}
|
|
52
|
+
const baseURL = `${this.serverUrl}/api-gateway/api/v2/dtables/${baseUuid}`;
|
|
53
|
+
logger.info({ baseURL }, 'SeaTableClient initialized');
|
|
54
|
+
this.http = axios.create({
|
|
55
|
+
baseURL,
|
|
56
|
+
timeout: this.timeoutMs,
|
|
57
|
+
});
|
|
58
|
+
// Add Bearer token to every request
|
|
59
|
+
this.http.interceptors.request.use(async (config) => {
|
|
60
|
+
const token = await this.tokenManager.getToken();
|
|
61
|
+
config.headers.Authorization = `Bearer ${token}`;
|
|
62
|
+
return config;
|
|
63
|
+
});
|
|
64
|
+
// Retry with exponential backoff
|
|
65
|
+
axiosRetry(this.http, {
|
|
66
|
+
retries: 3,
|
|
67
|
+
retryDelay: axiosRetry.exponentialDelay,
|
|
68
|
+
retryCondition: (error) => {
|
|
69
|
+
return axiosRetry.isNetworkOrIdempotentRequestError(error) || error.response?.status === 429;
|
|
70
|
+
},
|
|
71
|
+
});
|
|
72
|
+
this.initialized = true;
|
|
73
|
+
}
|
|
74
|
+
async request(op, fn) {
|
|
75
|
+
await this.ensureInitialized();
|
|
76
|
+
return this.limiter.schedule(async () => {
|
|
77
|
+
try {
|
|
78
|
+
return await fn(this.http);
|
|
79
|
+
}
|
|
80
|
+
catch (err) {
|
|
81
|
+
logAxiosError(err, op);
|
|
82
|
+
throw toCodedAxiosError(err, op);
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
// --- Metadata & Tables ---
|
|
87
|
+
async getMetadata() {
|
|
88
|
+
return this.request('getMetadata', async (http) => {
|
|
89
|
+
const res = await http.get('/metadata/');
|
|
90
|
+
return res.data.metadata ?? res.data;
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
async listTables() {
|
|
94
|
+
const meta = await this.getMetadata();
|
|
95
|
+
return (meta.tables ?? []);
|
|
96
|
+
}
|
|
97
|
+
// --- Rows ---
|
|
98
|
+
async listRows(query) {
|
|
99
|
+
const parsed = ListRowsQuerySchema.parse(query);
|
|
100
|
+
return this.request('listRows', async (http) => {
|
|
101
|
+
const params = {
|
|
102
|
+
table_name: parsed.table,
|
|
103
|
+
start: (parsed.page - 1) * parsed.page_size,
|
|
104
|
+
limit: parsed.page_size,
|
|
105
|
+
convert_keys: true,
|
|
106
|
+
};
|
|
107
|
+
if (parsed.view)
|
|
108
|
+
params.view_name = parsed.view;
|
|
109
|
+
const res = await http.get('/rows/', { params });
|
|
110
|
+
const rows = res.data.rows ?? res.data;
|
|
111
|
+
return { rows, page: parsed.page, page_size: parsed.page_size, has_more: rows.length === parsed.page_size };
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
async getRow(table, rowId) {
|
|
115
|
+
return this.request('getRow', async (http) => {
|
|
116
|
+
const res = await http.get(`/rows/${rowId}/`, {
|
|
117
|
+
params: { table_name: table, convert_keys: true },
|
|
118
|
+
});
|
|
119
|
+
return res.data;
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
async addRow(table, row) {
|
|
123
|
+
return this.request('addRow', async (http) => {
|
|
124
|
+
const res = await http.post('/rows/', {
|
|
125
|
+
table_name: table,
|
|
126
|
+
rows: [row],
|
|
127
|
+
convert_keys: true,
|
|
128
|
+
});
|
|
129
|
+
return res.data.first_row ?? res.data;
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
async updateRow(table, rowId, row) {
|
|
133
|
+
return this.request('updateRow', async (http) => {
|
|
134
|
+
const res = await http.put('/rows/', {
|
|
135
|
+
table_name: table,
|
|
136
|
+
updates: [{ row_id: rowId, row }],
|
|
137
|
+
});
|
|
138
|
+
return res.data;
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
async deleteRow(table, rowId) {
|
|
142
|
+
return this.request('deleteRow', async (http) => {
|
|
143
|
+
const res = await http.delete('/rows/', {
|
|
144
|
+
data: { table_name: table, row_ids: [rowId] },
|
|
145
|
+
});
|
|
146
|
+
return res.data;
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
async searchRows(table, query) {
|
|
150
|
+
// Build SQL WHERE clause from key-value pairs
|
|
151
|
+
const conditions = Object.entries(query).map(([col]) => `\`${col}\` = ?`);
|
|
152
|
+
const values = Object.values(query);
|
|
153
|
+
const sql = `SELECT * FROM \`${table}\` WHERE ${conditions.join(' AND ')}`;
|
|
154
|
+
const result = await this.querySql(sql, values);
|
|
155
|
+
return { rows: result.results };
|
|
156
|
+
}
|
|
157
|
+
// --- SQL ---
|
|
158
|
+
async querySql(sql, parameters) {
|
|
159
|
+
return this.request('querySql', async (http) => {
|
|
160
|
+
const body = { sql, convert_keys: true };
|
|
161
|
+
if (parameters?.length)
|
|
162
|
+
body.parameters = parameters;
|
|
163
|
+
const res = await http.post('/sql/', body);
|
|
164
|
+
return {
|
|
165
|
+
metadata: res.data.metadata ?? {},
|
|
166
|
+
results: res.data.results ?? res.data.rows ?? [],
|
|
167
|
+
};
|
|
168
|
+
});
|
|
169
|
+
}
|
|
170
|
+
async listCollaborators() {
|
|
171
|
+
await this.ensureInitialized();
|
|
172
|
+
return this.limiter.schedule(async () => {
|
|
173
|
+
try {
|
|
174
|
+
const token = await this.tokenManager.getToken();
|
|
175
|
+
const uuid = this.tokenManager.getDtableUuid();
|
|
176
|
+
const url = `${this.serverUrl}/api/v2.1/dtables/${uuid}/related-users/`;
|
|
177
|
+
const res = await axios.get(url, {
|
|
178
|
+
headers: { Authorization: `Bearer ${token}` },
|
|
179
|
+
timeout: this.timeoutMs,
|
|
180
|
+
});
|
|
181
|
+
return res.data.user_list ?? [];
|
|
182
|
+
}
|
|
183
|
+
catch (err) {
|
|
184
|
+
logAxiosError(err, 'listCollaborators');
|
|
185
|
+
throw toCodedAxiosError(err, 'listCollaborators');
|
|
186
|
+
}
|
|
187
|
+
});
|
|
188
|
+
}
|
|
189
|
+
// --- Links ---
|
|
190
|
+
async resolveLinkColumn(tableName, linkColumnName) {
|
|
191
|
+
const metadata = await this.getMetadata();
|
|
192
|
+
const tableObj = (metadata.tables ?? []).find((t) => t.name === tableName);
|
|
193
|
+
if (!tableObj)
|
|
194
|
+
throw new Error(`Table "${tableName}" not found`);
|
|
195
|
+
const colObj = (tableObj.columns ?? []).find((c) => c.name === linkColumnName);
|
|
196
|
+
if (!colObj)
|
|
197
|
+
throw new Error(`Column "${linkColumnName}" not found in table "${tableName}"`);
|
|
198
|
+
if (colObj.type !== 'link') {
|
|
199
|
+
throw new Error(`Column "${linkColumnName}" is type "${colObj.type}", expected "link"`);
|
|
200
|
+
}
|
|
201
|
+
const { link_id, table_id, other_table_id } = colObj.data;
|
|
202
|
+
// If the user is linking from the "other" side, swap the IDs
|
|
203
|
+
if (tableObj._id === table_id) {
|
|
204
|
+
return { link_id, table_id, other_table_id };
|
|
205
|
+
}
|
|
206
|
+
return { link_id, table_id: other_table_id, other_table_id: table_id };
|
|
207
|
+
}
|
|
208
|
+
async createLinks(args) {
|
|
209
|
+
await this.ensureInitialized();
|
|
210
|
+
const { link_id, table_id, other_table_id } = await this.resolveLinkColumn(args.table, args.linkColumn);
|
|
211
|
+
// Group pairs into other_rows_ids_map
|
|
212
|
+
const map = {};
|
|
213
|
+
for (const { fromRowId, toRowId } of args.pairs) {
|
|
214
|
+
if (!map[fromRowId])
|
|
215
|
+
map[fromRowId] = [];
|
|
216
|
+
map[fromRowId].push(toRowId);
|
|
217
|
+
}
|
|
218
|
+
return this.request('createLinks', async (http) => {
|
|
219
|
+
const res = await http.post('/links/', {
|
|
220
|
+
link_id,
|
|
221
|
+
table_id,
|
|
222
|
+
other_table_id,
|
|
223
|
+
other_rows_ids_map: map,
|
|
224
|
+
});
|
|
225
|
+
return res.data;
|
|
226
|
+
});
|
|
227
|
+
}
|
|
228
|
+
async deleteLinks(args) {
|
|
229
|
+
await this.ensureInitialized();
|
|
230
|
+
const { link_id, table_id, other_table_id } = await this.resolveLinkColumn(args.table, args.linkColumn);
|
|
231
|
+
// Group pairs into other_rows_ids_map
|
|
232
|
+
const map = {};
|
|
233
|
+
for (const { fromRowId, toRowId } of args.pairs) {
|
|
234
|
+
if (!map[fromRowId])
|
|
235
|
+
map[fromRowId] = [];
|
|
236
|
+
map[fromRowId].push(toRowId);
|
|
237
|
+
}
|
|
238
|
+
return this.request('deleteLinks', async (http) => {
|
|
239
|
+
const res = await http.delete('/links/', {
|
|
240
|
+
data: {
|
|
241
|
+
link_id,
|
|
242
|
+
table_id,
|
|
243
|
+
other_table_id,
|
|
244
|
+
other_rows_ids_map: map,
|
|
245
|
+
},
|
|
246
|
+
});
|
|
247
|
+
return res.data;
|
|
248
|
+
});
|
|
249
|
+
}
|
|
250
|
+
// --- Column options ---
|
|
251
|
+
async addColumnOptions(args) {
|
|
252
|
+
// SeaTable API requires both color and textColor on every option
|
|
253
|
+
const COLORS = ['#FFDDA3', '#FF9F9F', '#EEE8F3', '#B3CEF3', '#D4EDDA', '#D4C5F9', '#7BC8F6', '#3BC97A'];
|
|
254
|
+
const options = args.options.map((opt) => ({
|
|
255
|
+
name: opt.name,
|
|
256
|
+
color: opt.color ?? COLORS[Math.floor(Math.random() * COLORS.length)],
|
|
257
|
+
textColor: opt.textColor ?? '#202020',
|
|
258
|
+
}));
|
|
259
|
+
return this.request('addColumnOptions', async (http) => {
|
|
260
|
+
const res = await http.post('/column-options/', {
|
|
261
|
+
table_name: args.table,
|
|
262
|
+
column: args.column,
|
|
263
|
+
options,
|
|
264
|
+
});
|
|
265
|
+
return res.data;
|
|
266
|
+
});
|
|
267
|
+
}
|
|
268
|
+
// --- File upload ---
|
|
269
|
+
async uploadFile(args) {
|
|
270
|
+
await this.ensureInitialized();
|
|
271
|
+
// Note: no outer limiter.schedule() here — the sub-calls (getMetadata, getRow,
|
|
272
|
+
// updateRow) each schedule through the limiter individually. Wrapping everything
|
|
273
|
+
// would deadlock because Bottleneck has maxConcurrent=1.
|
|
274
|
+
try {
|
|
275
|
+
const { table, column, rowId, fileName, fileData, replace } = args;
|
|
276
|
+
// 1. Validate column type via metadata
|
|
277
|
+
const metadata = await this.getMetadata();
|
|
278
|
+
const tableObj = (metadata.tables ?? []).find((t) => t.name === table);
|
|
279
|
+
if (!tableObj)
|
|
280
|
+
throw new Error(`Table "${table}" not found`);
|
|
281
|
+
const colObj = (tableObj.columns ?? []).find((c) => c.name === column);
|
|
282
|
+
if (!colObj)
|
|
283
|
+
throw new Error(`Column "${column}" not found in table "${table}"`);
|
|
284
|
+
if (colObj.type !== 'image' && colObj.type !== 'file') {
|
|
285
|
+
throw new Error(`Column "${column}" is type "${colObj.type}", expected "image" or "file"`);
|
|
286
|
+
}
|
|
287
|
+
const columnType = colObj.type;
|
|
288
|
+
// 2. Get upload link (uses original API token, not base token)
|
|
289
|
+
const uploadInfo = await this.limiter.schedule(async () => {
|
|
290
|
+
const url = `${this.serverUrl}/api/v2.1/dtable/app-upload-link/`;
|
|
291
|
+
const res = await axios.get(url, {
|
|
292
|
+
headers: { Authorization: `Token ${this.apiToken}` },
|
|
293
|
+
timeout: this.timeoutMs,
|
|
294
|
+
});
|
|
295
|
+
return res.data;
|
|
296
|
+
});
|
|
297
|
+
// 3. Upload file via multipart form
|
|
298
|
+
const relativePath = columnType === 'image'
|
|
299
|
+
? uploadInfo.img_relative_path
|
|
300
|
+
: uploadInfo.file_relative_path;
|
|
301
|
+
const fileBuffer = Buffer.from(fileData, 'base64');
|
|
302
|
+
const formData = new FormData();
|
|
303
|
+
formData.append('file', new Blob([fileBuffer]), fileName);
|
|
304
|
+
formData.append('parent_dir', uploadInfo.parent_path);
|
|
305
|
+
formData.append('relative_path', relativePath);
|
|
306
|
+
const uploaded = await this.limiter.schedule(async () => {
|
|
307
|
+
const res = await axios.post(`${uploadInfo.upload_link}?ret-json=1`, formData, {
|
|
308
|
+
timeout: this.timeoutMs,
|
|
309
|
+
});
|
|
310
|
+
return Array.isArray(res.data) ? res.data[0] : res.data;
|
|
311
|
+
});
|
|
312
|
+
// 4. Construct asset URL
|
|
313
|
+
const workspaceId = this.tokenManager.getWorkspaceId();
|
|
314
|
+
if (!workspaceId) {
|
|
315
|
+
throw new Error('Missing workspace_id for asset URL construction');
|
|
316
|
+
}
|
|
317
|
+
// parent_path is "/asset/{uuid}", relativePath is e.g. "files/2026-03"
|
|
318
|
+
const assetUrl = `/workspace/${workspaceId}${uploadInfo.parent_path}/${relativePath}/${uploaded.name}`;
|
|
319
|
+
// 5. Merge with existing values unless replace=true
|
|
320
|
+
let newValue;
|
|
321
|
+
if (columnType === 'image') {
|
|
322
|
+
const urls = [assetUrl];
|
|
323
|
+
if (!replace) {
|
|
324
|
+
const existingRow = await this.getRow(table, rowId);
|
|
325
|
+
const existing = existingRow[column];
|
|
326
|
+
if (Array.isArray(existing))
|
|
327
|
+
urls.unshift(...existing);
|
|
328
|
+
}
|
|
329
|
+
newValue = urls;
|
|
330
|
+
}
|
|
331
|
+
else {
|
|
332
|
+
const fileObj = { name: uploaded.name, size: uploaded.size, type: 'file', url: assetUrl };
|
|
333
|
+
const files = [fileObj];
|
|
334
|
+
if (!replace) {
|
|
335
|
+
const existingRow = await this.getRow(table, rowId);
|
|
336
|
+
const existing = existingRow[column];
|
|
337
|
+
if (Array.isArray(existing))
|
|
338
|
+
files.unshift(...existing);
|
|
339
|
+
}
|
|
340
|
+
newValue = files;
|
|
341
|
+
}
|
|
342
|
+
// 6. Update the row
|
|
343
|
+
await this.updateRow(table, rowId, { [column]: newValue });
|
|
344
|
+
return {
|
|
345
|
+
file_name: uploaded.name,
|
|
346
|
+
file_size: uploaded.size ?? fileBuffer.length,
|
|
347
|
+
asset_url: assetUrl,
|
|
348
|
+
column_type: columnType,
|
|
349
|
+
};
|
|
350
|
+
}
|
|
351
|
+
catch (err) {
|
|
352
|
+
logAxiosError(err, 'uploadFile');
|
|
353
|
+
throw toCodedAxiosError(err, 'uploadFile');
|
|
354
|
+
}
|
|
355
|
+
}
|
|
356
|
+
}
|
|
357
|
+
/** Create a client from environment variables (selfhosted mode). */
|
|
358
|
+
export function createClientFromEnv() {
|
|
359
|
+
const env = getEnv();
|
|
360
|
+
if (!env.SEATABLE_API_TOKEN) {
|
|
361
|
+
throw new Error('SEATABLE_API_TOKEN is required to create a client from env');
|
|
362
|
+
}
|
|
363
|
+
return new SeaTableClient({
|
|
364
|
+
serverUrl: env.SEATABLE_SERVER_URL,
|
|
365
|
+
apiToken: env.SEATABLE_API_TOKEN,
|
|
366
|
+
timeoutMs: env.HTTP_TIMEOUT_MS,
|
|
367
|
+
});
|
|
368
|
+
}
|
|
369
|
+
/** Create a client from a provided API token (managed mode). Server URL from env. */
|
|
370
|
+
export function createClientFromToken(apiToken) {
|
|
371
|
+
const env = getEnv();
|
|
372
|
+
return new SeaTableClient({
|
|
373
|
+
serverUrl: env.SEATABLE_SERVER_URL,
|
|
374
|
+
apiToken,
|
|
375
|
+
timeoutMs: env.HTTP_TIMEOUT_MS,
|
|
376
|
+
});
|
|
377
|
+
}
|
|
378
|
+
//# sourceMappingURL=client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/seatable/client.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { BaseEntry } from '../config/env.js';
|
|
2
|
+
import { SeaTableClient, type SeaTableClientConfig } from './client.js';
|
|
3
|
+
export declare class ClientRegistry {
|
|
4
|
+
private readonly clients;
|
|
5
|
+
private readonly defaultName?;
|
|
6
|
+
constructor(bases: BaseEntry[], baseConfig: Omit<SeaTableClientConfig, 'apiToken'>);
|
|
7
|
+
get baseNames(): string[];
|
|
8
|
+
get isMultiBase(): boolean;
|
|
9
|
+
resolve(baseName?: string): SeaTableClient;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=clientRegistry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clientRegistry.d.ts","sourceRoot":"","sources":["../../src/seatable/clientRegistry.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AACjD,OAAO,EAAE,cAAc,EAAE,KAAK,oBAAoB,EAAE,MAAM,aAAa,CAAA;AAEvE,qBAAa,cAAc;IACvB,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAoC;IAC5D,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAQ;gBAGjC,KAAK,EAAE,SAAS,EAAE,EAClB,UAAU,EAAE,IAAI,CAAC,oBAAoB,EAAE,UAAU,CAAC;IAUtD,IAAI,SAAS,IAAI,MAAM,EAAE,CAExB;IAED,IAAI,WAAW,IAAI,OAAO,CAEzB;IAED,OAAO,CAAC,QAAQ,CAAC,EAAE,MAAM,GAAG,cAAc;CAiB7C"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { SeaTableClient } from './client.js';
|
|
2
|
+
export class ClientRegistry {
|
|
3
|
+
clients = new Map();
|
|
4
|
+
defaultName;
|
|
5
|
+
constructor(bases, baseConfig) {
|
|
6
|
+
for (const base of bases) {
|
|
7
|
+
this.clients.set(base.name, new SeaTableClient({ ...baseConfig, apiToken: base.apiToken }));
|
|
8
|
+
}
|
|
9
|
+
if (bases.length === 1) {
|
|
10
|
+
this.defaultName = bases[0].name;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
get baseNames() {
|
|
14
|
+
return Array.from(this.clients.keys());
|
|
15
|
+
}
|
|
16
|
+
get isMultiBase() {
|
|
17
|
+
return this.clients.size > 1;
|
|
18
|
+
}
|
|
19
|
+
resolve(baseName) {
|
|
20
|
+
if (!baseName) {
|
|
21
|
+
if (this.defaultName) {
|
|
22
|
+
return this.clients.get(this.defaultName);
|
|
23
|
+
}
|
|
24
|
+
throw new Error(`Multiple bases available (${this.baseNames.join(', ')}). Specify "base" parameter.`);
|
|
25
|
+
}
|
|
26
|
+
const client = this.clients.get(baseName);
|
|
27
|
+
if (!client) {
|
|
28
|
+
throw new Error(`Unknown base "${baseName}". Available: ${this.baseNames.join(', ')}`);
|
|
29
|
+
}
|
|
30
|
+
return client;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=clientRegistry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clientRegistry.js","sourceRoot":"","sources":["../../src/seatable/clientRegistry.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAA6B,MAAM,aAAa,CAAA;AAEvE,MAAM,OAAO,cAAc;IACN,OAAO,GAAG,IAAI,GAAG,EAA0B,CAAA;IAC3C,WAAW,CAAS;IAErC,YACI,KAAkB,EAClB,UAAkD;QAElD,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACvB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,cAAc,CAAC,EAAE,GAAG,UAAU,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAA;QAC/F,CAAC;QACD,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACrB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;QACpC,CAAC;IACL,CAAC;IAED,IAAI,SAAS;QACT,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAA;IAC1C,CAAC;IAED,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,GAAG,CAAC,CAAA;IAChC,CAAC;IAED,OAAO,CAAC,QAAiB;QACrB,IAAI,CAAC,QAAQ,EAAE,CAAC;YACZ,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAE,CAAA;YAC9C,CAAC;YACD,MAAM,IAAI,KAAK,CACX,6BAA6B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,8BAA8B,CACvF,CAAA;QACL,CAAC;QACD,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;QACzC,IAAI,CAAC,MAAM,EAAE,CAAC;YACV,MAAM,IAAI,KAAK,CACX,iBAAiB,QAAQ,iBAAiB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CACxE,CAAA;QACL,CAAC;QACD,OAAO,MAAM,CAAA;IACjB,CAAC;CACJ"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import type { ClientLike } from '../mcp/tools/types.js';
|
|
2
|
+
import type { ClientRegistry } from './clientRegistry.js';
|
|
3
|
+
/**
|
|
4
|
+
* A ClientLike proxy that delegates to a specific base client
|
|
5
|
+
* based on the currently set base name. This avoids modifying
|
|
6
|
+
* every tool file — the base parameter is extracted centrally
|
|
7
|
+
* in handleCallTool() and applied via setBase().
|
|
8
|
+
*/
|
|
9
|
+
export declare class ContextualClient implements ClientLike {
|
|
10
|
+
private readonly registry;
|
|
11
|
+
private currentBase?;
|
|
12
|
+
constructor(registry: ClientRegistry);
|
|
13
|
+
setBase(name?: string): void;
|
|
14
|
+
private get client();
|
|
15
|
+
listTables(): Promise<{
|
|
16
|
+
name: string;
|
|
17
|
+
_id: string;
|
|
18
|
+
}[]>;
|
|
19
|
+
getMetadata(): Promise<any>;
|
|
20
|
+
listRows(query: {
|
|
21
|
+
table: string;
|
|
22
|
+
page?: number;
|
|
23
|
+
page_size?: number;
|
|
24
|
+
view?: string;
|
|
25
|
+
}): Promise<{
|
|
26
|
+
rows: any[];
|
|
27
|
+
page?: number;
|
|
28
|
+
page_size?: number;
|
|
29
|
+
total?: number;
|
|
30
|
+
has_more?: boolean;
|
|
31
|
+
}>;
|
|
32
|
+
getRow(table: string, rowId: string): Promise<any>;
|
|
33
|
+
addRow(table: string, row: Record<string, unknown>): Promise<any>;
|
|
34
|
+
updateRow(table: string, rowId: string, row: Record<string, unknown>): Promise<any>;
|
|
35
|
+
deleteRow(table: string, rowId: string): Promise<{
|
|
36
|
+
success: boolean;
|
|
37
|
+
}>;
|
|
38
|
+
searchRows(table: string, query: Record<string, unknown>): Promise<{
|
|
39
|
+
rows: any[];
|
|
40
|
+
page?: number;
|
|
41
|
+
page_size?: number;
|
|
42
|
+
total?: number;
|
|
43
|
+
has_more?: boolean;
|
|
44
|
+
}>;
|
|
45
|
+
querySql(sql: string, parameters?: any[]): Promise<{
|
|
46
|
+
metadata: any;
|
|
47
|
+
results: any[];
|
|
48
|
+
}>;
|
|
49
|
+
listCollaborators(): Promise<{
|
|
50
|
+
email: string;
|
|
51
|
+
name: string;
|
|
52
|
+
}[]>;
|
|
53
|
+
createLinks(args: {
|
|
54
|
+
table: string;
|
|
55
|
+
linkColumn: string;
|
|
56
|
+
pairs: Array<{
|
|
57
|
+
fromRowId: string;
|
|
58
|
+
toRowId: string;
|
|
59
|
+
}>;
|
|
60
|
+
}): Promise<any>;
|
|
61
|
+
deleteLinks(args: {
|
|
62
|
+
table: string;
|
|
63
|
+
linkColumn: string;
|
|
64
|
+
pairs: Array<{
|
|
65
|
+
fromRowId: string;
|
|
66
|
+
toRowId: string;
|
|
67
|
+
}>;
|
|
68
|
+
}): Promise<any>;
|
|
69
|
+
addColumnOptions(args: {
|
|
70
|
+
table: string;
|
|
71
|
+
column: string;
|
|
72
|
+
options: Array<{
|
|
73
|
+
name: string;
|
|
74
|
+
color?: string;
|
|
75
|
+
textColor?: string;
|
|
76
|
+
}>;
|
|
77
|
+
}): Promise<any>;
|
|
78
|
+
uploadFile(args: {
|
|
79
|
+
table: string;
|
|
80
|
+
column: string;
|
|
81
|
+
rowId: string;
|
|
82
|
+
fileName: string;
|
|
83
|
+
fileData: string;
|
|
84
|
+
replace?: boolean;
|
|
85
|
+
}): Promise<{
|
|
86
|
+
file_name: string;
|
|
87
|
+
file_size: number;
|
|
88
|
+
asset_url: string;
|
|
89
|
+
column_type: string;
|
|
90
|
+
}>;
|
|
91
|
+
}
|
|
92
|
+
//# sourceMappingURL=contextualClient.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contextualClient.d.ts","sourceRoot":"","sources":["../../src/seatable/contextualClient.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAA;AACvD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAA;AAEzD;;;;;GAKG;AACH,qBAAa,gBAAiB,YAAW,UAAU;IAC/C,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAgB;IACzC,OAAO,CAAC,WAAW,CAAC,CAAQ;gBAEhB,QAAQ,EAAE,cAAc;IAIpC,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI;IAI5B,OAAO,KAAK,MAAM,GAEjB;IAGD,UAAU;;;;IAGV,WAAW;IAGX,QAAQ,CAAC,KAAK,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,SAAS,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAA;KAAE;;;;;;;IACnF,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM;IACnC,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAClD,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IACpE,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM;;;IACtC,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;;;;;;;IAGxD,QAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,GAAG,EAAE;;;;IAGxC,iBAAiB;;;;IAGjB,WAAW,CAAC,IAAI,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,KAAK,CAAC;YAAE,SAAS,EAAE,MAAM,CAAC;YAAC,OAAO,EAAE,MAAM,CAAA;SAAE,CAAC,CAAA;KAAE;IAC7G,WAAW,CAAC,IAAI,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,KAAK,CAAC;YAAE,SAAS,EAAE,MAAM,CAAC;YAAC,OAAO,EAAE,MAAM,CAAA;SAAE,CAAC,CAAA;KAAE;IAG7G,gBAAgB,CAAC,IAAI,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,KAAK,CAAC;YAAE,IAAI,EAAE,MAAM,CAAC;YAAC,KAAK,CAAC,EAAE,MAAM,CAAC;YAAC,SAAS,CAAC,EAAE,MAAM,CAAA;SAAE,CAAC,CAAA;KAAE;IAG9H,UAAU,CAAC,IAAI,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,OAAO,CAAA;KAAE;;;;;;CAC3H"}
|