本技能使用时需先配置 api_key;技能列表与触发词见 references/skills_index.md。
| 技能 | 状态 | 说明 |
|------|------|------|
| 船位 Ship Position | ✅ 已实现 | 获取最新船舶位置 |
| 档案 Archive | ✅ 已实现 | 船舶/公司档案 |
| 红海/波斯湾通航 Strait Traffic | ✅ 已实现 | 海峡通航统计(曼德、苏伊士、好望角、霍尔木兹) |
| 区域船舶 Area Traffic | ✅ 已实现 | 查询指定区域内的当前船舶:支持 bbox、areaId(区域清单 id)或 polygon(WKT) |
| PSC 检查 PSC Inspection | ✅ 已实现 | 单船 PSC(按 IMO)→ 统计异常 openclaw/anomalies* → 宏观统计 openclaw/stats/compare|defects/top|mix/compare |
| 港口 Port guide | ✅ 已实现 | 港口列表/检索(港名或代码)、单港详情(piuid→portId);portguide/getPort/token、portguide/getPortDetail/token |
| 租船 Charter | ✅ 已实现(内置模块) | 船盘/货盘邮件检索解析、按港口距离排序、船期查询;使用 hifleet-mytonnages/ 分册工作流 |
| 性能 Performance | 待实现 | 油耗、能效、主机性能 |
| 航程 Voyage | ✅ 已实现(部分) | 历史轨迹、航程、航线规划、历史挂靠、历史航次、上一港、当前停船|
| 航线 Route | 待实现 | 推荐航线、航路点 |
| 航运 Shipping | 待实现 | 运价、市场、新闻 |
| 气象海况 Weather | 待实现 | 风浪、台风、能见度 |
| 船队 Fleet | 待实现 | 多船监控、船队报表 |
| AIS | 待实现 | AIS 报文、轨迹回放 |
船位、档案、PSC、港口等已实现功能依赖 HiFleet API 鉴权:优先读取环境变量 HIFLEET_API_KEY,项目/ClawHub 内统一按 api_key 传入。
{base})
https://api.hifleet.com;其它部署设环境变量 HIFLEET_API_BASE(无末尾 /)。
{base}/路径,例如 {base}/position/getcallport/token。
国际航行船舶 : 通常有有效的IMO注册号码的船舶
电子围栏: 区域范围
获取(岸基+卫星+移动)船舶最新位置信息。支持关键字(船名或 MMSI)查询,自动走“先搜船、再查位”的两步流程。
api_key 从配置读取
scripts/get_position.py(支持关键字或 MMSI,可选用于命令行/集成)
两步流程:
position/shipSearch(shipname、api_key、i18n=zh、count)。
mmsi,调用 position/position/get/token 查位置并展示。
position/position/get/token 查位置。
若用户已提供 9 位数字 MMSI,可直接调用 position/position/get/token。
根据 IMO 或 MMSI 获取船舶档案(基本信息、尺度、舱容、建造、入级、动力、公司信息、互保协会等)。接口支持 imo 与 mmsi 二选一;船名需先通过 shipSearch 得到 MMSI/IMO。
api_key 从配置读取
scripts/get_archive.py(支持 IMO 或 MMSI,MMSI 直接传 mmsi 参数,需 api_key)
调用流程:检查 api_key → 按 IMO 或 MMSI 调用档案接口(内贸船无 IMO 可传 MMSI)→ 解析 data,按 labelZh 分块展示。
查询单船历史轨迹、挂靠、航次、上一离港及当前停船信息。均需 api_key;用户仅给船名/关键字时,先走 position/shipSearch 取得 MMSI(规则同船位技能)。
| 能力 | 接口 | 计费 |
|------|------|------|
| 历史轨迹(压缩) | GET/POST {base}/position/trajectory/token | 按轨迹点数阶梯(每 100 点 1 点,最低 2 点) |
| 历史轨迹(未压缩) | GET/POST {base}/position/trajectory/nocompressed/token | 按轨迹点数阶梯(每 100 点 1 点,最低 2 点) |
| 历史挂靠 | GET/POST {base}/position/getcallport/token | 按挂靠条数阶梯(每 20 条 1 点,最低 2 点) |
| 历史航次(简版) | GET/POST {base}/position/getvoyagelist/token | 按航次条数阶梯(每 20 条 1 点,最低 2 点) |
| 历史航次(详版) | GET/POST {base}/portofcall/getvoyages | 按航次条数阶梯(每 20 条 1 点,最低 2 点) |
| 上一港 | GET/POST {base}/position/lastdeparture/token | 固定计费(FIXED) |
| 当前停船 | GET/POST {base}/position/getstop/token | 固定计费(FIXED) |
按 MMSI 与时间区间查询 AIS 历史轨迹点(与挂靠/航次不同,返回点序列)。
mmsi(必选);starttime、endtime(必选,北京时间);可选 bbox(左经,下纬,右经,上纬,仅 zoom≥8 时过滤)、zoom(默认 7,最大 16)
GET/POST {base}/position/trajectory/token?mmsi={mmsi}&starttime={start}&endtime={end}&api_key=...
ships.offers.ship[] 含 ti(报位时间)、la/lo、sp(航速)、co(航向)、dis(累计航程)、isstoppoint 及停船相关字段
查询某船在指定时间段内的靠港记录(已合并港外临时停船等噪声,按时间降序,最新在前)。
mmsi(必选);starttime、endtime(必选,北京时间,如 2019-01-01 00:00:00);可选 accuracyval(默认 6)
GET/POST {base}/position/getcallport/token?mmsi={mmsi}&starttime={start}&endtime={end}&api_key=...
result=ok 时 list.shipRouteFeature[] 含 mPortname/cnportname、portcode、mUpdatetime(到港/挂靠时间)、mleavetime(离港时间)、country/countryCnName、lat/lon、fre(近一年该港挂靠次数)等
路由建议:
| 用户意图 | 优先接口 |
|----------|-----------|
| 最近航次、默认时间窗、不需自定义区间 | position/getvoyagelist/token(服务端默认约最近 10 个月,仅传 mmsi) |
| 指定起止时间、需航程/航速/吃水等明细 | portofcall/getvoyages |
mmsi
mmsi;starttime、endtime(必选,北京时间);可选 accuracyval(默认 5)、updatedistance(默认 1,是否补算航程距离)
GET/POST {base}/position/getvoyagelist/token?mmsi={mmsi}&api_key=...
GET/POST {base}/portofcall/getvoyages?mmsi={mmsi}&starttime={start}&endtime={end}&api_key=...
list.voyage[] 含 startport/endport、startportcode/endportcode、starttime/endtime、timelong(航行小时数)
result=OK 时 list[] 为 ShipVoyageBean,额外含中英文港名与国家、最大/平均航速、航程(海里)、吃水等
查询船舶最近一次离港港口与离港时间。
mmsi
GET/POST {base}/position/lastdeparture/token?mmsi={mmsi}&api_key=...
result=ok 时 list 为单条 LastDeparture:portcode、portname、departtime(北京时间)、country、countryCode
查询船舶最新停船/到港位置与停船时长(同 legacy /portofcall/get/shipstoppedplaceandtime 语义)。
mmsi
GET/POST {base}/position/getstop/token?mmsi={mmsi}&api_key=...
message=ok 时 data[] 含 portcode、enportname/cnportname、encountry/cncountry、lat/lon、stoptime、starttime、accumulatetime(累计停船时长描述)
调用流程:检查 api_key → 若无 MMSI 则 shipSearch → 按上表选接口 → 解析并展示;无数据时如实说明(result=failed / empty / data 或轨迹 ship[] 为空),勿伪造轨迹点、挂靠或航次。
咽喉航道通航船舶统计,支持曼德海峡、苏伊士运河、好望角、霍尔木兹海峡,按日期区间与方向返回船型统计及船舶明细。无 api_key 仅可查最近 1 周,有 api_key 时间区间不限。
api_key 从配置读取,有则时间不限。
scripts/get_strait_traffic.py(海峡名或 oid + 可选 startdate/enddate/i18n,有 api_key 可查超 7 天)
接口:POST {base}/position/statisticzonetraffic,Query 参数 oid、startdate、enddate、i18n(可选)、api_key(可选)。海峡 oid:曼德海峡 24480、苏伊士运河 132808、好望角 1062830、霍尔木兹海峡 24471。无 api_key 时校验时间区间 ≤ 7 天。
查询当前指定区域内的船舶列表。支持三种区域指定方式:矩形 bbox、区域 id(areaId) 或 WKT 多边形(polygon)。用户仅文字描述区域(如 [波斯湾]「红海」「北太平洋」「马六甲海峡」)时,先查区域清单再按 areaId 查询。
api_key 必填
scripts/get_areas.py(获取区域清单,供按名称选区域);scripts/get_area_traffic.py(bbox 四参数、--area-id 或 --polygon "POLYGON((...))",需 api_key)
调用流程:检查 api_key → 若用户给的是矩形坐标:组 bbox → GET {base}/position/gettraffic/token?bbox=...&api_key=...;若用户给的是文字描述:GET {base}/position/areas/token(可选 api_key)→ 用 name/cnName 匹配得 id → GET {base}/position/gettraffic/token?areaId={id}&api_key=...;若用户给的是WKT 多边形:GET {base}/position/gettraffic/token?polygon=...&api_key=... → 解析 list 展示船名、MMSI、经纬度、航速、状态、目的港等。
港口列表检索与单港详细信息。列表可用 portName 或 portCode 筛选;详情用列表项 piuid 作为 portId。
piuid);api_key 从配置读取;可选 HIFLEET_API_BASE
scripts/get_port.py(子命令 search [--port-name] [--port-code]、detail )
调用流程:检查 api_key → 调列表接口(按需加 portName、portCode)→ 展示命中项并请用户确认 → 用 piuid 调详情接口。
租船能力已合并为 hifleet-skills 的内置模块,分册与脚本位于 hifleet-mytonnages/:支持船盘/货盘邮件检索解析、按港口距离排序,以及 HiFleet 服务端船期查询。
hifleet-mytonnages/ 分册配置邮箱与记忆;船舶档案富化、港口 ID、距离排序和船期接口需配置 hifleet_api_key 或 HIFLEET_API_KEY
集装箱船舶绕航红海每日统计,按日期区间与方向返回船型统计及船舶明细。无 api_key 仅可查最近 1 周,有 api_key 时间区间不限。
api_key 从配置读取,有则时间不限。
scripts/get_avoidredsea_traffic.py( 必选 starttiime/endtime,有 api_key 可查超 7 天)
根据 IMO 查询船舶 港口国监督检查(PSC) 数据。接口为 GET {base}/pscapi/get,必须带 api_key(与其它需鉴权接口一致)。支持用户直接提供 IMO,或提供船名/关键字、9 位 MMSI 时先走 position/shipSearch,从命中结果的 imonumber 取得 IMO 再请求 PSC;无 IMO 的内贸船无法调本接口。
IMO 前缀);或船名/关键字;或 9 位 MMSI(与船位技能相同,先搜船再取 IMO);api_key 从配置读取
scripts/get_psc.py(IMO / 船名 / 船名 + MMSI / MMSI)
调用流程:检查 api_key → 若用户已给 IMO:GET pscapi/get?imo={imo}&api_key=... → 解析并展示(脚本对常见 status+data / list 结构做分条输出,否则整段 JSON)。若用户给 船名或 MMSI 关键字:与船位相同的搜船规则(0/1/多条、多条时让用户选 MMSI)→ 取选定船的 imonumber;若为空则提示无 IMO、无法查 PSC → 有 IMO 再调 pscapi/get。
基于日批统计的 异常事件表(psc_anomaly_event),与「单船 PSC 记录」互补:回答某时段、某当局/旗国/港口等维度下「滞留率/平均缺陷是否相对历史显著升高」等宏观问题。均需 api_key(与 pscapi/get 相同)。
OpenClaw 字段语义必守:详见 references/psc_stats_field_semantics.md。核心:authority 表示检查国/检查当局,不是船籍国;ship_type / shipType 表示检查类型,不是船型。真实船型统计当前日批维度不提供。接口细节见 references/psc_anomaly_api.md。
yyyy-MM-dd);可选 authority/flag/port(精确)、authorityContains/flagContains(子串 LIKE,适合「中国/China」等)、sliceType(AUTHORITY_FLAG=当局×旗国粗粒度异常;AUTHORITY_FLAG_PORT_TYPE=含港口×检查类型细切片)、severity、anomalyType 等;列表支持 page、pageSize
scripts/get_psc_anomalies.py(子命令 list / summary / get )
三类调用(Agent 按需组合):
GET {base}/pscapi/openclaw/anomalies/summary?api_key=...&dateFrom=...&dateTo=... → 按 severity 计数,适合先答「严重异常有多少」。
GET {base}/pscapi/openclaw/anomalies?api_key=...(同上筛选 + 分页)→ data.list 展示 title、dateEnd、severity、metric 等。
GET {base}/pscapi/openclaw/anomalies/{id}?api_key=... → 展开 description、evidence(JSON 字符串可格式化)。
数据稀疏时的回答规则(OpenClaw 必守)
psc_anomaly_event 可能只有极少行或全空,不得据此下结论「没有 PSC 风险」「监管很松」等。须遵守 references/psc_anomaly_api.md 中的 「异常表数据量过少」专节,要点如下:
| 情况 | Agent 应做 |
|------|------------|
| list 的 total == 0 或 summary 全为 0 | 明确说:仅表示「统计异常事件表」在当前筛选/时间窗内无命中,不代表无 PSC 活动、不代表无滞留;原因可能是检测阈值严、切片样本不足、未跑全量 backfill-anomalies、或 authority/flag/port 与库内精确字符串不一致。 |
| total 为个位数(如 1~5) | 如实列出;注明 样本极少、不宜做宏观推断;可建议放宽日期、减少筛选维度,或改用单船 PSC。 |
| 用户问「中国/巴拿马」等自然语言 | 优先用 authorityContains/flagContains(如 China、Panama)再查异常表;宏观「某检查国对哪些船旗」优先 sliceType=AUTHORITY_FLAG;仍 0 条时再说明精确值可能不一致或模型未命中。 |
| 用户要「某船有没有被查」 | 不要用异常表代替:应走上文 PSC 检查(pscapi/get + IMO)。 |
| 用户问「为什么一直没有异常」 | 可简述:日批模型只标记相对历史基线显著升高的切片;min-inspections、Z 阈值、是否已跑异常补算均会影响条数;运维侧可调 newpsc psc.stats 或补跑 backfill-anomalies(不展开实现细节除非用户是运维)。 |
与 异常事件表互补:直接基于 pscdata.psc(及 psc_defect_distribution)做可引用数字,支撑「哪国变严」「哪旗/哪港风险」「缺陷热点」「是否某旗占比上升」等;不替代因果推断与预测。
scripts/get_psc_openclaw_stats.py(compare / defects / mix)
Agent 路由建议:
| 用户意图 | 优先接口 |
|----------|-----------|
| 国家/全局监管变严、检查量/滞留率环比 | GET {base}/pscapi/openclaw/stats/compare(groupBy=AUTHORITY/GLOBAL,可用 authorityContains) |
| 船旗风险排行、某旗滞留率 | compare + groupBy=FLAG;结合 anomalies |
| 中国/某国主要检查港口、哪港严 | stats/compare 必调:groupBy=PORT 或 AUTHORITY_PORT + authorityContains(如 China);禁止在未请求接口时用常识港口列表冒充数据;禁止谎称「港口接口故障」除非返回明确错误(并说明 code)。 |
| 最近查什么缺陷、缺陷码热点 | GET {base}/pscapi/openclaw/stats/defects/top(需 newpsc 已写缺陷分布表) |
| 是否「针对」某旗 / 检查类型占比变化 | GET {base}/pscapi/openclaw/stats/mix/compare(mixDimension=FLAG 或 TYPE_INS);勿断言政治针对,TYPE_INS 不是散货船等船型 |
| 统计模型认定的异常 spike | 仍用 openclaw/anomalies* |
| 某船/IMO | pscapi/get |
合规:勿输出投资建议(「必避开某港」);可陈述事实与风险提示。无「风险预测」专用接口,对未来表述须谨慎。
本技能仅向 {base}(默认 https://api.hifleet.com,可由 HIFLEET_API_BASE 覆盖)下的船位/档案/航程/PSC/海峡通航/区域船舶等固定路径发起只读请求(GET 或 POST);鉴权接口使用 api_key。基址约定见 references/api_base.md;详见 SECURITY.md。
| 路径 | 说明 |
|------|------|
| SECURITY.md | 安全说明(网络行为、Token 用途、无动态代码) |
| references/api_base.md | API 基址 {base} 与 HIFLEET_API_BASE 约定 |
| references/skills_index.md | 技能清单(中英双语、触发词) |
| references/position_api.md | 船位 API 完整说明与响应字段 |
| references/archive_api.md | 档案 API 说明与 data 分类 |
| references/voyage_api.md | 航程 API:历史挂靠、历史航次、上一港、当前停船(OpenClaw) |
| references/strait_traffic_api.md | 红海/波斯湾海峡通航 API(oid、时间范围) |
| references/area_traffic_api.md | 区域船舶 API(bbox、areaId、polygon、api_key) |
| references/areas_api.md | 区域清单 API(海区/贸易区列表,供按名称选 areaId) |
| references/psc_api.md | PSC 检查 API(pscapi/get,imo + api_key) |
| references/psc_anomaly_api.md | PSC 统计异常 API(openclaw/anomalies*,api_key,可选 HIFLEET_API_BASE) |
| references/psc_openclaw_stats_api.md | PSC 宏观统计(openclaw/stats/compare、defects/top、mix/compare) |
| references/psc_stats_field_semantics.md | PSC 多表字段语义:authority=检查国、ship_type=检查类型(非船型) |
| scripts/get_position.py | 按关键字或 MMSI 获取船位(需 api_key;可选 HIFLEET_API_BASE) |
| scripts/get_archive.py | 按 IMO 或 MMSI 获取船舶档案(需 api_key;可选 HIFLEET_API_BASE) |
| scripts/get_strait_traffic.py | 海峡通航统计(POST {base}/position/statisticzonetraffic);可选 HIFLEET_API_BASE |
| scripts/get_avoidredsea_traffic.py | 集装箱红海饶航(POST {base}/routerisk/getAvoidRedSeaDetail/token);可选 HIFLEET_API_BASE |
| scripts/get_areas.py | 区域清单({base}/position/areas/token);可选 HIFLEET_API_BASE |
| scripts/get_area_traffic.py | 区域船舶({base}/position/gettraffic/token,需 api_key);可选 HIFLEET_API_BASE |
| scripts/get_psc.py | PSC 检查(需 api_key;可选 HIFLEET_API_BASE) |
| scripts/get_psc_anomalies.py | PSC 统计异常:list / summary / get id(需 api_key,可选 HIFLEET_API_BASE) |
| scripts/get_psc_openclaw_stats.py | PSC 宏观统计:compare / defects / mix(需 api_key,可选 HIFLEET_API_BASE) |
共 7 个版本