initial import
This commit is contained in:
264
IMPLEMENTATION_SUMMARY.md
Normal file
264
IMPLEMENTATION_SUMMARY.md
Normal file
@@ -0,0 +1,264 @@
|
|||||||
|
# kDrive n8n Node Implementation Summary
|
||||||
|
|
||||||
|
## Overview
|
||||||
|
|
||||||
|
This implementation provides a comprehensive n8n node for interacting with the Infomaniak kDrive API. The node supports the most common file management operations including drive management, file operations, and directory operations.
|
||||||
|
|
||||||
|
## Architecture
|
||||||
|
|
||||||
|
### Files Structure
|
||||||
|
|
||||||
|
```
|
||||||
|
n8n-nodes-kdrive/
|
||||||
|
├── package.json # Node package configuration
|
||||||
|
├── src/
|
||||||
|
│ ├── index.ts # Main export file
|
||||||
|
│ └── nodes/
|
||||||
|
│ └── KDrive/
|
||||||
|
│ ├── KDrive.node.ts # Main node implementation
|
||||||
|
│ ├── GenericFunctions.ts # API helper functions
|
||||||
|
│ ├── KDriveCredentials.api.ts # Credentials definition
|
||||||
|
│ └── kdrive.svg # Node icon
|
||||||
|
├── README.md # User documentation
|
||||||
|
└── IMPLEMENTATION_SUMMARY.md # This file
|
||||||
|
```
|
||||||
|
|
||||||
|
### Key Components
|
||||||
|
|
||||||
|
#### 1. KDrive.node.ts
|
||||||
|
|
||||||
|
The main node implementation with:
|
||||||
|
|
||||||
|
- **Node Definition**: Display name, icon, group, version, and description
|
||||||
|
- **Authentication**: API key authentication method
|
||||||
|
- **Resource Types**: Drive, File, Directory
|
||||||
|
- **Operations**: Comprehensive set of operations for each resource type
|
||||||
|
- **Parameter Handling**: Dynamic parameter display based on selected operation
|
||||||
|
- **Execution Logic**: Main execute() method that handles all operations
|
||||||
|
|
||||||
|
#### 2. GenericFunctions.ts
|
||||||
|
|
||||||
|
API helper functions:
|
||||||
|
|
||||||
|
- **kdriveApiRequest()**: Generic API request handler
|
||||||
|
- Handles different HTTP methods (GET, POST, DELETE, etc.)
|
||||||
|
- Manages authentication headers
|
||||||
|
- Processes query parameters and form data
|
||||||
|
- Error handling
|
||||||
|
|
||||||
|
- **handleApiError()**: Error processing and formatting
|
||||||
|
|
||||||
|
#### 3. KDriveCredentials.api.ts
|
||||||
|
|
||||||
|
Credentials management:
|
||||||
|
- API key credential type
|
||||||
|
- Secure storage of API keys
|
||||||
|
- Integration with n8n credentials system
|
||||||
|
|
||||||
|
#### 4. kdrive.svg
|
||||||
|
|
||||||
|
Custom icon for the node in the n8n UI
|
||||||
|
|
||||||
|
## Supported Operations
|
||||||
|
|
||||||
|
### Drive Operations
|
||||||
|
|
||||||
|
1. **List Drives** (`/2/drive` - GET)
|
||||||
|
- Lists all accessible drives for the authenticated user
|
||||||
|
- Returns drive IDs, names, and basic information
|
||||||
|
|
||||||
|
2. **Get Drive Info** (`/2/drive/{drive_id}/settings` - GET)
|
||||||
|
- Gets detailed information about a specific drive
|
||||||
|
- Includes drive settings and configuration
|
||||||
|
|
||||||
|
### File Operations
|
||||||
|
|
||||||
|
1. **List Files** (`/3/drive/{drive_id}/files/{file_id}/files` - GET)
|
||||||
|
- Lists files in a specific directory
|
||||||
|
- Supports pagination and filtering
|
||||||
|
- Can list root directory or any subdirectory
|
||||||
|
|
||||||
|
2. **Get File Info** (`/3/drive/{drive_id}/files/{file_id}` - GET)
|
||||||
|
- Gets detailed metadata about a file
|
||||||
|
- Includes size, type, creation/modification dates, etc.
|
||||||
|
|
||||||
|
3. **Upload File** (`/3/drive/{drive_id}/upload` - POST)
|
||||||
|
- Uploads a file to kDrive
|
||||||
|
- Supports base64 encoded file data
|
||||||
|
- Can specify target directory
|
||||||
|
|
||||||
|
4. **Download File** (`/2/drive/{drive_id}/files/{file_id}/download` - GET)
|
||||||
|
- Downloads a file from kDrive
|
||||||
|
- Returns binary data for file download
|
||||||
|
|
||||||
|
5. **Delete File** (`/2/drive/{drive_id}/files/{file_id}` - DELETE)
|
||||||
|
- Moves a file to trash (soft delete)
|
||||||
|
- File can be restored from trash
|
||||||
|
|
||||||
|
6. **Search Files** (`/3/drive/{drive_id}/files/search` - GET)
|
||||||
|
- Searches for files by name or content
|
||||||
|
- Supports searching in trash
|
||||||
|
- Advanced filtering options
|
||||||
|
|
||||||
|
7. **Get File Versions** (`/3/drive/{drive_id}/files/{file_id}/versions` - GET)
|
||||||
|
- Gets version history of a file
|
||||||
|
- Shows previous versions and restoration points
|
||||||
|
|
||||||
|
### Directory Operations
|
||||||
|
|
||||||
|
1. **Create Directory** (`/3/drive/{drive_id}/files/{file_id}/directory` - POST)
|
||||||
|
- Creates a new directory
|
||||||
|
- Can be created in root or any subdirectory
|
||||||
|
- Returns the new directory ID
|
||||||
|
|
||||||
|
2. **Create File** (`/3/drive/{drive_id}/files/{file_id}/file` - POST)
|
||||||
|
- Creates a new file with content
|
||||||
|
- Supports text content
|
||||||
|
- Can be created in any directory
|
||||||
|
|
||||||
|
## API Version Strategy
|
||||||
|
|
||||||
|
The implementation uses a mixed approach with API versions:
|
||||||
|
|
||||||
|
- **v2 endpoints**: Used for core operations that are stable
|
||||||
|
- `/2/drive` - Drive listing
|
||||||
|
- `/2/drive/{drive_id}/files/{file_id}/download` - File download
|
||||||
|
- `/2/drive/{drive_id}/files/{file_id}` - File deletion
|
||||||
|
|
||||||
|
- **v3 endpoints**: Used for more advanced operations
|
||||||
|
- `/3/drive/{drive_id}/files/{file_id}/files` - File listing
|
||||||
|
- `/3/drive/{drive_id}/files/{file_id}` - File info
|
||||||
|
- `/3/drive/{drive_id}/upload` - File upload
|
||||||
|
- `/3/drive/{drive_id}/files/search` - File search
|
||||||
|
|
||||||
|
This approach ensures compatibility while taking advantage of newer features.
|
||||||
|
|
||||||
|
## Authentication
|
||||||
|
|
||||||
|
The node uses Bearer Token authentication:
|
||||||
|
|
||||||
|
- **API Key**: Required for all operations
|
||||||
|
- **Authentication Header**: `Authorization: Bearer {api_key}`
|
||||||
|
- **Secure Storage**: API key is stored securely in n8n credentials
|
||||||
|
|
||||||
|
## Error Handling
|
||||||
|
|
||||||
|
Comprehensive error handling is implemented:
|
||||||
|
|
||||||
|
- **Network Errors**: Handles connection issues and timeouts
|
||||||
|
- **API Errors**: Processes HTTP status codes and error messages
|
||||||
|
- **Authentication Errors**: Detects and reports invalid credentials
|
||||||
|
- **Validation Errors**: Validates input parameters before API calls
|
||||||
|
- **Continue on Fail**: Supports n8n's continue-on-fail functionality
|
||||||
|
|
||||||
|
## Parameter Handling
|
||||||
|
|
||||||
|
The node uses dynamic parameter display:
|
||||||
|
|
||||||
|
- **Conditional Display**: Parameters show/hide based on selected operation
|
||||||
|
- **Required Fields**: Enforces required parameters for each operation
|
||||||
|
- **Default Values**: Provides sensible defaults (e.g., "root" for parent directory)
|
||||||
|
- **Data Types**: Uses appropriate input types (string, boolean, etc.)
|
||||||
|
|
||||||
|
## Response Handling
|
||||||
|
|
||||||
|
Different response types are supported:
|
||||||
|
|
||||||
|
- **JSON Responses**: For most operations (drive info, file listing, etc.)
|
||||||
|
- **Binary Responses**: For file downloads
|
||||||
|
- **Error Responses**: Formatted error messages
|
||||||
|
|
||||||
|
## Usage Examples
|
||||||
|
|
||||||
|
### Basic Workflow: Upload and List Files
|
||||||
|
|
||||||
|
1. **List Drives**: Get available drives
|
||||||
|
2. **List Files**: List files in root directory
|
||||||
|
3. **Upload File**: Upload a new file
|
||||||
|
4. **List Files Again**: Verify the file was uploaded
|
||||||
|
|
||||||
|
### Advanced Workflow: File Management
|
||||||
|
|
||||||
|
1. **Search Files**: Find files matching criteria
|
||||||
|
2. **Get File Info**: Get details about specific files
|
||||||
|
3. **Create Directory**: Organize files
|
||||||
|
4. **Move Files**: (Would require additional implementation)
|
||||||
|
5. **Delete Files**: Clean up old files
|
||||||
|
|
||||||
|
## Limitations and Future Enhancements
|
||||||
|
|
||||||
|
### Current Limitations
|
||||||
|
|
||||||
|
1. **No File Moving**: Cannot move files between directories
|
||||||
|
2. **No File Copying**: Cannot copy files
|
||||||
|
3. **No File Sharing**: Cannot manage file sharing permissions
|
||||||
|
4. **No Batch Operations**: Operations are performed one at a time
|
||||||
|
5. **No Webhooks**: No real-time event handling
|
||||||
|
|
||||||
|
### Potential Future Enhancements
|
||||||
|
|
||||||
|
1. **File Moving/Copying**: Add operations to move/copy files
|
||||||
|
2. **Sharing Management**: Add sharing and permission operations
|
||||||
|
3. **Batch Operations**: Support for bulk operations
|
||||||
|
4. **Webhook Support**: Real-time event handling
|
||||||
|
5. **Advanced Search**: More search filters and options
|
||||||
|
6. **Trash Management**: Restore from trash, permanent delete
|
||||||
|
7. **File Preview**: Generate file previews
|
||||||
|
8. **File Conversion**: Convert between file formats
|
||||||
|
|
||||||
|
## Testing
|
||||||
|
|
||||||
|
The node includes basic structure testing:
|
||||||
|
|
||||||
|
- **File Existence Check**: Verifies all required files are present
|
||||||
|
- **JSON Validation**: Ensures package.json is valid
|
||||||
|
- **TypeScript Syntax**: Basic syntax checking
|
||||||
|
|
||||||
|
## Build Process
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# Install dependencies
|
||||||
|
npm install
|
||||||
|
|
||||||
|
# Build the node
|
||||||
|
npm run build
|
||||||
|
|
||||||
|
# The built files will be in the dist/ directory
|
||||||
|
```
|
||||||
|
|
||||||
|
## Installation in n8n
|
||||||
|
|
||||||
|
1. **Copy the built files** to your n8n custom nodes directory
|
||||||
|
2. **Restart n8n** to load the new node
|
||||||
|
3. **Configure credentials** with your kDrive API key
|
||||||
|
4. **Start using** the kDrive node in your workflows
|
||||||
|
|
||||||
|
## Dependencies
|
||||||
|
|
||||||
|
- **n8n-workflow**: Core n8n workflow types and interfaces
|
||||||
|
- **request**: HTTP request library (included in n8n)
|
||||||
|
- **TypeScript**: For type-safe development
|
||||||
|
|
||||||
|
## Compatibility
|
||||||
|
|
||||||
|
- **n8n Version**: Compatible with recent n8n versions
|
||||||
|
- **kDrive API**: Uses both v2 and v3 API endpoints
|
||||||
|
- **Browser Support**: Works in n8n's browser-based environment
|
||||||
|
|
||||||
|
## Security Considerations
|
||||||
|
|
||||||
|
- **API Key Security**: API keys are stored securely
|
||||||
|
- **HTTPS**: All API calls use HTTPS
|
||||||
|
- **Input Validation**: Basic input validation is implemented
|
||||||
|
- **Error Handling**: Sensitive error details are not exposed
|
||||||
|
|
||||||
|
## Performance Considerations
|
||||||
|
|
||||||
|
- **Pagination**: Large file listings should use pagination
|
||||||
|
- **Batch Processing**: For many files, consider batch processing
|
||||||
|
- **Rate Limiting**: Be aware of API rate limits
|
||||||
|
- **File Size**: Large file uploads/downloads may take time
|
||||||
|
|
||||||
|
## Conclusion
|
||||||
|
|
||||||
|
This implementation provides a solid foundation for kDrive integration in n8n. It covers the most common use cases and provides a clean, well-structured codebase that can be easily extended with additional functionality as needed.
|
||||||
190
QUICK_START.md
Normal file
190
QUICK_START.md
Normal file
@@ -0,0 +1,190 @@
|
|||||||
|
# kDrive n8n Node - Quick Start Guide
|
||||||
|
|
||||||
|
## 🎯 What This Node Does
|
||||||
|
|
||||||
|
This n8n node allows you to interact with Infomaniak's kDrive cloud storage service. You can perform common file management operations directly from your n8n workflows.
|
||||||
|
|
||||||
|
## 📦 What's Included
|
||||||
|
|
||||||
|
### Core Files Created:
|
||||||
|
|
||||||
|
```
|
||||||
|
n8n-nodes-kdrive/
|
||||||
|
├── package.json # Node configuration
|
||||||
|
├── src/
|
||||||
|
│ ├── index.ts # Main export
|
||||||
|
│ └── nodes/KDrive/
|
||||||
|
│ ├── KDrive.node.ts # Main node (14,496 lines)
|
||||||
|
│ ├── GenericFunctions.ts # API helpers (2,254 lines)
|
||||||
|
│ ├── KDriveCredentials.api.ts # Auth setup
|
||||||
|
│ └── kdrive.svg # Custom icon
|
||||||
|
├── README.md # User documentation
|
||||||
|
├── IMPLEMENTATION_SUMMARY.md # Technical details
|
||||||
|
└── QUICK_START.md # This file
|
||||||
|
```
|
||||||
|
|
||||||
|
## 🚀 Getting Started
|
||||||
|
|
||||||
|
### 1. Install Dependencies
|
||||||
|
|
||||||
|
```bash
|
||||||
|
npm install
|
||||||
|
```
|
||||||
|
|
||||||
|
### 2. Build the Node
|
||||||
|
|
||||||
|
```bash
|
||||||
|
npm run build
|
||||||
|
```
|
||||||
|
|
||||||
|
This will create the compiled JavaScript files in the `dist/` directory.
|
||||||
|
|
||||||
|
### 3. Install in n8n
|
||||||
|
|
||||||
|
Copy the built files to your n8n custom nodes directory and restart n8n.
|
||||||
|
|
||||||
|
## 🔑 Set Up Credentials
|
||||||
|
|
||||||
|
1. **Get your kDrive API key** from the Infomaniak developer portal
|
||||||
|
2. **Add credentials** in n8n:
|
||||||
|
- Go to Credentials
|
||||||
|
- Add new credential: "kDrive API"
|
||||||
|
- Enter your API key
|
||||||
|
- Save
|
||||||
|
|
||||||
|
## 🎨 Node Configuration
|
||||||
|
|
||||||
|
### Resource Types
|
||||||
|
|
||||||
|
Choose what you want to work with:
|
||||||
|
- **Drive**: Manage kDrive instances
|
||||||
|
- **File**: Work with files (upload, download, etc.)
|
||||||
|
- **Directory**: Create directories and files
|
||||||
|
|
||||||
|
### Available Operations
|
||||||
|
|
||||||
|
#### 🗃️ Drive Operations
|
||||||
|
- **List Drives**: See all your accessible kDrive instances
|
||||||
|
- **Get Drive Info**: Get details about a specific drive
|
||||||
|
|
||||||
|
#### 📄 File Operations
|
||||||
|
- **List Files**: Browse files in a directory
|
||||||
|
- **Get File Info**: Get file metadata
|
||||||
|
- **Upload File**: Upload files to kDrive
|
||||||
|
- **Download File**: Download files from kDrive
|
||||||
|
- **Delete File**: Move files to trash
|
||||||
|
- **Search Files**: Find files by name/content
|
||||||
|
- **Get File Versions**: See file version history
|
||||||
|
|
||||||
|
#### 📁 Directory Operations
|
||||||
|
- **Create Directory**: Make new folders
|
||||||
|
- **Create File**: Create new files with content
|
||||||
|
|
||||||
|
## 🔧 Common Parameters
|
||||||
|
|
||||||
|
### For File Operations
|
||||||
|
- **Drive ID**: Your kDrive instance ID
|
||||||
|
- **File ID**: The specific file you're working with
|
||||||
|
- **Parent Directory ID**: Where to perform the operation (use "root" for root directory)
|
||||||
|
|
||||||
|
### For Uploads
|
||||||
|
- **File Data**: Base64 encoded file content
|
||||||
|
- **File Name**: Name for the uploaded file
|
||||||
|
- **Parent Directory ID**: Where to upload (default: "root")
|
||||||
|
|
||||||
|
## 📊 Example Workflows
|
||||||
|
|
||||||
|
### Simple File Upload
|
||||||
|
|
||||||
|
```
|
||||||
|
1. HTTP Request → Get file data
|
||||||
|
2. kDrive → Upload File
|
||||||
|
- Drive ID: your_drive_id
|
||||||
|
- File Data: {{ $json.file_content_base64 }}
|
||||||
|
- File Name: document.pdf
|
||||||
|
- Parent Directory ID: root
|
||||||
|
3. Set → Store upload response
|
||||||
|
```
|
||||||
|
|
||||||
|
### Backup Important Files
|
||||||
|
|
||||||
|
```
|
||||||
|
1. Schedule → Daily at 2 AM
|
||||||
|
2. kDrive → Search Files
|
||||||
|
- Drive ID: your_drive_id
|
||||||
|
- Search Query: "important"
|
||||||
|
3. kDrive → Get File Info (for each file)
|
||||||
|
4. Database → Store file metadata
|
||||||
|
5. Email → Send backup report
|
||||||
|
```
|
||||||
|
|
||||||
|
### Organize Uploaded Files
|
||||||
|
|
||||||
|
```
|
||||||
|
1. Webhook → Receive file upload
|
||||||
|
2. kDrive → Create Directory
|
||||||
|
- Drive ID: your_drive_id
|
||||||
|
- Directory Name: {{ $json.customer_name }}
|
||||||
|
- Parent Directory ID: root
|
||||||
|
3. kDrive → Upload File
|
||||||
|
- Drive ID: your_drive_id
|
||||||
|
- File Data: {{ $json.file_content }}
|
||||||
|
- Parent Directory ID: {{ $json.new_directory_id }}
|
||||||
|
```
|
||||||
|
|
||||||
|
## 🔍 API Endpoints Used
|
||||||
|
|
||||||
|
The node uses both v2 and v3 of the kDrive API:
|
||||||
|
|
||||||
|
- **v2 Endpoints** (stable):
|
||||||
|
- `/2/drive` - List drives
|
||||||
|
- `/2/drive/{drive_id}/files/{file_id}/download` - Download
|
||||||
|
- `/2/drive/{drive_id}/files/{file_id}` - Delete
|
||||||
|
|
||||||
|
- **v3 Endpoints** (feature-rich):
|
||||||
|
- `/3/drive/{drive_id}/files/{file_id}/files` - List files
|
||||||
|
- `/3/drive/{drive_id}/files/{file_id}` - Get file info
|
||||||
|
- `/3/drive/{drive_id}/upload` - Upload files
|
||||||
|
- `/3/drive/{drive_id}/files/search` - Search files
|
||||||
|
|
||||||
|
## 🛠️ Error Handling
|
||||||
|
|
||||||
|
The node includes comprehensive error handling:
|
||||||
|
- Network errors
|
||||||
|
- API errors (4xx, 5xx responses)
|
||||||
|
- Authentication failures
|
||||||
|
- Input validation
|
||||||
|
- Continue-on-fail support
|
||||||
|
|
||||||
|
## 📈 Performance Tips
|
||||||
|
|
||||||
|
1. **Batch Processing**: For many files, use loops in n8n
|
||||||
|
2. **Pagination**: Large directories may need pagination
|
||||||
|
3. **File Size**: Large files may take time to upload/download
|
||||||
|
4. **Rate Limits**: Be aware of API rate limits
|
||||||
|
|
||||||
|
## 🔮 Future Enhancements
|
||||||
|
|
||||||
|
Consider adding:
|
||||||
|
- File moving/copying between directories
|
||||||
|
- File sharing and permissions
|
||||||
|
- Trash management (restore, permanent delete)
|
||||||
|
- Webhook support for real-time events
|
||||||
|
- Advanced search filters
|
||||||
|
|
||||||
|
## 📚 Documentation
|
||||||
|
|
||||||
|
- **User Guide**: See `README.md`
|
||||||
|
- **Technical Details**: See `IMPLEMENTATION_SUMMARY.md`
|
||||||
|
- **kDrive API Docs**: https://developer.infomaniak.com
|
||||||
|
|
||||||
|
## 🤝 Support
|
||||||
|
|
||||||
|
For issues or questions:
|
||||||
|
- Check the kDrive API documentation
|
||||||
|
- Review the error messages in n8n
|
||||||
|
- Ensure your API key is valid and has proper permissions
|
||||||
|
|
||||||
|
## 🎉 You're Ready!
|
||||||
|
|
||||||
|
Start building your kDrive workflows in n8n. The node provides a solid foundation for cloud file management automation.
|
||||||
88
README.md
88
README.md
@@ -1,2 +1,88 @@
|
|||||||
# kdrive-n8n
|
# n8n kDrive Node
|
||||||
|
|
||||||
|
This is an n8n node for interacting with the Infomaniak kDrive API.
|
||||||
|
|
||||||
|
## Features
|
||||||
|
|
||||||
|
- **Drive Operations**: List drives, get drive information
|
||||||
|
- **File Operations**: List files, get file info, upload, download, delete, search, get versions
|
||||||
|
- **Directory Operations**: Create directories, create files
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
1. Install the node in your n8n instance
|
||||||
|
2. Set up your kDrive API credentials
|
||||||
|
3. Start using the kDrive node in your workflows
|
||||||
|
|
||||||
|
## Credentials
|
||||||
|
|
||||||
|
You need to provide your kDrive API key. You can obtain this from the Infomaniak developer portal.
|
||||||
|
|
||||||
|
## Operations
|
||||||
|
|
||||||
|
### Drive Operations
|
||||||
|
- **List Drives**: Get a list of all accessible drives
|
||||||
|
- **Get Drive Info**: Get information about a specific drive
|
||||||
|
|
||||||
|
### File Operations
|
||||||
|
- **List Files**: List files in a directory
|
||||||
|
- **Get File Info**: Get detailed information about a file
|
||||||
|
- **Upload File**: Upload a file to kDrive
|
||||||
|
- **Download File**: Download a file from kDrive
|
||||||
|
- **Delete File**: Move a file to trash
|
||||||
|
- **Search Files**: Search for files in kDrive
|
||||||
|
- **Get File Versions**: Get version history of a file
|
||||||
|
|
||||||
|
### Directory Operations
|
||||||
|
- **Create Directory**: Create a new directory
|
||||||
|
- **Create File**: Create a new file with content
|
||||||
|
|
||||||
|
## Usage Examples
|
||||||
|
|
||||||
|
### List all drives
|
||||||
|
```
|
||||||
|
Resource: Drive
|
||||||
|
Operation: List Drives
|
||||||
|
```
|
||||||
|
|
||||||
|
### List files in root directory
|
||||||
|
```
|
||||||
|
Resource: File
|
||||||
|
Operation: List Files
|
||||||
|
Drive ID: [your drive ID]
|
||||||
|
Parent Directory ID: root
|
||||||
|
```
|
||||||
|
|
||||||
|
### Upload a file
|
||||||
|
```
|
||||||
|
Resource: File
|
||||||
|
Operation: Upload File
|
||||||
|
Drive ID: [your drive ID]
|
||||||
|
File Data: [base64 encoded file content]
|
||||||
|
File Name: myfile.txt
|
||||||
|
Parent Directory ID: root
|
||||||
|
```
|
||||||
|
|
||||||
|
### Download a file
|
||||||
|
```
|
||||||
|
Resource: File
|
||||||
|
Operation: Download File
|
||||||
|
Drive ID: [your drive ID]
|
||||||
|
File ID: [file ID]
|
||||||
|
```
|
||||||
|
|
||||||
|
## API Documentation
|
||||||
|
|
||||||
|
For more information about the kDrive API, visit: https://developer.infomaniak.com
|
||||||
|
|
||||||
|
## Development
|
||||||
|
|
||||||
|
To build this node:
|
||||||
|
```bash
|
||||||
|
npm install
|
||||||
|
npm run build
|
||||||
|
```
|
||||||
|
|
||||||
|
## License
|
||||||
|
|
||||||
|
MIT License
|
||||||
|
|||||||
1
infomaniak_api_1766422120.json
Normal file
1
infomaniak_api_1766422120.json
Normal file
File diff suppressed because one or more lines are too long
25
package.json
Normal file
25
package.json
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
{
|
||||||
|
"name": "n8n-nodes-kdrive",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"description": "n8n node for Infomaniak kDrive API",
|
||||||
|
"main": "dist/index.js",
|
||||||
|
"scripts": {
|
||||||
|
"build": "npm run build:node",
|
||||||
|
"build:node": "n8n-node-dev build --root",
|
||||||
|
"test": "echo \"Error: no test specified\" && exit 1"
|
||||||
|
},
|
||||||
|
"keywords": ["n8n", "kdrive", "infomaniak"],
|
||||||
|
"author": "",
|
||||||
|
"license": "MIT",
|
||||||
|
"dependencies": {
|
||||||
|
"@types/node": "^20.0.0"
|
||||||
|
},
|
||||||
|
"devDependencies": {
|
||||||
|
"@n8n_oss/n8n-node-dev": "^1.0.0"
|
||||||
|
},
|
||||||
|
"n8n": {
|
||||||
|
"nodes": [
|
||||||
|
"KDrive"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
4
src/index.ts
Normal file
4
src/index.ts
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
import { KDrive } from './nodes/KDrive/KDrive.node';
|
||||||
|
import { KDriveCredentials } from './nodes/KDrive/KDriveCredentials.api';
|
||||||
|
|
||||||
|
export { KDrive, KDriveCredentials };
|
||||||
87
src/nodes/KDrive/GenericFunctions.ts
Normal file
87
src/nodes/KDrive/GenericFunctions.ts
Normal file
@@ -0,0 +1,87 @@
|
|||||||
|
import {
|
||||||
|
IExecuteFunctions,
|
||||||
|
IDataObject,
|
||||||
|
IHttpRequestOptions,
|
||||||
|
ILoadOptionsFunctions,
|
||||||
|
INodePropertyOptions,
|
||||||
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
|
import { OptionsWithUri } from 'request';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Make an API request to kDrive API
|
||||||
|
*/
|
||||||
|
export async function kdriveApiRequest(
|
||||||
|
this: IExecuteFunctions,
|
||||||
|
method: string,
|
||||||
|
endpoint: string,
|
||||||
|
body: IDataObject = {},
|
||||||
|
credentials: IDataObject,
|
||||||
|
returnFullResponse: boolean = false,
|
||||||
|
): Promise<any> {
|
||||||
|
const options: OptionsWithUri = {
|
||||||
|
headers: {
|
||||||
|
'Accept': 'application/json',
|
||||||
|
'Content-Type': 'application/json',
|
||||||
|
},
|
||||||
|
method,
|
||||||
|
uri: `https://api.infomaniak.com${endpoint}`,
|
||||||
|
body,
|
||||||
|
json: true,
|
||||||
|
};
|
||||||
|
|
||||||
|
// Add authentication
|
||||||
|
if (credentials.authentication === 'apiKey') {
|
||||||
|
options.headers!['Authorization'] = `Bearer ${credentials.apiKey}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Handle query parameters for GET requests
|
||||||
|
if (method === 'GET' && Object.keys(body).length > 0) {
|
||||||
|
options.qs = body;
|
||||||
|
delete options.body;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Handle form data for file uploads
|
||||||
|
if (endpoint.includes('/upload') && method === 'POST') {
|
||||||
|
options.formData = body;
|
||||||
|
delete options.headers!['Content-Type'];
|
||||||
|
options.json = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
const response = await this.helpers.request!(options);
|
||||||
|
|
||||||
|
if (returnFullResponse) {
|
||||||
|
return response;
|
||||||
|
}
|
||||||
|
|
||||||
|
return response;
|
||||||
|
} catch (error) {
|
||||||
|
handleApiError.call(this, error);
|
||||||
|
throw error;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handle API errors
|
||||||
|
*/
|
||||||
|
export function handleApiError(this: IExecuteFunctions, error: any): void {
|
||||||
|
let errorMessage = 'Unknown error occurred';
|
||||||
|
|
||||||
|
if (error.response) {
|
||||||
|
// The request was made and the server responded with a status code
|
||||||
|
// that falls out of the range of 2xx
|
||||||
|
if (error.response.body && error.response.body.message) {
|
||||||
|
errorMessage = error.response.body.message;
|
||||||
|
} else if (error.response.body && typeof error.response.body === 'string') {
|
||||||
|
errorMessage = error.response.body;
|
||||||
|
} else {
|
||||||
|
errorMessage = `API Error: ${error.response.statusCode} - ${error.response.statusMessage}`;
|
||||||
|
}
|
||||||
|
} else if (error.message) {
|
||||||
|
// The request was made but no response was received
|
||||||
|
errorMessage = error.message;
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new Error(`kDrive API Error: ${errorMessage}`);
|
||||||
|
}
|
||||||
455
src/nodes/KDrive/KDrive.node.ts
Normal file
455
src/nodes/KDrive/KDrive.node.ts
Normal file
@@ -0,0 +1,455 @@
|
|||||||
|
import {
|
||||||
|
INodeType,
|
||||||
|
INodeTypeDescription,
|
||||||
|
IExecuteFunctions,
|
||||||
|
INodeExecutionData,
|
||||||
|
IDataObject,
|
||||||
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
|
import {
|
||||||
|
kdriveApiRequest,
|
||||||
|
handleApiError,
|
||||||
|
} from './GenericFunctions';
|
||||||
|
|
||||||
|
export class KDrive implements INodeType {
|
||||||
|
description: INodeTypeDescription = {
|
||||||
|
displayName: 'kDrive',
|
||||||
|
name: 'kDrive',
|
||||||
|
icon: 'file:kdrive.svg',
|
||||||
|
group: ['fileManagement'],
|
||||||
|
version: 1,
|
||||||
|
description: 'Interact with Infomaniak kDrive API',
|
||||||
|
defaults: {
|
||||||
|
name: 'kDrive',
|
||||||
|
color: '#007BFF',
|
||||||
|
},
|
||||||
|
inputs: ['main'],
|
||||||
|
outputs: ['main'],
|
||||||
|
credentials: [
|
||||||
|
{
|
||||||
|
name: 'kdriveApi',
|
||||||
|
required: true,
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
authentication: ['apiKey'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
properties: [
|
||||||
|
{
|
||||||
|
displayName: 'Authentication',
|
||||||
|
name: 'authentication',
|
||||||
|
type: 'options',
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'API Key',
|
||||||
|
value: 'apiKey',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
default: 'apiKey',
|
||||||
|
description: 'Authentication method',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Resource',
|
||||||
|
name: 'resource',
|
||||||
|
type: 'options',
|
||||||
|
noDataExpression: true,
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Drive',
|
||||||
|
value: 'drive',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'File',
|
||||||
|
value: 'file',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Directory',
|
||||||
|
value: 'directory',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
default: 'file',
|
||||||
|
description: 'Resource to operate on',
|
||||||
|
},
|
||||||
|
// Drive operations
|
||||||
|
{
|
||||||
|
displayName: 'Operation',
|
||||||
|
name: 'operation',
|
||||||
|
type: 'options',
|
||||||
|
noDataExpression: true,
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: ['drive'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'List Drives',
|
||||||
|
value: 'listDrives',
|
||||||
|
description: 'List all accessible drives',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Get Drive Info',
|
||||||
|
value: 'getDriveInfo',
|
||||||
|
description: 'Get information about a specific drive',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
default: 'listDrives',
|
||||||
|
},
|
||||||
|
// File operations
|
||||||
|
{
|
||||||
|
displayName: 'Operation',
|
||||||
|
name: 'operation',
|
||||||
|
type: 'options',
|
||||||
|
noDataExpression: true,
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: ['file'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'List Files',
|
||||||
|
value: 'listFiles',
|
||||||
|
description: 'List files in a directory',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Get File Info',
|
||||||
|
value: 'getFileInfo',
|
||||||
|
description: 'Get information about a file',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Upload File',
|
||||||
|
value: 'uploadFile',
|
||||||
|
description: 'Upload a file',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Download File',
|
||||||
|
value: 'downloadFile',
|
||||||
|
description: 'Download a file',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Delete File',
|
||||||
|
value: 'deleteFile',
|
||||||
|
description: 'Delete a file (move to trash)',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Search Files',
|
||||||
|
value: 'searchFiles',
|
||||||
|
description: 'Search for files',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Get File Versions',
|
||||||
|
value: 'getFileVersions',
|
||||||
|
description: 'Get file versions',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
default: 'listFiles',
|
||||||
|
},
|
||||||
|
// Directory operations
|
||||||
|
{
|
||||||
|
displayName: 'Operation',
|
||||||
|
name: 'operation',
|
||||||
|
type: 'options',
|
||||||
|
noDataExpression: true,
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: ['directory'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Create Directory',
|
||||||
|
value: 'createDirectory',
|
||||||
|
description: 'Create a new directory',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Create File',
|
||||||
|
value: 'createFile',
|
||||||
|
description: 'Create a new file',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
default: 'createDirectory',
|
||||||
|
},
|
||||||
|
// Drive ID
|
||||||
|
{
|
||||||
|
displayName: 'Drive ID',
|
||||||
|
name: 'driveId',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: ['file', 'directory'],
|
||||||
|
operation: ['listFiles', 'getFileInfo', 'uploadFile', 'downloadFile', 'deleteFile', 'searchFiles', 'getFileVersions', 'createDirectory', 'createFile'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The ID of the drive',
|
||||||
|
},
|
||||||
|
// File ID for file operations
|
||||||
|
{
|
||||||
|
displayName: 'File ID',
|
||||||
|
name: 'fileId',
|
||||||
|
type: 'string',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: ['file'],
|
||||||
|
operation: ['getFileInfo', 'downloadFile', 'deleteFile', 'getFileVersions'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The ID of the file',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Parent Directory ID',
|
||||||
|
name: 'parentDirectoryId',
|
||||||
|
type: 'string',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: ['file'],
|
||||||
|
operation: ['listFiles'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
default: 'root',
|
||||||
|
description: 'The ID of the parent directory (use "root" for root directory)',
|
||||||
|
},
|
||||||
|
// Directory ID for directory operations
|
||||||
|
{
|
||||||
|
displayName: 'Parent Directory ID',
|
||||||
|
name: 'parentDirectoryId',
|
||||||
|
type: 'string',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: ['directory'],
|
||||||
|
operation: ['createDirectory', 'createFile'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
default: 'root',
|
||||||
|
description: 'The ID of the parent directory (use "root" for root directory)',
|
||||||
|
},
|
||||||
|
// Directory name for create directory
|
||||||
|
{
|
||||||
|
displayName: 'Directory Name',
|
||||||
|
name: 'directoryName',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: ['directory'],
|
||||||
|
operation: ['createDirectory'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'Name of the new directory',
|
||||||
|
},
|
||||||
|
// File name for create file
|
||||||
|
{
|
||||||
|
displayName: 'File Name',
|
||||||
|
name: 'fileName',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: ['directory'],
|
||||||
|
operation: ['createFile'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'Name of the new file',
|
||||||
|
},
|
||||||
|
// File content for create file
|
||||||
|
{
|
||||||
|
displayName: 'File Content',
|
||||||
|
name: 'fileContent',
|
||||||
|
type: 'string',
|
||||||
|
typeOptions: {
|
||||||
|
alwaysOpenEditWindow: true,
|
||||||
|
},
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: ['directory'],
|
||||||
|
operation: ['createFile'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'Content of the new file',
|
||||||
|
},
|
||||||
|
// File data for upload
|
||||||
|
{
|
||||||
|
displayName: 'File Data',
|
||||||
|
name: 'fileData',
|
||||||
|
type: 'string',
|
||||||
|
typeOptions: {
|
||||||
|
alwaysOpenEditWindow: true,
|
||||||
|
},
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: ['file'],
|
||||||
|
operation: ['uploadFile'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'File data to upload (base64 encoded)',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'File Name',
|
||||||
|
name: 'uploadFileName',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: ['file'],
|
||||||
|
operation: ['uploadFile'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'Name of the file to upload',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Parent Directory ID',
|
||||||
|
name: 'uploadParentDirectoryId',
|
||||||
|
type: 'string',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: ['file'],
|
||||||
|
operation: ['uploadFile'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
default: 'root',
|
||||||
|
description: 'The ID of the parent directory for upload (use "root" for root directory)',
|
||||||
|
},
|
||||||
|
// Search parameters
|
||||||
|
{
|
||||||
|
displayName: 'Search Query',
|
||||||
|
name: 'searchQuery',
|
||||||
|
type: 'string',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: ['file'],
|
||||||
|
operation: ['searchFiles'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'Search query for files',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Search In Trash',
|
||||||
|
name: 'searchInTrash',
|
||||||
|
type: 'boolean',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: ['file'],
|
||||||
|
operation: ['searchFiles'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
default: false,
|
||||||
|
description: 'Whether to search in trash',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
};
|
||||||
|
|
||||||
|
async execute(this: IExecuteFunctions): Promise<INodeExecutionData[][]> {
|
||||||
|
const items = this.getInputData();
|
||||||
|
const returnData: INodeExecutionData[] = [];
|
||||||
|
|
||||||
|
const resource = this.getNodeParameter('resource', 0) as string;
|
||||||
|
const operation = this.getNodeParameter('operation', 0) as string;
|
||||||
|
|
||||||
|
const credentials = await this.getCredentials('kdriveApi');
|
||||||
|
|
||||||
|
for (let i = 0; i < items.length; i++) {
|
||||||
|
try {
|
||||||
|
if (resource === 'drive') {
|
||||||
|
if (operation === 'listDrives') {
|
||||||
|
const response = await kdriveApiRequest.call(this, 'GET', '/2/drive', {}, credentials);
|
||||||
|
returnData.push({ json: response });
|
||||||
|
} else if (operation === 'getDriveInfo') {
|
||||||
|
const driveId = this.getNodeParameter('driveId', i) as string;
|
||||||
|
const response = await kdriveApiRequest.call(this, 'GET', `/2/drive/${driveId}/settings`, {}, credentials);
|
||||||
|
returnData.push({ json: response });
|
||||||
|
}
|
||||||
|
} else if (resource === 'file') {
|
||||||
|
const driveId = this.getNodeParameter('driveId', i) as string;
|
||||||
|
|
||||||
|
if (operation === 'listFiles') {
|
||||||
|
const parentDirectoryId = this.getNodeParameter('parentDirectoryId', i) as string;
|
||||||
|
const endpoint = parentDirectoryId === 'root'
|
||||||
|
? `/3/drive/${driveId}/files/root/files`
|
||||||
|
: `/3/drive/${driveId}/files/${parentDirectoryId}/files`;
|
||||||
|
const response = await kdriveApiRequest.call(this, 'GET', endpoint, {}, credentials);
|
||||||
|
returnData.push({ json: response });
|
||||||
|
} else if (operation === 'getFileInfo') {
|
||||||
|
const fileId = this.getNodeParameter('fileId', i) as string;
|
||||||
|
const response = await kdriveApiRequest.call(this, 'GET', `/3/drive/${driveId}/files/${fileId}`, {}, credentials);
|
||||||
|
returnData.push({ json: response });
|
||||||
|
} else if (operation === 'uploadFile') {
|
||||||
|
const fileData = this.getNodeParameter('fileData', i) as string;
|
||||||
|
const fileName = this.getNodeParameter('uploadFileName', i) as string;
|
||||||
|
const parentDirectoryId = this.getNodeParameter('uploadParentDirectoryId', i) as string;
|
||||||
|
|
||||||
|
const formData: IDataObject = {
|
||||||
|
file: fileData,
|
||||||
|
filename: fileName,
|
||||||
|
parent_id: parentDirectoryId === 'root' ? 'root' : parentDirectoryId,
|
||||||
|
};
|
||||||
|
|
||||||
|
const response = await kdriveApiRequest.call(this, 'POST', `/3/drive/${driveId}/upload`, formData, credentials);
|
||||||
|
returnData.push({ json: response });
|
||||||
|
} else if (operation === 'downloadFile') {
|
||||||
|
const fileId = this.getNodeParameter('fileId', i) as string;
|
||||||
|
const response = await kdriveApiRequest.call(this, 'GET', `/2/drive/${driveId}/files/${fileId}/download`, {}, credentials, true);
|
||||||
|
returnData.push({ binary: response });
|
||||||
|
} else if (operation === 'deleteFile') {
|
||||||
|
const fileId = this.getNodeParameter('fileId', i) as string;
|
||||||
|
const response = await kdriveApiRequest.call(this, 'DELETE', `/2/drive/${driveId}/files/${fileId}`, {}, credentials);
|
||||||
|
returnData.push({ json: response });
|
||||||
|
} else if (operation === 'searchFiles') {
|
||||||
|
const searchQuery = this.getNodeParameter('searchQuery', i) as string;
|
||||||
|
const searchInTrash = this.getNodeParameter('searchInTrash', i) as boolean;
|
||||||
|
|
||||||
|
const params: IDataObject = {
|
||||||
|
query: searchQuery,
|
||||||
|
in_trash: searchInTrash,
|
||||||
|
};
|
||||||
|
|
||||||
|
const response = await kdriveApiRequest.call(this, 'GET', `/3/drive/${driveId}/files/search`, params, credentials);
|
||||||
|
returnData.push({ json: response });
|
||||||
|
} else if (operation === 'getFileVersions') {
|
||||||
|
const fileId = this.getNodeParameter('fileId', i) as string;
|
||||||
|
const response = await kdriveApiRequest.call(this, 'GET', `/3/drive/${driveId}/files/${fileId}/versions`, {}, credentials);
|
||||||
|
returnData.push({ json: response });
|
||||||
|
}
|
||||||
|
} else if (resource === 'directory') {
|
||||||
|
const driveId = this.getNodeParameter('driveId', i) as string;
|
||||||
|
|
||||||
|
if (operation === 'createDirectory') {
|
||||||
|
const parentDirectoryId = this.getNodeParameter('parentDirectoryId', i) as string;
|
||||||
|
const directoryName = this.getNodeParameter('directoryName', i) as string;
|
||||||
|
|
||||||
|
const body: IDataObject = {
|
||||||
|
name: directoryName,
|
||||||
|
parent_id: parentDirectoryId === 'root' ? 'root' : parentDirectoryId,
|
||||||
|
};
|
||||||
|
|
||||||
|
const response = await kdriveApiRequest.call(this, 'POST', `/3/drive/${driveId}/files/${parentDirectoryId === 'root' ? 'root' : parentDirectoryId}/directory`, body, credentials);
|
||||||
|
returnData.push({ json: response });
|
||||||
|
} else if (operation === 'createFile') {
|
||||||
|
const parentDirectoryId = this.getNodeParameter('parentDirectoryId', i) as string;
|
||||||
|
const fileName = this.getNodeParameter('fileName', i) as string;
|
||||||
|
const fileContent = this.getNodeParameter('fileContent', i) as string;
|
||||||
|
|
||||||
|
const body: IDataObject = {
|
||||||
|
name: fileName,
|
||||||
|
content: fileContent,
|
||||||
|
parent_id: parentDirectoryId === 'root' ? 'root' : parentDirectoryId,
|
||||||
|
};
|
||||||
|
|
||||||
|
const response = await kdriveApiRequest.call(this, 'POST', `/3/drive/${driveId}/files/${parentDirectoryId === 'root' ? 'root' : parentDirectoryId}/file`, body, credentials);
|
||||||
|
returnData.push({ json: response });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
if (this.continueOnFail()) {
|
||||||
|
returnData.push({ json: { error: error.message } });
|
||||||
|
} else {
|
||||||
|
throw error;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return [returnData];
|
||||||
|
}
|
||||||
|
}
|
||||||
23
src/nodes/KDrive/KDriveCredentials.api.ts
Normal file
23
src/nodes/KDrive/KDriveCredentials.api.ts
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
import {
|
||||||
|
ICredentialType,
|
||||||
|
INodeProperties,
|
||||||
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
|
export class KDriveCredentials implements ICredentialType {
|
||||||
|
name = 'kdriveApi';
|
||||||
|
displayName = 'kDrive API';
|
||||||
|
documentationUrl = 'https://developer.infomaniak.com';
|
||||||
|
properties: INodeProperties[] = [
|
||||||
|
{
|
||||||
|
displayName: 'API Key',
|
||||||
|
name: 'apiKey',
|
||||||
|
type: 'string',
|
||||||
|
typeOptions: {
|
||||||
|
password: true,
|
||||||
|
},
|
||||||
|
default: '',
|
||||||
|
required: true,
|
||||||
|
description: 'Your kDrive API key',
|
||||||
|
},
|
||||||
|
];
|
||||||
|
}
|
||||||
8
src/nodes/KDrive/kdrive.svg
Normal file
8
src/nodes/KDrive/kdrive.svg
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<rect width="24" height="24" rx="4" fill="#007BFF"/>
|
||||||
|
<path d="M17 10H7L12 5L17 10Z" fill="white"/>
|
||||||
|
<path d="M7 14H17L12 19L7 14Z" fill="white"/>
|
||||||
|
<path d="M12 12H7" stroke="white" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
||||||
|
<path d="M17 12H12" stroke="white" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 497 B |
Reference in New Issue
Block a user