打通 oshwhub origin=pro 现代 Pro 3.x 工程的 EPRO2 源抓取链路。3/5
modern Pro 项目完整解出(共 8423 docs / 542 MB plain):
- X86 主板 7374 docs / 481 MB plain (chain=85, editor=3.2.15)
- 220V 桌面电源 771 docs / 26 MB plain (chain=28, editor=3.2.69)
- ESP-VoCat 278 docs / 7.5 MB plain (chain=12, editor=3.2.91)
剩余 2/5 是 legacy Pro 2.x(立创泰山派 RK3566、梁山派),项目 meta
返回 branch_uuid=null + editorVersion="2.1.40",没有 git-style chain
模型,文档直接挂在 boards[].sch/pcb 字段上,访问端点暂未挖通;元
数据落库 metadata.json,source/ 留空。
实现要点:
- fetch_pro_source(): 4 步流程(project → branch HEAD → structures
→ /branches/<B>/histories/<HEAD> 即返完整 chain,无需 ?limit 批量
端点)+ 逐 history 走 AES-128-GCM 解密(16 字节 IV,pycryptodome
原生支持)+ gunzip + 按 DOCHEAD 切 per-doc EPRO2 流
- EPRO2 解析坑:行末单 `|` 是行终止符不是字段分隔符,必须先
rstrip("|") 再 split("||"),否则 payload JSON 解析失败 silently
swallow 导致 cur_doc 不设 → 第一轮 X86 板 7374 docs 抽出来只剩 2 个
- docType 实测远不止 BOARD/PCB/SCH/SCH_PAGE,还含 SYMBOL /
FOOTPRINT / DEVICE / BLOB / FONT / CONFIG —— Pro 把组件库快照也
随项目存到 history,下游做 EPRO2→KiCad 转换时必须先把这些 lib
doc 加载进 symbol cache
- Pro 2.x vs 3.x 是不同存储模型 —— 3.x 走 branch 模型(已打通),
2.x 走 boards[] 直链(未打通);判别条件:project meta 的
branch_uuid 是否为 null
CLI 新增 --with-pro-source / --backfill-pro-source / --pro-cookie /
--origin(按 origin 字段服务端过滤 listing API),crawl_one() 按
origin=pro 自动 dispatch 到 Pro fetcher。
schema:docType 类型从 integer 放宽到 [integer, string, null]
(兼容 Std 的 1/3 + Pro 的 BOARD/SCH 等),新增 message_count 字段。
License 注意:本批 5 个项目全是 NC-SA / GPL,未达 Pro source doc
§4.2 Forge 白名单(MIT/BSD/Apache/CC0/CC-BY/CERN-OHL-P/Unlicense)。
按 CLAUDE.md "研究用、不再分发" 原则 raw 入库无碍;Forge 投影时
另过白名单。
详细技术细节见 docs/sources/easyeda_pro_source.md rev 3 + log.md。
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
4 lines
2.4 KiB
Plaintext
4 lines
2.4 KiB
Plaintext
{"type":"DOCHEAD","ticket":1431}||{"docType":"DEVICE","client":"5796efe0-71be-4764-a7be-8620972bb90b","uuid":"5dd039d9c81e459d901a6243e889bf81","updateTime":1735986458000,"version":"1654803888","user":{"uuid":"f6d958b048194965970a097419f0f68a","nickname":"重庆枫叶","username":"cqlcp","avatar":"//image.lceda.cn/avatars/2026/1/FneZQD4JKfDDm92UUIa483axw2OD9PF1E07L9Aby.webp"}}|
|
|
{"type":"DOCHEAD","ticket":1432}||{"docType":"DEVICE","client":"5796efe0-71be-4764-a7be-8620972bb90b","uuid":"5dd039d9c81e459d901a6243e889bf81","updateTime":1735986458000,"version":"1654803888","user":{"uuid":"f6d958b048194965970a097419f0f68a","nickname":"重庆枫叶","username":"cqlcp","avatar":"//image.lceda.cn/avatars/2026/1/FneZQD4JKfDDm92UUIa483axw2OD9PF1E07L9Aby.webp"}}|
|
|
{"type":"META","ticket":1433,"id":"META"}||{"title":"DBT50G-7.62-2P-BK-P","tags":["连接器","栅栏式接线端子"],"source":"0db34980e92e486c88148fbe069056c2|0819f05c4eef4c71ace90d822a990e87","images":["https://alimg.szlcsc.com/upload/public/product/middle/20230107/18D6034DD822EC60C287F8F6E2BC4266.jpg"],"attributes":{"LCSC Part Name":"7.62mm 1x2P 每排P数:2 排数:1 直针 边脚","Supplier Part":"C496127","Manufacturer":"DORABO(地博电气)","Manufacturer Part":"DBT50G-7.62-2P-BK-P","Supplier Footprint":"插件,P=7.62mm","JLCPCB Part Class":"扩展库","Datasheet":"https://atta.szlcsc.com/upload/public/pdf/source/20230321/5EF6A0D07A73B1490602C5D26A4C0507.pdf","Supplier":"LCSC","Add into BOM":"yes","Convert to PCB":"yes","Symbol":"739959cbca5e4fc49bbf719243a78140","Designator":"U?","Footprint":"07809187a92046d687fb3e29af4d7e4e","3D Model":"75c6d9a5c2a2456996c82035a056898c","3D Model Title":"CONN-TH_2P-P7.62_L15.2-W16.7-EX4.2","3D Model Transform":"649.239,598.43345,0,0,0,0,0,-120.748,-141.732","Barrier Type":"带盖板","Pitch":"7.62mm","Structure":"1x2P","Mounting Style":"直针","Pin Location":"边脚","Number of Pins":"2P","Number of Rows":"1","Current Rating (Max)":"20A","Voltage Rating (Max)":"300V","Wire Gauge - AWG":"12~22","Wire Gauge - mm2":"-","Operating Temperature Range":"-40℃~+105℃","Color":"黑色","Number of PINs Per Row":"2","Name":"={Manufacturer Part}","Description":"隔板类型:带盖板;间距:7.62mm;结构:1x2P;安装方式:直针;引脚位置:边脚;排数:1;额定电流:20A;额定电压:300V;线规 - AWG:12~22;线规 - 平方毫米:-;工作温度范围:-40℃~+105℃;颜色:黑色;每排PIN数:2;"}}|
|