iRightMenu Pro Lua API 参考

完整的 Lua 插件 API 参考文档。

引擎版本: 1.3.0 最后更新: 2026 年 4 月

真值来源:客户端 LuaAPIRegistry.swiftengineVersion(按 since: 字段最大值计算)。


API 模块索引

模块 说明 文档
app.api API 可用性查询 api.md
app.plugin 插件信息 plugin-info.md
app.log 日志记录 log.md
app.context Finder 上下文 context.md
app.dialog 对话框和表单 dialog.md
app.progress 进度对话框 progress.md
app.notification 系统通知 notification.md
app.settings 插件设置 settings.md
app.file 文件操作 file.md
app.path 路径工具 path.md
app.shell Shell 命令 shell.md
app.finder Finder 操作 finder.md
app.clipboard 剪贴板 clipboard.md
app.system 系统信息 system.md
app.json JSON 操作 json.md
app.plist Plist 操作 plist.md
app.http HTTP 请求 http.md
app.archive 归档操作 archive.md
app.image 图片处理 image.md
app.crypto 加密编码 crypto.md
app.string 字符串工具 string.md
app.date 日期时间 date.md
app.regex 正则表达式 regex.md
app.process 进程管理 process.md
app.application macOS 应用 application.md
app.database SQLite 数据库 database.md
app.i18n 国际化 i18n.md
app.applescript AppleScript applescript.md
app.thread 并发/协程 thread.md
app.uti 类型标识符 uti.md
app.url URL 解析构建 url.md
app.xattr 扩展属性/标签 xattr.md
app.trash 废纸篓 trash.md
app.metadata Spotlight 元数据 metadata.md
app.csv CSV 解析生成 csv.md
app.xml XML 解析生成 xml.md
app.pdf PDF 操作 pdf.md
app.network 网络信息 network.md
app.power 电源/电池 power.md
app.screen 屏幕/外观 screen.md
app.audio 音频控制 audio.md
app.bluetooth 蓝牙设备 bluetooth.md
app.window 窗口管理 window.md
app.location 位置服务 location.md
app.ocr 文字识别 ocr.md
app.qrcode 二维码 qrcode.md
app.wakelock 防休眠 wakelock.md
app.watcher 文件监听 watcher.md
app.share macOS 分享 share.md
app.shortcuts 快捷指令 shortcuts.md
app.timer 定时器 timer.md
app.color 颜色工具 color.md
app.keychain 安全凭证存储 keychain.md
app.defaults UserDefaults 偏好 defaults.md
app.websocket WebSocket 客户端 websocket.md
app.keyboard 键盘模拟 keyboard.md
app.mouse 鼠标模拟 mouse.md
app.chooser 快速选择器 chooser.md
app.webview WebView 窗口 webview.md
app.dock Dock 角标/弹跳 dock.md
app.hotkey 全局热键 hotkey.md
app.statusbar 状态栏图标 statusbar.md

快速参考

常用 API 速查

-- 日志
app.log.info("消息")
app.log.error("错误")

-- 上下文
local files = app.context.selectedFiles()
local dir = app.context.currentDirectory()

-- 对话框
app.dialog.alert("标题", "内容")
local ok = app.dialog.confirm("确认吗?")
local input = app.dialog.input("请输入", "默认值")

-- 进度
app.progress.show("处理中", {message = "请稍候..."})
app.progress.update(50, "一半了")
app.progress.hide()

-- 通知
app.notification.show("完成", "处理了 10 个文件")

-- 设置
local val = app.settings.get("key", "default")
app.settings.set("key", "value")

-- 文件
local content = app.file.read("/path/to/file")
app.file.write("/path/to/file", "content")
app.file.copy(src, dst)
app.file.move(src, dst)
app.file.delete(path)

-- 路径
app.path.basename("/a/b/c.txt")  -- "c.txt"
app.path.dirname("/a/b/c.txt")   -- "/a/b"
app.path.join("/a", "b", "c")    -- "/a/b/c"
app.path.exists(path)            -- true/false

-- Shell
local result = app.shell.execute("ls -la")
-- result.code, result.stdout, result.stderr
app.shell.quote("my file")      -- "'my file'"(Shell 安全引用)

-- JSON
local t = app.json.parse('{"a":1}')
local s = app.json.stringify({a = 1})

-- UTI / URL
local uti = app.uti.fromExtension("pdf")   -- "com.adobe.pdf"
local url = app.url.parse("https://example.com/path?q=1")

-- 扩展属性 / 标签
local tags = app.xattr.getTags(path)
app.xattr.addTag(path, "重要")
app.trash.moveToTrash(path)

-- 数据格式
local rows = app.csv.parseFile("data.csv", {header = true})
local doc = app.xml.parseFile("config.xml")
local info = app.pdf.info("document.pdf")

-- 网络 / 系统
local ip = app.network.localIP()
local bat = app.power.battery()
local isDark = app.screen.isDarkMode()
app.audio.setVolume(0.5)

-- OCR / 二维码
local text = app.ocr.recognize("image.png")
app.qrcode.generate("hello", {path = "/tmp/qr.png"})

-- 防休眠 / 文件监听
local id = app.wakelock.preventSleep({duration = 3600})
local wid = app.watcher.watch("/path", function(e) end)

-- 分享 / 快捷指令
app.share.show({"/path/to/file.pdf"})
app.shortcuts.run("My Shortcut", {input = "hello"})

-- 定时器
app.timer.after(3, function() print("done") end)
local tid = app.timer.every(10, function() print("tick") end)

-- 颜色
local c = app.color.parse("#FF6600")
local hex = app.color.lighten("#336699", 20)
local ratio = app.color.contrast("#000", "#FFF")

-- Keychain
app.keychain.set("api_key", "sk-xxx")
local token = app.keychain.get("api_key")
app.keychain.has("api_key")  -- true/false

-- UserDefaults
local val = app.defaults.read("com.apple.finder", "AppleShowAllFiles")
app.defaults.write("com.apple.finder", "AppleShowAllFiles", true)

-- WebSocket
local wsId = app.websocket.connect("wss://echo.websocket.org", {
    onMessage = function(id, data) print(data) end
})
app.websocket.send(wsId, "hello")

-- 键盘/鼠标
app.keyboard.hotkey({"cmd"}, "c")
app.mouse.click(100, 200)
local pos = app.mouse.position()

-- 选择器
local item = app.chooser.show({{text = "A"}, {text = "B"}})

-- WebView
local wvId = app.webview.open({html = "<h1>Hello</h1>"})
app.webview.eval(wvId, "document.title")

-- 蓝牙
local devices = app.bluetooth.connectedDevices()
app.bluetooth.watch("deviceDisconnected", function(e) end)

-- 窗口管理
local windows = app.window.list({app = "Safari"})
app.window.move({app = "Safari"}, 0, 0)
app.window.maximize({app = "Safari"})

-- 位置
local loc = app.location.current()
local addr = app.location.reverseGeocode(loc.latitude, loc.longitude)

-- 事件监听(各模块)
app.application.watch("terminate", function(e) end)
app.system.watch("sleep", function() end)
app.power.watch("powerSourceChanged", function(e) end)
app.network.watch("networkChanged", function(e) end)
app.screen.watch("darkModeChanged", function(e) end)

返回值约定

所有 API 统一采用 result, error 双返回值模式:

local result, err = app.xxx.yyy(...)
if not result then
    -- err 为错误原因字符串(权限拒绝 / 参数缺失 / 连接超时等)
    app.log.error("失败: " .. (err or "unknown"))
end

规则:

  • 成功:返回结果值(string / number / bool / table),第二个返回值自动为 nil
  • 失败:返回 nil, "错误描述"false, "错误描述"
  • 用户取消:对话框取消返回 nil(不带错误信息,不算错误)

错误语义边界:

  • Shell:命令 exit code != 0 是 API 成功(result = {code, stdout, stderr}),仅连接超时才返回 error
  • HTTP:HTTP 4xx/5xx 是 API 成功(result = {status, body}),仅网络错误/DNS 失败才返回 error
  • Dialog:用户取消是正常返回 nil,不是错误
开发者文档
使用帮助
使用说明 脚本菜单 常见问题
脚本开发
开发指南
插件开发
快速开始 开发指南 示例插件
API 参考
概览 API 查询 插件信息 日志 Finder 上下文 插件设置 国际化
UI 与交互
对话框 进度条 系统通知 选择器 WebView 状态栏 Dock
文件与路径
文件操作 路径工具 Finder 操作 废纸篓 扩展属性 元数据 文件监听
数据格式
JSON Plist CSV XML PDF 图片
文本与编码
字符串 正则表达式 日期时间 颜色 加密编码
系统
Shell 命令 进程管理 应用管理 系统信息 AppleScript 快捷指令
系统信息
网络信息 电源/电池 屏幕/外观 音频控制 蓝牙设备 位置服务
网络
HTTP 请求 WebSocket URL 工具
输入与剪贴板
键盘模拟 鼠标模拟 全局热键 剪贴板 窗口管理
存储
SQLite Keychain UserDefaults
媒体
文字识别 二维码
工具
归档 类型标识 分享 定时器 防休眠 并发/协程