@credal/actions 0.1.43 → 0.1.46

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 +6 -0
  2. package/dist/actions/autogen/templates.d.ts +1 -0
  3. package/dist/actions/autogen/templates.js +38 -1
  4. package/dist/actions/autogen/types.d.ts +23 -0
  5. package/dist/actions/autogen/types.js +9 -1
  6. package/dist/actions/groups.js +1 -0
  7. package/dist/actions/providers/salesforce/fetchSalesforceSchema.d.ts +3 -0
  8. package/dist/actions/providers/salesforce/fetchSalesforceSchema.js +42 -0
  9. package/dist/actions/providers/salesforce/getSalesforceRecordByQuery.d.ts +3 -0
  10. package/dist/actions/providers/salesforce/getSalesforceRecordByQuery.js +43 -0
  11. package/dist/actions/providers/snowflake/auth/getSnowflakeConnection.d.ts +1 -0
  12. package/dist/actions/providers/snowflake/auth/getSnowflakeConnection.js +84 -16
  13. package/dist/actions/providers/snowflake/runSnowflakeQuery.js +4 -27
  14. package/dist/actions/util/formatDataForCodeInterpreter.d.ts +10 -0
  15. package/dist/actions/util/formatDataForCodeInterpreter.js +43 -0
  16. package/package.json +3 -1
  17. package/dist/actions/providers/confluence/updatePage.d.ts +0 -3
  18. package/dist/actions/providers/confluence/updatePage.js +0 -46
  19. package/dist/actions/providers/generic/fillTemplateAction.d.ts +0 -7
  20. package/dist/actions/providers/generic/fillTemplateAction.js +0 -18
  21. package/dist/actions/providers/generic/genericApiCall.d.ts +0 -3
  22. package/dist/actions/providers/generic/genericApiCall.js +0 -38
  23. package/dist/actions/providers/googlemaps/nearbysearch.d.ts +0 -3
  24. package/dist/actions/providers/googlemaps/nearbysearch.js +0 -96
  25. package/dist/actions/providers/snowflake/runSnowflakeQueryWriteResultsToS3.d.ts +0 -3
  26. package/dist/actions/providers/snowflake/runSnowflakeQueryWriteResultsToS3.js +0 -154
  27. package/dist/actions/providers/x/scrapeTweetDataWithNitter.d.ts +0 -3
  28. package/dist/actions/providers/x/scrapeTweetDataWithNitter.js +0 -45
@@ -72,6 +72,7 @@ const updateSpreadsheet_2 = __importDefault(require("./providers/microsoft/updat
72
72
  const updateDocument_1 = __importDefault(require("./providers/microsoft/updateDocument"));
73
73
  const createDocument_1 = __importDefault(require("./providers/microsoft/createDocument"));
74
74
  const getDocument_1 = __importDefault(require("./providers/microsoft/getDocument"));
75
+ const fetchSalesforceSchema_1 = __importDefault(require("./providers/salesforce/fetchSalesforceSchema"));
75
76
  exports.ActionMapper = {
76
77
  generic: {
77
78
  fillTemplate: {
@@ -406,6 +407,11 @@ exports.ActionMapper = {
406
407
  paramsSchema: types_1.salesforceGetSalesforceRecordsByQueryParamsSchema,
407
408
  outputSchema: types_1.salesforceGetSalesforceRecordsByQueryOutputSchema,
408
409
  },
410
+ fetchSalesforceSchemaByObject: {
411
+ fn: fetchSalesforceSchema_1.default,
412
+ paramsSchema: types_1.salesforceFetchSalesforceSchemaByObjectParamsSchema,
413
+ outputSchema: types_1.salesforceFetchSalesforceSchemaByObjectOutputSchema,
414
+ },
409
415
  },
410
416
  microsoft: {
411
417
  messageTeamsChat: {
@@ -57,6 +57,7 @@ export declare const salesforceCreateCaseDefinition: ActionTemplate;
57
57
  export declare const salesforceGenerateSalesReportDefinition: ActionTemplate;
58
58
  export declare const salesforceGetSalesforceRecordsByQueryDefinition: ActionTemplate;
59
59
  export declare const salesforceGetRecordDefinition: ActionTemplate;
60
+ export declare const salesforceFetchSalesforceSchemaByObjectDefinition: ActionTemplate;
60
61
  export declare const microsoftCreateDocumentDefinition: ActionTemplate;
61
62
  export declare const microsoftUpdateDocumentDefinition: ActionTemplate;
62
63
  export declare const microsoftUpdateSpreadsheetDefinition: ActionTemplate;
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.ashbySearchCandidatesDefinition = exports.ashbyListCandidatesDefinition = exports.ashbyAddCandidateToProjectDefinition = exports.ashbyGetCandidateInfoDefinition = exports.ashbyCreateNoteDefinition = exports.lookerEnableUserByEmailDefinition = exports.finnhubGetBasicFinancialsDefinition = exports.finnhubSymbolLookupDefinition = exports.googleOauthUpdatePresentationDefinition = exports.googleOauthCreatePresentationDefinition = exports.googleOauthUpdateSpreadsheetDefinition = exports.googleOauthCreateSpreadsheetDefinition = exports.googleOauthScheduleCalendarMeetingDefinition = exports.googleOauthUpdateDocDefinition = exports.googleOauthCreateNewGoogleDocDefinition = exports.resendSendEmailDefinition = exports.firecrawlScrapeTweetDataWithNitterDefinition = exports.firecrawlScrapeUrlDefinition = exports.nwsGetForecastForLocationDefinition = exports.openstreetmapGetLatitudeLongitudeFromLocationDefinition = exports.snowflakeRunSnowflakeQueryDefinition = exports.snowflakeGetRowByFieldValueDefinition = exports.mongoInsertMongoDocDefinition = exports.xCreateShareXPostUrlDefinition = exports.linkedinCreateShareLinkedinPostUrlDefinition = exports.zendeskAssignTicketDefinition = exports.zendeskAddCommentToTicketDefinition = exports.zendeskUpdateTicketStatusDefinition = exports.zendeskGetTicketDetailsDefinition = exports.zendeskCreateZendeskTicketDefinition = exports.credalCallCopilotDefinition = exports.googlemapsNearbysearchRestaurantsDefinition = exports.googlemapsValidateAddressDefinition = exports.jiraUpdateJiraTicketStatusDefinition = exports.jiraUpdateJiraTicketDetailsDefinition = exports.jiraGetJiraTicketHistoryDefinition = exports.jiraGetJiraTicketDetailsDefinition = exports.jiraCreateJiraTicketDefinition = exports.jiraCommentJiraTicketDefinition = exports.jiraAssignJiraTicketDefinition = exports.confluenceFetchPageContentDefinition = exports.confluenceOverwritePageDefinition = exports.mathAddDefinition = exports.slackGetChannelMessagesDefinition = exports.slackListConversationsDefinition = exports.slackSendMessageDefinition = exports.asanaUpdateTaskDefinition = exports.asanaCreateTaskDefinition = exports.asanaCommentTaskDefinition = exports.genericFillTemplateDefinition = void 0;
4
- exports.githubCreatePullRequestDefinition = exports.githubCreateBranchDefinition = exports.githubCreateOrUpdateFileDefinition = exports.microsoftGetDocumentDefinition = exports.microsoftMessageTeamsChannelDefinition = exports.microsoftMessageTeamsChatDefinition = exports.microsoftUpdateSpreadsheetDefinition = exports.microsoftUpdateDocumentDefinition = exports.microsoftCreateDocumentDefinition = exports.salesforceGetRecordDefinition = exports.salesforceGetSalesforceRecordsByQueryDefinition = exports.salesforceGenerateSalesReportDefinition = exports.salesforceCreateCaseDefinition = exports.salesforceUpdateRecordDefinition = exports.ashbyUpdateCandidateDefinition = exports.ashbyCreateCandidateDefinition = exports.ashbyListCandidateNotesDefinition = void 0;
4
+ exports.githubCreatePullRequestDefinition = exports.githubCreateBranchDefinition = exports.githubCreateOrUpdateFileDefinition = exports.microsoftGetDocumentDefinition = exports.microsoftMessageTeamsChannelDefinition = exports.microsoftMessageTeamsChatDefinition = exports.microsoftUpdateSpreadsheetDefinition = exports.microsoftUpdateDocumentDefinition = exports.microsoftCreateDocumentDefinition = exports.salesforceFetchSalesforceSchemaByObjectDefinition = exports.salesforceGetRecordDefinition = exports.salesforceGetSalesforceRecordsByQueryDefinition = exports.salesforceGenerateSalesReportDefinition = exports.salesforceCreateCaseDefinition = exports.salesforceUpdateRecordDefinition = exports.ashbyUpdateCandidateDefinition = exports.ashbyCreateCandidateDefinition = exports.ashbyListCandidateNotesDefinition = void 0;
5
5
  exports.genericFillTemplateDefinition = {
6
6
  description: "Simple utility that takes a template and returns it filled in",
7
7
  scopes: [],
@@ -5413,6 +5413,43 @@ exports.salesforceGetRecordDefinition = {
5413
5413
  name: "getRecord",
5414
5414
  provider: "salesforce",
5415
5415
  };
5416
+ exports.salesforceFetchSalesforceSchemaByObjectDefinition = {
5417
+ description: "Fetch the schema of a Salesforce object",
5418
+ scopes: [],
5419
+ parameters: {
5420
+ type: "object",
5421
+ required: ["objectType"],
5422
+ properties: {
5423
+ objectType: {
5424
+ type: "string",
5425
+ description: "The Salesforce object type to fetch the schema for (e.g., Lead, Account, Contact)",
5426
+ },
5427
+ },
5428
+ },
5429
+ output: {
5430
+ type: "object",
5431
+ required: ["success"],
5432
+ properties: {
5433
+ success: {
5434
+ type: "boolean",
5435
+ description: "Whether the schema was successfully retrieved",
5436
+ },
5437
+ schema: {
5438
+ type: "object",
5439
+ description: "The retrieved schema data",
5440
+ additionalProperties: {
5441
+ type: "string",
5442
+ },
5443
+ },
5444
+ error: {
5445
+ type: "string",
5446
+ description: "The error that occurred if the schema was not successfully retrieved",
5447
+ },
5448
+ },
5449
+ },
5450
+ name: "fetchSalesforceSchemaByObject",
5451
+ provider: "salesforce",
5452
+ };
5416
5453
  exports.microsoftCreateDocumentDefinition = {
5417
5454
  description: "Creates a new Office365 document",
5418
5455
  scopes: ["Files.ReadWrite", "Sites.Manage.All", "Sites.ReadWrite.All"],
@@ -2427,6 +2427,29 @@ export declare const salesforceGetRecordOutputSchema: z.ZodObject<{
2427
2427
  }>;
2428
2428
  export type salesforceGetRecordOutputType = z.infer<typeof salesforceGetRecordOutputSchema>;
2429
2429
  export type salesforceGetRecordFunction = ActionFunction<salesforceGetRecordParamsType, AuthParamsType, salesforceGetRecordOutputType>;
2430
+ export declare const salesforceFetchSalesforceSchemaByObjectParamsSchema: z.ZodObject<{
2431
+ objectType: z.ZodString;
2432
+ }, "strip", z.ZodTypeAny, {
2433
+ objectType: string;
2434
+ }, {
2435
+ objectType: string;
2436
+ }>;
2437
+ export type salesforceFetchSalesforceSchemaByObjectParamsType = z.infer<typeof salesforceFetchSalesforceSchemaByObjectParamsSchema>;
2438
+ export declare const salesforceFetchSalesforceSchemaByObjectOutputSchema: z.ZodObject<{
2439
+ success: z.ZodBoolean;
2440
+ schema: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
2441
+ error: z.ZodOptional<z.ZodString>;
2442
+ }, "strip", z.ZodTypeAny, {
2443
+ success: boolean;
2444
+ error?: string | undefined;
2445
+ schema?: Record<string, string> | undefined;
2446
+ }, {
2447
+ success: boolean;
2448
+ error?: string | undefined;
2449
+ schema?: Record<string, string> | undefined;
2450
+ }>;
2451
+ export type salesforceFetchSalesforceSchemaByObjectOutputType = z.infer<typeof salesforceFetchSalesforceSchemaByObjectOutputSchema>;
2452
+ export type salesforceFetchSalesforceSchemaByObjectFunction = ActionFunction<salesforceFetchSalesforceSchemaByObjectParamsType, AuthParamsType, salesforceFetchSalesforceSchemaByObjectOutputType>;
2430
2453
  export declare const microsoftCreateDocumentParamsSchema: z.ZodObject<{
2431
2454
  siteId: z.ZodOptional<z.ZodString>;
2432
2455
  name: z.ZodString;
@@ -2,7 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.zendeskAssignTicketParamsSchema = exports.zendeskAddCommentToTicketOutputSchema = exports.zendeskAddCommentToTicketParamsSchema = exports.zendeskUpdateTicketStatusOutputSchema = exports.zendeskUpdateTicketStatusParamsSchema = exports.zendeskGetTicketDetailsOutputSchema = exports.zendeskGetTicketDetailsParamsSchema = exports.zendeskCreateZendeskTicketOutputSchema = exports.zendeskCreateZendeskTicketParamsSchema = exports.credalCallCopilotOutputSchema = exports.credalCallCopilotParamsSchema = exports.googlemapsNearbysearchRestaurantsOutputSchema = exports.googlemapsNearbysearchRestaurantsParamsSchema = exports.googlemapsValidateAddressOutputSchema = exports.googlemapsValidateAddressParamsSchema = exports.jiraUpdateJiraTicketStatusOutputSchema = exports.jiraUpdateJiraTicketStatusParamsSchema = exports.jiraUpdateJiraTicketDetailsOutputSchema = exports.jiraUpdateJiraTicketDetailsParamsSchema = exports.jiraGetJiraTicketHistoryOutputSchema = exports.jiraGetJiraTicketHistoryParamsSchema = exports.jiraGetJiraTicketDetailsOutputSchema = exports.jiraGetJiraTicketDetailsParamsSchema = exports.jiraCreateJiraTicketOutputSchema = exports.jiraCreateJiraTicketParamsSchema = exports.jiraCommentJiraTicketOutputSchema = exports.jiraCommentJiraTicketParamsSchema = exports.jiraAssignJiraTicketOutputSchema = exports.jiraAssignJiraTicketParamsSchema = exports.confluenceFetchPageContentOutputSchema = exports.confluenceFetchPageContentParamsSchema = exports.confluenceOverwritePageOutputSchema = exports.confluenceOverwritePageParamsSchema = exports.mathAddOutputSchema = exports.mathAddParamsSchema = exports.slackGetChannelMessagesOutputSchema = exports.slackGetChannelMessagesParamsSchema = exports.slackListConversationsOutputSchema = exports.slackListConversationsParamsSchema = exports.slackSendMessageOutputSchema = exports.slackSendMessageParamsSchema = exports.asanaUpdateTaskOutputSchema = exports.asanaUpdateTaskParamsSchema = exports.asanaCreateTaskOutputSchema = exports.asanaCreateTaskParamsSchema = exports.asanaCommentTaskOutputSchema = exports.asanaCommentTaskParamsSchema = exports.genericFillTemplateOutputSchema = exports.genericFillTemplateParamsSchema = exports.AuthParamsSchema = void 0;
4
4
  exports.ashbySearchCandidatesParamsSchema = exports.ashbyListCandidatesOutputSchema = exports.ashbyListCandidatesParamsSchema = exports.ashbyAddCandidateToProjectOutputSchema = exports.ashbyAddCandidateToProjectParamsSchema = exports.ashbyGetCandidateInfoOutputSchema = exports.ashbyGetCandidateInfoParamsSchema = exports.ashbyCreateNoteOutputSchema = exports.ashbyCreateNoteParamsSchema = exports.lookerEnableUserByEmailOutputSchema = exports.lookerEnableUserByEmailParamsSchema = exports.finnhubGetBasicFinancialsOutputSchema = exports.finnhubGetBasicFinancialsParamsSchema = exports.finnhubSymbolLookupOutputSchema = exports.finnhubSymbolLookupParamsSchema = exports.googleOauthUpdatePresentationOutputSchema = exports.googleOauthUpdatePresentationParamsSchema = exports.googleOauthCreatePresentationOutputSchema = exports.googleOauthCreatePresentationParamsSchema = exports.googleOauthUpdateSpreadsheetOutputSchema = exports.googleOauthUpdateSpreadsheetParamsSchema = exports.googleOauthCreateSpreadsheetOutputSchema = exports.googleOauthCreateSpreadsheetParamsSchema = exports.googleOauthScheduleCalendarMeetingOutputSchema = exports.googleOauthScheduleCalendarMeetingParamsSchema = exports.googleOauthUpdateDocOutputSchema = exports.googleOauthUpdateDocParamsSchema = 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.snowflakeRunSnowflakeQueryOutputSchema = exports.snowflakeRunSnowflakeQueryParamsSchema = exports.snowflakeGetRowByFieldValueOutputSchema = exports.snowflakeGetRowByFieldValueParamsSchema = exports.mongoInsertMongoDocOutputSchema = exports.mongoInsertMongoDocParamsSchema = exports.xCreateShareXPostUrlOutputSchema = exports.xCreateShareXPostUrlParamsSchema = exports.linkedinCreateShareLinkedinPostUrlOutputSchema = exports.linkedinCreateShareLinkedinPostUrlParamsSchema = exports.zendeskAssignTicketOutputSchema = void 0;
5
- exports.githubCreatePullRequestOutputSchema = exports.githubCreatePullRequestParamsSchema = exports.githubCreateBranchOutputSchema = exports.githubCreateBranchParamsSchema = exports.githubCreateOrUpdateFileOutputSchema = exports.githubCreateOrUpdateFileParamsSchema = exports.microsoftGetDocumentOutputSchema = exports.microsoftGetDocumentParamsSchema = exports.microsoftMessageTeamsChannelOutputSchema = exports.microsoftMessageTeamsChannelParamsSchema = exports.microsoftMessageTeamsChatOutputSchema = exports.microsoftMessageTeamsChatParamsSchema = exports.microsoftUpdateSpreadsheetOutputSchema = exports.microsoftUpdateSpreadsheetParamsSchema = exports.microsoftUpdateDocumentOutputSchema = exports.microsoftUpdateDocumentParamsSchema = exports.microsoftCreateDocumentOutputSchema = exports.microsoftCreateDocumentParamsSchema = exports.salesforceGetRecordOutputSchema = exports.salesforceGetRecordParamsSchema = exports.salesforceGetSalesforceRecordsByQueryOutputSchema = exports.salesforceGetSalesforceRecordsByQueryParamsSchema = exports.salesforceGenerateSalesReportOutputSchema = exports.salesforceGenerateSalesReportParamsSchema = exports.salesforceCreateCaseOutputSchema = exports.salesforceCreateCaseParamsSchema = exports.salesforceUpdateRecordOutputSchema = exports.salesforceUpdateRecordParamsSchema = exports.ashbyUpdateCandidateOutputSchema = exports.ashbyUpdateCandidateParamsSchema = exports.ashbyCreateCandidateOutputSchema = exports.ashbyCreateCandidateParamsSchema = exports.ashbyListCandidateNotesOutputSchema = exports.ashbyListCandidateNotesParamsSchema = exports.ashbySearchCandidatesOutputSchema = void 0;
5
+ exports.githubCreatePullRequestOutputSchema = exports.githubCreatePullRequestParamsSchema = exports.githubCreateBranchOutputSchema = exports.githubCreateBranchParamsSchema = exports.githubCreateOrUpdateFileOutputSchema = exports.githubCreateOrUpdateFileParamsSchema = exports.microsoftGetDocumentOutputSchema = exports.microsoftGetDocumentParamsSchema = exports.microsoftMessageTeamsChannelOutputSchema = exports.microsoftMessageTeamsChannelParamsSchema = exports.microsoftMessageTeamsChatOutputSchema = exports.microsoftMessageTeamsChatParamsSchema = exports.microsoftUpdateSpreadsheetOutputSchema = exports.microsoftUpdateSpreadsheetParamsSchema = exports.microsoftUpdateDocumentOutputSchema = exports.microsoftUpdateDocumentParamsSchema = exports.microsoftCreateDocumentOutputSchema = exports.microsoftCreateDocumentParamsSchema = exports.salesforceFetchSalesforceSchemaByObjectOutputSchema = exports.salesforceFetchSalesforceSchemaByObjectParamsSchema = exports.salesforceGetRecordOutputSchema = exports.salesforceGetRecordParamsSchema = exports.salesforceGetSalesforceRecordsByQueryOutputSchema = exports.salesforceGetSalesforceRecordsByQueryParamsSchema = exports.salesforceGenerateSalesReportOutputSchema = exports.salesforceGenerateSalesReportParamsSchema = exports.salesforceCreateCaseOutputSchema = exports.salesforceCreateCaseParamsSchema = exports.salesforceUpdateRecordOutputSchema = exports.salesforceUpdateRecordParamsSchema = exports.ashbyUpdateCandidateOutputSchema = exports.ashbyUpdateCandidateParamsSchema = exports.ashbyCreateCandidateOutputSchema = exports.ashbyCreateCandidateParamsSchema = exports.ashbyListCandidateNotesOutputSchema = exports.ashbyListCandidateNotesParamsSchema = exports.ashbySearchCandidatesOutputSchema = void 0;
6
6
  const zod_1 = require("zod");
7
7
  exports.AuthParamsSchema = zod_1.z.object({
8
8
  authToken: zod_1.z.string().optional(),
@@ -2149,6 +2149,14 @@ exports.salesforceGetRecordOutputSchema = zod_1.z.object({
2149
2149
  record: zod_1.z.record(zod_1.z.string()).describe("The retrieved record data").optional(),
2150
2150
  error: zod_1.z.string().describe("The error that occurred if the record was not successfully retrieved").optional(),
2151
2151
  });
2152
+ exports.salesforceFetchSalesforceSchemaByObjectParamsSchema = zod_1.z.object({
2153
+ objectType: zod_1.z.string().describe("The Salesforce object type to fetch the schema for (e.g., Lead, Account, Contact)"),
2154
+ });
2155
+ exports.salesforceFetchSalesforceSchemaByObjectOutputSchema = zod_1.z.object({
2156
+ success: zod_1.z.boolean().describe("Whether the schema was successfully retrieved"),
2157
+ schema: zod_1.z.record(zod_1.z.string()).describe("The retrieved schema data").optional(),
2158
+ error: zod_1.z.string().describe("The error that occurred if the schema was not successfully retrieved").optional(),
2159
+ });
2152
2160
  exports.microsoftCreateDocumentParamsSchema = zod_1.z.object({
2153
2161
  siteId: zod_1.z.string().describe("The ID of the site where the document will be created").optional(),
2154
2162
  name: zod_1.z.string().describe("The name of the new document (include extension like .docx or .xlsx)"),
@@ -110,6 +110,7 @@ exports.ACTION_GROUPS = {
110
110
  templates_1.salesforceGenerateSalesReportDefinition,
111
111
  templates_1.salesforceGetRecordDefinition,
112
112
  templates_1.salesforceGetSalesforceRecordsByQueryDefinition,
113
+ templates_1.salesforceFetchSalesforceSchemaByObjectDefinition,
113
114
  ],
114
115
  },
115
116
  MICROSOFT: {
@@ -0,0 +1,3 @@
1
+ import type { salesforceFetchSalesforceSchemaByObjectFunction } from "../../autogen/types";
2
+ declare const fetchSalesforceSchemaByObject: salesforceFetchSalesforceSchemaByObjectFunction;
3
+ export default fetchSalesforceSchemaByObject;
@@ -0,0 +1,42 @@
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
+ const fetchSalesforceSchemaByObject = (_a) => __awaiter(void 0, [_a], void 0, function* ({ params, authParams, }) {
14
+ const { authToken, baseUrl } = authParams;
15
+ const { objectType } = params;
16
+ if (!authToken || !baseUrl) {
17
+ return {
18
+ success: false,
19
+ error: "authToken and baseUrl are required for Salesforce API",
20
+ };
21
+ }
22
+ const url = `${baseUrl}/services/data/v56.0/sobjects/${objectType}/describe/`;
23
+ try {
24
+ const response = yield axiosClient_1.axiosClient.get(url, {
25
+ headers: {
26
+ Authorization: `Bearer ${authToken}`,
27
+ },
28
+ });
29
+ return {
30
+ success: true,
31
+ schema: response.data.fields,
32
+ };
33
+ }
34
+ catch (error) {
35
+ console.error("Error retrieving Salesforce schema:", error);
36
+ return {
37
+ success: false,
38
+ error: error instanceof Error ? error.message : "An unknown error occurred",
39
+ };
40
+ }
41
+ });
42
+ exports.default = fetchSalesforceSchemaByObject;
@@ -0,0 +1,3 @@
1
+ import { salesforceGetSalesforceRecordsByQueryFunction } from "../../autogen/types";
2
+ declare const getSalesforceRecordByQuery: salesforceGetSalesforceRecordsByQueryFunction;
3
+ export default getSalesforceRecordByQuery;
@@ -0,0 +1,43 @@
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
+ const getSalesforceRecordByQuery = (_a) => __awaiter(void 0, [_a], void 0, function* ({ params, authParams, }) {
14
+ const { authToken, baseUrl } = authParams;
15
+ const { query, limit } = params;
16
+ if (!authToken || !baseUrl) {
17
+ return {
18
+ success: false,
19
+ error: "authToken and baseUrl are required for Salesforce API",
20
+ };
21
+ }
22
+ // The API limits the maximum number of records returned to 2000, the limit lets the user set a smaller custom limit
23
+ const url = `${baseUrl}/services/data/v56.0/query/?q=${encodeURIComponent(query + " LIMIT " + (limit != undefined && limit <= 2000 ? limit : 2000))}`;
24
+ try {
25
+ const response = yield axiosClient_1.axiosClient.get(url, {
26
+ headers: {
27
+ Authorization: `Bearer ${authToken}`,
28
+ },
29
+ });
30
+ return {
31
+ success: true,
32
+ records: response.data,
33
+ };
34
+ }
35
+ catch (error) {
36
+ console.error("Error retrieving Salesforce record:", error);
37
+ return {
38
+ success: false,
39
+ error: error instanceof Error ? error.message : "An unknown error occurred",
40
+ };
41
+ }
42
+ });
43
+ exports.default = getSalesforceRecordByQuery;
@@ -6,3 +6,4 @@ export declare function getSnowflakeConnection(snowflakeData: {
6
6
  warehouse: string;
7
7
  database: string;
8
8
  }, authParams: AuthParamsType): Connection;
9
+ export declare function connectToSnowflakeAndWarehouse(connection: Connection, warehouse?: string): Promise<void>;
@@ -1,16 +1,71 @@
1
1
  "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
36
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
37
+ return new (P || (P = Promise))(function (resolve, reject) {
38
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
39
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
40
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
41
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
42
+ });
43
+ };
2
44
  var __importDefault = (this && this.__importDefault) || function (mod) {
3
45
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
46
  };
5
47
  Object.defineProperty(exports, "__esModule", { value: true });
6
48
  exports.getSnowflakeConnection = getSnowflakeConnection;
7
- const crypto_1 = __importDefault(require("crypto"));
49
+ exports.connectToSnowflakeAndWarehouse = connectToSnowflakeAndWarehouse;
8
50
  const snowflake_sdk_1 = __importDefault(require("snowflake-sdk"));
51
+ const forge = __importStar(require("node-forge"));
52
+ const getPrivateKeyCorrectFormat = (privateKey) => {
53
+ try {
54
+ // Parse the private key
55
+ const pemKey = forge.pem.decode(privateKey)[0];
56
+ // Re-encode it properly with correct formatting
57
+ return forge.pem.encode(pemKey);
58
+ }
59
+ catch (error) {
60
+ console.error("Error processing private key:", error);
61
+ throw new Error("Invalid private key format. Please check the key format and try again.");
62
+ }
63
+ };
9
64
  function getSnowflakeConnection(snowflakeData, authParams) {
10
65
  const { authToken, apiKey } = authParams;
11
66
  const { account, username, warehouse, database } = snowflakeData;
12
67
  if (authToken) {
13
- // Always try to use Nango-Snowflake OAuth
68
+ // Always try to use Nango-Snowflake OAuth (unused for now)
14
69
  return snowflake_sdk_1.default.createConnection({
15
70
  account: account,
16
71
  username: username,
@@ -22,20 +77,6 @@ function getSnowflakeConnection(snowflakeData, authParams) {
22
77
  });
23
78
  }
24
79
  else if (apiKey) {
25
- // Use the apiKey for authentication (one off)
26
- const getPrivateKeyCorrectFormat = (privateKey) => {
27
- const buffer = Buffer.from(privateKey);
28
- const privateKeyObject = crypto_1.default.createPrivateKey({
29
- key: buffer,
30
- format: "pem",
31
- passphrase: "password",
32
- });
33
- const privateKeyCorrectFormat = privateKeyObject.export({
34
- format: "pem",
35
- type: "pkcs8",
36
- });
37
- return privateKeyCorrectFormat.toString();
38
- };
39
80
  const privateKeyCorrectFormatString = getPrivateKeyCorrectFormat(apiKey);
40
81
  return snowflake_sdk_1.default.createConnection({
41
82
  account: account,
@@ -51,3 +92,30 @@ function getSnowflakeConnection(snowflakeData, authParams) {
51
92
  throw new Error("Snowflake authToken or apiKey is required");
52
93
  }
53
94
  }
95
+ function connectToSnowflakeAndWarehouse(connection, warehouse) {
96
+ return __awaiter(this, void 0, void 0, function* () {
97
+ yield new Promise((resolve, reject) => {
98
+ connection.connect((err, conn) => {
99
+ if (err) {
100
+ console.error("Unable to connect to Snowflake:", err.message);
101
+ return reject(err);
102
+ }
103
+ resolve(conn);
104
+ });
105
+ });
106
+ if (warehouse) {
107
+ yield new Promise((resolve, reject) => {
108
+ connection.execute({
109
+ sqlText: `USE WAREHOUSE ${warehouse}`,
110
+ complete: (err, stmt, rows) => {
111
+ if (err) {
112
+ console.error("Unable to use warehouse:", err.message);
113
+ return reject(err);
114
+ }
115
+ resolve(rows);
116
+ },
117
+ });
118
+ });
119
+ }
120
+ });
121
+ }
@@ -14,6 +14,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
14
14
  Object.defineProperty(exports, "__esModule", { value: true });
15
15
  const snowflake_sdk_1 = __importDefault(require("snowflake-sdk"));
16
16
  const getSnowflakeConnection_1 = require("./auth/getSnowflakeConnection");
17
+ const formatDataForCodeInterpreter_1 = require("../../util/formatDataForCodeInterpreter");
17
18
  snowflake_sdk_1.default.configure({ logLevel: "ERROR" });
18
19
  const runSnowflakeQuery = (_a) => __awaiter(void 0, [_a], void 0, function* ({ params, authParams, }) {
19
20
  const { databaseName, warehouse, query, user, accountName, outputFormat = "json" } = params;
@@ -34,24 +35,8 @@ const runSnowflakeQuery = (_a) => __awaiter(void 0, [_a], void 0, function* ({ p
34
35
  });
35
36
  });
36
37
  // Format the results based on the output format
37
- let formattedData;
38
- if (outputFormat.toLowerCase() === "csv") {
39
- if (queryResults.length === 0) {
40
- formattedData = "";
41
- }
42
- else {
43
- const headers = Object.keys(queryResults[0]).join(",");
44
- const rows = queryResults.map(row => Object.values(row)
45
- .map(value => (typeof value === "object" && value !== null ? JSON.stringify(value) : value))
46
- .join(","));
47
- formattedData = [headers, ...rows].join("\n");
48
- }
49
- }
50
- else {
51
- // Default to JSON
52
- formattedData = JSON.stringify(queryResults).replace(/\s+/g, "");
53
- }
54
- return { formattedData, resultsLength: queryResults.length };
38
+ const { formattedData, resultsLength } = (0, formatDataForCodeInterpreter_1.formatDataForCodeInterpreter)(queryResults, outputFormat);
39
+ return { formattedData, resultsLength };
55
40
  });
56
41
  // Set up a connection using snowflake-sdk
57
42
  const connection = (0, getSnowflakeConnection_1.getSnowflakeConnection)({
@@ -62,15 +47,7 @@ const runSnowflakeQuery = (_a) => __awaiter(void 0, [_a], void 0, function* ({ p
62
47
  }, { authToken: authParams.authToken, apiKey: authParams.apiKey });
63
48
  try {
64
49
  // Connect to Snowflake
65
- yield new Promise((resolve, reject) => {
66
- connection.connect((err, conn) => {
67
- if (err) {
68
- console.error("Unable to connect to Snowflake:", err.message);
69
- return reject(err);
70
- }
71
- resolve(conn);
72
- });
73
- });
50
+ yield (0, getSnowflakeConnection_1.connectToSnowflakeAndWarehouse)(connection, warehouse);
74
51
  const { formattedData, resultsLength } = yield executeQueryAndFormatData();
75
52
  // Return fields to match schema definition
76
53
  connection.destroy(err => {
@@ -0,0 +1,10 @@
1
+ /**
2
+ * Formats query results into either CSV or JSON format for code interpreter
3
+ * @param queryResults The results from a database query
4
+ * @param outputFormat The desired output format ("csv" or "json")
5
+ * @returns Object containing formatted data and result count
6
+ */
7
+ export declare function formatDataForCodeInterpreter(queryResults: any[], outputFormat?: string): {
8
+ formattedData: string;
9
+ resultsLength: number;
10
+ };
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ /* eslint-disable @typescript-eslint/no-explicit-any */
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.formatDataForCodeInterpreter = formatDataForCodeInterpreter;
5
+ /**
6
+ * Formats query results into either CSV or JSON format for code interpreter
7
+ * @param queryResults The results from a database query
8
+ * @param outputFormat The desired output format ("csv" or "json")
9
+ * @returns Object containing formatted data and result count
10
+ */
11
+ function formatDataForCodeInterpreter(queryResults, outputFormat = "json") {
12
+ let formattedData;
13
+ if (outputFormat.toLowerCase() === "csv") {
14
+ if (queryResults.length === 0) {
15
+ formattedData = "";
16
+ }
17
+ else {
18
+ const headers = Object.keys(queryResults[0]).join(",");
19
+ // Helper function to properly escape CSV fields
20
+ const escapeCsvField = (field) => {
21
+ if (field === null || field === undefined)
22
+ return "";
23
+ const stringValue = typeof field === "object" ? JSON.stringify(field) : String(field);
24
+ // If the field contains commas, quotes, or newlines, it needs to be quoted
25
+ if (stringValue.includes(",") ||
26
+ stringValue.includes('"') ||
27
+ stringValue.includes("\n") ||
28
+ stringValue.includes("\r")) {
29
+ // Escape quotes by doubling them and wrap in quotes
30
+ return '"' + stringValue.replace(/"/g, '""') + '"';
31
+ }
32
+ return stringValue;
33
+ };
34
+ const rows = queryResults.map(row => Object.values(row).map(escapeCsvField).join(","));
35
+ formattedData = [headers, ...rows].join("\n");
36
+ }
37
+ }
38
+ else {
39
+ // Default to JSON - keep it formatted for readability
40
+ formattedData = JSON.stringify(queryResults, null, 2);
41
+ }
42
+ return { formattedData, resultsLength: queryResults.length };
43
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@credal/actions",
3
- "version": "0.1.43",
3
+ "version": "0.1.46",
4
4
  "description": "AI Actions by Credal AI",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -27,6 +27,7 @@
27
27
  "@types/js-yaml": "^4.0.9",
28
28
  "@types/jsonwebtoken": "^9.0.9",
29
29
  "@types/node": "^22.10.1",
30
+ "@types/node-forge": "^1.3.11",
30
31
  "@typescript-eslint/eslint-plugin": "^8.18.0",
31
32
  "@typescript-eslint/parser": "^8.18.0",
32
33
  "eslint": "^9.16.0",
@@ -52,6 +53,7 @@
52
53
  "json-schema-to-zod": "^2.5.0",
53
54
  "jsonwebtoken": "^9.0.2",
54
55
  "mongodb": "^6.13.1",
56
+ "node-forge": "^1.3.1",
55
57
  "octokit": "^4.1.2",
56
58
  "resend": "^4.1.2",
57
59
  "snowflake-sdk": "^2.0.2",
@@ -1,3 +0,0 @@
1
- import { confluenceUpdatePageFunction } from "../../../actions/autogen/types";
2
- declare const confluenceUpdatePage: confluenceUpdatePageFunction;
3
- export default confluenceUpdatePage;
@@ -1,46 +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 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 confluenceUpdatePage = (_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 information");
27
- }
28
- const config = getConfluenceRequestConfig(baseUrl, username, authToken);
29
- // Get current version number
30
- const response = yield axiosClient_1.axiosClient.get(`/api/v2/pages/${pageId}`, 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 = confluenceUpdatePage;
@@ -1,7 +0,0 @@
1
- import type { ActionFunction } from "../../autogen/types";
2
- declare const fillTemplateAction: ActionFunction<{
3
- template: string;
4
- }, {
5
- result: string;
6
- }, unknown>;
7
- export default fillTemplateAction;
@@ -1,18 +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 fillTemplateAction = (_a) => __awaiter(void 0, [_a], void 0, function* ({ template }) {
13
- // Simply return the template without any modification
14
- return {
15
- result: template,
16
- };
17
- });
18
- exports.default = fillTemplateAction;
@@ -1,3 +0,0 @@
1
- import type { genericUniversalTestActionFunction } from "../../autogen/types";
2
- declare const genericApiCall: genericUniversalTestActionFunction;
3
- export default genericApiCall;
@@ -1,38 +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 genericApiCall = (_a) => __awaiter(void 0, [_a], void 0, function* ({ params, }) {
17
- try {
18
- const { endpoint, method, headers, body } = params;
19
- const response = yield (0, axios_1.default)({
20
- url: endpoint,
21
- method,
22
- headers,
23
- data: method !== "GET" ? body : undefined,
24
- });
25
- return {
26
- statusCode: response.status,
27
- headers: response.headers,
28
- data: response.data,
29
- };
30
- }
31
- catch (error) {
32
- if (axios_1.default.isAxiosError(error)) {
33
- throw Error("Axios Error: " + (error.message || "Failed to make API call"));
34
- }
35
- throw Error("Error: " + (error || "Failed to make API call"));
36
- }
37
- });
38
- exports.default = genericApiCall;
@@ -1,3 +0,0 @@
1
- import { googlemapsNearbysearchFunction } from "../../autogen/types";
2
- declare const nearbysearch: googlemapsNearbysearchFunction;
3
- export default nearbysearch;
@@ -1,96 +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 types_1 = require("../../autogen/types");
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",
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",
50
- ];
51
- const nearbysearch = (_a) => __awaiter(void 0, [_a], void 0, function* ({ params, authParams, }) {
52
- const url = `https://places.googleapis.com/v1/places:searchNearby`;
53
- const fieldMask = [
54
- "places.displayName",
55
- "places.formattedAddress",
56
- "places.priceLevel",
57
- "places.rating",
58
- "places.primaryTypeDisplayName",
59
- "places.editorialSummary",
60
- "places.regularOpeningHours",
61
- ].join(",");
62
- const response = yield axios_1.default.post(url, {
63
- maxResultCount: 20,
64
- includedTypes: INCLUDED_TYPES,
65
- locationRestriction: {
66
- circle: {
67
- center: {
68
- latitude: params.latitude,
69
- longitude: params.longitude,
70
- },
71
- radius: 10000,
72
- },
73
- },
74
- }, {
75
- headers: {
76
- "X-Goog-Api-Key": authParams.apiKey,
77
- "X-Goog-FieldMask": fieldMask,
78
- "Content-Type": "application/json",
79
- },
80
- });
81
- return types_1.googlemapsNearbysearchOutputSchema.parse({
82
- results: response.data.places.map((place) => {
83
- var _a, _b;
84
- return ({
85
- name: place.displayName.text,
86
- address: place.formattedAddress,
87
- priceLevel: place.priceLevel,
88
- rating: place.rating,
89
- primaryType: place.primaryTypeDisplayName.text,
90
- editorialSummary: ((_a = place.editorialSummary) === null || _a === void 0 ? void 0 : _a.text) || "",
91
- openingHours: ((_b = place.regularOpeningHours) === null || _b === void 0 ? void 0 : _b.weekdayDescriptions.join("\n")) || "",
92
- });
93
- }),
94
- });
95
- });
96
- exports.default = nearbysearch;
@@ -1,3 +0,0 @@
1
- import { snowflakeRunSnowflakeQueryWriteResultsToS3Function } from "../../autogen/types";
2
- declare const runSnowflakeQueryWriteResultsToS3: snowflakeRunSnowflakeQueryWriteResultsToS3Function;
3
- export default runSnowflakeQueryWriteResultsToS3;
@@ -1,154 +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 snowflake_sdk_1 = __importDefault(require("snowflake-sdk"));
16
- const crypto_1 = __importDefault(require("crypto"));
17
- const client_s3_1 = require("@aws-sdk/client-s3");
18
- const s3_request_presigner_1 = require("@aws-sdk/s3-request-presigner");
19
- const uuid_1 = require("uuid");
20
- // Only log errors.
21
- snowflake_sdk_1.default.configure({ logLevel: "ERROR" });
22
- const runSnowflakeQueryWriteResultsToS3 = (_a) => __awaiter(void 0, [_a], void 0, function* ({ params, authParams, }) {
23
- const { databaseName, warehouse, query, user, accountName, s3BucketName, s3Region, outputFormat = "json" } = params;
24
- const { apiKey: privateKey, awsAccessKeyId, awsSecretAccessKey } = authParams;
25
- if (!privateKey) {
26
- throw new Error("Snowflake private key is required");
27
- }
28
- if (!awsAccessKeyId || !awsSecretAccessKey) {
29
- throw new Error("AWS credentials are required");
30
- }
31
- if (!accountName || !user || !databaseName || !warehouse || !query || !s3BucketName) {
32
- throw new Error("Missing required parameters for Snowflake query or S3 destination");
33
- }
34
- const getPrivateKeyCorrectFormat = (privateKey) => {
35
- const buffer = Buffer.from(privateKey);
36
- const privateKeyObject = crypto_1.default.createPrivateKey({
37
- key: buffer,
38
- format: "pem",
39
- passphrase: "password",
40
- });
41
- const privateKeyCorrectFormat = privateKeyObject.export({
42
- format: "pem",
43
- type: "pkcs8",
44
- });
45
- return privateKeyCorrectFormat.toString();
46
- };
47
- const executeQueryAndFormatData = () => __awaiter(void 0, void 0, void 0, function* () {
48
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
49
- const queryResults = yield new Promise((resolve, reject) => {
50
- connection.execute({
51
- sqlText: query,
52
- complete: (err, stmt, rows) => {
53
- if (err) {
54
- return reject(err);
55
- }
56
- return resolve(rows || []);
57
- },
58
- });
59
- });
60
- // Format the results based on the output format
61
- let formattedData;
62
- if (outputFormat.toLowerCase() === "csv") {
63
- if (queryResults.length === 0) {
64
- formattedData = "";
65
- }
66
- else {
67
- const headers = Object.keys(queryResults[0]).join(",");
68
- const rows = queryResults.map(row => Object.values(row)
69
- .map(value => (typeof value === "object" && value !== null ? JSON.stringify(value) : value))
70
- .join(","));
71
- formattedData = [headers, ...rows].join("\n");
72
- }
73
- }
74
- else {
75
- // Default to JSON
76
- formattedData = JSON.stringify(queryResults, null, 2);
77
- }
78
- return { formattedData, resultsLength: queryResults.length };
79
- });
80
- const uploadToS3AndGetURL = (formattedData) => __awaiter(void 0, void 0, void 0, function* () {
81
- // Create S3 client
82
- const s3Client = new client_s3_1.S3Client({
83
- region: s3Region,
84
- credentials: {
85
- accessKeyId: awsAccessKeyId,
86
- secretAccessKey: awsSecretAccessKey,
87
- },
88
- });
89
- const contentType = outputFormat.toLowerCase() === "csv" ? "text/csv" : "application/json";
90
- const fileExtension = outputFormat.toLowerCase() === "csv" ? "csv" : "json";
91
- const finalKey = `${databaseName}/${(0, uuid_1.v4)()}.${fileExtension}`;
92
- // Upload to S3 without ACL
93
- const uploadCommand = new client_s3_1.PutObjectCommand({
94
- Bucket: s3BucketName,
95
- Key: finalKey,
96
- Body: formattedData,
97
- ContentType: contentType,
98
- });
99
- yield s3Client.send(uploadCommand);
100
- // Generate a presigned URL (valid for an hour)
101
- const getObjectCommand = new client_s3_1.GetObjectCommand({
102
- Bucket: s3BucketName,
103
- Key: finalKey,
104
- });
105
- const presignedUrl = yield (0, s3_request_presigner_1.getSignedUrl)(s3Client, getObjectCommand, { expiresIn: 3600 });
106
- return presignedUrl;
107
- });
108
- // Process the private key
109
- const privateKeyCorrectFormatString = getPrivateKeyCorrectFormat(privateKey);
110
- // Set up a connection using snowflake-sdk
111
- const connection = snowflake_sdk_1.default.createConnection({
112
- account: accountName,
113
- username: user,
114
- privateKey: privateKeyCorrectFormatString,
115
- authenticator: "SNOWFLAKE_JWT",
116
- role: "ACCOUNTADMIN",
117
- warehouse: warehouse,
118
- database: databaseName,
119
- });
120
- try {
121
- // Connect to Snowflake
122
- yield new Promise((resolve, reject) => {
123
- connection.connect((err, conn) => {
124
- if (err) {
125
- console.error("Unable to connect to Snowflake:", err.message);
126
- return reject(err);
127
- }
128
- resolve(conn);
129
- });
130
- });
131
- const { formattedData, resultsLength } = yield executeQueryAndFormatData();
132
- const presignedUrl = yield uploadToS3AndGetURL(formattedData);
133
- // Return fields to match schema definition
134
- connection.destroy(err => {
135
- if (err) {
136
- console.log("Failed to disconnect from Snowflake:", err);
137
- }
138
- });
139
- return {
140
- bucketUrl: presignedUrl,
141
- message: `Query results successfully written to S3. URL valid for 1 hour.`,
142
- rowCount: resultsLength,
143
- };
144
- }
145
- catch (error) {
146
- connection.destroy(err => {
147
- if (err) {
148
- console.log("Failed to disconnect from Snowflake:", err);
149
- }
150
- });
151
- throw Error(`An error occurred: ${error}`);
152
- }
153
- });
154
- exports.default = runSnowflakeQueryWriteResultsToS3;
@@ -1,3 +0,0 @@
1
- import { xScrapePostDataWithNitterFunction } from "../../autogen/types";
2
- declare const scrapeTweetDataWithNitter: xScrapePostDataWithNitterFunction;
3
- export default scrapeTweetDataWithNitter;
@@ -1,45 +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 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;