niri-ipc

🪟 Niri 窗口智能自动化管家

🥥29总安装量 10评分人数 9
100% 的用户推荐

基于 Niri Wayland 合成器官方 IPC 协议的本地窗口管理技能,通过 Python 脚本封装实现安全的窗口查询与自动化控制,专为 Linux 桌面效率优化设计。

A

基本安全,请在特定环境下使用

  • 来自社区或个人来源,建议先隔离验证
  • ✅ 代码安全规范,无 eval/exec/system 等危险函数,仅使用 Python 标准库
  • ✅ 无网络通信,仅通过本地 UNIX Socket 与 Niri 合成器交互,数据完全本地保留
  • ✅ 完善的输入验证(argparse)和错误处理,无命令注入或代码执行风险
  • ⚠️ 来源为个人开发者账号(T3),非官方组织或知名开源项目
  • ⚠️ niri_socket.py 可发送任意 IPC 请求,可能触发退出合成器等破坏性操作,需谨慎使用

使用说明

核心用法

Niri IPC 技能为 OpenClaw Agent 提供了与 Niri Wayland 合成器交互的完整能力,主要通过三层接口实现:

1. 基础查询层niri.py):封装 niri msg --json 命令,支持获取版本、显示器输出、工作区、窗口列表及当前聚焦窗口等状态信息。

2. 智能控制层niri_ctl.py):提供基于子串匹配的窗口管理,无需记忆窗口 ID 即可通过应用名称或标题模糊匹配执行聚焦、关闭、移动至工作区等操作。

3. 原始 IPC 层niri_socket.py):直接通过 UNIX Socket 与 $NIRI_SOCKET 通信,支持批量请求和事件流订阅,适用于状态栏开发等高级场景。

典型工作流包括:查询窗口状态 → 匹配目标窗口 → 执行聚焦/移动/关闭操作,或订阅事件流实现实时桌面状态同步。

显著优点

  • 零外部依赖:仅使用 Python 标准库,无 pip 安装风险,部署极简
  • 多层安全封装:从高层抽象到原始 IPC 的分层设计,满足不同复杂度需求
  • 原生 JSON 支持:所有查询返回结构化数据,便于 Agent 解析和后续自动化
  • 事件驱动能力:支持实时事件流,可构建响应式桌面工具
  • 输入安全:全面使用 argparse 进行参数校验,无命令注入风险

潜在缺点与局限性

  • 环境强绑定:必须在 Niri 会话内运行,依赖 $NIRI_SOCKET 环境变量,无法跨 compositor 或远程使用
  • T3 来源限制:由个人开发者维护,非 Niri 官方项目,长期维护稳定性存疑
  • 功能边界明确:仅支持 Niri 特定功能,无法迁移至 Sway、Hyprland 等其他 Wayland 合成器
  • 破坏性操作风险:原始 socket 接口可触发退出合成器、关闭显示器等高危操作,需用户自行把控

适合的目标群体

  • Niri 用户:已采用 Niri 作为日常 Wayland 合成器的 Linux 桌面用户
  • 效率工具开发者:构建 Niri 专属状态栏、工作区指示器、窗口切换器的开发者
  • 自动化爱好者:希望通过 Agent 实现智能窗口管理、工作流自动化的技术用户
  • r/unixporn 风格用户:追求高度可定制桌面环境的发烧友

使用风险

  • 会话依赖风险:若 $NIRI_SOCKET 未设置或 Niri 未运行,所有命令将失败
  • 版本兼容风险:Niri 升级后可能出现 niri msg 协议不匹配,需重启合成器
  • 误操作风险:窗口关闭、工作区切换等操作无二次确认,自动化脚本可能干扰当前工作
  • 权限隐含要求:虽无显式权限申请,但 IPC 操作隐含需要与 Niri 进程同用户权限

niri-ipc 内容

文件夹图标references文件夹
文件夹图标scripts文件夹
手动下载zip · 8.0 kB
ipc.mdtext/markdown
请选择文件