Brickly Brick Python runtime 官方 SDK。
Project description
brickly-sdk
Brickly Brick Python runtime 官方 SDK。它通过 stdin/stdout 与宿主通信,封装 BPP (Brickly Plugin Protocol),让 Python Brick 可以专注写命令逻辑,而不是手写协议消息。
stdout 会被 SDK 保留给 BPP 协议消息;业务日志请使用 brick.log(...) 写入 stderr。
安装
pip install brickly-sdk==0.1.0
国内环境可以使用 PyPI 镜像:
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple brickly-sdk==0.1.0
快速开始
from brickly import BricklyRuntime
brick = BricklyRuntime("com.example.python")
@brick.on_command("hello")
def hello(ctx, input_value):
ctx.progress(0.5, "处理中...")
ctx.chunk("hello\n")
return {"ok": True, "input": input_value}
brick.run()
SDK 会自动处理:
host.hello->runtime.readyruntime.ping->runtime.pongcommand.invoke命令分发command.cancel取消信号、ctx.is_cancelled()和ctx.on_cancel(...)command.progress、command.chunk和command.outputhost.*请求 ID 分配,以及host.result/host.error路由runtime.shutdown-> 可选 shutdown hook ->runtime.bye- 子窗口创建、窗口方法调用、
window.*事件路由 - 事件总线
events.publish(...)/events.on(...) - 跨 Brick 调用
invoke(...)、invoke_root(...)、invoke_stream(...) - 跨 Brick 会话
open_session(...) - 平台能力
platform.screenshot、platform.screen、platform.input、platform.clipboard、platform.system
与 Node SDK 的同步关系
Python SDK 的协议语义与 @syllm/brickly-sdk 保持一致:
- Python 使用
snake_case方法名,例如create_browser_window()、set_full_screen()。 - Node 使用
camelCase方法名,例如createBrowserWindow()、setFullScreen()。 - 两者底层发送的 BPP 消息类型和窗口方法名一致。
- Python 不提供 Node 的 TypeScript
CommandMap类型生成能力;Python 侧依赖类型标注和中文 docstring 提供 IDE 补全。
命令上下文
命令处理函数会收到 CommandContext:
@brick.on_command("process")
def process(ctx, input_value):
ctx.progress(0.2, "准备中")
if ctx.is_cancelled():
return {"cancelled": True}
ctx.output("debug", {"step": "start"})
ctx.chunk("第一段输出\n")
return {"ok": True}
常用属性和方法:
ctx.request_id:当前请求 IDctx.command_id:当前命令 IDctx.invocation:宿主传入的可信调用来源和依赖 Profile 映射ctx.config:当前 Profile 配置快照ctx.ui:子窗口 APIctx.events:事件总线 APIctx.platform:平台能力 APIctx.system:ctx.platform.system的快捷别名ctx.progress(value, message):上报进度ctx.chunk(chunk, name=None):追加流式输出ctx.output(name, value):设置具名输出ctx.invoke(...):在命令作用域内调用另一个 Brickctx.invoke_stream(...):流式调用另一个 Brickctx.open_session(...):打开跨 Brick 会话
子窗口
from brickly import BricklyRuntime
brick = BricklyRuntime("com.example.window")
@brick.on_command("open")
def open_window(ctx, _input):
win = ctx.ui.create_browser_window("ui/index.html", {"width": 640, "height": 480})
win.on("closed", lambda payload: brick.log("窗口已关闭", payload))
win.set_title("Hello from Python")
win.web_contents.send("app:hello", {"requestId": ctx.request_id, "text": "你好"})
return {"windowId": win.id}
brick.run()
WindowHandle 提供与 Node SDK 对齐的常用窗口方法,例如:
- 几何尺寸:
set_bounds()、get_bounds()、set_position()、set_size() - 内容区域:
set_content_bounds()、get_content_bounds()、set_content_size() - 状态切换:
minimize()、maximize()、restore()、show()、hide()、focus() - 状态查询:
is_visible()、is_focused()、is_minimized()、is_full_screen() - 外观能力:
set_title()、set_opacity()、set_background_color()、set_has_shadow() - 网络事件:
on_network() - webContents:
send()、execute_javascript()、open_dev_tools()、go_back()、set_zoom_factor()、copy()、paste()、undo()
跨 Brick 调用
命令处理函数内部使用 ctx.invoke(...):
result = ctx.invoke(
"com.brickly.openai",
"chat",
{"prompt": "hello"},
profile_id="work",
)
如果宿主在 ctx.invocation.dependencyProfiles 中给目标 Brick 指定了 Profile,且调用时没有显式传
profile_id,SDK 会自动沿用该 Profile。这一点与 Node SDK 行为一致。
命令处理函数外部需要使用显式 root 调用:
result = brick.invoke_root(
"com.brickly.openai",
"chat",
{"prompt": "hello"},
profile_id="work",
)
流式调用:
for event in ctx.invoke_stream("com.brickly.openai", "chat", {"prompt": "hello"}):
if event["type"] == "progress":
ctx.progress(event.get("progress", 0), event.get("message"))
elif event["type"] == "chunk":
ctx.chunk(event.get("chunk"))
elif event["type"] == "output":
ctx.output(event["name"], event.get("value"))
elif event["type"] == "result":
return event["result"]
跨 Brick 调用需要在调用方 manifest 的 dependencies 中声明目标 Brick 和命令:
"dependencies": {
"com.brickly.openai": {
"commands": ["chat"]
}
}
跨 Brick 会话
当目标 Brick 需要保留内存状态时,使用 ctx.open_session(...):
session = ctx.open_session("com.brickly.openai", profile_id="work")
try:
session.invoke("start-thread", {"title": "草稿"})
reply = session.invoke("chat", {"prompt": "继续这个话题"})
finally:
session.close()
平台能力
系统 API:
@brick.on_command("show-app-info")
def show_app_info(ctx, _input):
return {
"appName": ctx.system.get_app_name(),
"appVersion": ctx.system.get_app_version(),
"userData": ctx.system.get_path("userData"),
"isWindows": ctx.system.is_windows(),
}
剪贴板 API:
@brick.on_command("replace-clipboard")
def replace_clipboard(ctx, _input):
previous = ctx.platform.clipboard.read_content()
updated = ctx.platform.clipboard.set_content({"kind": "text", "text": "来自 Python"})
return {"previous": previous, "updated": updated}
输入和屏幕 API:
@brick.on_command("screen-info")
def screen_info(ctx, _input):
point = ctx.platform.screen.get_cursor_screen_point()
display = ctx.platform.screen.get_primary_display()
return {"point": point, "display": display}
@brick.on_command("click")
def click(ctx, _input):
ctx.platform.input.mouse_click(100, 100)
ctx.platform.input.keyboard_tap("A", "control")
return {"ok": True}
这些能力由宿主按 manifest 权限校验。缺少权限时,宿主会返回 host.error,SDK 会抛出 BppError。
错误处理
抛出 BppError 可以保留明确错误码:
from brickly import BppError
raise BppError("INVALID_INPUT", "url 不能为空")
普通异常会被 SDK 转换为 INTERNAL_ERROR 并返回给宿主。
日志
brick.log("开始处理", {"id": 1})
brick.log(...) 会写入 stderr。不要手动给日志加 [brickId] 前缀,宿主日志中心会自动附加 Brick ID、来源、流和作用域信息。
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file brickly_sdk-0.1.1.tar.gz.
File metadata
- Download URL: brickly_sdk-0.1.1.tar.gz
- Upload date:
- Size: 21.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
42e2b9837cddf74b70772c0334d9d43aa86bb2cf60cdc50bce80b42463e420a7
|
|
| MD5 |
89634ed4a92b4bf49ce9bc353d227c85
|
|
| BLAKE2b-256 |
8218a76c41f2ca4a71634b950586c0bbca2091d1801c11a3dbae303c6e1dc18f
|
File details
Details for the file brickly_sdk-0.1.1-py3-none-any.whl.
File metadata
- Download URL: brickly_sdk-0.1.1-py3-none-any.whl
- Upload date:
- Size: 19.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bc1b784464244d7d12002dd6baa2856bdc3a5e74844f45856db4c8f6dfc110ec
|
|
| MD5 |
39fa63cbf044d24b443e39dd78a07cf0
|
|
| BLAKE2b-256 |
da3350a08aad9394c3742b88a5c3b4f2e61465d461bbb387acfc1a7560804149
|