@credal/actions 0.1.21 → 0.1.23

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.
Files changed (28) hide show
  1. package/dist/actions/actionMapper.js +11 -5
  2. package/dist/actions/autogen/templates.d.ts +2 -1
  3. package/dist/actions/autogen/templates.js +39 -13
  4. package/dist/actions/autogen/types.d.ts +30 -13
  5. package/dist/actions/autogen/types.js +12 -6
  6. package/dist/actions/groups.js +3 -3
  7. package/dist/actions/providers/confluence/fetchPageContent.d.ts +3 -0
  8. package/dist/actions/providers/confluence/fetchPageContent.js +41 -0
  9. package/dist/actions/providers/confluence/overwritePage.d.ts +3 -0
  10. package/dist/actions/providers/confluence/overwritePage.js +46 -0
  11. package/dist/actions/providers/confluence/updatePage.js +5 -2
  12. package/dist/actions/providers/googlemaps/nearbysearch.js +31 -31
  13. package/dist/actions/providers/x/scrapeTweetDataWithNitter.d.ts +3 -0
  14. package/dist/actions/providers/x/scrapeTweetDataWithNitter.js +45 -0
  15. package/dist/actions/providers/zendesk/createZendeskTicket.js +15 -18
  16. package/package.json +1 -1
  17. package/dist/actions/autogen/definitions.d.ts +0 -5
  18. package/dist/actions/autogen/definitions.js +0 -132
  19. package/dist/actions/definitions.js +0 -35
  20. package/dist/actions/invokeMapper.d.ts +0 -9
  21. package/dist/actions/invokeMapper.js +0 -33
  22. package/dist/actions/providers/jira/createTicket.d.ts +0 -3
  23. package/dist/actions/providers/jira/createTicket.js +0 -34
  24. package/dist/actions/providers/slack/list_conversations.d.ts +0 -3
  25. package/dist/actions/providers/slack/list_conversations.js +0 -60
  26. package/dist/actions/schema.js +0 -6
  27. package/dist/actions/types.js +0 -2
  28. package/dist/main.js +0 -11
@@ -5,7 +5,6 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.ActionMapper = void 0;
7
7
  const types_1 = require("./autogen/types");
8
- const updatePage_1 = __importDefault(require("./providers/confluence/updatePage"));
9
8
  const callCopilot_1 = __importDefault(require("./providers/credal/callCopilot"));
10
9
  const validateAddress_1 = __importDefault(require("./providers/googlemaps/validateAddress"));
11
10
  const add_1 = __importDefault(require("./providers/math/add"));
@@ -26,6 +25,8 @@ const createXSharePostUrl_1 = __importDefault(require("./providers/x/createXShar
26
25
  const scrapeTweetDataWithNitter_1 = __importDefault(require("./providers/firecrawl/scrapeTweetDataWithNitter"));
27
26
  const symbolLookup_1 = __importDefault(require("./providers/finnhub/symbolLookup"));
28
27
  const getBasicFinancials_1 = __importDefault(require("./providers/finnhub/getBasicFinancials"));
28
+ const overwritePage_1 = __importDefault(require("./providers/confluence/overwritePage"));
29
+ const fetchPageContent_1 = __importDefault(require("./providers/confluence/fetchPageContent"));
29
30
  exports.ActionMapper = {
30
31
  math: {
31
32
  add: {
@@ -47,10 +48,15 @@ exports.ActionMapper = {
47
48
  },
48
49
  },
49
50
  confluence: {
50
- updatePage: {
51
- fn: updatePage_1.default,
52
- paramsSchema: types_1.confluenceUpdatePageParamsSchema,
53
- outputSchema: types_1.confluenceUpdatePageOutputSchema,
51
+ overwritePage: {
52
+ fn: overwritePage_1.default,
53
+ paramsSchema: types_1.confluenceOverwritePageParamsSchema,
54
+ outputSchema: types_1.confluenceOverwritePageOutputSchema,
55
+ },
56
+ fetchPageContent: {
57
+ fn: fetchPageContent_1.default,
58
+ paramsSchema: types_1.confluenceFetchPageContentParamsSchema,
59
+ outputSchema: types_1.confluenceFetchPageContentOutputSchema,
54
60
  },
55
61
  },
56
62
  googlemaps: {
@@ -2,7 +2,8 @@ import { ActionTemplate } from "../../actions/parse";
2
2
  export declare const slackSendMessageDefinition: ActionTemplate;
3
3
  export declare const slackListConversationsDefinition: ActionTemplate;
4
4
  export declare const mathAddDefinition: ActionTemplate;
5
- export declare const confluenceUpdatePageDefinition: ActionTemplate;
5
+ export declare const confluenceOverwritePageDefinition: ActionTemplate;
6
+ export declare const confluenceFetchPageContentDefinition: ActionTemplate;
6
7
  export declare const jiraCreateJiraTicketDefinition: ActionTemplate;
7
8
  export declare const googlemapsValidateAddressDefinition: ActionTemplate;
8
9
  export declare const googlemapsNearbysearchRestaurantsDefinition: ActionTemplate;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.finnhubGetBasicFinancialsDefinition = exports.finnhubSymbolLookupDefinition = exports.googleOauthCreateNewGoogleDocDefinition = exports.resendSendEmailDefinition = exports.firecrawlScrapeTweetDataWithNitterDefinition = exports.firecrawlScrapeUrlDefinition = exports.nwsGetForecastForLocationDefinition = exports.openstreetmapGetLatitudeLongitudeFromLocationDefinition = exports.snowflakeGetRowByFieldValueDefinition = exports.mongoInsertMongoDocDefinition = exports.xCreateShareXPostUrlDefinition = exports.linkedinCreateShareLinkedinPostUrlDefinition = exports.zendeskCreateZendeskTicketDefinition = exports.credalCallCopilotDefinition = exports.googlemapsNearbysearchRestaurantsDefinition = exports.googlemapsValidateAddressDefinition = exports.jiraCreateJiraTicketDefinition = exports.confluenceUpdatePageDefinition = exports.mathAddDefinition = exports.slackListConversationsDefinition = exports.slackSendMessageDefinition = void 0;
3
+ exports.finnhubGetBasicFinancialsDefinition = exports.finnhubSymbolLookupDefinition = exports.googleOauthCreateNewGoogleDocDefinition = exports.resendSendEmailDefinition = exports.firecrawlScrapeTweetDataWithNitterDefinition = exports.firecrawlScrapeUrlDefinition = exports.nwsGetForecastForLocationDefinition = exports.openstreetmapGetLatitudeLongitudeFromLocationDefinition = exports.snowflakeGetRowByFieldValueDefinition = exports.mongoInsertMongoDocDefinition = exports.xCreateShareXPostUrlDefinition = exports.linkedinCreateShareLinkedinPostUrlDefinition = exports.zendeskCreateZendeskTicketDefinition = exports.credalCallCopilotDefinition = exports.googlemapsNearbysearchRestaurantsDefinition = exports.googlemapsValidateAddressDefinition = exports.jiraCreateJiraTicketDefinition = exports.confluenceFetchPageContentDefinition = exports.confluenceOverwritePageDefinition = exports.mathAddDefinition = exports.slackListConversationsDefinition = exports.slackSendMessageDefinition = void 0;
4
4
  exports.slackSendMessageDefinition = {
5
5
  description: "Sends a message to a Slack channel",
6
6
  scopes: ["chat:write"],
@@ -90,32 +90,62 @@ exports.mathAddDefinition = {
90
90
  name: "add",
91
91
  provider: "math",
92
92
  };
93
- exports.confluenceUpdatePageDefinition = {
93
+ exports.confluenceOverwritePageDefinition = {
94
94
  description: "Updates a Confluence page with the new content specified",
95
95
  scopes: [],
96
96
  parameters: {
97
97
  type: "object",
98
- required: ["pageId", "title", "username", "content"],
98
+ required: ["pageId", "title", "content"],
99
99
  properties: {
100
100
  pageId: {
101
101
  type: "string",
102
- description: "The page id that should be updated",
102
+ description: "The page id for the page to add content to",
103
103
  },
104
104
  title: {
105
105
  type: "string",
106
106
  description: "The title of the page that should be updated",
107
107
  },
108
- username: {
108
+ content: {
109
+ type: "string",
110
+ description: "The new content for the page",
111
+ },
112
+ },
113
+ },
114
+ name: "overwritePage",
115
+ provider: "confluence",
116
+ };
117
+ exports.confluenceFetchPageContentDefinition = {
118
+ description: "Fetches content from a Confluence page",
119
+ scopes: [],
120
+ parameters: {
121
+ type: "object",
122
+ required: ["pageId"],
123
+ properties: {
124
+ pageId: {
109
125
  type: "string",
110
- description: "The username of the person updating the page",
126
+ description: "The ID of the page to fetch content from",
127
+ },
128
+ },
129
+ },
130
+ output: {
131
+ type: "object",
132
+ required: ["pageId", "title", "content"],
133
+ properties: {
134
+ pageId: {
135
+ type: "string",
136
+ description: "The ID of the page",
137
+ },
138
+ title: {
139
+ type: "string",
140
+ description: "The title of the page",
111
141
  },
112
142
  content: {
113
143
  type: "string",
114
- description: "The new content for the page",
144
+ description: "The content of the page in storage format (HTML)",
115
145
  },
116
146
  },
117
147
  },
118
- name: "updatePage",
148
+ name: "fetchPageContent",
119
149
  provider: "confluence",
120
150
  };
121
151
  exports.jiraCreateJiraTicketDefinition = {
@@ -518,7 +548,7 @@ exports.zendeskCreateZendeskTicketDefinition = {
518
548
  scopes: [],
519
549
  parameters: {
520
550
  type: "object",
521
- required: ["subject", "requesterEmail", "subdomain"],
551
+ required: ["subject", "subdomain"],
522
552
  properties: {
523
553
  subject: {
524
554
  type: "string",
@@ -528,10 +558,6 @@ exports.zendeskCreateZendeskTicketDefinition = {
528
558
  type: "string",
529
559
  description: "The body of the ticket",
530
560
  },
531
- requesterEmail: {
532
- type: "string",
533
- description: "The email of the requester",
534
- },
535
561
  subdomain: {
536
562
  type: "string",
537
563
  description: "The subdomain of the Zendesk account",
@@ -14,20 +14,20 @@ export declare const AuthParamsSchema: z.ZodObject<{
14
14
  emailBcc: z.ZodOptional<z.ZodString>;
15
15
  cloudId: z.ZodOptional<z.ZodString>;
16
16
  }, "strip", z.ZodTypeAny, {
17
- username?: string | undefined;
18
17
  authToken?: string | undefined;
19
18
  baseUrl?: string | undefined;
20
19
  apiKey?: string | undefined;
20
+ username?: string | undefined;
21
21
  userAgent?: string | undefined;
22
22
  emailFrom?: string | undefined;
23
23
  emailReplyTo?: string | undefined;
24
24
  emailBcc?: string | undefined;
25
25
  cloudId?: string | undefined;
26
26
  }, {
27
- username?: string | undefined;
28
27
  authToken?: string | undefined;
29
28
  baseUrl?: string | undefined;
30
29
  apiKey?: string | undefined;
30
+ username?: string | undefined;
31
31
  userAgent?: string | undefined;
32
32
  emailFrom?: string | undefined;
33
33
  emailReplyTo?: string | undefined;
@@ -105,26 +105,46 @@ export declare const mathAddOutputSchema: z.ZodObject<{
105
105
  }>;
106
106
  export type mathAddOutputType = z.infer<typeof mathAddOutputSchema>;
107
107
  export type mathAddFunction = ActionFunction<mathAddParamsType, AuthParamsType, mathAddOutputType>;
108
- export declare const confluenceUpdatePageParamsSchema: z.ZodObject<{
108
+ export declare const confluenceOverwritePageParamsSchema: z.ZodObject<{
109
+ pageId: z.ZodString;
110
+ title: z.ZodString;
111
+ content: z.ZodString;
112
+ }, "strip", z.ZodTypeAny, {
113
+ pageId: string;
114
+ title: string;
115
+ content: string;
116
+ }, {
117
+ pageId: string;
118
+ title: string;
119
+ content: string;
120
+ }>;
121
+ export type confluenceOverwritePageParamsType = z.infer<typeof confluenceOverwritePageParamsSchema>;
122
+ export declare const confluenceOverwritePageOutputSchema: z.ZodVoid;
123
+ export type confluenceOverwritePageOutputType = z.infer<typeof confluenceOverwritePageOutputSchema>;
124
+ export type confluenceOverwritePageFunction = ActionFunction<confluenceOverwritePageParamsType, AuthParamsType, confluenceOverwritePageOutputType>;
125
+ export declare const confluenceFetchPageContentParamsSchema: z.ZodObject<{
126
+ pageId: z.ZodString;
127
+ }, "strip", z.ZodTypeAny, {
128
+ pageId: string;
129
+ }, {
130
+ pageId: string;
131
+ }>;
132
+ export type confluenceFetchPageContentParamsType = z.infer<typeof confluenceFetchPageContentParamsSchema>;
133
+ export declare const confluenceFetchPageContentOutputSchema: z.ZodObject<{
109
134
  pageId: z.ZodString;
110
135
  title: z.ZodString;
111
- username: z.ZodString;
112
136
  content: z.ZodString;
113
137
  }, "strip", z.ZodTypeAny, {
114
138
  pageId: string;
115
139
  title: string;
116
- username: string;
117
140
  content: string;
118
141
  }, {
119
142
  pageId: string;
120
143
  title: string;
121
- username: string;
122
144
  content: string;
123
145
  }>;
124
- export type confluenceUpdatePageParamsType = z.infer<typeof confluenceUpdatePageParamsSchema>;
125
- export declare const confluenceUpdatePageOutputSchema: z.ZodVoid;
126
- export type confluenceUpdatePageOutputType = z.infer<typeof confluenceUpdatePageOutputSchema>;
127
- export type confluenceUpdatePageFunction = ActionFunction<confluenceUpdatePageParamsType, AuthParamsType, confluenceUpdatePageOutputType>;
146
+ export type confluenceFetchPageContentOutputType = z.infer<typeof confluenceFetchPageContentOutputSchema>;
147
+ export type confluenceFetchPageContentFunction = ActionFunction<confluenceFetchPageContentParamsType, AuthParamsType, confluenceFetchPageContentOutputType>;
128
148
  export declare const jiraCreateJiraTicketParamsSchema: z.ZodObject<{
129
149
  projectKey: z.ZodString;
130
150
  summary: z.ZodString;
@@ -571,16 +591,13 @@ export type credalCallCopilotFunction = ActionFunction<credalCallCopilotParamsTy
571
591
  export declare const zendeskCreateZendeskTicketParamsSchema: z.ZodObject<{
572
592
  subject: z.ZodString;
573
593
  body: z.ZodOptional<z.ZodString>;
574
- requesterEmail: z.ZodString;
575
594
  subdomain: z.ZodString;
576
595
  }, "strip", z.ZodTypeAny, {
577
596
  subject: string;
578
- requesterEmail: string;
579
597
  subdomain: string;
580
598
  body?: string | undefined;
581
599
  }, {
582
600
  subject: string;
583
- requesterEmail: string;
584
601
  subdomain: string;
585
602
  body?: string | undefined;
586
603
  }>;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.finnhubGetBasicFinancialsOutputSchema = exports.finnhubGetBasicFinancialsParamsSchema = exports.finnhubSymbolLookupOutputSchema = exports.finnhubSymbolLookupParamsSchema = exports.googleOauthCreateNewGoogleDocOutputSchema = exports.googleOauthCreateNewGoogleDocParamsSchema = exports.resendSendEmailOutputSchema = exports.resendSendEmailParamsSchema = exports.firecrawlScrapeTweetDataWithNitterOutputSchema = exports.firecrawlScrapeTweetDataWithNitterParamsSchema = exports.firecrawlScrapeUrlOutputSchema = exports.firecrawlScrapeUrlParamsSchema = exports.nwsGetForecastForLocationOutputSchema = exports.nwsGetForecastForLocationParamsSchema = exports.openstreetmapGetLatitudeLongitudeFromLocationOutputSchema = exports.openstreetmapGetLatitudeLongitudeFromLocationParamsSchema = exports.snowflakeGetRowByFieldValueOutputSchema = exports.snowflakeGetRowByFieldValueParamsSchema = exports.mongoInsertMongoDocOutputSchema = exports.mongoInsertMongoDocParamsSchema = exports.xCreateShareXPostUrlOutputSchema = exports.xCreateShareXPostUrlParamsSchema = exports.linkedinCreateShareLinkedinPostUrlOutputSchema = exports.linkedinCreateShareLinkedinPostUrlParamsSchema = exports.zendeskCreateZendeskTicketOutputSchema = exports.zendeskCreateZendeskTicketParamsSchema = exports.credalCallCopilotOutputSchema = exports.credalCallCopilotParamsSchema = exports.googlemapsNearbysearchRestaurantsOutputSchema = exports.googlemapsNearbysearchRestaurantsParamsSchema = exports.googlemapsValidateAddressOutputSchema = exports.googlemapsValidateAddressParamsSchema = exports.jiraCreateJiraTicketOutputSchema = exports.jiraCreateJiraTicketParamsSchema = exports.confluenceUpdatePageOutputSchema = exports.confluenceUpdatePageParamsSchema = exports.mathAddOutputSchema = exports.mathAddParamsSchema = exports.slackListConversationsOutputSchema = exports.slackListConversationsParamsSchema = exports.slackSendMessageOutputSchema = exports.slackSendMessageParamsSchema = exports.AuthParamsSchema = void 0;
3
+ exports.finnhubGetBasicFinancialsOutputSchema = exports.finnhubGetBasicFinancialsParamsSchema = exports.finnhubSymbolLookupOutputSchema = exports.finnhubSymbolLookupParamsSchema = exports.googleOauthCreateNewGoogleDocOutputSchema = exports.googleOauthCreateNewGoogleDocParamsSchema = exports.resendSendEmailOutputSchema = exports.resendSendEmailParamsSchema = exports.firecrawlScrapeTweetDataWithNitterOutputSchema = exports.firecrawlScrapeTweetDataWithNitterParamsSchema = exports.firecrawlScrapeUrlOutputSchema = exports.firecrawlScrapeUrlParamsSchema = exports.nwsGetForecastForLocationOutputSchema = exports.nwsGetForecastForLocationParamsSchema = exports.openstreetmapGetLatitudeLongitudeFromLocationOutputSchema = exports.openstreetmapGetLatitudeLongitudeFromLocationParamsSchema = exports.snowflakeGetRowByFieldValueOutputSchema = exports.snowflakeGetRowByFieldValueParamsSchema = exports.mongoInsertMongoDocOutputSchema = exports.mongoInsertMongoDocParamsSchema = exports.xCreateShareXPostUrlOutputSchema = exports.xCreateShareXPostUrlParamsSchema = exports.linkedinCreateShareLinkedinPostUrlOutputSchema = exports.linkedinCreateShareLinkedinPostUrlParamsSchema = exports.zendeskCreateZendeskTicketOutputSchema = exports.zendeskCreateZendeskTicketParamsSchema = exports.credalCallCopilotOutputSchema = exports.credalCallCopilotParamsSchema = exports.googlemapsNearbysearchRestaurantsOutputSchema = exports.googlemapsNearbysearchRestaurantsParamsSchema = exports.googlemapsValidateAddressOutputSchema = exports.googlemapsValidateAddressParamsSchema = exports.jiraCreateJiraTicketOutputSchema = exports.jiraCreateJiraTicketParamsSchema = exports.confluenceFetchPageContentOutputSchema = exports.confluenceFetchPageContentParamsSchema = exports.confluenceOverwritePageOutputSchema = exports.confluenceOverwritePageParamsSchema = exports.mathAddOutputSchema = exports.mathAddParamsSchema = exports.slackListConversationsOutputSchema = exports.slackListConversationsParamsSchema = exports.slackSendMessageOutputSchema = exports.slackSendMessageParamsSchema = exports.AuthParamsSchema = void 0;
4
4
  const zod_1 = require("zod");
5
5
  exports.AuthParamsSchema = zod_1.z.object({
6
6
  authToken: zod_1.z.string().optional(),
@@ -36,13 +36,20 @@ exports.mathAddParamsSchema = zod_1.z.object({
36
36
  b: zod_1.z.number().describe("The second number to add"),
37
37
  });
38
38
  exports.mathAddOutputSchema = zod_1.z.object({ result: zod_1.z.number().describe("The sum of the two numbers") });
39
- exports.confluenceUpdatePageParamsSchema = zod_1.z.object({
40
- pageId: zod_1.z.string().describe("The page id that should be updated"),
39
+ exports.confluenceOverwritePageParamsSchema = zod_1.z.object({
40
+ pageId: zod_1.z.string().describe("The page id for the page to add content to"),
41
41
  title: zod_1.z.string().describe("The title of the page that should be updated"),
42
- username: zod_1.z.string().describe("The username of the person updating the page"),
43
42
  content: zod_1.z.string().describe("The new content for the page"),
44
43
  });
45
- exports.confluenceUpdatePageOutputSchema = zod_1.z.void();
44
+ exports.confluenceOverwritePageOutputSchema = zod_1.z.void();
45
+ exports.confluenceFetchPageContentParamsSchema = zod_1.z.object({
46
+ pageId: zod_1.z.string().describe("The ID of the page to fetch content from"),
47
+ });
48
+ exports.confluenceFetchPageContentOutputSchema = zod_1.z.object({
49
+ pageId: zod_1.z.string().describe("The ID of the page"),
50
+ title: zod_1.z.string().describe("The title of the page"),
51
+ content: zod_1.z.string().describe("The content of the page in storage format (HTML)"),
52
+ });
46
53
  exports.jiraCreateJiraTicketParamsSchema = zod_1.z.object({
47
54
  projectKey: zod_1.z.string().describe("The key for the project you want to add it to"),
48
55
  summary: zod_1.z.string().describe("The summary of the new ticket"),
@@ -182,7 +189,6 @@ exports.credalCallCopilotOutputSchema = zod_1.z.object({
182
189
  exports.zendeskCreateZendeskTicketParamsSchema = zod_1.z.object({
183
190
  subject: zod_1.z.string().describe("The subject of the ticket"),
184
191
  body: zod_1.z.string().describe("The body of the ticket").optional(),
185
- requesterEmail: zod_1.z.string().describe("The email of the requester"),
186
192
  subdomain: zod_1.z.string().describe("The subdomain of the Zendesk account"),
187
193
  });
188
194
  exports.zendeskCreateZendeskTicketOutputSchema = zod_1.z.object({
@@ -7,9 +7,9 @@ exports.ACTION_GROUPS = {
7
7
  description: "Actions for interacting with Slack",
8
8
  actions: [templates_1.slackListConversationsDefinition, templates_1.slackSendMessageDefinition],
9
9
  },
10
- CONFLUENCE_UPDATE_PAGE: {
11
- description: "Action for updating Confluence",
12
- actions: [templates_1.confluenceUpdatePageDefinition],
10
+ CONFLUENCE: {
11
+ description: "Action for interacting with Confluence",
12
+ actions: [templates_1.confluenceOverwritePageDefinition, templates_1.confluenceFetchPageContentDefinition],
13
13
  },
14
14
  MATH_ADD: {
15
15
  description: "Action for adding two numbers",
@@ -0,0 +1,3 @@
1
+ import { confluenceFetchPageContentFunction } from "../../autogen/types";
2
+ declare const confluenceFetchPageContent: confluenceFetchPageContentFunction;
3
+ export default confluenceFetchPageContent;
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ const axiosClient_1 = require("../../util/axiosClient");
13
+ function getConfluenceRequestConfig(baseUrl, username, apiToken) {
14
+ return {
15
+ baseURL: baseUrl,
16
+ headers: {
17
+ Accept: "application/json",
18
+ Authorization: `Basic ${Buffer.from(`${username}:${apiToken}`).toString("base64")}`,
19
+ },
20
+ };
21
+ }
22
+ const confluenceFetchPageContent = (_a) => __awaiter(void 0, [_a], void 0, function* ({ params, authParams, }) {
23
+ var _b, _c;
24
+ const { pageId } = params;
25
+ const { baseUrl, authToken, username } = authParams;
26
+ if (!baseUrl || !authToken || !username) {
27
+ throw new Error("Missing required authentication parameters");
28
+ }
29
+ const config = getConfluenceRequestConfig(baseUrl, username, authToken);
30
+ // Get page content and metadata
31
+ const response = yield axiosClient_1.axiosClient.get(`/api/v2/pages/${pageId}?body-format=storage`, config);
32
+ // Extract needed data from response
33
+ const title = response.data.title;
34
+ const content = ((_c = (_b = response.data.body) === null || _b === void 0 ? void 0 : _b.storage) === null || _c === void 0 ? void 0 : _c.value) || "";
35
+ return {
36
+ pageId,
37
+ title,
38
+ content,
39
+ };
40
+ });
41
+ exports.default = confluenceFetchPageContent;
@@ -0,0 +1,3 @@
1
+ import { confluenceOverwritePageFunction } from "../../autogen/types";
2
+ declare const confluenceOverwritePage: confluenceOverwritePageFunction;
3
+ export default confluenceOverwritePage;
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ const axiosClient_1 = require("../../util/axiosClient");
13
+ function getConfluenceRequestConfig(baseUrl, username, apiToken) {
14
+ return {
15
+ baseURL: baseUrl,
16
+ headers: {
17
+ Accept: "application/json",
18
+ Authorization: `Basic ${Buffer.from(`${username}:${apiToken}`).toString("base64")}`,
19
+ },
20
+ };
21
+ }
22
+ const confluenceOverwritePage = (_a) => __awaiter(void 0, [_a], void 0, function* ({ params, authParams, }) {
23
+ const { pageId, content, title } = params;
24
+ const { baseUrl, authToken, username } = authParams;
25
+ if (!baseUrl || !authToken || !username) {
26
+ throw new Error("Missing required authentication parameters");
27
+ }
28
+ const config = getConfluenceRequestConfig(baseUrl, username, authToken);
29
+ // Get current page content and version number
30
+ const response = yield axiosClient_1.axiosClient.get(`/api/v2/pages/${pageId}?body-format=storage`, config);
31
+ const currVersion = response.data.version.number;
32
+ const payload = {
33
+ id: pageId,
34
+ status: "current",
35
+ title,
36
+ body: {
37
+ representation: "storage",
38
+ value: content,
39
+ },
40
+ version: {
41
+ number: currVersion + 1,
42
+ },
43
+ };
44
+ yield axiosClient_1.axiosClient.put(`/api/v2/pages/${pageId}`, payload, config);
45
+ });
46
+ exports.default = confluenceOverwritePage;
@@ -20,8 +20,11 @@ function getConfluenceRequestConfig(baseUrl, username, apiToken) {
20
20
  };
21
21
  }
22
22
  const confluenceUpdatePage = (_a) => __awaiter(void 0, [_a], void 0, function* ({ params, authParams, }) {
23
- const { pageId, username, content, title } = params;
24
- const { baseUrl, authToken } = authParams;
23
+ const { pageId, content, title } = params;
24
+ const { baseUrl, authToken, username } = authParams;
25
+ if (!baseUrl || !authToken || !username) {
26
+ throw new Error("Missing required authentication information");
27
+ }
25
28
  const config = getConfluenceRequestConfig(baseUrl, username, authToken);
26
29
  // Get current version number
27
30
  const response = yield axiosClient_1.axiosClient.get(`/api/v2/pages/${pageId}`, config);
@@ -15,38 +15,38 @@ Object.defineProperty(exports, "__esModule", { value: true });
15
15
  const axios_1 = __importDefault(require("axios"));
16
16
  const types_1 = require("../../autogen/types");
17
17
  const INCLUDED_TYPES = [
18
- // "monument",
19
- // "museum",
20
- // "art_gallery",
21
- // "sculpture",
22
- // "cultural_landmark",
23
- // "historical_place",
24
- // "performing_arts_theater",
25
- // "university",
26
- // "aquarium",
27
- // "botanical_garden",
28
- // "comedy_club",
29
- // "park",
30
- // "movie_theater",
31
- // "national_park",
32
- // "garden",
33
- // "night_club",
34
- // "tourist_attraction",
35
- // "water_park",
36
- // "zoo",
37
- // "bar",
18
+ "monument",
19
+ "museum",
20
+ "art_gallery",
21
+ "sculpture",
22
+ "cultural_landmark",
23
+ "historical_place",
24
+ "performing_arts_theater",
25
+ "university",
26
+ "aquarium",
27
+ "botanical_garden",
28
+ "comedy_club",
29
+ "park",
30
+ "movie_theater",
31
+ "national_park",
32
+ "garden",
33
+ "night_club",
34
+ "tourist_attraction",
35
+ "water_park",
36
+ "zoo",
37
+ "bar",
38
38
  "restaurant",
39
- // "food_court",
40
- // "bakery",
41
- // "cafe",
42
- // "coffee_shop",
43
- // "pub",
44
- // "wine_bar",
45
- // "spa",
46
- // "beach",
47
- // "market",
48
- // "shopping_mall",
49
- // "stadium",
39
+ "food_court",
40
+ "bakery",
41
+ "cafe",
42
+ "coffee_shop",
43
+ "pub",
44
+ "wine_bar",
45
+ "spa",
46
+ "beach",
47
+ "market",
48
+ "shopping_mall",
49
+ "stadium",
50
50
  ];
51
51
  const nearbysearch = (_a) => __awaiter(void 0, [_a], void 0, function* ({ params, authParams, }) {
52
52
  const url = `https://places.googleapis.com/v1/places:searchNearby`;
@@ -0,0 +1,3 @@
1
+ import { xScrapePostDataWithNitterFunction } from "../../autogen/types";
2
+ declare const scrapeTweetDataWithNitter: xScrapePostDataWithNitterFunction;
3
+ export default scrapeTweetDataWithNitter;
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ const firecrawl_js_1 = __importDefault(require("@mendable/firecrawl-js"));
16
+ const scrapeTweetDataWithNitter = (_a) => __awaiter(void 0, [_a], void 0, function* ({ params, authParams, }) {
17
+ const tweetUrlRegex = /^(?:https?:\/\/)?(?:www\.)?(?:twitter\.com|x\.com)\/([a-zA-Z0-9_]+)\/status\/(\d+)(?:\?.*)?$/;
18
+ if (!tweetUrlRegex.test(params.tweetUrl)) {
19
+ throw new Error("Invalid tweet URL. Expected format: https://twitter.com/username/status/id or https://x.com/username/status/id");
20
+ }
21
+ const nitterUrl = params.tweetUrl.replace(/^(?:https?:\/\/)?(?:www\.)?(?:twitter\.com|x\.com)/i, "https://nitter.net");
22
+ // Initialize Firecrawl
23
+ if (!authParams.apiKey) {
24
+ throw new Error("API key is required for X+Nitter+Firecrawl");
25
+ }
26
+ const firecrawl = new firecrawl_js_1.default({
27
+ apiKey: authParams.apiKey,
28
+ });
29
+ try {
30
+ // Scrape the Nitter URL
31
+ const result = yield firecrawl.scrapeUrl(nitterUrl);
32
+ if (!result.success) {
33
+ throw new Error(`Failed to scrape tweet: ${result.error || "Unknown error"}`);
34
+ }
35
+ // Extract the tweet text from the scraped content - simple approach - in practice, you might need more robust parsing based on nitter html structure
36
+ const tweetContent = result.markdown;
37
+ return {
38
+ text: tweetContent || "Error scraping with firecrawl",
39
+ };
40
+ }
41
+ catch (error) {
42
+ throw new Error(`Error scraping tweet: ${error instanceof Error ? error.message : error}`);
43
+ }
44
+ });
45
+ exports.default = scrapeTweetDataWithNitter;
@@ -11,8 +11,8 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  const axiosClient_1 = require("../../util/axiosClient");
13
13
  const createZendeskTicket = (_a) => __awaiter(void 0, [_a], void 0, function* ({ params, authParams, }) {
14
- const { apiKey } = authParams;
15
- const { subdomain, subject, body, requesterEmail } = params;
14
+ const { apiKey, username } = authParams;
15
+ const { subdomain, subject, body } = params;
16
16
  const url = `https://${subdomain}.zendesk.com/api/v2/tickets.json`;
17
17
  const payload = {
18
18
  ticket: {
@@ -25,21 +25,18 @@ const createZendeskTicket = (_a) => __awaiter(void 0, [_a], void 0, function* ({
25
25
  if (!apiKey) {
26
26
  throw new Error("API key is required");
27
27
  }
28
- try {
29
- const response = yield axiosClient_1.axiosClient.post(url, payload, {
30
- auth: {
31
- username: `${requesterEmail}/token`,
32
- password: apiKey,
33
- },
34
- headers: {
35
- "Content-Type": "application/json",
36
- },
37
- });
38
- return response.data;
39
- }
40
- catch (error) {
41
- console.error("Error creating ticket", error);
42
- return { ticketId: "Error" };
43
- }
28
+ const response = yield axiosClient_1.axiosClient.post(url, payload, {
29
+ auth: {
30
+ username: `${username}/token`,
31
+ password: apiKey,
32
+ },
33
+ headers: {
34
+ "Content-Type": "application/json",
35
+ },
36
+ });
37
+ return {
38
+ ticketId: response.data.ticket.id,
39
+ ticketUrl: `https://${subdomain}.zendesk.com/requests/${response.data.ticket.id}`,
40
+ };
44
41
  });
45
42
  exports.default = createZendeskTicket;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@credal/actions",
3
- "version": "0.1.21",
3
+ "version": "0.1.23",
4
4
  "description": "AI Actions by Credal AI",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -1,5 +0,0 @@
1
- import { ActionTemplate } from "@/actions/parse";
2
- export declare const slackSendMessageDefinition: ActionTemplate;
3
- export declare const slackListConversationsDefinition: ActionTemplate;
4
- export declare const mathAddDefinition: ActionTemplate;
5
- export declare const confluenceUpdatePageDefinition: ActionTemplate;
@@ -1,132 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.confluenceUpdatePageDefinition = exports.mathAddDefinition = exports.slackListConversationsDefinition = exports.slackSendMessageDefinition = void 0;
4
- exports.slackSendMessageDefinition = {
5
- provider: "slack",
6
- name: "send_message",
7
- description: "Sends a message to a Slack channel",
8
- scopes: ["chat:write"],
9
- parameters: {
10
- channel: {
11
- type: "string",
12
- description: "The Slack channel to send the message to (e.g., \\#general, \\#alerts)",
13
- required: true,
14
- },
15
- message: {
16
- type: "string",
17
- description: "The message content to send to Slack. Can include markdown formatting.",
18
- required: true,
19
- },
20
- },
21
- output: {},
22
- };
23
- exports.slackListConversationsDefinition = {
24
- provider: "slack",
25
- name: "list_conversations",
26
- description: "Lists all conversations in a Slack workspace",
27
- scopes: ["channels:read", "groups:read", "im:read", "mpim:read"],
28
- authToken: {
29
- type: "string",
30
- description: "The Slack access token to use",
31
- required: true,
32
- },
33
- parameters: {},
34
- output: {
35
- channels: {
36
- type: "array",
37
- description: "A list of channels in Slack",
38
- required: true,
39
- items: {
40
- type: "object",
41
- description: "A channel in Slack",
42
- required: true,
43
- properties: {
44
- id: {
45
- type: "string",
46
- description: "The ID of the channel",
47
- required: true,
48
- },
49
- name: {
50
- type: "string",
51
- description: "The name of the channel",
52
- required: true,
53
- },
54
- topic: {
55
- type: "string",
56
- description: "The topic of the channel",
57
- required: true,
58
- },
59
- purpose: {
60
- type: "string",
61
- description: "The purpose of the channel",
62
- required: true,
63
- },
64
- },
65
- },
66
- },
67
- },
68
- };
69
- exports.mathAddDefinition = {
70
- provider: "math",
71
- name: "add",
72
- description: "Adds two numbers together",
73
- scopes: [],
74
- parameters: {
75
- a: {
76
- type: "number",
77
- description: "The first number to add",
78
- required: true,
79
- },
80
- b: {
81
- type: "number",
82
- description: "The second number to add",
83
- required: true,
84
- },
85
- },
86
- output: {
87
- result: {
88
- type: "number",
89
- description: "The sum of the two numbers",
90
- required: true,
91
- },
92
- },
93
- };
94
- exports.confluenceUpdatePageDefinition = {
95
- provider: "confluence",
96
- name: "updatePage",
97
- description: "Updates a confluence page with the new content specified",
98
- scopes: [],
99
- authToken: {
100
- type: "string",
101
- description: "The access token to use for confluence",
102
- required: true,
103
- },
104
- baseUrl: {
105
- type: "string",
106
- description: "The base url required to access the confluence instance",
107
- required: true,
108
- },
109
- parameters: {
110
- pageId: {
111
- type: "string",
112
- description: "The page id that should be updated",
113
- required: true,
114
- },
115
- title: {
116
- type: "string",
117
- description: "The title of the page that should be updated",
118
- required: true,
119
- },
120
- username: {
121
- type: "string",
122
- description: "The username of the person updating the page",
123
- required: true,
124
- },
125
- content: {
126
- type: "string",
127
- description: "The new content for the page",
128
- required: true,
129
- },
130
- },
131
- output: {},
132
- };
@@ -1,35 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.mathAddDefinition = exports.slackSendMessageDefinition = void 0;
4
- exports.slackSendMessageDefinition = {
5
- name: "send_message",
6
- description: "Sends a message to a Slack channel",
7
- parameters: {
8
- "channel": {
9
- "type": "string",
10
- "description": "The Slack channel to send the message to (e.g., \\#general, \\#alerts)",
11
- "required": true
12
- },
13
- "message": {
14
- "type": "string",
15
- "description": "The message content to send to Slack. Can include markdown formatting.",
16
- "required": true
17
- }
18
- }
19
- };
20
- exports.mathAddDefinition = {
21
- name: "add",
22
- description: "Adds two numbers together",
23
- parameters: {
24
- "a": {
25
- "type": "number",
26
- "description": "The first number to add",
27
- "required": true
28
- },
29
- "b": {
30
- "type": "number",
31
- "description": "The second number to add",
32
- "required": true
33
- }
34
- }
35
- };
@@ -1,9 +0,0 @@
1
- import { type ActionFunction } from "./autogen/types";
2
- import { z } from "zod";
3
- interface ActionFunctionComponents {
4
- fn: ActionFunction<any, any, any>;
5
- paramsSchema: z.ZodSchema;
6
- outputSchema: z.ZodSchema;
7
- }
8
- export declare const FunctionMapper: Record<string, Record<string, ActionFunctionComponents>>;
9
- export {};
@@ -1,33 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.FunctionMapper = void 0;
7
- const add_1 = __importDefault(require("./providers/math/add"));
8
- const list_conversations_1 = __importDefault(require("./providers/slack/list_conversations"));
9
- const updatePage_1 = __importDefault(require("./providers/confluence/updatePage"));
10
- const types_1 = require("./autogen/types");
11
- exports.FunctionMapper = {
12
- math: {
13
- add: {
14
- fn: add_1.default,
15
- paramsSchema: types_1.mathAddParamsSchema,
16
- outputSchema: types_1.mathAddOutputSchema,
17
- },
18
- },
19
- slack: {
20
- listConversations: {
21
- fn: list_conversations_1.default,
22
- paramsSchema: types_1.slackListConversationsParamsSchema,
23
- outputSchema: types_1.slackListConversationsOutputSchema,
24
- },
25
- },
26
- confluence: {
27
- updatePage: {
28
- fn: updatePage_1.default,
29
- paramsSchema: types_1.confluenceUpdatePageParamsSchema,
30
- outputSchema: types_1.confluenceUpdatePageOutputSchema,
31
- },
32
- },
33
- };
@@ -1,3 +0,0 @@
1
- import { jiraCreateTicketFunction } from "../../autogen/types";
2
- declare const createTicket: jiraCreateTicketFunction;
3
- export default createTicket;
@@ -1,34 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- var __importDefault = (this && this.__importDefault) || function (mod) {
12
- return (mod && mod.__esModule) ? mod : { "default": mod };
13
- };
14
- Object.defineProperty(exports, "__esModule", { value: true });
15
- const axios_1 = __importDefault(require("axios"));
16
- const createTicket = (_a) => __awaiter(void 0, [_a], void 0, function* ({ params, authParams, }) {
17
- const { authToken, baseUrl } = authParams;
18
- const url = `${baseUrl}/rest/api/3/issue`;
19
- const payload = {
20
- fields: Object.assign({ project: {
21
- key: params.projectKey,
22
- }, summary: params.summary, description: params.description, issuetype: {
23
- name: params.issueType,
24
- } }, (params.reporter ? { reporter: { id: params.reporter } } : {})),
25
- };
26
- const response = yield axios_1.default.post(url, payload, {
27
- headers: {
28
- Authorization: `Basic ${Buffer.from(`${params.username}:${authToken}`).toString("base64")}`,
29
- "Content-Type": "application/json",
30
- },
31
- });
32
- return response.data;
33
- });
34
- exports.default = createTicket;
@@ -1,3 +0,0 @@
1
- import { slackListConversationsFunction } from "../../../actions/autogen/types";
2
- declare const slackListConversations: slackListConversationsFunction;
3
- export default slackListConversations;
@@ -1,60 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- const web_api_1 = require("@slack/web-api");
13
- const slackListConversations = (_a) => __awaiter(void 0, [_a], void 0, function* ({ authParams, }) {
14
- var _b;
15
- const client = new web_api_1.WebClient(authParams.authToken);
16
- const allChannels = [];
17
- let cursor;
18
- const limit = 100;
19
- try {
20
- do {
21
- const response = yield client.conversations.list({
22
- exclude_archived: true,
23
- limit: limit,
24
- cursor: cursor,
25
- });
26
- if (!response.ok) {
27
- throw new Error(`Slack API error: ${response.error}`);
28
- }
29
- // Add channels from this page to our results
30
- if (response.channels && Array.isArray(response.channels)) {
31
- allChannels.push(...response.channels);
32
- }
33
- // Get cursor for next page
34
- cursor = (_b = response.response_metadata) === null || _b === void 0 ? void 0 : _b.next_cursor;
35
- // If user specified a limit and we've hit it, stop paginating
36
- if (limit && allChannels.length >= limit) {
37
- allChannels.splice(limit); // Trim to exact limit
38
- break;
39
- }
40
- } while (cursor && cursor.length > 0);
41
- return {
42
- channels: allChannels.map(channel => ({
43
- id: channel.id,
44
- name: channel.name,
45
- topic: channel.topic.value,
46
- purpose: channel.purpose.value,
47
- })),
48
- };
49
- }
50
- catch (error) {
51
- if (error instanceof Error) {
52
- // Enhance error with more context
53
- throw new Error(`Failed to list Slack conversations: ${error.message}`);
54
- }
55
- else {
56
- throw error;
57
- }
58
- }
59
- });
60
- exports.default = slackListConversations;
@@ -1,6 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createParametersObject = createParametersObject;
4
- function createParametersObject(parameters) {
5
- return Object.fromEntries(Object.entries(parameters).map(([key, param]) => [key, param.type]));
6
- }
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
package/dist/main.js DELETED
@@ -1,11 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const list_conversations_1 = __importDefault(require("./actions/providers/slack/list_conversations"));
7
- const result = (0, list_conversations_1.default)({
8
- accessToken: "xoxp-4172665288294-8092684180551-8154529379075-89f1f70cc06e5648e8f912ba96f56626"
9
- }).then((result) => {
10
- console.log(result);
11
- });