Files
FacereDataset/data/raw/oshwhub/ba64bd6f1c9c467ba3b674a54943557d/source/20d9ac185c6245dfa07604968b5e391b.epro2
Knowit 3282a028c4 Add EasyEDA Pro EPRO2 source ingestion (3/5 batch test)
打通 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>
2026-04-28 21:45:52 +08:00

4 lines
2.1 KiB
Plaintext

{"type":"DOCHEAD","ticket":636}||{"docType":"DEVICE","client":"0bb2c9fe-c897-4bff-b46c-eaa1f7c27461","uuid":"20d9ac185c6245dfa07604968b5e391b","updateTime":1749545742000,"version":"1656103224","editVersion":"3.2.91","user":{"uuid":"16555ec60452466ea4dbaa7c6b92cd89","nickname":"乐鑫小铁匠","username":"esp-college","avatar":"//image.lceda.cn/avatars/2023/7/DgnM9iWggXtWZa70BQwJnpb1x7P2etO5s7i6vqxp.png"}}|
{"type":"DOCHEAD","ticket":637}||{"docType":"DEVICE","client":"0bb2c9fe-c897-4bff-b46c-eaa1f7c27461","uuid":"20d9ac185c6245dfa07604968b5e391b","updateTime":1749545742000,"version":"1656103224","editVersion":"3.2.91","user":{"uuid":"16555ec60452466ea4dbaa7c6b92cd89","nickname":"乐鑫小铁匠","username":"esp-college","avatar":"//image.lceda.cn/avatars/2023/7/DgnM9iWggXtWZa70BQwJnpb1x7P2etO5s7i6vqxp.png"}}|
{"type":"META","ticket":638,"id":"META"}||{"title":"AO3401A_C15127","tags":["三极管/MOS管/晶体管","场效应管(MOSFET)"],"source":"be56508f80684877b262e15e4d50e175|0819f05c4eef4c71ace90d822a990e87","images":["https://alimg.szlcsc.com/upload/public/product/middle/20221228/95563555C16143CA79D7F958A8A4E28F.jpg"],"attributes":{"LCSC Part Name":"P沟道30V4A","Supplier Part":"C15127","Manufacturer":"AOS","Manufacturer Part":"AO3401A","Supplier Footprint":"SOT-23-3L","JLCPCB Part Class":"BasicPart","Datasheet":"https://atta.szlcsc.com/upload/public/pdf/source/20160507/1462613609053.pdf","Supplier":"LCSC","Add into BOM":"yes","Convert to PCB":"yes","Symbol":"69b99e1bee754b2388851005a07c8b0b","Designator":"Q?","Footprint":"eb28c1d19e1943a68a523b1924655892","3D Model":"c62791f0466c4ae2a892c056b845b0ca","3D Model Title":"SOT-23-3P_L2.9-W1.3-H1.0-LS2.4-P0.95","3D Model Transform":"98.64468,114.173,0,180,0,0,0,0,0","Type":"P沟道","Drain Source Voltage (Vdss)":"30V","Continuous Drain Current (Id)":"4A","Power Dissipation (Pd)":"1.4W","Drain Source On Resistance (RDS(on)@Vgs,Id)":"44mΩ@10V,4.3A","Gate Threshold Voltage (Vgs(th)@Id)":"1.3V@250uA","Name":"={ManufacturerPart}","Description":"类型:P沟道;漏源电压(Vdss):30V;连续漏极电流(Id):4A;功率(Pd):1.4W;导通电阻(RDS(on)@Vgs,Id):44mΩ@10V,4.3A;"}}|