@bubblelab/bubble-core 0.1.68 → 0.1.69
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/bubble-bundle.d.ts +85 -85
- package/dist/bubbles/service-bubble/agi-inc.d.ts +112 -112
- package/dist/bubbles/service-bubble/ai-agent.d.ts +72 -72
- package/dist/bubbles/service-bubble/airtable.d.ts +156 -156
- package/dist/bubbles/service-bubble/apify/apify.d.ts +12 -12
- package/dist/bubbles/service-bubble/ashby/ashby.d.ts +140 -140
- package/dist/bubbles/service-bubble/ashby/ashby.js +1 -1
- package/dist/bubbles/service-bubble/ashby/ashby.js.map +1 -1
- package/dist/bubbles/service-bubble/browserbase/browserbase.d.ts +51 -51
- package/dist/bubbles/service-bubble/crustdata/crustdata.d.ts +32 -32
- package/dist/bubbles/service-bubble/eleven-labs.d.ts +60 -60
- package/dist/bubbles/service-bubble/firecrawl.d.ts +396 -396
- package/dist/bubbles/service-bubble/followupboss.d.ts +492 -492
- package/dist/bubbles/service-bubble/fullenrich/fullenrich.d.ts +116 -116
- package/dist/bubbles/service-bubble/github.d.ts +152 -152
- package/dist/bubbles/service-bubble/gmail.d.ts +576 -576
- package/dist/bubbles/service-bubble/google-calendar.d.ts +232 -232
- package/dist/bubbles/service-bubble/google-drive.d.ts +422 -156
- package/dist/bubbles/service-bubble/google-drive.d.ts.map +1 -1
- package/dist/bubbles/service-bubble/google-drive.js +282 -30
- package/dist/bubbles/service-bubble/google-drive.js.map +1 -1
- package/dist/bubbles/service-bubble/google-sheets/google-sheets.d.ts +78 -78
- package/dist/bubbles/service-bubble/hello-world.d.ts +4 -4
- package/dist/bubbles/service-bubble/http.d.ts +20 -20
- package/dist/bubbles/service-bubble/insforge-db.d.ts +10 -10
- package/dist/bubbles/service-bubble/jira/jira.d.ts +54 -54
- package/dist/bubbles/service-bubble/notion/notion.d.ts +624 -624
- package/dist/bubbles/service-bubble/postgresql.d.ts +10 -10
- package/dist/bubbles/service-bubble/resend.d.ts +20 -20
- package/dist/bubbles/service-bubble/slack/slack.d.ts +304 -304
- package/dist/bubbles/service-bubble/storage.d.ts +40 -40
- package/dist/bubbles/service-bubble/stripe/stripe.d.ts +72 -72
- package/dist/bubbles/service-bubble/telegram.d.ts +938 -938
- package/dist/bubbles/tool-bubble/amazon-shopping-tool/amazon-shopping-tool.d.ts +26 -26
- package/dist/bubbles/tool-bubble/bubbleflow-validation-tool.d.ts +4 -4
- package/dist/bubbles/tool-bubble/chart-js-tool.d.ts +4 -4
- package/dist/bubbles/tool-bubble/code-edit-tool.d.ts +4 -4
- package/dist/bubbles/tool-bubble/company-enrichment-tool.d.ts +24 -24
- package/dist/bubbles/tool-bubble/get-bubble-details-tool.d.ts +4 -4
- package/dist/bubbles/tool-bubble/get-trigger-detail-tool.d.ts +4 -4
- package/dist/bubbles/tool-bubble/google-maps-tool.d.ts +28 -28
- package/dist/bubbles/tool-bubble/instagram-tool.d.ts +8 -8
- package/dist/bubbles/tool-bubble/linkedin-connection-tool/linkedin-connection-tool.d.ts +8 -8
- package/dist/bubbles/tool-bubble/linkedin-connection-tool/linkedin-connection-tool.d.ts.map +1 -1
- package/dist/bubbles/tool-bubble/linkedin-connection-tool/linkedin-connection-tool.schema.d.ts +8 -8
- package/dist/bubbles/tool-bubble/linkedin-connection-tool/linkedin-connection-tool.schema.d.ts.map +1 -1
- package/dist/bubbles/tool-bubble/linkedin-connection-tool/linkedin-connection-tool.schema.js +31 -25
- package/dist/bubbles/tool-bubble/linkedin-connection-tool/linkedin-connection-tool.schema.js.map +1 -1
- package/dist/bubbles/tool-bubble/linkedin-tool.d.ts +116 -116
- package/dist/bubbles/tool-bubble/list-bubbles-tool.d.ts +4 -4
- package/dist/bubbles/tool-bubble/people-search-tool.d.ts +38 -38
- package/dist/bubbles/tool-bubble/reddit-scrape-tool.d.ts +14 -14
- package/dist/bubbles/tool-bubble/research-agent-tool.d.ts +8 -8
- package/dist/bubbles/tool-bubble/sql-query-tool.d.ts +12 -12
- package/dist/bubbles/tool-bubble/tiktok-tool.d.ts +16 -16
- package/dist/bubbles/tool-bubble/tool-template.d.ts +4 -4
- package/dist/bubbles/tool-bubble/twitter-tool.d.ts +46 -46
- package/dist/bubbles/tool-bubble/web-crawl-tool.d.ts +4 -4
- package/dist/bubbles/tool-bubble/web-extract-tool.d.ts +4 -4
- package/dist/bubbles/tool-bubble/web-scrape-tool.d.ts +4 -4
- package/dist/bubbles/tool-bubble/web-search-tool.d.ts +10 -10
- package/dist/bubbles/tool-bubble/youtube-tool.d.ts +8 -8
- package/dist/bubbles/workflow-bubble/database-analyzer.workflow.d.ts +4 -4
- package/dist/bubbles/workflow-bubble/generate-document.workflow.d.ts +16 -16
- package/dist/bubbles/workflow-bubble/parse-document.workflow.d.ts +4 -4
- package/dist/bubbles/workflow-bubble/pdf-form-operations.workflow.d.ts +90 -90
- package/dist/bubbles/workflow-bubble/pdf-ocr.workflow.d.ts +16 -16
- package/dist/bubbles/workflow-bubble/slack-data-assistant.workflow.d.ts +10 -10
- package/dist/bubbles/workflow-bubble/slack-formatter-agent.d.ts +50 -50
- package/dist/bubbles/workflow-bubble/slack-notifier.workflow.d.ts +4 -4
- package/dist/bubbles.json +290 -74
- package/package.json +2 -2
package/dist/bubbles.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": "2.0.0",
|
|
3
|
-
"generatedAt": "2026-
|
|
3
|
+
"generatedAt": "2026-02-01T06:36:13.937Z",
|
|
4
4
|
"totalCount": 58,
|
|
5
5
|
"bubbles": [
|
|
6
6
|
{
|
|
@@ -8623,6 +8623,15 @@
|
|
|
8623
8623
|
"minLength": 1,
|
|
8624
8624
|
"description": "The ID of the Google Doc to retrieve"
|
|
8625
8625
|
},
|
|
8626
|
+
"tab_id": {
|
|
8627
|
+
"type": "string",
|
|
8628
|
+
"description": "Specific tab ID to read. If omitted, reads first tab."
|
|
8629
|
+
},
|
|
8630
|
+
"include_all_tabs": {
|
|
8631
|
+
"type": "boolean",
|
|
8632
|
+
"default": false,
|
|
8633
|
+
"description": "Return info for all tabs including their plain text content"
|
|
8634
|
+
},
|
|
8626
8635
|
"credentials": {
|
|
8627
8636
|
"type": "object",
|
|
8628
8637
|
"additionalProperties": {
|
|
@@ -8666,6 +8675,10 @@
|
|
|
8666
8675
|
"default": "replace",
|
|
8667
8676
|
"description": "Update mode: \"replace\" clears existing content first, \"append\" adds to the end"
|
|
8668
8677
|
},
|
|
8678
|
+
"tab_id": {
|
|
8679
|
+
"type": "string",
|
|
8680
|
+
"description": "Tab to write to. If omitted, writes to first tab."
|
|
8681
|
+
},
|
|
8669
8682
|
"credentials": {
|
|
8670
8683
|
"type": "object",
|
|
8671
8684
|
"additionalProperties": {
|
|
@@ -8680,6 +8693,106 @@
|
|
|
8680
8693
|
"content"
|
|
8681
8694
|
],
|
|
8682
8695
|
"additionalProperties": false
|
|
8696
|
+
},
|
|
8697
|
+
{
|
|
8698
|
+
"type": "object",
|
|
8699
|
+
"properties": {
|
|
8700
|
+
"operation": {
|
|
8701
|
+
"type": "string",
|
|
8702
|
+
"enum": [
|
|
8703
|
+
"replace_text"
|
|
8704
|
+
],
|
|
8705
|
+
"description": "Find and replace text in a Google Doc while preserving formatting"
|
|
8706
|
+
},
|
|
8707
|
+
"document_id": {
|
|
8708
|
+
"type": "string",
|
|
8709
|
+
"minLength": 1,
|
|
8710
|
+
"description": "The ID of the Google Doc to perform replacements in"
|
|
8711
|
+
},
|
|
8712
|
+
"replacements": {
|
|
8713
|
+
"type": "array",
|
|
8714
|
+
"items": {
|
|
8715
|
+
"type": "object",
|
|
8716
|
+
"properties": {
|
|
8717
|
+
"find": {
|
|
8718
|
+
"type": "string",
|
|
8719
|
+
"description": "Text to find"
|
|
8720
|
+
},
|
|
8721
|
+
"replace": {
|
|
8722
|
+
"type": "string",
|
|
8723
|
+
"description": "Text to replace with"
|
|
8724
|
+
},
|
|
8725
|
+
"match_case": {
|
|
8726
|
+
"type": "boolean",
|
|
8727
|
+
"default": true,
|
|
8728
|
+
"description": "Whether to match case when finding text"
|
|
8729
|
+
}
|
|
8730
|
+
},
|
|
8731
|
+
"required": [
|
|
8732
|
+
"find",
|
|
8733
|
+
"replace"
|
|
8734
|
+
],
|
|
8735
|
+
"additionalProperties": false
|
|
8736
|
+
},
|
|
8737
|
+
"description": "List of find/replace pairs"
|
|
8738
|
+
},
|
|
8739
|
+
"tab_id": {
|
|
8740
|
+
"type": "string",
|
|
8741
|
+
"description": "Tab to perform replacements in. If omitted, applies to all tabs."
|
|
8742
|
+
},
|
|
8743
|
+
"credentials": {
|
|
8744
|
+
"type": "object",
|
|
8745
|
+
"additionalProperties": {
|
|
8746
|
+
"type": "string"
|
|
8747
|
+
},
|
|
8748
|
+
"description": "Object mapping credential types to values (injected at runtime)"
|
|
8749
|
+
}
|
|
8750
|
+
},
|
|
8751
|
+
"required": [
|
|
8752
|
+
"operation",
|
|
8753
|
+
"document_id",
|
|
8754
|
+
"replacements"
|
|
8755
|
+
],
|
|
8756
|
+
"additionalProperties": false
|
|
8757
|
+
},
|
|
8758
|
+
{
|
|
8759
|
+
"type": "object",
|
|
8760
|
+
"properties": {
|
|
8761
|
+
"operation": {
|
|
8762
|
+
"type": "string",
|
|
8763
|
+
"enum": [
|
|
8764
|
+
"copy_doc"
|
|
8765
|
+
],
|
|
8766
|
+
"description": "Create a copy of a Google Doc (useful for templates)"
|
|
8767
|
+
},
|
|
8768
|
+
"document_id": {
|
|
8769
|
+
"type": "string",
|
|
8770
|
+
"minLength": 1,
|
|
8771
|
+
"description": "Source document ID to copy"
|
|
8772
|
+
},
|
|
8773
|
+
"new_name": {
|
|
8774
|
+
"type": "string",
|
|
8775
|
+
"minLength": 1,
|
|
8776
|
+
"description": "Name for the new document"
|
|
8777
|
+
},
|
|
8778
|
+
"parent_folder_id": {
|
|
8779
|
+
"type": "string",
|
|
8780
|
+
"description": "Folder to place the copy in"
|
|
8781
|
+
},
|
|
8782
|
+
"credentials": {
|
|
8783
|
+
"type": "object",
|
|
8784
|
+
"additionalProperties": {
|
|
8785
|
+
"type": "string"
|
|
8786
|
+
},
|
|
8787
|
+
"description": "Object mapping credential types to values (injected at runtime)"
|
|
8788
|
+
}
|
|
8789
|
+
},
|
|
8790
|
+
"required": [
|
|
8791
|
+
"operation",
|
|
8792
|
+
"document_id",
|
|
8793
|
+
"new_name"
|
|
8794
|
+
],
|
|
8795
|
+
"additionalProperties": false
|
|
8683
8796
|
}
|
|
8684
8797
|
]
|
|
8685
8798
|
},
|
|
@@ -9343,6 +9456,37 @@
|
|
|
9343
9456
|
"type": "string",
|
|
9344
9457
|
"description": "Extracted plain text content from the document"
|
|
9345
9458
|
},
|
|
9459
|
+
"tabs": {
|
|
9460
|
+
"type": "array",
|
|
9461
|
+
"items": {
|
|
9462
|
+
"type": "object",
|
|
9463
|
+
"properties": {
|
|
9464
|
+
"tabId": {
|
|
9465
|
+
"type": "string",
|
|
9466
|
+
"description": "Unique tab identifier"
|
|
9467
|
+
},
|
|
9468
|
+
"title": {
|
|
9469
|
+
"type": "string",
|
|
9470
|
+
"description": "Tab title"
|
|
9471
|
+
},
|
|
9472
|
+
"index": {
|
|
9473
|
+
"type": "number",
|
|
9474
|
+
"description": "Tab position index"
|
|
9475
|
+
},
|
|
9476
|
+
"plainText": {
|
|
9477
|
+
"type": "string",
|
|
9478
|
+
"description": "Plain text content of the tab"
|
|
9479
|
+
}
|
|
9480
|
+
},
|
|
9481
|
+
"required": [
|
|
9482
|
+
"tabId",
|
|
9483
|
+
"title",
|
|
9484
|
+
"index"
|
|
9485
|
+
],
|
|
9486
|
+
"additionalProperties": false
|
|
9487
|
+
},
|
|
9488
|
+
"description": "All tabs in the document"
|
|
9489
|
+
},
|
|
9346
9490
|
"error": {
|
|
9347
9491
|
"type": "string",
|
|
9348
9492
|
"description": "Error message if operation failed"
|
|
@@ -9388,10 +9532,74 @@
|
|
|
9388
9532
|
"error"
|
|
9389
9533
|
],
|
|
9390
9534
|
"additionalProperties": false
|
|
9535
|
+
},
|
|
9536
|
+
{
|
|
9537
|
+
"type": "object",
|
|
9538
|
+
"properties": {
|
|
9539
|
+
"operation": {
|
|
9540
|
+
"type": "string",
|
|
9541
|
+
"enum": [
|
|
9542
|
+
"replace_text"
|
|
9543
|
+
],
|
|
9544
|
+
"description": "Find and replace text in a Google Doc"
|
|
9545
|
+
},
|
|
9546
|
+
"success": {
|
|
9547
|
+
"type": "boolean",
|
|
9548
|
+
"description": "Whether the replacements were made successfully"
|
|
9549
|
+
},
|
|
9550
|
+
"replacements_made": {
|
|
9551
|
+
"type": "number",
|
|
9552
|
+
"description": "Total number of replacements made"
|
|
9553
|
+
},
|
|
9554
|
+
"error": {
|
|
9555
|
+
"type": "string",
|
|
9556
|
+
"description": "Error message if operation failed"
|
|
9557
|
+
}
|
|
9558
|
+
},
|
|
9559
|
+
"required": [
|
|
9560
|
+
"operation",
|
|
9561
|
+
"success",
|
|
9562
|
+
"error"
|
|
9563
|
+
],
|
|
9564
|
+
"additionalProperties": false
|
|
9565
|
+
},
|
|
9566
|
+
{
|
|
9567
|
+
"type": "object",
|
|
9568
|
+
"properties": {
|
|
9569
|
+
"operation": {
|
|
9570
|
+
"type": "string",
|
|
9571
|
+
"enum": [
|
|
9572
|
+
"copy_doc"
|
|
9573
|
+
],
|
|
9574
|
+
"description": "Create a copy of a Google Doc"
|
|
9575
|
+
},
|
|
9576
|
+
"success": {
|
|
9577
|
+
"type": "boolean",
|
|
9578
|
+
"description": "Whether the document was copied successfully"
|
|
9579
|
+
},
|
|
9580
|
+
"new_document_id": {
|
|
9581
|
+
"type": "string",
|
|
9582
|
+
"description": "ID of the new document"
|
|
9583
|
+
},
|
|
9584
|
+
"new_document_url": {
|
|
9585
|
+
"type": "string",
|
|
9586
|
+
"description": "URL to view the new document"
|
|
9587
|
+
},
|
|
9588
|
+
"error": {
|
|
9589
|
+
"type": "string",
|
|
9590
|
+
"description": "Error message if operation failed"
|
|
9591
|
+
}
|
|
9592
|
+
},
|
|
9593
|
+
"required": [
|
|
9594
|
+
"operation",
|
|
9595
|
+
"success",
|
|
9596
|
+
"error"
|
|
9597
|
+
],
|
|
9598
|
+
"additionalProperties": false
|
|
9391
9599
|
}
|
|
9392
9600
|
]
|
|
9393
9601
|
},
|
|
9394
|
-
"usageExample": "// Upload File example\nconst googleDrive_upload_file = new GoogleDriveBubble({\n operation: \"upload_file\", // Upload a file to Google Drive\n name: \"example string\", // Name for the uploaded file\n content: \"example string\", // File content as base64 encoded string or plain text\n mimeType: \"example string\", // MIME type of the file (auto-detected if not provided)\n parent_folder_id: \"example string\", // ID of the parent folder (uploads to root if not provided)\n convert_to_google_docs: false // default, // Convert uploaded file to Google Docs format if possible\n});\n\nconst result = await googleDrive_upload_file.action();\n// outputSchema for result.data when operation === 'upload_file':\n// {\n// operation: \"upload_file\" // Upload a file to Google Drive,\n// success: boolean // Whether the file was uploaded successfully,\n// file: { id: string // Unique file identifier, name: string // Name of the file, mimeType: string // MIME type of the file, size: string | undefined // Size of the file in bytes, createdTime: string | undefined // Creation time in RFC 3339 format, modifiedTime: string | undefined // Last modified time in RFC 3339 format, webViewLink: string | undefined // Link to view the file in Google Drive, webContentLink: string | undefined // Link to download the file, parents: string[] | undefined // Parent folder IDs, shared: boolean | undefined // Whether the file is shared, owners: { displayName: string | undefined // Owner display name, emailAddress: string | undefined // Owner email address }[] | undefined // File owners } | undefined // Uploaded file metadata,\n// error: string // Error message if operation failed\n// }\n\n\n// Download File example\nconst googleDrive_download_file = new GoogleDriveBubble({\n operation: \"download_file\", // Download a file from Google Drive\n file_id: \"example string\", // Google Drive file ID to download\n export_format: \"example string\", // Export format for Google Workspace files (e.g., \"application/pdf\", \"text/plain\")\n});\n\nconst result = await googleDrive_download_file.action();\n// outputSchema for result.data when operation === 'download_file':\n// {\n// operation: \"download_file\" // Download a file from Google Drive,\n// success: boolean // Whether the file was downloaded successfully,\n// content: string | undefined // File content as plain text (for text-based files) or base64 encoded string (for binary files),\n// filename: string | undefined // Original filename,\n// mimeType: string | undefined // MIME type of the downloaded file,\n// error: string // Error message if operation failed\n// }\n\n\n// List Files example\nconst googleDrive_list_files = new GoogleDriveBubble({\n operation: \"list_files\", // List files and folders in Google Drive\n folder_id: \"example string\", // ID of folder to list files from (lists from root if not provided)\n query: \"example string\", // Search query to filter files (e.g., \"name contains 'report'\"\n max_results: 100 // default, // Maximum number of files to return\n include_folders: true // default, // Include folders in the results\n order_by: \"modifiedTime desc\" // default, // Order results by field (e.g., \"name\", \"modifiedTime desc\")\n});\n\nconst result = await googleDrive_list_files.action();\n// outputSchema for result.data when operation === 'list_files':\n// {\n// operation: \"list_files\" // List files and folders in Google Drive,\n// success: boolean // Whether the file list was retrieved successfully,\n// files: { id: string // Unique file identifier, name: string // Name of the file, mimeType: string // MIME type of the file, size: string | undefined // Size of the file in bytes, createdTime: string | undefined // Creation time in RFC 3339 format, modifiedTime: string | undefined // Last modified time in RFC 3339 format, webViewLink: string | undefined // Link to view the file in Google Drive, webContentLink: string | undefined // Link to download the file, parents: string[] | undefined // Parent folder IDs, shared: boolean | undefined // Whether the file is shared, owners: { displayName: string | undefined // Owner display name, emailAddress: string | undefined // Owner email address }[] | undefined // File owners }[] | undefined // List of files and folders,\n// total_count: number | undefined // Total number of files found,\n// next_page_token: string | undefined // Token for fetching next page of results,\n// error: string // Error message if operation failed\n// }\n\n\n// Create Folder example\nconst googleDrive_create_folder = new GoogleDriveBubble({\n operation: \"create_folder\", // Create a new folder in Google Drive\n name: \"example string\", // Name of the folder to create\n parent_folder_id: \"example string\", // ID of the parent folder (creates in root if not provided)\n});\n\nconst result = await googleDrive_create_folder.action();\n// outputSchema for result.data when operation === 'create_folder':\n// {\n// operation: \"create_folder\" // Create a new folder in Google Drive,\n// success: boolean // Whether the folder was created successfully,\n// folder: { id: string // Unique folder identifier, name: string // Name of the folder, webViewLink: string | undefined // Link to view the folder in Google Drive, parents: string[] | undefined // Parent folder IDs } | undefined // Created folder metadata,\n// error: string // Error message if operation failed\n// }\n\n\n// Delete File example\nconst googleDrive_delete_file = new GoogleDriveBubble({\n operation: \"delete_file\", // Delete a file or folder from Google Drive\n file_id: \"example string\", // Google Drive file or folder ID to delete\n permanent: false // default, // Permanently delete (true) or move to trash (false)\n});\n\nconst result = await googleDrive_delete_file.action();\n// outputSchema for result.data when operation === 'delete_file':\n// {\n// operation: \"delete_file\" // Delete a file or folder from Google Drive,\n// success: boolean // Whether the file was deleted successfully,\n// deleted_file_id: string | undefined // ID of the deleted file,\n// error: string // Error message if operation failed\n// }\n\n\n// Get File Info example\nconst googleDrive_get_file_info = new GoogleDriveBubble({\n operation: \"get_file_info\", // Get detailed information about a file or folder\n file_id: \"example string\", // Google Drive file or folder ID to get info for\n include_permissions: false // default, // Include file permissions in the response\n});\n\nconst result = await googleDrive_get_file_info.action();\n// outputSchema for result.data when operation === 'get_file_info':\n// {\n// operation: \"get_file_info\" // Get detailed information about a file or folder,\n// success: boolean // Whether the file information was retrieved successfully,\n// file: { id: string // Unique file identifier, name: string // Name of the file, mimeType: string // MIME type of the file, size: string | undefined // Size of the file in bytes, createdTime: string | undefined // Creation time in RFC 3339 format, modifiedTime: string | undefined // Last modified time in RFC 3339 format, webViewLink: string | undefined // Link to view the file in Google Drive, webContentLink: string | undefined // Link to download the file, parents: string[] | undefined // Parent folder IDs, shared: boolean | undefined // Whether the file is shared, owners: { displayName: string | undefined // Owner display name, emailAddress: string | undefined // Owner email address }[] | undefined // File owners } | undefined // File metadata and information,\n// permissions: { id: string, type: string, role: string, emailAddress: string | undefined // Permission holder email address, displayName: string | undefined // Permission holder display name }[] | undefined // File permissions (if requested),\n// error: string // Error message if operation failed\n// }\n\n\n// Share File example\nconst googleDrive_share_file = new GoogleDriveBubble({\n operation: \"share_file\", // Share a file or folder with specific users or make it public\n file_id: \"example string\", // Google Drive file or folder ID to share\n email_address: \"example string\", // Email address to share with (for specific user sharing)\n role: \"reader\" // options: \"reader\", \"writer\", \"commenter\", \"owner\", // Permission role to grant\n type: \"user\" // options: \"user\", \"group\", \"domain\", \"anyone\", // Type of permission to create\n send_notification: true // default, // Send notification email to the user\n});\n\nconst result = await googleDrive_share_file.action();\n// outputSchema for result.data when operation === 'share_file':\n// {\n// operation: \"share_file\" // Share a file or folder with specific users or make it public,\n// success: boolean // Whether the file was shared successfully,\n// permission_id: string | undefined // ID of the created permission,\n// share_link: string | undefined // Shareable link to the file,\n// error: string // Error message if operation failed\n// }\n\n\n// Move File example\nconst googleDrive_move_file = new GoogleDriveBubble({\n operation: \"move_file\", // Move a file or folder to a different location in Google Drive\n file_id: \"example string\", // Google Drive file or folder ID to move\n new_parent_folder_id: \"example string\", // ID of the new parent folder (moves to root if not provided)\n remove_parent_folder_id: \"example string\", // ID of the parent folder to remove (removes from all parents if not provided)\n});\n\nconst result = await googleDrive_move_file.action();\n// outputSchema for result.data when operation === 'move_file':\n// {\n// operation: \"move_file\" // Move a file or folder to a different location in Google Drive,\n// success: boolean // Whether the file was moved successfully,\n// file: { id: string // Unique file identifier, name: string // Name of the file, mimeType: string // MIME type of the file, size: string | undefined // Size of the file in bytes, createdTime: string | undefined // Creation time in RFC 3339 format, modifiedTime: string | undefined // Last modified time in RFC 3339 format, webViewLink: string | undefined // Link to view the file in Google Drive, webContentLink: string | undefined // Link to download the file, parents: string[] | undefined // Parent folder IDs, shared: boolean | undefined // Whether the file is shared, owners: { displayName: string | undefined // Owner display name, emailAddress: string | undefined // Owner email address }[] | undefined // File owners } | undefined // Updated file metadata after move,\n// error: string // Error message if operation failed\n// }\n\n\n// Get Doc example\nconst googleDrive_get_doc = new GoogleDriveBubble({\n operation: \"get_doc\", // Get the content and metadata of a Google Doc using the Google Docs API, use this over download_file for Google Docs\n document_id: \"example string\", // The ID of the Google Doc to retrieve\n});\n\nconst result = await googleDrive_get_doc.action();\n// outputSchema for result.data when operation === 'get_doc':\n// {\n// operation: \"get_doc\" // Get the content and metadata of a Google Doc using the Google Docs API,\n// success: boolean // Whether the document was retrieved successfully,\n// document: { documentId: string // The ID of the document, title: string // The title of the document, revisionId: string | undefined // The revision ID of the document, body: Record<string, unknown> | undefined // The main body of the document containing content array, suggestionsViewMode: string | undefined // The suggestions view mode applied to the document, inlineObjects: Record<string, unknown> | undefined // The inline objects (images, etc.) in the document, lists: Record<string, unknown> | undefined // The lists in the document, keyed by list ID } | undefined // The Google Docs document content and metadata,\n// plainText: string | undefined // Extracted plain text content from the document,\n// error: string // Error message if operation failed\n// }\n\n\n// Update Doc example\nconst googleDrive_update_doc = new GoogleDriveBubble({\n operation: \"update_doc\", // Update a Google Doc with new content using the Google Docs API batchUpdate\n document_id: \"example string\", // The ID of the Google Doc to update\n content: \"example string\", // The text or markdown content to write to the document (auto-detected)\n mode: \"replace\" // options: \"replace\", \"append\", // Update mode: \"replace\" clears existing content first, \"append\" adds to the end\n});\n\nconst result = await googleDrive_update_doc.action();\n// outputSchema for result.data when operation === 'update_doc':\n// {\n// operation: \"update_doc\" // Update a Google Doc with new content using the Google Docs API batchUpdate,\n// success: boolean // Whether the document was updated successfully,\n// documentId: string | undefined // The ID of the updated document,\n// revisionId: string | undefined // The new revision ID after the update,\n// error: string // Error message if operation failed\n// }\n\n\n// Always check success status before using data\nif (!result.success) {\n throw new Error(`google-drive failed: ${result.error}`);\n}\n\n// Access the actual data\nconst actualData = result.data;\nconsole.log(actualData);",
|
|
9602
|
+
"usageExample": "// Upload File example\nconst googleDrive_upload_file = new GoogleDriveBubble({\n operation: \"upload_file\", // Upload a file to Google Drive\n name: \"example string\", // Name for the uploaded file\n content: \"example string\", // File content as base64 encoded string or plain text\n mimeType: \"example string\", // MIME type of the file (auto-detected if not provided)\n parent_folder_id: \"example string\", // ID of the parent folder (uploads to root if not provided)\n convert_to_google_docs: false // default, // Convert uploaded file to Google Docs format if possible\n});\n\nconst result = await googleDrive_upload_file.action();\n// outputSchema for result.data when operation === 'upload_file':\n// {\n// operation: \"upload_file\" // Upload a file to Google Drive,\n// success: boolean // Whether the file was uploaded successfully,\n// file: { id: string // Unique file identifier, name: string // Name of the file, mimeType: string // MIME type of the file, size: string | undefined // Size of the file in bytes, createdTime: string | undefined // Creation time in RFC 3339 format, modifiedTime: string | undefined // Last modified time in RFC 3339 format, webViewLink: string | undefined // Link to view the file in Google Drive, webContentLink: string | undefined // Link to download the file, parents: string[] | undefined // Parent folder IDs, shared: boolean | undefined // Whether the file is shared, owners: { displayName: string | undefined // Owner display name, emailAddress: string | undefined // Owner email address }[] | undefined // File owners } | undefined // Uploaded file metadata,\n// error: string // Error message if operation failed\n// }\n\n\n// Download File example\nconst googleDrive_download_file = new GoogleDriveBubble({\n operation: \"download_file\", // Download a file from Google Drive\n file_id: \"example string\", // Google Drive file ID to download\n export_format: \"example string\", // Export format for Google Workspace files (e.g., \"application/pdf\", \"text/plain\")\n});\n\nconst result = await googleDrive_download_file.action();\n// outputSchema for result.data when operation === 'download_file':\n// {\n// operation: \"download_file\" // Download a file from Google Drive,\n// success: boolean // Whether the file was downloaded successfully,\n// content: string | undefined // File content as plain text (for text-based files) or base64 encoded string (for binary files),\n// filename: string | undefined // Original filename,\n// mimeType: string | undefined // MIME type of the downloaded file,\n// error: string // Error message if operation failed\n// }\n\n\n// List Files example\nconst googleDrive_list_files = new GoogleDriveBubble({\n operation: \"list_files\", // List files and folders in Google Drive\n folder_id: \"example string\", // ID of folder to list files from (lists from root if not provided)\n query: \"example string\", // Search query to filter files (e.g., \"name contains 'report'\"\n max_results: 100 // default, // Maximum number of files to return\n include_folders: true // default, // Include folders in the results\n order_by: \"modifiedTime desc\" // default, // Order results by field (e.g., \"name\", \"modifiedTime desc\")\n});\n\nconst result = await googleDrive_list_files.action();\n// outputSchema for result.data when operation === 'list_files':\n// {\n// operation: \"list_files\" // List files and folders in Google Drive,\n// success: boolean // Whether the file list was retrieved successfully,\n// files: { id: string // Unique file identifier, name: string // Name of the file, mimeType: string // MIME type of the file, size: string | undefined // Size of the file in bytes, createdTime: string | undefined // Creation time in RFC 3339 format, modifiedTime: string | undefined // Last modified time in RFC 3339 format, webViewLink: string | undefined // Link to view the file in Google Drive, webContentLink: string | undefined // Link to download the file, parents: string[] | undefined // Parent folder IDs, shared: boolean | undefined // Whether the file is shared, owners: { displayName: string | undefined // Owner display name, emailAddress: string | undefined // Owner email address }[] | undefined // File owners }[] | undefined // List of files and folders,\n// total_count: number | undefined // Total number of files found,\n// next_page_token: string | undefined // Token for fetching next page of results,\n// error: string // Error message if operation failed\n// }\n\n\n// Create Folder example\nconst googleDrive_create_folder = new GoogleDriveBubble({\n operation: \"create_folder\", // Create a new folder in Google Drive\n name: \"example string\", // Name of the folder to create\n parent_folder_id: \"example string\", // ID of the parent folder (creates in root if not provided)\n});\n\nconst result = await googleDrive_create_folder.action();\n// outputSchema for result.data when operation === 'create_folder':\n// {\n// operation: \"create_folder\" // Create a new folder in Google Drive,\n// success: boolean // Whether the folder was created successfully,\n// folder: { id: string // Unique folder identifier, name: string // Name of the folder, webViewLink: string | undefined // Link to view the folder in Google Drive, parents: string[] | undefined // Parent folder IDs } | undefined // Created folder metadata,\n// error: string // Error message if operation failed\n// }\n\n\n// Delete File example\nconst googleDrive_delete_file = new GoogleDriveBubble({\n operation: \"delete_file\", // Delete a file or folder from Google Drive\n file_id: \"example string\", // Google Drive file or folder ID to delete\n permanent: false // default, // Permanently delete (true) or move to trash (false)\n});\n\nconst result = await googleDrive_delete_file.action();\n// outputSchema for result.data when operation === 'delete_file':\n// {\n// operation: \"delete_file\" // Delete a file or folder from Google Drive,\n// success: boolean // Whether the file was deleted successfully,\n// deleted_file_id: string | undefined // ID of the deleted file,\n// error: string // Error message if operation failed\n// }\n\n\n// Get File Info example\nconst googleDrive_get_file_info = new GoogleDriveBubble({\n operation: \"get_file_info\", // Get detailed information about a file or folder\n file_id: \"example string\", // Google Drive file or folder ID to get info for\n include_permissions: false // default, // Include file permissions in the response\n});\n\nconst result = await googleDrive_get_file_info.action();\n// outputSchema for result.data when operation === 'get_file_info':\n// {\n// operation: \"get_file_info\" // Get detailed information about a file or folder,\n// success: boolean // Whether the file information was retrieved successfully,\n// file: { id: string // Unique file identifier, name: string // Name of the file, mimeType: string // MIME type of the file, size: string | undefined // Size of the file in bytes, createdTime: string | undefined // Creation time in RFC 3339 format, modifiedTime: string | undefined // Last modified time in RFC 3339 format, webViewLink: string | undefined // Link to view the file in Google Drive, webContentLink: string | undefined // Link to download the file, parents: string[] | undefined // Parent folder IDs, shared: boolean | undefined // Whether the file is shared, owners: { displayName: string | undefined // Owner display name, emailAddress: string | undefined // Owner email address }[] | undefined // File owners } | undefined // File metadata and information,\n// permissions: { id: string, type: string, role: string, emailAddress: string | undefined // Permission holder email address, displayName: string | undefined // Permission holder display name }[] | undefined // File permissions (if requested),\n// error: string // Error message if operation failed\n// }\n\n\n// Share File example\nconst googleDrive_share_file = new GoogleDriveBubble({\n operation: \"share_file\", // Share a file or folder with specific users or make it public\n file_id: \"example string\", // Google Drive file or folder ID to share\n email_address: \"example string\", // Email address to share with (for specific user sharing)\n role: \"reader\" // options: \"reader\", \"writer\", \"commenter\", \"owner\", // Permission role to grant\n type: \"user\" // options: \"user\", \"group\", \"domain\", \"anyone\", // Type of permission to create\n send_notification: true // default, // Send notification email to the user\n});\n\nconst result = await googleDrive_share_file.action();\n// outputSchema for result.data when operation === 'share_file':\n// {\n// operation: \"share_file\" // Share a file or folder with specific users or make it public,\n// success: boolean // Whether the file was shared successfully,\n// permission_id: string | undefined // ID of the created permission,\n// share_link: string | undefined // Shareable link to the file,\n// error: string // Error message if operation failed\n// }\n\n\n// Move File example\nconst googleDrive_move_file = new GoogleDriveBubble({\n operation: \"move_file\", // Move a file or folder to a different location in Google Drive\n file_id: \"example string\", // Google Drive file or folder ID to move\n new_parent_folder_id: \"example string\", // ID of the new parent folder (moves to root if not provided)\n remove_parent_folder_id: \"example string\", // ID of the parent folder to remove (removes from all parents if not provided)\n});\n\nconst result = await googleDrive_move_file.action();\n// outputSchema for result.data when operation === 'move_file':\n// {\n// operation: \"move_file\" // Move a file or folder to a different location in Google Drive,\n// success: boolean // Whether the file was moved successfully,\n// file: { id: string // Unique file identifier, name: string // Name of the file, mimeType: string // MIME type of the file, size: string | undefined // Size of the file in bytes, createdTime: string | undefined // Creation time in RFC 3339 format, modifiedTime: string | undefined // Last modified time in RFC 3339 format, webViewLink: string | undefined // Link to view the file in Google Drive, webContentLink: string | undefined // Link to download the file, parents: string[] | undefined // Parent folder IDs, shared: boolean | undefined // Whether the file is shared, owners: { displayName: string | undefined // Owner display name, emailAddress: string | undefined // Owner email address }[] | undefined // File owners } | undefined // Updated file metadata after move,\n// error: string // Error message if operation failed\n// }\n\n\n// Get Doc example\nconst googleDrive_get_doc = new GoogleDriveBubble({\n operation: \"get_doc\", // Get the content and metadata of a Google Doc using the Google Docs API, use this over download_file for Google Docs\n document_id: \"example string\", // The ID of the Google Doc to retrieve\n tab_id: \"example string\", // Specific tab ID to read. If omitted, reads first tab.\n include_all_tabs: false // default, // Return info for all tabs including their plain text content\n});\n\nconst result = await googleDrive_get_doc.action();\n// outputSchema for result.data when operation === 'get_doc':\n// {\n// operation: \"get_doc\" // Get the content and metadata of a Google Doc using the Google Docs API,\n// success: boolean // Whether the document was retrieved successfully,\n// document: { documentId: string // The ID of the document, title: string // The title of the document, revisionId: string | undefined // The revision ID of the document, body: Record<string, unknown> | undefined // The main body of the document containing content array, suggestionsViewMode: string | undefined // The suggestions view mode applied to the document, inlineObjects: Record<string, unknown> | undefined // The inline objects (images, etc.) in the document, lists: Record<string, unknown> | undefined // The lists in the document, keyed by list ID } | undefined // The Google Docs document content and metadata,\n// plainText: string | undefined // Extracted plain text content from the document,\n// tabs: { tabId: string // Unique tab identifier, title: string // Tab title, index: number // Tab position index, plainText: string | undefined // Plain text content of the tab }[] | undefined // All tabs in the document,\n// error: string // Error message if operation failed\n// }\n\n\n// Update Doc example\nconst googleDrive_update_doc = new GoogleDriveBubble({\n operation: \"update_doc\", // Update a Google Doc with new content using the Google Docs API batchUpdate\n document_id: \"example string\", // The ID of the Google Doc to update\n content: \"example string\", // The text or markdown content to write to the document (auto-detected)\n mode: \"replace\" // options: \"replace\", \"append\", // Update mode: \"replace\" clears existing content first, \"append\" adds to the end\n tab_id: \"example string\", // Tab to write to. If omitted, writes to first tab.\n});\n\nconst result = await googleDrive_update_doc.action();\n// outputSchema for result.data when operation === 'update_doc':\n// {\n// operation: \"update_doc\" // Update a Google Doc with new content using the Google Docs API batchUpdate,\n// success: boolean // Whether the document was updated successfully,\n// documentId: string | undefined // The ID of the updated document,\n// revisionId: string | undefined // The new revision ID after the update,\n// error: string // Error message if operation failed\n// }\n\n\n// Replace Text example\nconst googleDrive_replace_text = new GoogleDriveBubble({\n operation: \"replace_text\", // Find and replace text in a Google Doc while preserving formatting\n document_id: \"example string\", // The ID of the Google Doc to perform replacements in\n replacements: [{ find: \"example string\" // Text to find, replace: \"example string\" // Text to replace with, match_case: true // default // Whether to match case when finding text }], // List of find/replace pairs\n tab_id: \"example string\", // Tab to perform replacements in. If omitted, applies to all tabs.\n});\n\nconst result = await googleDrive_replace_text.action();\n// outputSchema for result.data when operation === 'replace_text':\n// {\n// operation: \"replace_text\" // Find and replace text in a Google Doc,\n// success: boolean // Whether the replacements were made successfully,\n// replacements_made: number | undefined // Total number of replacements made,\n// error: string // Error message if operation failed\n// }\n\n\n// Copy Doc example\nconst googleDrive_copy_doc = new GoogleDriveBubble({\n operation: \"copy_doc\", // Create a copy of a Google Doc (useful for templates)\n document_id: \"example string\", // Source document ID to copy\n new_name: \"example string\", // Name for the new document\n parent_folder_id: \"example string\", // Folder to place the copy in\n});\n\nconst result = await googleDrive_copy_doc.action();\n// outputSchema for result.data when operation === 'copy_doc':\n// {\n// operation: \"copy_doc\" // Create a copy of a Google Doc,\n// success: boolean // Whether the document was copied successfully,\n// new_document_id: string | undefined // ID of the new document,\n// new_document_url: string | undefined // URL to view the new document,\n// error: string // Error message if operation failed\n// }\n\n\n// Always check success status before using data\nif (!result.success) {\n throw new Error(`google-drive failed: ${result.error}`);\n}\n\n// Access the actual data\nconst actualData = result.data;\nconsole.log(actualData);",
|
|
9395
9603
|
"requiredCredentials": [
|
|
9396
9604
|
"GOOGLE_DRIVE_CRED"
|
|
9397
9605
|
]
|
|
@@ -57721,98 +57929,106 @@
|
|
|
57721
57929
|
"type": "tool",
|
|
57722
57930
|
"shortDescription": "LinkedIn connection automation - send connection requests with optional notes",
|
|
57723
57931
|
"useCase": "General purpose bubble for various workflow needs",
|
|
57724
|
-
"outputSchema": "
|
|
57932
|
+
"outputSchema": "Complex schema - see usage example for structure",
|
|
57725
57933
|
"inputJsonSchema": {
|
|
57726
|
-
"
|
|
57727
|
-
|
|
57728
|
-
"operation": {
|
|
57729
|
-
"type": "string",
|
|
57730
|
-
"enum": [
|
|
57731
|
-
"send_connection"
|
|
57732
|
-
],
|
|
57733
|
-
"description": "Send a connection request to a LinkedIn profile"
|
|
57734
|
-
},
|
|
57735
|
-
"profile_url": {
|
|
57736
|
-
"type": "string",
|
|
57737
|
-
"minLength": 1,
|
|
57738
|
-
"description": "LinkedIn profile URL (e.g., https://www.linkedin.com/in/username)"
|
|
57739
|
-
},
|
|
57740
|
-
"message": {
|
|
57741
|
-
"type": "string",
|
|
57742
|
-
"maxLength": 300,
|
|
57743
|
-
"description": "Optional personalized note to include with the connection request (max 300 characters)"
|
|
57744
|
-
},
|
|
57745
|
-
"credentials": {
|
|
57934
|
+
"anyOf": [
|
|
57935
|
+
{
|
|
57746
57936
|
"type": "object",
|
|
57747
|
-
"
|
|
57748
|
-
"
|
|
57937
|
+
"properties": {
|
|
57938
|
+
"operation": {
|
|
57939
|
+
"type": "string",
|
|
57940
|
+
"enum": [
|
|
57941
|
+
"send_connection"
|
|
57942
|
+
],
|
|
57943
|
+
"description": "Send a connection request to a LinkedIn profile"
|
|
57944
|
+
},
|
|
57945
|
+
"profile_url": {
|
|
57946
|
+
"type": "string",
|
|
57947
|
+
"minLength": 1,
|
|
57948
|
+
"description": "LinkedIn profile URL (e.g., https://www.linkedin.com/in/username)"
|
|
57949
|
+
},
|
|
57950
|
+
"message": {
|
|
57951
|
+
"type": "string",
|
|
57952
|
+
"maxLength": 300,
|
|
57953
|
+
"description": "Optional personalized note to include with the connection request (max 300 characters)"
|
|
57954
|
+
},
|
|
57955
|
+
"credentials": {
|
|
57956
|
+
"type": "object",
|
|
57957
|
+
"additionalProperties": {
|
|
57958
|
+
"type": "string"
|
|
57959
|
+
},
|
|
57960
|
+
"description": "Required: LINKEDIN_CRED for authenticated LinkedIn session"
|
|
57961
|
+
}
|
|
57749
57962
|
},
|
|
57750
|
-
"
|
|
57963
|
+
"required": [
|
|
57964
|
+
"operation",
|
|
57965
|
+
"profile_url"
|
|
57966
|
+
],
|
|
57967
|
+
"additionalProperties": false
|
|
57751
57968
|
}
|
|
57752
|
-
|
|
57753
|
-
"required": [
|
|
57754
|
-
"operation",
|
|
57755
|
-
"profile_url"
|
|
57756
|
-
],
|
|
57757
|
-
"additionalProperties": false
|
|
57969
|
+
]
|
|
57758
57970
|
},
|
|
57759
57971
|
"outputJsonSchema": {
|
|
57760
|
-
"
|
|
57761
|
-
|
|
57762
|
-
"operation": {
|
|
57763
|
-
"type": "string",
|
|
57764
|
-
"enum": [
|
|
57765
|
-
"send_connection"
|
|
57766
|
-
]
|
|
57767
|
-
},
|
|
57768
|
-
"success": {
|
|
57769
|
-
"type": "boolean",
|
|
57770
|
-
"description": "Whether the connection request was sent"
|
|
57771
|
-
},
|
|
57772
|
-
"message": {
|
|
57773
|
-
"type": "string",
|
|
57774
|
-
"description": "Success or status message"
|
|
57775
|
-
},
|
|
57776
|
-
"profile": {
|
|
57972
|
+
"anyOf": [
|
|
57973
|
+
{
|
|
57777
57974
|
"type": "object",
|
|
57778
57975
|
"properties": {
|
|
57779
|
-
"
|
|
57976
|
+
"operation": {
|
|
57780
57977
|
"type": "string",
|
|
57781
|
-
"
|
|
57978
|
+
"enum": [
|
|
57979
|
+
"send_connection"
|
|
57980
|
+
]
|
|
57782
57981
|
},
|
|
57783
|
-
"
|
|
57784
|
-
"type": "
|
|
57785
|
-
"description": "
|
|
57982
|
+
"success": {
|
|
57983
|
+
"type": "boolean",
|
|
57984
|
+
"description": "Whether the connection request was sent"
|
|
57786
57985
|
},
|
|
57787
|
-
"
|
|
57986
|
+
"message": {
|
|
57788
57987
|
"type": "string",
|
|
57789
|
-
"description": "
|
|
57988
|
+
"description": "Success or status message"
|
|
57790
57989
|
},
|
|
57791
|
-
"
|
|
57990
|
+
"profile": {
|
|
57991
|
+
"type": "object",
|
|
57992
|
+
"properties": {
|
|
57993
|
+
"name": {
|
|
57994
|
+
"type": "string",
|
|
57995
|
+
"description": "Full name of the profile owner"
|
|
57996
|
+
},
|
|
57997
|
+
"headline": {
|
|
57998
|
+
"type": "string",
|
|
57999
|
+
"description": "Professional headline"
|
|
58000
|
+
},
|
|
58001
|
+
"location": {
|
|
58002
|
+
"type": "string",
|
|
58003
|
+
"description": "Location information"
|
|
58004
|
+
},
|
|
58005
|
+
"profile_url": {
|
|
58006
|
+
"type": "string",
|
|
58007
|
+
"description": "LinkedIn profile URL"
|
|
58008
|
+
}
|
|
58009
|
+
},
|
|
58010
|
+
"required": [
|
|
58011
|
+
"name",
|
|
58012
|
+
"profile_url"
|
|
58013
|
+
],
|
|
58014
|
+
"additionalProperties": false,
|
|
58015
|
+
"description": "Profile information of the person"
|
|
58016
|
+
},
|
|
58017
|
+
"error": {
|
|
57792
58018
|
"type": "string",
|
|
57793
|
-
"description": "
|
|
58019
|
+
"description": "Error message if operation failed"
|
|
57794
58020
|
}
|
|
57795
58021
|
},
|
|
57796
58022
|
"required": [
|
|
57797
|
-
"
|
|
57798
|
-
"
|
|
58023
|
+
"operation",
|
|
58024
|
+
"success",
|
|
58025
|
+
"error"
|
|
57799
58026
|
],
|
|
57800
|
-
"additionalProperties": false
|
|
57801
|
-
"description": "Profile information of the person"
|
|
57802
|
-
},
|
|
57803
|
-
"error": {
|
|
57804
|
-
"type": "string",
|
|
57805
|
-
"description": "Error message if operation failed"
|
|
58027
|
+
"additionalProperties": false
|
|
57806
58028
|
}
|
|
57807
|
-
|
|
57808
|
-
"required": [
|
|
57809
|
-
"operation",
|
|
57810
|
-
"success",
|
|
57811
|
-
"error"
|
|
57812
|
-
],
|
|
57813
|
-
"additionalProperties": false
|
|
58029
|
+
]
|
|
57814
58030
|
},
|
|
57815
|
-
"usageExample": "//
|
|
58031
|
+
"usageExample": "// Send Connection example\nconst linkedinConnectionTool_send_connection = new LinkedInConnectionTool({\n operation: \"send_connection\", // Send a connection request to a LinkedIn profile\n profile_url: \"example string\", // LinkedIn profile URL (e.g., https://www.linkedin.com/in/username)\n message: \"example string\", // Optional personalized note to include with the connection request (max 300 characters)\n});\n\nconst result = await linkedinConnectionTool_send_connection.action();\n// outputSchema for result.data when operation === 'send_connection':\n// {\n// operation: \"send_connection\",\n// success: boolean // Whether the connection request was sent,\n// message: string | undefined // Success or status message,\n// profile: { name: string // Full name of the profile owner, headline: string | undefined // Professional headline, location: string | undefined // Location information, profile_url: string // LinkedIn profile URL } | undefined // Profile information of the person,\n// error: string // Error message if operation failed\n// }\n\n\n// Always check success status before using data\nif (!result.success) {\n throw new Error(`linkedin-connection-tool failed: ${result.error}`);\n}\n\n// Access the actual data\nconst actualData = result.data;\nconsole.log(actualData);",
|
|
57816
58032
|
"requiredCredentials": [
|
|
57817
58033
|
"LINKEDIN_CRED",
|
|
57818
58034
|
"CLOUDFLARE_R2_ACCESS_KEY",
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@bubblelab/bubble-core",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.69",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"license": "Apache-2.0",
|
|
6
6
|
"main": "./dist/index.js",
|
|
@@ -40,7 +40,7 @@
|
|
|
40
40
|
"puppeteer-core": "^24.10.0",
|
|
41
41
|
"resend": "^4.8.0",
|
|
42
42
|
"zod": "^3.24.1",
|
|
43
|
-
"@bubblelab/shared-schemas": "0.1.
|
|
43
|
+
"@bubblelab/shared-schemas": "0.1.70"
|
|
44
44
|
},
|
|
45
45
|
"devDependencies": {
|
|
46
46
|
"zod-to-json-schema": "^3.24.6",
|