onedrive by membranedev/application-skills
npx skills add https://github.com/membranedev/application-skills --skill onedriveMS OneDrive 是微软提供的云存储服务。它允许用户在云端存储文件、照片和文档,并可从任何设备访问。OneDrive 通常被个人和企业用于个人和协作文件管理。
官方文档:https://learn.microsoft.com/en-us/onedrive/developer/
根据需要使用的操作名称和参数。
此技能使用 Membrane CLI 与 MS OneDrive 交互。Membrane 会自动处理身份验证和凭证刷新——因此您可以专注于集成逻辑,而不是身份验证的底层细节。
安装 Membrane CLI,以便您可以从终端运行 membrane 命令:
npm install -g @membranehq/cli
membrane login --tenant
浏览器窗口将打开以进行身份验证。
广告位招租
在这里展示您的产品或服务
触达数万 AI 开发者,精准高效
无头环境: 运行该命令,复制打印出的 URL 供用户在浏览器中打开,然后使用 membrane login complete <code> 完成验证。
创建新连接:
membrane search onedrive --elementType=connector --json
从 output.items[0].element?.id 获取连接器 ID,然后:
membrane connect --connectorId=CONNECTOR_ID --json
用户在浏览器中完成身份验证。输出中包含新的连接 ID。
当您不确定连接是否已存在时:
检查现有连接:
membrane connection list --json
如果存在 MS OneDrive 连接,请记下其 connectionId。
当您知道要做什么但不知道确切的操作 ID 时:
membrane action list --intent=QUERY --connectionId=CONNECTION_ID --json
这将返回包含 id 和 inputSchema 的操作对象,以便您知道如何运行它。
| 名称 | 键 | 描述 |
|---|---|---|
| 上传小文件 | upload-small-file | 使用简单上传方式上传最大 4MB 的文件。 |
| 获取与我共享的内容 | get-shared-with-me | 获取与当前用户共享的文件和文件夹列表 |
| 获取最近文件 | get-recent-files | 获取当前用户最近访问的文件列表 |
| 列出驱动器 | list-drives | 列出当前用户可用的所有驱动器 |
| 获取下载 URL | get-download-url | 获取文件的预验证下载 URL(有效期较短) |
| 创建共享链接 | create-sharing-link | 为文件或文件夹创建共享链接 |
| 搜索文件 | search-files | 使用搜索查询在 OneDrive 中搜索文件和文件夹 |
| 重命名项目 | rename-item | 重命名文件或文件夹 |
| 移动项目 | move-item | 将文件或文件夹移动到新位置或重命名它 |
| 复制项目 | copy-item | 将文件或文件夹复制到新位置。 |
| 删除项目 | delete-item | 按其 ID 删除文件或文件夹(移至回收站) |
| 创建文件夹 | create-folder | 在指定的父文件夹中创建新文件夹 |
| 通过路径获取项目 | get-item-by-path | 通过相对于根目录的路径检索文件或文件夹的元数据 |
| 通过 ID 获取项目 | get-item-by-id | 通过唯一 ID 检索文件或文件夹的元数据 |
| 列出文件夹内容 | list-folder-contents | 按项目 ID 列出特定文件夹内的所有文件和文件夹 |
| 列出根目录项目 | list-root-items | 列出当前用户 OneDrive 根目录中的所有文件和文件夹 |
| 获取我的驱动器 | get-my-drive | 检索当前用户 OneDrive 的属性和关系 |
membrane action run --connectionId=CONNECTION_ID ACTION_ID --json
传递 JSON 参数:
membrane action run --connectionId=CONNECTION_ID ACTION_ID --json --input "{ \"key\": \"value\" }"
当可用操作无法满足您的用例时,您可以通过 Membrane 的代理直接向 MS OneDrive API 发送请求。Membrane 会自动将基础 URL 附加到您提供的路径,并注入正确的身份验证头——如果凭证过期,还会透明地刷新。
membrane request CONNECTION_ID /path/to/endpoint
常用选项:
| 标志 | 描述 |
|---|---|
-X, --method | HTTP 方法(GET、POST、PUT、PATCH、DELETE)。默认为 GET |
-H, --header | 添加请求头(可重复),例如 -H "Accept: application/json" |
-d, --data | 请求体(字符串) |
--json | 发送 JSON 请求体并设置 Content-Type: application/json 的简写 |
--rawData | 按原样发送请求体,不做任何处理 |
--query | 查询字符串参数(可重复),例如 --query "limit=10" |
--pathParam | 路径参数(可重复),例如 --pathParam "id=123" |
membrane action list --intent=QUERY(将 QUERY 替换为您的意图)以查找现有操作。预构建的操作处理了原始 API 调用可能遗漏的分页、字段映射和边缘情况。每周安装量
770
仓库
GitHub 星标数
18
首次出现
13 天前
安全审计
安装于
gemini-cli770
github-copilot770
codex770
kimi-cli770
amp770
cline770
MS OneDrive is a cloud storage service provided by Microsoft. It allows users to store files, photos, and documents in the cloud and access them from any device. OneDrive is commonly used by individuals and businesses for personal and collaborative file management.
Official docs: https://learn.microsoft.com/en-us/onedrive/developer/
Use action names and parameters as needed.
This skill uses the Membrane CLI to interact with MS OneDrive. Membrane handles authentication and credentials refresh automatically — so you can focus on the integration logic rather than auth plumbing.
Install the Membrane CLI so you can run membrane from the terminal:
npm install -g @membranehq/cli
membrane login --tenant
A browser window opens for authentication.
Headless environments: Run the command, copy the printed URL for the user to open in a browser, then complete with membrane login complete <code>.
Create a new connection:
membrane search onedrive --elementType=connector --json
Take the connector ID from output.items[0].element?.id, then:
membrane connect --connectorId=CONNECTOR_ID --json
The user completes authentication in the browser. The output contains the new connection id.
When you are not sure if connection already exists:
Check existing connections:
membrane connection list --json
If a MS OneDrive connection exists, note its connectionId
When you know what you want to do but not the exact action ID:
membrane action list --intent=QUERY --connectionId=CONNECTION_ID --json
This will return action objects with id and inputSchema in it, so you will know how to run it.
| Name | Key | Description |
|---|---|---|
| Upload Small File | upload-small-file | Upload a file up to 4MB using simple upload. |
| Get Shared With Me | get-shared-with-me | Get a list of files and folders shared with the current user |
| Get Recent Files | get-recent-files | Get a list of recently accessed files by the current user |
| List Drives | list-drives | List all drives available to the current user |
| Get Download URL | get-download-url | Get a pre-authenticated download URL for a file (valid for a short period) |
| Create Sharing Link | create-sharing-link | Create a sharing link for a file or folder |
| Search Files | search-files | Search for files and folders in OneDrive using a search query |
| Rename Item | rename-item | Rename a file or folder |
| Move Item |
membrane action run --connectionId=CONNECTION_ID ACTION_ID --json
To pass JSON parameters:
membrane action run --connectionId=CONNECTION_ID ACTION_ID --json --input "{ \"key\": \"value\" }"
When the available actions don't cover your use case, you can send requests directly to the MS OneDrive API through Membrane's proxy. Membrane automatically appends the base URL to the path you provide and injects the correct authentication headers — including transparent credential refresh if they expire.
membrane request CONNECTION_ID /path/to/endpoint
Common options:
| Flag | Description |
|---|---|
-X, --method | HTTP method (GET, POST, PUT, PATCH, DELETE). Defaults to GET |
-H, --header | Add a request header (repeatable), e.g. -H "Accept: application/json" |
-d, --data | Request body (string) |
--json | Shorthand to send a JSON body and set Content-Type: application/json |
--rawData |
membrane action list --intent=QUERY (replace QUERY with your intent) to find existing actions before writing custom API calls. Pre-built actions handle pagination, field mapping, and edge cases that raw API calls miss.Weekly Installs
770
Repository
GitHub Stars
18
First Seen
13 days ago
Security Audits
Gen Agent Trust HubPassSocketPassSnykPass
Installed on
gemini-cli770
github-copilot770
codex770
kimi-cli770
amp770
cline770
Next.js 最佳实践指南:文件约定、RSC边界、异步模式与性能优化
45,400 周安装
股票分析工具 - 一键生成NVDA、TSLA、AAPL等股票情感分析报告
759 周安装
spec-miner:AI代码规范挖掘器 - 从代码库自动提取需求与文档
760 周安装
销售线索筛选框架指南:提升转化率,优化销售流程 | 销售效率工具
760 周安装
hairy-utils:JavaScript/TypeScript 核心工具库 | 异步处理、类型检查、函数式编程
761 周安装
设计系统构建指南:Figma、Airbnb专家框架,助您规模化产品设计
761 周安装
Claude智能体开发指南:创建自主AI助手,掌握agent-development核心技巧
762 周安装
| move-item |
| Move a file or folder to a new location or rename it |
| Copy Item | copy-item | Copy a file or folder to a new location. |
| Delete Item | delete-item | Delete a file or folder by its ID (moves to recycle bin) |
| Create Folder | create-folder | Create a new folder in the specified parent folder |
| Get Item by Path | get-item-by-path | Retrieve metadata for a file or folder by its path relative to root |
| Get Item by ID | get-item-by-id | Retrieve metadata for a file or folder by its unique ID |
| List Folder Contents | list-folder-contents | List all files and folders within a specific folder by item ID |
| List Root Items | list-root-items | List all files and folders in the root of the current user's OneDrive |
| Get My Drive | get-my-drive | Retrieve properties and relationships of the current user's OneDrive |
| Send the body as-is without any processing |
--query | Query-string parameter (repeatable), e.g. --query "limit=10" |
--pathParam | Path parameter (repeatable), e.g. --pathParam "id=123" |