@sassoftware/sas-score-mcp-serverjs 0.4.0 → 0.4.1-15
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/cli.js +112 -33
- package/package.json +5 -5
- package/skills/sas-list-tables-smart/SKILL.md +123 -0
- package/skills/sas-read-and-score/SKILL.md +54 -53
- package/skills/sas-read-strategy/SKILL.md +10 -10
- package/skills/sas-score-workflow/SKILL.md +19 -1
- package/skills/sas-spec-migration/SKILL.md +303 -0
- package/src/authpkce.js +219 -0
- package/src/createMcpServer.js +16 -6
- package/src/expressMcpServer.js +354 -338
- package/src/handleGetDelete.js +1 -1
- package/src/oauthHandlers/authorize.js +46 -0
- package/src/oauthHandlers/baseUrl.js +8 -0
- package/src/oauthHandlers/callback.js +93 -0
- package/src/oauthHandlers/getMetadata.js +27 -0
- package/src/oauthHandlers/index.js +7 -0
- package/src/oauthHandlers/token.js +37 -0
- package/src/processHeaders.js +88 -0
- package/src/toolHelpers/_listLibrary.js +0 -1
- package/src/toolHelpers/getLogonPayload.js +5 -1
- package/src/toolHelpers/readCerts.js +4 -4
- package/src/toolHelpers/refreshTokenOauth.js +3 -3
- package/src/toolSet/.claude/settings.local.json +13 -0
- package/src/toolSet/devaScore.js +61 -61
- package/src/toolSet/findJob.js +9 -16
- package/src/toolSet/findJobdef.js +4 -5
- package/src/toolSet/findLibrary.js +68 -68
- package/src/toolSet/findModel.js +4 -5
- package/src/toolSet/findTable.js +6 -6
- package/src/toolSet/getEnv.js +10 -7
- package/src/toolSet/listJobdefs.js +61 -62
- package/src/toolSet/listJobs.js +61 -62
- package/src/toolSet/listLibraries.js +78 -80
- package/src/toolSet/listModels.js +56 -56
- package/src/toolSet/listTables.js +66 -66
- package/src/toolSet/makeTools.js +1 -3
- package/src/toolSet/modelInfo.js +4 -5
- package/src/toolSet/modelScore.js +7 -7
- package/src/toolSet/readTable.js +63 -67
- package/src/toolSet/runCasProgram.js +9 -9
- package/src/toolSet/runJob.js +81 -82
- package/src/toolSet/runJobdef.js +82 -83
- package/src/toolSet/runMacro.js +82 -82
- package/src/toolSet/runProgram.js +8 -13
- package/src/toolSet/sasQuery.js +77 -79
- package/src/toolSet/sasQueryTemplate.js +4 -5
- package/src/toolSet/sasQueryTemplate2.js +4 -5
- package/src/toolSet/scrInfo.js +3 -5
- package/src/toolSet/scrScore.js +69 -70
- package/src/toolSet/searchAssets.js +5 -6
- package/src/toolSet/setContext.js +65 -66
- package/src/toolSet/superstat.js +61 -60
- package/src/toolSet/tableInfo.js +58 -59
|
@@ -1,68 +1,68 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright © 2025, SAS Institute Inc., Cary, NC, USA. All Rights Reserved.
|
|
3
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
4
|
-
*/
|
|
5
|
-
import { z } from 'zod';
|
|
6
|
-
import _listLibrary from '../toolHelpers/_listLibrary.js';
|
|
7
|
-
function findLibrary(_appContext) {
|
|
8
|
-
|
|
9
|
-
let description = `
|
|
10
|
-
find-library — locate a specific CAS or SAS library.
|
|
11
|
-
|
|
12
|
-
USE when: find library, find lib, does library exist, is library available, lookup library
|
|
13
|
-
DO NOT USE for: list libraries (use list-libraries), find table/job/jobdef/model (use respective tools), table structure (use table-info), create library (use run-sas-program)
|
|
14
|
-
|
|
15
|
-
PARAMETERS
|
|
16
|
-
- name: string (required) — library/caslib name; if multiple supplied, use first
|
|
17
|
-
- server: 'cas' | 'sas' (default: 'cas') — target environment
|
|
18
|
-
|
|
19
|
-
ROUTING RULES
|
|
20
|
-
- "find lib <name>" → { name: "<name>", server: "cas" }
|
|
21
|
-
- "find lib <name> in cas" → { name: "<name>", server: "cas" }
|
|
22
|
-
- "find library <name> in sas" → { name: "<name>", server: "sas" }
|
|
23
|
-
- "does library <name> exist" → { name: "<name>", server: "cas" }
|
|
24
|
-
- "find lib" with no name → ask "Which library name would you like to find?"
|
|
25
|
-
- "list libraries / list libs" → use list-libraries instead
|
|
26
|
-
- "tables in <lib>" → use list-tables instead
|
|
27
|
-
|
|
28
|
-
EXAMPLES
|
|
29
|
-
- "find lib Public" → { name: "Public", server: "cas" }
|
|
30
|
-
- "find library sasuser in sas" → { name: "sasuser", server: "sas" }
|
|
31
|
-
- "does library Formats exist" → { name: "Formats", server: "cas" }
|
|
32
|
-
|
|
33
|
-
NEGATIVE EXAMPLES (do not route here)
|
|
34
|
-
- "list libs" (use list-libraries)
|
|
35
|
-
- "show tables in Public" (use list-tables)
|
|
36
|
-
- "find table cars in sashelp" (use find-table)
|
|
37
|
-
- "find job cars_job" (use find-job)
|
|
38
|
-
|
|
39
|
-
ERRORS
|
|
40
|
-
Returns { libraries: [] } if not found; { libraries: [name, ...] } if found. Never hallucinate library names.
|
|
41
|
-
`;
|
|
42
|
-
|
|
43
|
-
let spec = {
|
|
44
|
-
name: 'find-library',
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
1
|
+
/*
|
|
2
|
+
* Copyright © 2025, SAS Institute Inc., Cary, NC, USA. All Rights Reserved.
|
|
3
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
*/
|
|
5
|
+
import { z } from 'zod';
|
|
6
|
+
import _listLibrary from '../toolHelpers/_listLibrary.js';
|
|
7
|
+
function findLibrary(_appContext) {
|
|
8
|
+
|
|
9
|
+
let description = `
|
|
10
|
+
find-library — locate a specific CAS or SAS library.
|
|
11
|
+
|
|
12
|
+
USE when: find library, find lib, does library exist, is library available, lookup library
|
|
13
|
+
DO NOT USE for: list libraries (use list-libraries), find table/job/jobdef/model (use respective tools), table structure (use table-info), create library (use run-sas-program)
|
|
14
|
+
|
|
15
|
+
PARAMETERS
|
|
16
|
+
- name: string (required) — library/caslib name; if multiple supplied, use first
|
|
17
|
+
- server: 'cas' | 'sas' (default: 'cas') — target environment
|
|
18
|
+
|
|
19
|
+
ROUTING RULES
|
|
20
|
+
- "find lib <name>" → { name: "<name>", server: "cas" }
|
|
21
|
+
- "find lib <name> in cas" → { name: "<name>", server: "cas" }
|
|
22
|
+
- "find library <name> in sas" → { name: "<name>", server: "sas" }
|
|
23
|
+
- "does library <name> exist" → { name: "<name>", server: "cas" }
|
|
24
|
+
- "find lib" with no name → ask "Which library name would you like to find?"
|
|
25
|
+
- "list libraries / list libs" → use list-libraries instead
|
|
26
|
+
- "tables in <lib>" → use list-tables instead
|
|
27
|
+
|
|
28
|
+
EXAMPLES
|
|
29
|
+
- "find lib Public" → { name: "Public", server: "cas" }
|
|
30
|
+
- "find library sasuser in sas" → { name: "sasuser", server: "sas" }
|
|
31
|
+
- "does library Formats exist" → { name: "Formats", server: "cas" }
|
|
32
|
+
|
|
33
|
+
NEGATIVE EXAMPLES (do not route here)
|
|
34
|
+
- "list libs" (use list-libraries)
|
|
35
|
+
- "show tables in Public" (use list-tables)
|
|
36
|
+
- "find table cars in sashelp" (use find-table)
|
|
37
|
+
- "find job cars_job" (use find-job)
|
|
38
|
+
|
|
39
|
+
ERRORS
|
|
40
|
+
Returns { libraries: [] } if not found; { libraries: [name, ...] } if found. Never hallucinate library names.
|
|
41
|
+
`;
|
|
42
|
+
|
|
43
|
+
let spec = {
|
|
44
|
+
name: 'find-library',
|
|
45
|
+
description: description,
|
|
46
|
+
inputSchema: z.object({
|
|
47
|
+
name: z.string(),
|
|
48
|
+
server: z.string().optional()
|
|
49
|
+
}),
|
|
50
|
+
|
|
51
|
+
handler: async (params) => {
|
|
52
|
+
// normalize server to lowercase & default
|
|
53
|
+
if (!params.server) params.server = 'cas';
|
|
54
|
+
params.server = params.server.toLowerCase();
|
|
55
|
+
|
|
56
|
+
// If multiple names passed (comma or space separated), take the first token (defensive)
|
|
57
|
+
if (params.name && /[,\s]+/.test(params.name.trim())) {
|
|
58
|
+
params.name = params.name.split(/[,\s]+/).filter(Boolean)[0];
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
let r = await _listLibrary(params);
|
|
62
|
+
return r;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
return spec;
|
|
66
|
+
}
|
|
67
|
+
export default findLibrary;
|
|
68
|
+
|
package/src/toolSet/findModel.js
CHANGED
|
@@ -44,12 +44,10 @@ Returns { models: [] } if not found; { models: [name, ...] } if found. Never hal
|
|
|
44
44
|
|
|
45
45
|
let spec = {
|
|
46
46
|
name: 'find-model',
|
|
47
|
-
aliases: ['findModel','find model','find_model'],
|
|
48
47
|
description: description,
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
},
|
|
52
|
-
required: ['name'],
|
|
48
|
+
inputSchema: z.object({
|
|
49
|
+
name: z.string()
|
|
50
|
+
}),
|
|
53
51
|
handler: async (params) => {
|
|
54
52
|
let r = await _listModels(params);
|
|
55
53
|
return r;
|
|
@@ -59,3 +57,4 @@ Returns { models: [] } if not found; { models: [name, ...] } if found. Never hal
|
|
|
59
57
|
}
|
|
60
58
|
|
|
61
59
|
export default findModel;
|
|
60
|
+
|
package/src/toolSet/findTable.js
CHANGED
|
@@ -45,14 +45,13 @@ Returns { tables: [] } if not found; { tables: [name, ...] } if found. Never hal
|
|
|
45
45
|
|
|
46
46
|
let spec = {
|
|
47
47
|
name: 'find-table',
|
|
48
|
-
aliases: ['findTable','find table','find_table'],
|
|
49
48
|
description: description,
|
|
50
|
-
|
|
51
|
-
server: z.string().default('cas'), // default server is 'cas',
|
|
49
|
+
inputSchema: z.object({
|
|
52
50
|
name: z.string(),
|
|
53
|
-
lib: z.string()
|
|
54
|
-
|
|
55
|
-
|
|
51
|
+
lib: z.string(),
|
|
52
|
+
server: z.string().optional() // default server is 'cas'
|
|
53
|
+
}),
|
|
54
|
+
|
|
56
55
|
handler: async (params) => {
|
|
57
56
|
// Check if the params.scenario is a string and parse it
|
|
58
57
|
let r = await _listTables(params);
|
|
@@ -63,3 +62,4 @@ Returns { tables: [] } if not found; { tables: [name, ...] } if found. Never hal
|
|
|
63
62
|
}
|
|
64
63
|
|
|
65
64
|
export default findTable;
|
|
65
|
+
|
package/src/toolSet/getEnv.js
CHANGED
|
@@ -38,17 +38,20 @@ Returns variable name with current value, or null if not found. Return structure
|
|
|
38
38
|
`;
|
|
39
39
|
|
|
40
40
|
let spec = {
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
41
|
+
name: 'get-env',
|
|
42
|
+
description: description,
|
|
43
|
+
inputSchema: {
|
|
44
|
+
type: 'object',
|
|
45
|
+
properties: {
|
|
46
|
+
name: { type: 'string' }
|
|
47
|
+
},
|
|
48
|
+
required: ['name']
|
|
46
49
|
},
|
|
47
|
-
|
|
48
|
-
handler: async (params) => {
|
|
50
|
+
handler: async (params) => {
|
|
49
51
|
return await _getEnv(params);
|
|
50
52
|
}
|
|
51
53
|
}
|
|
52
54
|
return spec;
|
|
53
55
|
}
|
|
54
56
|
export default getEnv;
|
|
57
|
+
|
|
@@ -1,62 +1,61 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright © 2025, SAS Institute Inc., Cary, NC, USA. All Rights Reserved.
|
|
3
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
4
|
-
*/
|
|
5
|
-
import { z } from 'zod';
|
|
6
|
-
import _listJobdefs from '../toolHelpers/_listJobdefs.js';
|
|
7
|
-
function listJobdefs(_appContext) {
|
|
8
|
-
|
|
9
|
-
let description = `
|
|
10
|
-
list-jobdefs — enumerate SAS Viya job definitions (jobdefs) assets.
|
|
11
|
-
|
|
12
|
-
USE when: list jobdefs, show jobdefs, browse jobdefs, list available jobdefs, next page
|
|
13
|
-
DO NOT USE for: find single jobdef (use find-jobdef), execute jobdef (use run-jobdef), find job (use find-job), sas code (use run-sas-program)
|
|
14
|
-
|
|
15
|
-
PARAMETERS
|
|
16
|
-
- limit: number (default: 10) — number of jobdefs per page
|
|
17
|
-
- start: number (default: 1) — 1-based page offset
|
|
18
|
-
- where: string (default: '') — optional filter expression
|
|
19
|
-
|
|
20
|
-
ROUTING RULES
|
|
21
|
-
- list jobdefs → { start: 1, limit: 10 }
|
|
22
|
-
- show me 25 jobdefs → { start: 1, limit: 25 }
|
|
23
|
-
- next jobdefs → { start: previousStart + previousLimit, limit: previousLimit }
|
|
24
|
-
|
|
25
|
-
EXAMPLES
|
|
26
|
-
- list jobdefs → { start: 1, limit: 10 }
|
|
27
|
-
- list 25 jobdefs → { start: 1, limit: 25 }
|
|
28
|
-
- next jobdefs → { start: 11, limit: 10 }
|
|
29
|
-
|
|
30
|
-
NEGATIVE EXAMPLES (do not route here)
|
|
31
|
-
- find jobdef abc (use find-jobdef)
|
|
32
|
-
- list jobs (use list-jobs)
|
|
33
|
-
- run jobdef abc (use run-jobdef)
|
|
34
|
-
- list models (use list-models)
|
|
35
|
-
|
|
36
|
-
PAGINATION
|
|
37
|
-
If returned length === limit, hint: next start = start + limit. Empty result with start > 1 means paged past end.
|
|
38
|
-
|
|
39
|
-
ERRORS
|
|
40
|
-
Surface backend error directly; never fabricate jobdef names.
|
|
41
|
-
`;
|
|
42
|
-
|
|
43
|
-
let spec = {
|
|
44
|
-
name: 'list-jobdefs',
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
export default listJobdefs;
|
|
1
|
+
/*
|
|
2
|
+
* Copyright © 2025, SAS Institute Inc., Cary, NC, USA. All Rights Reserved.
|
|
3
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
*/
|
|
5
|
+
import { z } from 'zod';
|
|
6
|
+
import _listJobdefs from '../toolHelpers/_listJobdefs.js';
|
|
7
|
+
function listJobdefs(_appContext) {
|
|
8
|
+
|
|
9
|
+
let description = `
|
|
10
|
+
list-jobdefs — enumerate SAS Viya job definitions (jobdefs) assets.
|
|
11
|
+
|
|
12
|
+
USE when: list jobdefs, show jobdefs, browse jobdefs, list available jobdefs, next page
|
|
13
|
+
DO NOT USE for: find single jobdef (use find-jobdef), execute jobdef (use run-jobdef), find job (use find-job), sas code (use run-sas-program)
|
|
14
|
+
|
|
15
|
+
PARAMETERS
|
|
16
|
+
- limit: number (default: 10) — number of jobdefs per page
|
|
17
|
+
- start: number (default: 1) — 1-based page offset
|
|
18
|
+
- where: string (default: '') — optional filter expression
|
|
19
|
+
|
|
20
|
+
ROUTING RULES
|
|
21
|
+
- list jobdefs → { start: 1, limit: 10 }
|
|
22
|
+
- show me 25 jobdefs → { start: 1, limit: 25 }
|
|
23
|
+
- next jobdefs → { start: previousStart + previousLimit, limit: previousLimit }
|
|
24
|
+
|
|
25
|
+
EXAMPLES
|
|
26
|
+
- list jobdefs → { start: 1, limit: 10 }
|
|
27
|
+
- list 25 jobdefs → { start: 1, limit: 25 }
|
|
28
|
+
- next jobdefs → { start: 11, limit: 10 }
|
|
29
|
+
|
|
30
|
+
NEGATIVE EXAMPLES (do not route here)
|
|
31
|
+
- find jobdef abc (use find-jobdef)
|
|
32
|
+
- list jobs (use list-jobs)
|
|
33
|
+
- run jobdef abc (use run-jobdef)
|
|
34
|
+
- list models (use list-models)
|
|
35
|
+
|
|
36
|
+
PAGINATION
|
|
37
|
+
If returned length === limit, hint: next start = start + limit. Empty result with start > 1 means paged past end.
|
|
38
|
+
|
|
39
|
+
ERRORS
|
|
40
|
+
Surface backend error directly; never fabricate jobdef names.
|
|
41
|
+
`;
|
|
42
|
+
|
|
43
|
+
let spec = {
|
|
44
|
+
name: 'list-jobdefs',
|
|
45
|
+
description: description,
|
|
46
|
+
inputSchema: z.object({
|
|
47
|
+
limit: z.number().optional(),
|
|
48
|
+
start: z.number().optional(),
|
|
49
|
+
where: z.string().optional()
|
|
50
|
+
}),
|
|
51
|
+
// No 'server' required; backend context is implicit in helper
|
|
52
|
+
handler: async (params) => {
|
|
53
|
+
// _listJobdefs handles all validation and defaults
|
|
54
|
+
const result = await _listJobdefs(params);
|
|
55
|
+
return result;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
return spec;
|
|
59
|
+
}
|
|
60
|
+
export default listJobdefs;
|
|
61
|
+
|
package/src/toolSet/listJobs.js
CHANGED
|
@@ -1,62 +1,61 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright © 2025, SAS Institute Inc., Cary, NC, USA. All Rights Reserved.
|
|
3
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
4
|
-
*/
|
|
5
|
-
import { z } from 'zod';
|
|
6
|
-
import _listJobs from '../toolHelpers/_listJobs.js';
|
|
7
|
-
function listJobs(_appContext) {
|
|
8
|
-
|
|
9
|
-
let description = `
|
|
10
|
-
list-jobs — enumerate SAS Viya job assets.
|
|
11
|
-
|
|
12
|
-
USE when: list jobs, show jobs, browse jobs, list available jobs, next page
|
|
13
|
-
DO NOT USE for: find single job (use find-job), execute job (use run-job), run job def (use run-jobdef), sas code (use run-sas-program)
|
|
14
|
-
|
|
15
|
-
PARAMETERS
|
|
16
|
-
- limit: number (default: 10) — number of jobs per page
|
|
17
|
-
- start: number (default: 1) — 1-based page offset
|
|
18
|
-
- where: string (default: '') — optional filter expression
|
|
19
|
-
|
|
20
|
-
ROUTING RULES
|
|
21
|
-
- list jobs → { start: 1, limit: 10 }
|
|
22
|
-
- show me 25 jobs → { start: 1, limit: 25 }
|
|
23
|
-
- next jobs → { start: previousStart + previousLimit, limit: previousLimit }
|
|
24
|
-
|
|
25
|
-
EXAMPLES
|
|
26
|
-
- list jobs → { start: 1, limit: 10 }
|
|
27
|
-
- list 25 jobs → { start: 1, limit: 25 }
|
|
28
|
-
- next jobs → { start: 11, limit: 10 }
|
|
29
|
-
|
|
30
|
-
NEGATIVE EXAMPLES (do not route here)
|
|
31
|
-
- find job abc (use find-job)
|
|
32
|
-
- run job abc (use run-job)
|
|
33
|
-
- list models (use list-models)
|
|
34
|
-
- list tables in lib xyz (use list-tables)
|
|
35
|
-
|
|
36
|
-
PAGINATION
|
|
37
|
-
If returned length === limit, hint: next start = start + limit. Empty result with start > 1 means paged past end.
|
|
38
|
-
|
|
39
|
-
ERRORS
|
|
40
|
-
Surface backend error directly; never fabricate job names.
|
|
41
|
-
`;
|
|
42
|
-
|
|
43
|
-
let spec = {
|
|
44
|
-
name: 'list-jobs',
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
export default listJobs;
|
|
1
|
+
/*
|
|
2
|
+
* Copyright © 2025, SAS Institute Inc., Cary, NC, USA. All Rights Reserved.
|
|
3
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
*/
|
|
5
|
+
import { z } from 'zod';
|
|
6
|
+
import _listJobs from '../toolHelpers/_listJobs.js';
|
|
7
|
+
function listJobs(_appContext) {
|
|
8
|
+
|
|
9
|
+
let description = `
|
|
10
|
+
list-jobs — enumerate SAS Viya job assets.
|
|
11
|
+
|
|
12
|
+
USE when: list jobs, show jobs, browse jobs, list available jobs, next page
|
|
13
|
+
DO NOT USE for: find single job (use find-job), execute job (use run-job), run job def (use run-jobdef), sas code (use run-sas-program)
|
|
14
|
+
|
|
15
|
+
PARAMETERS
|
|
16
|
+
- limit: number (default: 10) — number of jobs per page
|
|
17
|
+
- start: number (default: 1) — 1-based page offset
|
|
18
|
+
- where: string (default: '') — optional filter expression
|
|
19
|
+
|
|
20
|
+
ROUTING RULES
|
|
21
|
+
- list jobs → { start: 1, limit: 10 }
|
|
22
|
+
- show me 25 jobs → { start: 1, limit: 25 }
|
|
23
|
+
- next jobs → { start: previousStart + previousLimit, limit: previousLimit }
|
|
24
|
+
|
|
25
|
+
EXAMPLES
|
|
26
|
+
- list jobs → { start: 1, limit: 10 }
|
|
27
|
+
- list 25 jobs → { start: 1, limit: 25 }
|
|
28
|
+
- next jobs → { start: 11, limit: 10 }
|
|
29
|
+
|
|
30
|
+
NEGATIVE EXAMPLES (do not route here)
|
|
31
|
+
- find job abc (use find-job)
|
|
32
|
+
- run job abc (use run-job)
|
|
33
|
+
- list models (use list-models)
|
|
34
|
+
- list tables in lib xyz (use list-tables)
|
|
35
|
+
|
|
36
|
+
PAGINATION
|
|
37
|
+
If returned length === limit, hint: next start = start + limit. Empty result with start > 1 means paged past end.
|
|
38
|
+
|
|
39
|
+
ERRORS
|
|
40
|
+
Surface backend error directly; never fabricate job names.
|
|
41
|
+
`;
|
|
42
|
+
|
|
43
|
+
let spec = {
|
|
44
|
+
name: 'list-jobs',
|
|
45
|
+
description: description,
|
|
46
|
+
inputSchema: z.object({
|
|
47
|
+
limit: z.number().optional(),
|
|
48
|
+
start: z.number().optional(),
|
|
49
|
+
where: z.string().optional()
|
|
50
|
+
}),
|
|
51
|
+
// No 'server' required; backend context is implicit in helper
|
|
52
|
+
handler: async (params) => {
|
|
53
|
+
// _listJob handles all validation and defaults
|
|
54
|
+
const result = await _listJobs(params);
|
|
55
|
+
return result;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
return spec;
|
|
59
|
+
}
|
|
60
|
+
export default listJobs;
|
|
61
|
+
|
|
@@ -1,80 +1,78 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright © 2025, SAS Institute Inc., Cary, NC, USA. All Rights Reserved.
|
|
3
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
4
|
-
*/
|
|
5
|
-
import { z } from 'zod';
|
|
6
|
-
import _listLibrary from '../toolHelpers/_listLibrary.js';
|
|
7
|
-
function listLibraries(_appContext) {
|
|
8
|
-
let description = `
|
|
9
|
-
list-libraries — enumerate CAS or SAS libraries.
|
|
10
|
-
|
|
11
|
-
USE when user asks to: list/show/enumerate libraries, caslibs, sas libs, or available libraries.
|
|
12
|
-
DO NOT USE for: listing tables in a library (→ list-tables), column/table metadata, job execution, models, scoring.
|
|
13
|
-
|
|
14
|
-
PARAMETERS
|
|
15
|
-
- server: 'cas' | 'sas' | 'all' (default: 'all')
|
|
16
|
-
- limit: integer > 0 (default: 10)
|
|
17
|
-
- start: 1-based offset (default: 1)
|
|
18
|
-
- where: optional filter expression (default: '')
|
|
19
|
-
|
|
20
|
-
ROUTING RULES
|
|
21
|
-
- "cas libs / cas libraries / in cas" → { server: 'cas' }
|
|
22
|
-
- "sas libs / sas libraries / in sas" → { server: 'sas' }
|
|
23
|
-
- "all libs / all libraries" → { server: 'all' }
|
|
24
|
-
- "list tables in <libname>" → route to list-tables, NOT here
|
|
25
|
-
- server unspecified → default { server: 'all' }
|
|
26
|
-
- "all cas libs" with no limit specified → { server: 'cas', limit: 50 } + paging note
|
|
27
|
-
- "next" after prior call (start:S, limit:L) → { start: S + L, limit: L }
|
|
28
|
-
- ambiguous "list" or "libs" with no context → assume { server: 'cas' }
|
|
29
|
-
|
|
30
|
-
EXAMPLES
|
|
31
|
-
- "list libraries" → { server: 'all', start: 1, limit: 10 }
|
|
32
|
-
- "list libs " → { server: 'all', start: 1, limit: 10 }
|
|
33
|
-
|
|
34
|
-
- "list all libs" → { server: 'all', start: 1, limit: 10 }
|
|
35
|
-
- "list cas libraries" → { server: 'cas', start: 1, limit: 10 }
|
|
36
|
-
- "show me 25 sas libs" → { server: 'sas', limit: 25, start: 1 }
|
|
37
|
-
- "next" (prev: start:1,limit:10) → { server: <same>, start: 11, limit: 10 }
|
|
38
|
-
- "filter cas libs" (no filter given) → ask: "What filter expression should I apply?"
|
|
39
|
-
|
|
40
|
-
NEGATIVE EXAMPLES (do not route here)
|
|
41
|
-
- "list tables in SASHELP" → list-tables
|
|
42
|
-
- "list models / jobs / jobdefs"→ respective tools
|
|
43
|
-
- "run a program to create a lib" → run-sas-program
|
|
44
|
-
|
|
45
|
-
PAGINATION
|
|
46
|
-
If returned item count === limit, hint: next start = start + limit.
|
|
47
|
-
If start > 1 and result is empty, note paging may have exceeded available items.
|
|
48
|
-
|
|
49
|
-
ERRORS
|
|
50
|
-
Return structured error with a message field. Never hallucinate library names.
|
|
51
|
-
`;
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
// Canonical kebab-case tool name; legacy aliases preserved for compatibility
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
let spec = {
|
|
58
|
-
name: 'list-libraries',
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
export default listLibraries;
|
|
80
|
-
|
|
1
|
+
/*
|
|
2
|
+
* Copyright © 2025, SAS Institute Inc., Cary, NC, USA. All Rights Reserved.
|
|
3
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
*/
|
|
5
|
+
import { z } from 'zod';
|
|
6
|
+
import _listLibrary from '../toolHelpers/_listLibrary.js';
|
|
7
|
+
function listLibraries(_appContext) {
|
|
8
|
+
let description = `
|
|
9
|
+
list-libraries — enumerate CAS or SAS libraries.
|
|
10
|
+
|
|
11
|
+
USE when user asks to: list/show/enumerate libraries, caslibs, sas libs, or available libraries.
|
|
12
|
+
DO NOT USE for: listing tables in a library (→ list-tables), column/table metadata, job execution, models, scoring.
|
|
13
|
+
|
|
14
|
+
PARAMETERS
|
|
15
|
+
- server: 'cas' | 'sas' | 'all' (default: 'all')
|
|
16
|
+
- limit: integer > 0 (default: 10)
|
|
17
|
+
- start: 1-based offset (default: 1)
|
|
18
|
+
- where: optional filter expression (default: '')
|
|
19
|
+
|
|
20
|
+
ROUTING RULES
|
|
21
|
+
- "cas libs / cas libraries / in cas" → { server: 'cas' }
|
|
22
|
+
- "sas libs / sas libraries / in sas" → { server: 'sas' }
|
|
23
|
+
- "all libs / all libraries" → { server: 'all' }
|
|
24
|
+
- "list tables in <libname>" → route to list-tables, NOT here
|
|
25
|
+
- server unspecified → default { server: 'all' }
|
|
26
|
+
- "all cas libs" with no limit specified → { server: 'cas', limit: 50 } + paging note
|
|
27
|
+
- "next" after prior call (start:S, limit:L) → { start: S + L, limit: L }
|
|
28
|
+
- ambiguous "list" or "libs" with no context → assume { server: 'cas' }
|
|
29
|
+
|
|
30
|
+
EXAMPLES
|
|
31
|
+
- "list libraries" → { server: 'all', start: 1, limit: 10 }
|
|
32
|
+
- "list libs " → { server: 'all', start: 1, limit: 10 }
|
|
33
|
+
|
|
34
|
+
- "list all libs" → { server: 'all', start: 1, limit: 10 }
|
|
35
|
+
- "list cas libraries" → { server: 'cas', start: 1, limit: 10 }
|
|
36
|
+
- "show me 25 sas libs" → { server: 'sas', limit: 25, start: 1 }
|
|
37
|
+
- "next" (prev: start:1,limit:10) → { server: <same>, start: 11, limit: 10 }
|
|
38
|
+
- "filter cas libs" (no filter given) → ask: "What filter expression should I apply?"
|
|
39
|
+
|
|
40
|
+
NEGATIVE EXAMPLES (do not route here)
|
|
41
|
+
- "list tables in SASHELP" → list-tables
|
|
42
|
+
- "list models / jobs / jobdefs"→ respective tools
|
|
43
|
+
- "run a program to create a lib" → run-sas-program
|
|
44
|
+
|
|
45
|
+
PAGINATION
|
|
46
|
+
If returned item count === limit, hint: next start = start + limit.
|
|
47
|
+
If start > 1 and result is empty, note paging may have exceeded available items.
|
|
48
|
+
|
|
49
|
+
ERRORS
|
|
50
|
+
Return structured error with a message field. Never hallucinate library names.
|
|
51
|
+
`;
|
|
52
|
+
|
|
53
|
+
|
|
54
|
+
// Canonical kebab-case tool name; legacy aliases preserved for compatibility
|
|
55
|
+
|
|
56
|
+
|
|
57
|
+
let spec = {
|
|
58
|
+
name: 'list-libraries',
|
|
59
|
+
description: description,
|
|
60
|
+
inputSchema: z.object({
|
|
61
|
+
server: z.string().optional(),
|
|
62
|
+
limit: z.number().optional(),
|
|
63
|
+
start: z.number().optional(),
|
|
64
|
+
where: z.string().optional()
|
|
65
|
+
}),
|
|
66
|
+
// 'server' has a default so we don't mark it required
|
|
67
|
+
handler: async (params) => {
|
|
68
|
+
// normalize server just in case caller sends 'CAS'/'SAS'
|
|
69
|
+
params.server = (params.server || 'all').toLowerCase();
|
|
70
|
+
|
|
71
|
+
let r = await _listLibrary(params);
|
|
72
|
+
return r;
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
return spec;
|
|
76
|
+
}
|
|
77
|
+
export default listLibraries;
|
|
78
|
+
|