Tencent MPS
一个面向 crypto 场景的 Agent 技能。原始说明:腾讯云 MPS 媒体处理服务,支持以下功能:【视频转码】转码/压缩/格式转换/H.264/H.265/AV1/MP4/编码/码率/分辨率/帧率。【画质增强】画质增强/老片修复/超分/视频超分/真人增强/漫剧增强/防抖/720P/1080P/2K/4K。【音频处理】音频分离/人声提取/伴奏提取/去...
name: jf-open-pro-smart-doorlock-control
description: 杰峰智能门锁设备控制技能(开发版)。支持查询设备是否支持门锁能力、登录设备、获取设备接口访问令牌,以及远程一键开锁。
metadata:
version: 1.0.0
author: JFTech
category: device
tags:
triggers:
prerequisites:
region:
支持杰峰智能门锁设备的远程控制功能:
适用场景:
| 变量名 | 说明 | 默认值 | 必需 |
|--------|------|--------|------|
| JF_UUID | 开放平台用户 uuid | - | ✅ |
| JF_APP_KEY | 开放平台应用 appKey | - | ✅ |
| JF_APP_SECRET | 开放平台应用密钥 | - | ✅ |
| JF_MOVE_CARD | 移动卡标识(用于签名) | 2 | ✅ |
| JF_DEVICE_SN | 设备序列号 | - | ✅ |
| JF_DEVICE_TOKEN | 设备接口访问令牌 | - | ✅ |
| JF_ENDPOINT | API 接入地址 | api-cn.jftechws.com | ❌ |
| 功能 | 地址 | 方法 | 需要 Token | 需要在线 |
|------|------|------|------------|----------|
| 查询设备能力 | POST /gwp/v3/rtc/device/getability/{token} | POST | ✅ | ✅ |
| 获取门锁配置 | POST /gwp/v3/rtc/device/doorLockTransparent/{token} | POST | ✅ | ✅ |
| 登录设备 | POST /gwp/v3/rtc/device/login/{token} | POST | ✅ | ✅ |
| 获取设备 Token | POST /gwp/v3/rtc/device/token | POST | ❌ | ❌ |
| 远程开锁 | POST /gwp/v3/rtc/device/doorLockRemoteUnlock/{token} | POST | ✅ | ✅ |
API: POST /gwp/v3/rtc/device/getability/{deviceToken}
Name: DoorFunction
说明: 查询设备能力集,确认设备是否支持门锁功能及相关特性。
响应参数:
| 字段 | 类型 | 说明 |
|------|------|------|
| DoorFunction.DoorAbilityMask | int | 门锁能力掩码(按位标识各类门锁能力) |
| DoorFunction.LocalAbilityMask | int | 本地能力掩码(按位标识本地支持的能力) |
| DoorFunction.UserManage | object | 用户管理能力信息 |
| DoorFunction.UserManage.TypeMsk | int | 用户类型掩码 |
| DoorFunction.AdminAbility | int | 管理员能力值 |
| DoorFunction.TmpPwdRange | object | 临时密码范围配置 |
| DoorFunction.TmpPwdRange.Start | int | 临时密码起始值 |
| DoorFunction.TmpPwdRange.End | int | 临时密码结束值 |
| DoorFunction.TmpPwdRange.UsrTypeMask | int | 临时密码适用的用户类型掩码 |
| DoorFunction.TipVolume | int | 提示音量档位 |
| DoorFunction.RebootMachine | int | 重启设备支持标识 |
| DoorFunction.OPTrans | int | 透明传输能力标识 |
| DoorFunction.IOTFaceModuleOta | object | 人脸识别模块 OTA 信息 |
| DoorFunction.IOTFaceModuleOta.Enable | bool | 人脸识别模块 OTA 使能状态 |
| DoorFunction.IOTFaceModuleOta.Pid | int | 人脸识别模块产品 ID |
| DoorFunction.IOTFaceModuleOta.ModuleName | string | 人脸识别模块名称 |
| DoorFunction.IOTFaceModuleOta.NavVersion | string | 人脸识别模块导航版本 |
| DoorFunction.QsCapMask | int | 快速启动能力掩码 |
| DoorFunction.QsPid | int | 快速启动产品 ID |
| DoorFunction.NavVersion | string | 导航版本号 |
API: POST /gwp/v3/rtc/device/doorLockTransparent/{deviceToken}
请求参数:
| 参数 | 类型 | 必需 | 说明 | 取值 |
|------|------|------|------|------|
| Name | string | ✅ | 方法名称 | OPDoorLockProCmd |
| OPDoorLockProCmd.Cmd | string | ✅ | 命令码 | GetDoorConfig |
请求示例:
{
"Name": "OPDoorLockProCmd",
"OPDoorLockProCmd": {
"Cmd": "GetDoorConfig"
}
}
响应参数:
| 字段 | 类型 | 说明 |
|------|------|------|
| DoorConfig.PirConfig.Enable | bool | 逗留侦测是否使能 |
| DoorConfig.PirConfig.sensitivity | int | 灵敏度:低/中/高(0/1/2) |
| DoorConfig.UnlockDirection.Direction | int | 方向:左/右(0/1) |
| DoorConfig.AutoLock.LockMode | int | 手动上锁/自动上锁(0/1) |
| DoorConfig.AutoLock.AutoLockInterval | int | 自动锁定时间:10~99 秒 |
| DoorConfig.UnlockMode.mode | int | 单开模式/组合模式(0/1) |
| DoorConfig.VolumeControl.Volume | int | 音量:静音/小/中/大(0/1/2/3) |
| DoorConfig.FaceAlarmTone.Enable | bool | 人脸声音开关是否使能 |
| DoorConfig.MotorTorque.Torque | int | 扭矩:小/中/大(0/1/2) |
| DoorConfig.NormalOpenMode.Mode | int | 常开模式:关闭/开启(0/1) |
| DoorConfig.DeployDefense.Enable | int | 布防状态:撤防/布防(0/1) |
API: POST /gwp/v3/rtc/device/login/{deviceToken}
请求参数:
| 参数 | 类型 | 必需 | 说明 | 示例 |
|------|------|------|------|------|
| UserName | string | ✅ | 设备用户名,恢复出厂后部分设备默认为 admin | admin |
| PassWord | string | ❌ | 设备登录密码 | 123456 |
| KeepaliveTime | int | ❌ | 保活时长,单位秒(默认 5 分钟,最长 24 小时) | 300 |
响应参数:
| 字段 | 类型 | 说明 |
|------|------|------|
| Ret | int | 设备登录状态码(100=成功) |
| DeviceType | string | 设备类型(IOT/IPC/DVR 等) |
| AliveInterval | int | 客户端与设备保活时间周期,单位秒 |
| ChannelNum | int | 设备通道数 |
| SessionID | string | 会话 ID |
说明: 设备默认 1 分钟无操作自动断开连接,若需保持长时间连接可设置 KeepaliveTime 进行保活。
API: POST /gwp/v3/rtc/device/token
说明: 获取 deviceToken,用于后续的门锁操作。Token 有效期 24 小时。
API: POST /gwp/v3/rtc/device/doorLockRemoteUnlock/{deviceToken}
请求参数:
| 参数 | 类型 | 必需 | 说明 | 取值 |
|------|------|------|------|------|
| sn | string | ✅ | 设备序列号 | - |
| props.doorLock.remoteUnlock.password | string | ❌ | 锁端密码(密码开锁时必填) | - |
| props.doorLock.remoteOneKeyUnlock | int | ❌ | 无密码一键开锁标记,填 1 | - |
| props.doorLock.userType | int | ❌ | 远程开锁为 5 | 5 |
| props.doorLock.memberID | int | ❌ | 成员 ID,1 表示主账号 | 1 |
说明: 支持两种开锁方式。提供密码时使用密码开锁,不提供密码时使用无密码一键开锁。
# 设置环境变量(使用占位符,请替换为实际值)
export JF_UUID="uuidxxxx"
export JF_APP_KEY="appkeyxxxx"
export JF_APP_SECRET="appsecretxxxx"
export JF_MOVE_CARD="2"
export JF_DEVICE_SN="snxxx1"
export JF_DEVICE_TOKEN="NTQ0NzQ3YmE3MXwyYzFk..."
export JF_ENDPOINT="api-cn.jftechws.com"
cd ~/.qoderwork/skills/jf-open-pro-smart-doorlock-control/scripts
python3 doorlock_control.py --action check-support
python3 doorlock_control.py --action get-config
# 使用默认用户名 admin 登录
python3 doorlock_control.py --action login --username "admin" --password "123456"
# 设置保活时长为 10 分钟
python3 doorlock_control.py --action login --username "admin" --password "123456" --keepalive-time 600
python3 doorlock_control.py --action get-token --device-sn "snxxx1"
# 无密码一键开锁
python3 doorlock_control.py --action unlock
# 使用密码开锁
python3 doorlock_control.py --action unlock --password "123456"
| code | 说明 | 处理建议 |
|------|------|----------|
| 2000 | 成功 | - |
| 28007 | Header 参数错误 | 检查 uuid、appKey、timeMillis、signature |
| 40103 | 无效 Token | deviceToken 过期,重新获取 |
| 50000 | 服务器内部错误 | 联系杰峰技术支持 |
| Ret | 说明 |
|-----|------|
| 100 | 成功 |
| 103 | 非法请求(设备不支持该功能) |
| 106 | 用户名或密码错误 |
| 文件 | 说明 |
|------|------|
| SKILL.md | 技能文档 |
| scripts/doorlock_control.py | Python 执行脚本 |
| scripts/crypto.py | 签名/时间戳加密工具(复用) |