Jf Open Pro Ai Indoor Security

API key required
Security

杰峰开放平台室内安防技能。实时监测客厅等居家场景,全方位守护人身与居家安全,实时掌握家人动态。筑牢安全防线,同步感知居家日常,安心守护居家点滴时光。

Install

openclaw skills install jf-open-pro-ai-indoor-security

jf-open-pro-ai-indoor-security - 室内安防技能

技能描述

实时监测客厅等居家场景,全方位守护人身与居家安全,实时掌握家人动态。筑牢安全防线,同步感知居家日常,安心守护居家点滴时光。

核心功能:

  • 服务状态管理 - 开启/关闭室内安防服务
  • 异常提醒配置 - 查询和设置异常提醒(疑似陌生人/明火/危险行为)
  • 异常告警查询 - 查询疑似陌生人、明火、危险行为、有人进入/离开告警
  • 成员管理 - 新增、删除、修改、查询家庭成员
  • 统计数据 - 查询进入/离开次数、最大人数、存在时长、日/周图表

触发词

  • 室内安防 / 家人看护 / 居家安全
  • 异常告警 / 成员管理 / 家人动态

⚠️ 环境变量检查(使用前必读)

使用本技能前,必须先检查以下 7 个必需环境变量是否已配置!

检查清单

序号环境变量配置项是否必需检查状态
1JF_UUIDjf_uuid✅ 必需□ 已配置
2JF_APP_KEYjf_appKey✅ 必需□ 已配置
3JF_APP_SECRETjf_secret✅ 必需□ 已配置
4JF_MOVE_CARDjf_moveCard✅ 必需□ 已配置
5JF_DEVICE_SNjf_device_sn✅ 必需□ 已配置
6JF_AUTHORIZATIONjf_authorization✅ 必需□ 已配置
7JF_USERjf_user✅ 必需□ 已配置

前置条件

前置条件

  1. 设备在线 - 设备需在线且可访问
  2. 设备绑定 - 设备需先绑定到开放平台账号
  3. 套餐开通 - 需开通相应 AI 套餐 - 需开通室内安防 AI 套餐

签名算法** - 使用杰峰官方 SignatureUtil.getEncryptStr() 方法生成 signature 2. 时间戳算法 - 使用杰峰官方 TimeMillisUtil.getTimMillis() 方法生成 timeMillis 3. 设备绑定 - 设备需先绑定到开放平台账号

环境变量

变量名配置项说明默认值必需
JF_UUIDjf_uuid开放平台用户 uuid-
JF_APP_KEYjf_appKey开放平台应用 appKey-
JF_APP_SECRETjf_secret开放平台应用密钥-
JF_MOVE_CARDjf_moveCard移动卡标识(用于签名)2
JF_DEVICE_SNjf_device_sn设备序列号-
JF_AUTHORIZATIONjf_authorization用户 token (JWT)-
JF_USERjf_user用户 ID-
JF_ENDPOINT-API 接入地址api.jftechws.com

API 接口

功能地址方法需要 Token需要在线
查询服务状态POST /indoor/ai/analysis/switch/getPOST
开关服务POST /indoor/ai/analysis/switch/changePOST
查询异常配置POST /indoor/abnormalAlarmConfig/listPOST
更新异常配置POST /indoor/abnormalAlarmConfig/savePOST
异常告警列表POST /indoor/alarm/pagePOST
新增成员POST /indoor/face/sample/addPOST
删除成员POST /indoor/face/sample/deletePOST
修改成员POST /indoor/face/sample/updatePOST
成员列表POST /indoor/face/sample/listPOST
统计查询POST /indoor/static/behavior/*POST
统计图表POST /indoor/static/exist/*POST

核心功能

1. 服务状态管理

查询服务状态: POST /indoor/ai/analysis/switch/get

开关服务: POST /indoor/ai/analysis/switch/change

2. 异常提醒配置

异常类型枚举:

枚举值说明
SuspectedStranger疑似陌生人
FireDetection明火
DangerousBehavior危险行为

灵敏度枚举:

枚举值说明
low
middle
high

3. 异常告警查询

异常告警类型:

枚举值说明
SuspectedStranger疑似陌生人
FireDetection明火
DangerousBehavior危险行为
SomeoneEntered有人进入
SomeoneLeft有人离开

4. 成员管理

新增成员: POST /indoor/face/sample/add

删除成员: POST /indoor/face/sample/delete

修改成员: POST /indoor/face/sample/update

成员列表: POST /indoor/face/sample/list

5. 统计数据

行为统计:

  • queryCount - 查询标签总次数(进入/离开)
  • dayDataChart - 当日数据图(进入/离开)
  • weekDataChart - 周数据图(进入/离开)

存在统计:

  • queryCount - 查询最大人数/存在时长
  • dayDataChart - 当日数据图(最大人数/存在时长)
  • weekDataChart - 周数据图(最大人数/存在时长)

使用示例

环境准备

# 设置环境变量
export JF_UUID="<your-uuid>"
export JF_APP_KEY="<your-appkey>"
export JF_APP_SECRET="<your-secret>"
export JF_MOVE_CARD="7"
export JF_DEVICE_SN="<your-device-sn>"
export JF_AUTHORIZATION="eyJhbGciOiJIUzI1NiIs..."
export JF_USER="<your-uuid>"
export JF_ENDPOINT="api.jftechws.com"

1. 查询服务状态

cd ~/.openclaw/workspace/jf-open-pro-ai-indoor-security/scripts

# 查询室内安防服务状态
python3 indoor_security.py --action status \
  --sn "<your-device-sn>" \
  --user "<your-uuid>"

2. 成员管理

# 新增成员
python3 member_manager.py --action add \
  --name "爸爸" --avatar "base64_image" --notice 1 \
  --sn "<your-device-sn>" \
  --user "<your-uuid>"

# 查询成员列表
python3 member_manager.py --action list \
  --sn "<your-device-sn>" \
  --user "<your-uuid>"

# 删除成员
python3 member_manager.py --action delete --id 10 \
  --sn "<your-device-sn>" \
  --user "<your-uuid>"

3. 查询异常告警

# 查询疑似陌生人告警
python3 alarm_query.py --action list \
  --msg-type "SuspectedStranger" \
  --start-time 1733241600 --end-time 1733846399 \
  --sn "<your-device-sn>" \
  --user "<your-uuid>"

4. 查询统计数据

# 查询进入次数
python3 stats_query.py --action behavior-count \
  --type "SomeoneEntered" \
  --start-time 1733241600 --end-time 1733327999 \
  --sn "<your-device-sn>" \
  --user "<your-uuid>"

# 查询当日进入图表
python3 stats_query.py --action day-chart \
  --chart-type behavior \
  --type "SomeoneEntered" \
  --start-time 1733241600 --end-time 1733327999 \
  --sn "<your-device-sn>" \
  --user "<your-uuid>"

# 查询最大人数
python3 stats_query.py --action exist-count \
  --type "MaxPersonCount" \
  --start-time 1733241600 --end-time 1733327999 \
  --sn "<your-device-sn>" \
  --user "<your-uuid>"

状态码

平台状态码

code说明处理建议
2000成功-
28007Header 参数错误检查 uuid、appKey、timeMillis、signature
40103无效 Tokenauthorization 过期,重新获取
12504授权失败 - 设备未开通套餐登录开放平台为设备绑定室内安防套餐卡
50000服务器内部错误联系杰峰技术支持

错误码 12504 详细处理步骤

错误信息: authorize failed,Please check it in the open platform

原因: 设备未开通室内安防服务,或未绑定套餐卡

解决步骤:

  1. 登录杰峰开放平台:https://developer.jftech.com
  2. 进入 套餐管理 / 服务管理
  3. 找到 室内安防 套餐
  4. 为设备购买并绑定套餐卡
  5. 等待配置生效(通常 1-5 分钟)
  6. 重新调用 API 测试

注意事项

  1. 时间戳 - 统计查询使用秒级时间戳
  2. 套餐开通 - 使用前需确保设备已开通室内安防套餐
  3. Token 有效期 - authorization 需在有效期内
  4. 签名算法 - 使用杰峰官方移位加密算法
  5. 成员图片 - 新增成员时需要提供 base64 格式的图片

相关文件

文件说明
SKILL.md技能文档
scripts/indoor_security.py服务状态管理脚本
scripts/member_manager.py成员管理脚本
scripts/alarm_query.py告警查询脚本
scripts/stats_query.py统计数据查询脚本
references/indoor-security-api.mdAPI 参考文档

参考文档


📋 前置配置文档(环境变量缺失时参考)

⚠️ 重要提示: 如果在使用本技能时发现缺少必需的环境变量,请先完成以下配置步骤,然后再继续操作。

必需环境变量清单

以下 7 个环境变量 必须全部配置,缺一不可:

#变量名配置项说明
1JF_UUIDjf_uuid开放平台用户 uuid
2JF_APP_KEYjf_appKey开放平台应用 appKey
3JF_APP_SECRETjf_secret开放平台应用密钥
4JF_MOVE_CARDjf_moveCard移动卡标识(用于签名)
5JF_DEVICE_SNjf_device_sn设备序列号
6JF_AUTHORIZATIONjf_authorization用户 token (JWT)
7JF_USERjf_user用户 ID

参数获取指南

1. JF_UUID(jf_uuid)

登录杰峰开放平台 → 个人中心/开发者信息 → 复制用户 UUID

2. JF_APP_KEY(jf_appKey)

登录杰峰开放平台 → 应用管理 → 我的应用 → 复制 appKey

3. JF_APP_SECRET(jf_secret)

登录杰峰开放平台 → 应用管理 → 应用详情 → 复制 secret 密钥

4. JF_MOVE_CARD(jf_moveCard)

通过 appKey 查询接口获取,或在开放平台应用详情页查看

5. JF_DEVICE_SN(jf_device_sn)

查看设备底部标签,或在开放平台设备管理中查看

6. JF_AUTHORIZATION(jf_authorization)⭐

  • 使用杰峰用户系统:参考用户登录接口获取 Authorization 值(JWT Token)
  • 使用开发者自己的用户系统:传值参考套餐卡使用中的 userId

7. JF_USER(jf_user)

与 JF_UUID 通常相同,或在开放平台个人中心查看


配置示例

export JF_UUID="your-uuid-here"
export JF_APP_KEY="your-appkey-here"
export JF_APP_SECRET="your-secret-here"
export JF_MOVE_CARD="your-movecard-here"
export JF_DEVICE_SN="your-device-sn-here"
export JF_AUTHORIZATION="your-authorization-token-here"
export JF_USER="your-user-id-here"

重要提醒

使用原则: 后续所有 API 调用,必须严格使用用户环境变量中配置的参数值,不允许技能自己发散去获取或推算参数!