@huyuan-ai/cli 1.0.0 → 1.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1454) hide show
  1. package/package.json +14 -6
  2. package/vendor/opencli/dist/analysis.d.ts +38 -0
  3. package/vendor/opencli/dist/analysis.js +166 -0
  4. package/vendor/opencli/dist/browser/base-page.d.ts +50 -0
  5. package/vendor/opencli/dist/browser/base-page.js +193 -0
  6. package/vendor/opencli/dist/browser/bridge.d.ts +21 -0
  7. package/vendor/opencli/dist/browser/bridge.js +109 -0
  8. package/vendor/opencli/dist/browser/cdp.d.ts +40 -0
  9. package/vendor/opencli/dist/browser/cdp.js +310 -0
  10. package/vendor/opencli/dist/browser/cdp.test.d.ts +1 -0
  11. package/vendor/opencli/dist/browser/cdp.test.js +52 -0
  12. package/vendor/opencli/dist/browser/daemon-client.d.ts +74 -0
  13. package/vendor/opencli/dist/browser/daemon-client.js +113 -0
  14. package/vendor/opencli/dist/browser/daemon-client.test.d.ts +1 -0
  15. package/vendor/opencli/dist/browser/daemon-client.test.js +77 -0
  16. package/vendor/opencli/dist/browser/discover.d.ts +15 -0
  17. package/vendor/opencli/dist/browser/discover.js +19 -0
  18. package/vendor/opencli/dist/browser/dom-helpers.d.ts +41 -0
  19. package/vendor/opencli/dist/browser/dom-helpers.js +227 -0
  20. package/vendor/opencli/dist/browser/dom-helpers.test.d.ts +1 -0
  21. package/vendor/opencli/dist/browser/dom-helpers.test.js +105 -0
  22. package/vendor/opencli/dist/browser/dom-snapshot.d.ts +86 -0
  23. package/vendor/opencli/dist/browser/dom-snapshot.js +804 -0
  24. package/vendor/opencli/dist/browser/dom-snapshot.test.d.ts +11 -0
  25. package/vendor/opencli/dist/browser/dom-snapshot.test.js +248 -0
  26. package/vendor/opencli/dist/browser/errors.d.ts +13 -0
  27. package/vendor/opencli/dist/browser/errors.js +40 -0
  28. package/vendor/opencli/dist/browser/index.d.ts +13 -0
  29. package/vendor/opencli/dist/browser/index.js +12 -0
  30. package/vendor/opencli/dist/browser/page.d.ts +62 -0
  31. package/vendor/opencli/dist/browser/page.js +304 -0
  32. package/vendor/opencli/dist/browser/page.test.d.ts +1 -0
  33. package/vendor/opencli/dist/browser/page.test.js +44 -0
  34. package/vendor/opencli/dist/browser/stealth.d.ts +16 -0
  35. package/vendor/opencli/dist/browser/stealth.js +353 -0
  36. package/vendor/opencli/dist/browser/stealth.test.d.ts +1 -0
  37. package/vendor/opencli/dist/browser/stealth.test.js +134 -0
  38. package/vendor/opencli/dist/browser/tabs.d.ts +13 -0
  39. package/vendor/opencli/dist/browser/tabs.js +70 -0
  40. package/vendor/opencli/dist/browser/utils.d.ts +10 -0
  41. package/vendor/opencli/dist/browser/utils.js +27 -0
  42. package/vendor/opencli/dist/browser.test.d.ts +1 -0
  43. package/vendor/opencli/dist/browser.test.js +159 -0
  44. package/vendor/opencli/dist/build-manifest.d.ts +47 -0
  45. package/vendor/opencli/dist/build-manifest.js +225 -0
  46. package/vendor/opencli/dist/build-manifest.test.d.ts +1 -0
  47. package/vendor/opencli/dist/build-manifest.test.js +176 -0
  48. package/vendor/opencli/dist/capabilityRouting.d.ts +4 -0
  49. package/vendor/opencli/dist/capabilityRouting.js +31 -0
  50. package/vendor/opencli/dist/capabilityRouting.test.d.ts +1 -0
  51. package/vendor/opencli/dist/capabilityRouting.test.js +42 -0
  52. package/vendor/opencli/dist/cascade.d.ts +46 -0
  53. package/vendor/opencli/dist/cascade.js +149 -0
  54. package/vendor/opencli/dist/cli-manifest.json +16706 -0
  55. package/vendor/opencli/dist/cli.d.ts +9 -0
  56. package/vendor/opencli/dist/cli.js +953 -0
  57. package/vendor/opencli/dist/cli.test.d.ts +1 -0
  58. package/vendor/opencli/dist/cli.test.js +88 -0
  59. package/vendor/opencli/dist/clis/1688/item.d.ts +70 -0
  60. package/vendor/opencli/dist/clis/1688/item.js +187 -0
  61. package/vendor/opencli/dist/clis/1688/item.test.d.ts +1 -0
  62. package/vendor/opencli/dist/clis/1688/item.test.js +67 -0
  63. package/vendor/opencli/dist/clis/1688/search.d.ts +56 -0
  64. package/vendor/opencli/dist/clis/1688/search.js +309 -0
  65. package/vendor/opencli/dist/clis/1688/search.test.d.ts +1 -0
  66. package/vendor/opencli/dist/clis/1688/search.test.js +75 -0
  67. package/vendor/opencli/dist/clis/1688/shared.d.ts +112 -0
  68. package/vendor/opencli/dist/clis/1688/shared.js +514 -0
  69. package/vendor/opencli/dist/clis/1688/shared.test.d.ts +1 -0
  70. package/vendor/opencli/dist/clis/1688/shared.test.js +57 -0
  71. package/vendor/opencli/dist/clis/1688/store.d.ts +45 -0
  72. package/vendor/opencli/dist/clis/1688/store.js +226 -0
  73. package/vendor/opencli/dist/clis/1688/store.test.d.ts +1 -0
  74. package/vendor/opencli/dist/clis/1688/store.test.js +62 -0
  75. package/vendor/opencli/dist/clis/36kr/article.d.ts +1 -0
  76. package/vendor/opencli/dist/clis/36kr/article.js +62 -0
  77. package/vendor/opencli/dist/clis/36kr/hot.d.ts +3 -0
  78. package/vendor/opencli/dist/clis/36kr/hot.js +80 -0
  79. package/vendor/opencli/dist/clis/36kr/hot.test.d.ts +1 -0
  80. package/vendor/opencli/dist/clis/36kr/hot.test.js +15 -0
  81. package/vendor/opencli/dist/clis/36kr/news.d.ts +1 -0
  82. package/vendor/opencli/dist/clis/36kr/news.js +51 -0
  83. package/vendor/opencli/dist/clis/36kr/news.test.d.ts +1 -0
  84. package/vendor/opencli/dist/clis/36kr/news.test.js +85 -0
  85. package/vendor/opencli/dist/clis/36kr/search.d.ts +1 -0
  86. package/vendor/opencli/dist/clis/36kr/search.js +72 -0
  87. package/vendor/opencli/dist/clis/_shared/common.d.ts +8 -0
  88. package/vendor/opencli/dist/clis/_shared/common.js +10 -0
  89. package/vendor/opencli/dist/clis/_shared/desktop-commands.d.ts +22 -0
  90. package/vendor/opencli/dist/clis/_shared/desktop-commands.js +108 -0
  91. package/vendor/opencli/dist/clis/amazon/bestsellers.d.ts +1 -0
  92. package/vendor/opencli/dist/clis/amazon/bestsellers.js +7 -0
  93. package/vendor/opencli/dist/clis/amazon/bestsellers.test.d.ts +1 -0
  94. package/vendor/opencli/dist/clis/amazon/bestsellers.test.js +29 -0
  95. package/vendor/opencli/dist/clis/amazon/discussion.d.ts +20 -0
  96. package/vendor/opencli/dist/clis/amazon/discussion.js +91 -0
  97. package/vendor/opencli/dist/clis/amazon/discussion.test.d.ts +1 -0
  98. package/vendor/opencli/dist/clis/amazon/discussion.test.js +36 -0
  99. package/vendor/opencli/dist/clis/amazon/movers-shakers.d.ts +1 -0
  100. package/vendor/opencli/dist/clis/amazon/movers-shakers.js +7 -0
  101. package/vendor/opencli/dist/clis/amazon/new-releases.d.ts +1 -0
  102. package/vendor/opencli/dist/clis/amazon/new-releases.js +7 -0
  103. package/vendor/opencli/dist/clis/amazon/offer.d.ts +23 -0
  104. package/vendor/opencli/dist/clis/amazon/offer.js +140 -0
  105. package/vendor/opencli/dist/clis/amazon/offer.test.d.ts +1 -0
  106. package/vendor/opencli/dist/clis/amazon/offer.test.js +29 -0
  107. package/vendor/opencli/dist/clis/amazon/product.d.ts +18 -0
  108. package/vendor/opencli/dist/clis/amazon/product.js +92 -0
  109. package/vendor/opencli/dist/clis/amazon/product.test.d.ts +1 -0
  110. package/vendor/opencli/dist/clis/amazon/product.test.js +24 -0
  111. package/vendor/opencli/dist/clis/amazon/rankings.d.ts +59 -0
  112. package/vendor/opencli/dist/clis/amazon/rankings.js +226 -0
  113. package/vendor/opencli/dist/clis/amazon/rankings.test.d.ts +1 -0
  114. package/vendor/opencli/dist/clis/amazon/rankings.test.js +41 -0
  115. package/vendor/opencli/dist/clis/amazon/search.d.ts +18 -0
  116. package/vendor/opencli/dist/clis/amazon/search.js +87 -0
  117. package/vendor/opencli/dist/clis/amazon/search.test.d.ts +1 -0
  118. package/vendor/opencli/dist/clis/amazon/search.test.js +22 -0
  119. package/vendor/opencli/dist/clis/amazon/shared.d.ts +75 -0
  120. package/vendor/opencli/dist/clis/amazon/shared.js +365 -0
  121. package/vendor/opencli/dist/clis/amazon/shared.test.d.ts +1 -0
  122. package/vendor/opencli/dist/clis/amazon/shared.test.js +44 -0
  123. package/vendor/opencli/dist/clis/antigravity/dump.d.ts +1 -0
  124. package/vendor/opencli/dist/clis/antigravity/dump.js +28 -0
  125. package/vendor/opencli/dist/clis/antigravity/extract-code.d.ts +1 -0
  126. package/vendor/opencli/dist/clis/antigravity/extract-code.js +32 -0
  127. package/vendor/opencli/dist/clis/antigravity/model.d.ts +1 -0
  128. package/vendor/opencli/dist/clis/antigravity/model.js +44 -0
  129. package/vendor/opencli/dist/clis/antigravity/new.d.ts +1 -0
  130. package/vendor/opencli/dist/clis/antigravity/new.js +25 -0
  131. package/vendor/opencli/dist/clis/antigravity/read.d.ts +1 -0
  132. package/vendor/opencli/dist/clis/antigravity/read.js +34 -0
  133. package/vendor/opencli/dist/clis/antigravity/send.d.ts +1 -0
  134. package/vendor/opencli/dist/clis/antigravity/send.js +35 -0
  135. package/vendor/opencli/dist/clis/antigravity/serve.d.ts +14 -0
  136. package/vendor/opencli/dist/clis/antigravity/serve.js +512 -0
  137. package/vendor/opencli/dist/clis/antigravity/status.d.ts +1 -0
  138. package/vendor/opencli/dist/clis/antigravity/status.js +18 -0
  139. package/vendor/opencli/dist/clis/antigravity/watch.d.ts +1 -0
  140. package/vendor/opencli/dist/clis/antigravity/watch.js +41 -0
  141. package/vendor/opencli/dist/clis/apple-podcasts/commands.test.d.ts +2 -0
  142. package/vendor/opencli/dist/clis/apple-podcasts/commands.test.js +99 -0
  143. package/vendor/opencli/dist/clis/apple-podcasts/episodes.d.ts +1 -0
  144. package/vendor/opencli/dist/clis/apple-podcasts/episodes.js +28 -0
  145. package/vendor/opencli/dist/clis/apple-podcasts/search.d.ts +1 -0
  146. package/vendor/opencli/dist/clis/apple-podcasts/search.js +30 -0
  147. package/vendor/opencli/dist/clis/apple-podcasts/top.d.ts +1 -0
  148. package/vendor/opencli/dist/clis/apple-podcasts/top.js +44 -0
  149. package/vendor/opencli/dist/clis/apple-podcasts/utils.d.ts +11 -0
  150. package/vendor/opencli/dist/clis/apple-podcasts/utils.js +30 -0
  151. package/vendor/opencli/dist/clis/apple-podcasts/utils.test.d.ts +1 -0
  152. package/vendor/opencli/dist/clis/apple-podcasts/utils.test.js +57 -0
  153. package/vendor/opencli/dist/clis/arxiv/paper.d.ts +1 -0
  154. package/vendor/opencli/dist/clis/arxiv/paper.js +21 -0
  155. package/vendor/opencli/dist/clis/arxiv/search.d.ts +1 -0
  156. package/vendor/opencli/dist/clis/arxiv/search.js +24 -0
  157. package/vendor/opencli/dist/clis/arxiv/utils.d.ts +18 -0
  158. package/vendor/opencli/dist/clis/arxiv/utils.js +49 -0
  159. package/vendor/opencli/dist/clis/band/bands.d.ts +1 -0
  160. package/vendor/opencli/dist/clis/band/bands.js +72 -0
  161. package/vendor/opencli/dist/clis/band/mentions.d.ts +1 -0
  162. package/vendor/opencli/dist/clis/band/mentions.js +127 -0
  163. package/vendor/opencli/dist/clis/band/post.d.ts +1 -0
  164. package/vendor/opencli/dist/clis/band/post.js +175 -0
  165. package/vendor/opencli/dist/clis/band/posts.d.ts +1 -0
  166. package/vendor/opencli/dist/clis/band/posts.js +94 -0
  167. package/vendor/opencli/dist/clis/barchart/flow.d.ts +1 -0
  168. package/vendor/opencli/dist/clis/barchart/flow.js +115 -0
  169. package/vendor/opencli/dist/clis/barchart/greeks.d.ts +1 -0
  170. package/vendor/opencli/dist/clis/barchart/greeks.js +119 -0
  171. package/vendor/opencli/dist/clis/barchart/options.d.ts +1 -0
  172. package/vendor/opencli/dist/clis/barchart/options.js +106 -0
  173. package/vendor/opencli/dist/clis/barchart/quote.d.ts +1 -0
  174. package/vendor/opencli/dist/clis/barchart/quote.js +133 -0
  175. package/vendor/opencli/dist/clis/bbc/news.d.ts +1 -0
  176. package/vendor/opencli/dist/clis/bbc/news.js +41 -0
  177. package/vendor/opencli/dist/clis/bilibili/comments.d.ts +5 -0
  178. package/vendor/opencli/dist/clis/bilibili/comments.js +40 -0
  179. package/vendor/opencli/dist/clis/bilibili/comments.test.d.ts +1 -0
  180. package/vendor/opencli/dist/clis/bilibili/comments.test.js +83 -0
  181. package/vendor/opencli/dist/clis/bilibili/download.d.ts +10 -0
  182. package/vendor/opencli/dist/clis/bilibili/download.js +81 -0
  183. package/vendor/opencli/dist/clis/bilibili/dynamic.d.ts +1 -0
  184. package/vendor/opencli/dist/clis/bilibili/dynamic.js +33 -0
  185. package/vendor/opencli/dist/clis/bilibili/dynamic.test.d.ts +1 -0
  186. package/vendor/opencli/dist/clis/bilibili/dynamic.test.js +68 -0
  187. package/vendor/opencli/dist/clis/bilibili/favorite.d.ts +1 -0
  188. package/vendor/opencli/dist/clis/bilibili/favorite.js +41 -0
  189. package/vendor/opencli/dist/clis/bilibili/feed.d.ts +1 -0
  190. package/vendor/opencli/dist/clis/bilibili/feed.js +64 -0
  191. package/vendor/opencli/dist/clis/bilibili/following.d.ts +1 -0
  192. package/vendor/opencli/dist/clis/bilibili/following.js +42 -0
  193. package/vendor/opencli/dist/clis/bilibili/history.d.ts +1 -0
  194. package/vendor/opencli/dist/clis/bilibili/history.js +44 -0
  195. package/vendor/opencli/dist/clis/bilibili/hot.yaml +38 -0
  196. package/vendor/opencli/dist/clis/bilibili/me.d.ts +1 -0
  197. package/vendor/opencli/dist/clis/bilibili/me.js +13 -0
  198. package/vendor/opencli/dist/clis/bilibili/ranking.d.ts +1 -0
  199. package/vendor/opencli/dist/clis/bilibili/ranking.js +24 -0
  200. package/vendor/opencli/dist/clis/bilibili/search.d.ts +1 -0
  201. package/vendor/opencli/dist/clis/bilibili/search.js +24 -0
  202. package/vendor/opencli/dist/clis/bilibili/subtitle.d.ts +1 -0
  203. package/vendor/opencli/dist/clis/bilibili/subtitle.js +92 -0
  204. package/vendor/opencli/dist/clis/bilibili/subtitle.test.d.ts +1 -0
  205. package/vendor/opencli/dist/clis/bilibili/subtitle.test.js +49 -0
  206. package/vendor/opencli/dist/clis/bilibili/user-videos.d.ts +1 -0
  207. package/vendor/opencli/dist/clis/bilibili/user-videos.js +38 -0
  208. package/vendor/opencli/dist/clis/bilibili/utils.d.ts +19 -0
  209. package/vendor/opencli/dist/clis/bilibili/utils.js +126 -0
  210. package/vendor/opencli/dist/clis/bilibili/utils.test.d.ts +1 -0
  211. package/vendor/opencli/dist/clis/bilibili/utils.test.js +17 -0
  212. package/vendor/opencli/dist/clis/bloomberg/businessweek.d.ts +1 -0
  213. package/vendor/opencli/dist/clis/bloomberg/businessweek.js +17 -0
  214. package/vendor/opencli/dist/clis/bloomberg/economics.d.ts +1 -0
  215. package/vendor/opencli/dist/clis/bloomberg/economics.js +17 -0
  216. package/vendor/opencli/dist/clis/bloomberg/feeds.d.ts +1 -0
  217. package/vendor/opencli/dist/clis/bloomberg/feeds.js +15 -0
  218. package/vendor/opencli/dist/clis/bloomberg/industries.d.ts +1 -0
  219. package/vendor/opencli/dist/clis/bloomberg/industries.js +17 -0
  220. package/vendor/opencli/dist/clis/bloomberg/main.d.ts +1 -0
  221. package/vendor/opencli/dist/clis/bloomberg/main.js +17 -0
  222. package/vendor/opencli/dist/clis/bloomberg/markets.d.ts +1 -0
  223. package/vendor/opencli/dist/clis/bloomberg/markets.js +17 -0
  224. package/vendor/opencli/dist/clis/bloomberg/news.d.ts +1 -0
  225. package/vendor/opencli/dist/clis/bloomberg/news.js +105 -0
  226. package/vendor/opencli/dist/clis/bloomberg/opinions.d.ts +1 -0
  227. package/vendor/opencli/dist/clis/bloomberg/opinions.js +17 -0
  228. package/vendor/opencli/dist/clis/bloomberg/politics.d.ts +1 -0
  229. package/vendor/opencli/dist/clis/bloomberg/politics.js +17 -0
  230. package/vendor/opencli/dist/clis/bloomberg/tech.d.ts +1 -0
  231. package/vendor/opencli/dist/clis/bloomberg/tech.js +17 -0
  232. package/vendor/opencli/dist/clis/bloomberg/utils.d.ts +34 -0
  233. package/vendor/opencli/dist/clis/bloomberg/utils.js +364 -0
  234. package/vendor/opencli/dist/clis/bloomberg/utils.test.d.ts +1 -0
  235. package/vendor/opencli/dist/clis/bloomberg/utils.test.js +129 -0
  236. package/vendor/opencli/dist/clis/bluesky/feeds.yaml +29 -0
  237. package/vendor/opencli/dist/clis/bluesky/followers.yaml +33 -0
  238. package/vendor/opencli/dist/clis/bluesky/following.yaml +33 -0
  239. package/vendor/opencli/dist/clis/bluesky/profile.yaml +27 -0
  240. package/vendor/opencli/dist/clis/bluesky/search.yaml +34 -0
  241. package/vendor/opencli/dist/clis/bluesky/starter-packs.yaml +34 -0
  242. package/vendor/opencli/dist/clis/bluesky/thread.yaml +32 -0
  243. package/vendor/opencli/dist/clis/bluesky/trending.yaml +27 -0
  244. package/vendor/opencli/dist/clis/bluesky/user.yaml +34 -0
  245. package/vendor/opencli/dist/clis/boss/batchgreet.d.ts +1 -0
  246. package/vendor/opencli/dist/clis/boss/batchgreet.js +60 -0
  247. package/vendor/opencli/dist/clis/boss/chatlist.d.ts +1 -0
  248. package/vendor/opencli/dist/clis/boss/chatlist.js +33 -0
  249. package/vendor/opencli/dist/clis/boss/chatmsg.d.ts +1 -0
  250. package/vendor/opencli/dist/clis/boss/chatmsg.js +42 -0
  251. package/vendor/opencli/dist/clis/boss/detail.d.ts +1 -0
  252. package/vendor/opencli/dist/clis/boss/detail.js +62 -0
  253. package/vendor/opencli/dist/clis/boss/exchange.d.ts +1 -0
  254. package/vendor/opencli/dist/clis/boss/exchange.js +45 -0
  255. package/vendor/opencli/dist/clis/boss/greet.d.ts +1 -0
  256. package/vendor/opencli/dist/clis/boss/greet.js +48 -0
  257. package/vendor/opencli/dist/clis/boss/invite.d.ts +1 -0
  258. package/vendor/opencli/dist/clis/boss/invite.js +63 -0
  259. package/vendor/opencli/dist/clis/boss/joblist.d.ts +1 -0
  260. package/vendor/opencli/dist/clis/boss/joblist.js +30 -0
  261. package/vendor/opencli/dist/clis/boss/mark.d.ts +1 -0
  262. package/vendor/opencli/dist/clis/boss/mark.js +69 -0
  263. package/vendor/opencli/dist/clis/boss/recommend.d.ts +1 -0
  264. package/vendor/opencli/dist/clis/boss/recommend.js +44 -0
  265. package/vendor/opencli/dist/clis/boss/resume.d.ts +1 -0
  266. package/vendor/opencli/dist/clis/boss/resume.js +149 -0
  267. package/vendor/opencli/dist/clis/boss/search.d.ts +1 -0
  268. package/vendor/opencli/dist/clis/boss/search.js +155 -0
  269. package/vendor/opencli/dist/clis/boss/send.d.ts +1 -0
  270. package/vendor/opencli/dist/clis/boss/send.js +43 -0
  271. package/vendor/opencli/dist/clis/boss/stats.d.ts +1 -0
  272. package/vendor/opencli/dist/clis/boss/stats.js +65 -0
  273. package/vendor/opencli/dist/clis/boss/utils.d.ts +92 -0
  274. package/vendor/opencli/dist/clis/boss/utils.js +223 -0
  275. package/vendor/opencli/dist/clis/chaoxing/assignments.d.ts +1 -0
  276. package/vendor/opencli/dist/clis/chaoxing/assignments.js +75 -0
  277. package/vendor/opencli/dist/clis/chaoxing/exams.d.ts +1 -0
  278. package/vendor/opencli/dist/clis/chaoxing/exams.js +74 -0
  279. package/vendor/opencli/dist/clis/chaoxing/utils.d.ts +58 -0
  280. package/vendor/opencli/dist/clis/chaoxing/utils.js +223 -0
  281. package/vendor/opencli/dist/clis/chaoxing/utils.test.d.ts +1 -0
  282. package/vendor/opencli/dist/clis/chaoxing/utils.test.js +45 -0
  283. package/vendor/opencli/dist/clis/chatgpt/ask.d.ts +1 -0
  284. package/vendor/opencli/dist/clis/chatgpt/ask.js +88 -0
  285. package/vendor/opencli/dist/clis/chatgpt/ax.d.ts +7 -0
  286. package/vendor/opencli/dist/clis/chatgpt/ax.js +249 -0
  287. package/vendor/opencli/dist/clis/chatgpt/model.d.ts +1 -0
  288. package/vendor/opencli/dist/clis/chatgpt/model.js +24 -0
  289. package/vendor/opencli/dist/clis/chatgpt/new.d.ts +1 -0
  290. package/vendor/opencli/dist/clis/chatgpt/new.js +27 -0
  291. package/vendor/opencli/dist/clis/chatgpt/read.d.ts +1 -0
  292. package/vendor/opencli/dist/clis/chatgpt/read.js +31 -0
  293. package/vendor/opencli/dist/clis/chatgpt/send.d.ts +1 -0
  294. package/vendor/opencli/dist/clis/chatgpt/send.js +52 -0
  295. package/vendor/opencli/dist/clis/chatgpt/status.d.ts +1 -0
  296. package/vendor/opencli/dist/clis/chatgpt/status.js +25 -0
  297. package/vendor/opencli/dist/clis/chatwise/ask.d.ts +1 -0
  298. package/vendor/opencli/dist/clis/chatwise/ask.js +80 -0
  299. package/vendor/opencli/dist/clis/chatwise/export.d.ts +1 -0
  300. package/vendor/opencli/dist/clis/chatwise/export.js +46 -0
  301. package/vendor/opencli/dist/clis/chatwise/history.d.ts +1 -0
  302. package/vendor/opencli/dist/clis/chatwise/history.js +60 -0
  303. package/vendor/opencli/dist/clis/chatwise/model.d.ts +1 -0
  304. package/vendor/opencli/dist/clis/chatwise/model.js +84 -0
  305. package/vendor/opencli/dist/clis/chatwise/new.d.ts +1 -0
  306. package/vendor/opencli/dist/clis/chatwise/new.js +2 -0
  307. package/vendor/opencli/dist/clis/chatwise/read.d.ts +1 -0
  308. package/vendor/opencli/dist/clis/chatwise/read.js +39 -0
  309. package/vendor/opencli/dist/clis/chatwise/screenshot.d.ts +1 -0
  310. package/vendor/opencli/dist/clis/chatwise/screenshot.js +2 -0
  311. package/vendor/opencli/dist/clis/chatwise/send.d.ts +1 -0
  312. package/vendor/opencli/dist/clis/chatwise/send.js +49 -0
  313. package/vendor/opencli/dist/clis/chatwise/status.d.ts +1 -0
  314. package/vendor/opencli/dist/clis/chatwise/status.js +2 -0
  315. package/vendor/opencli/dist/clis/codex/ask.d.ts +1 -0
  316. package/vendor/opencli/dist/clis/codex/ask.js +71 -0
  317. package/vendor/opencli/dist/clis/codex/dump.d.ts +1 -0
  318. package/vendor/opencli/dist/clis/codex/dump.js +2 -0
  319. package/vendor/opencli/dist/clis/codex/export.d.ts +1 -0
  320. package/vendor/opencli/dist/clis/codex/export.js +37 -0
  321. package/vendor/opencli/dist/clis/codex/extract-diff.d.ts +1 -0
  322. package/vendor/opencli/dist/clis/codex/extract-diff.js +44 -0
  323. package/vendor/opencli/dist/clis/codex/history.d.ts +1 -0
  324. package/vendor/opencli/dist/clis/codex/history.js +43 -0
  325. package/vendor/opencli/dist/clis/codex/model.d.ts +1 -0
  326. package/vendor/opencli/dist/clis/codex/model.js +55 -0
  327. package/vendor/opencli/dist/clis/codex/new.d.ts +1 -0
  328. package/vendor/opencli/dist/clis/codex/new.js +2 -0
  329. package/vendor/opencli/dist/clis/codex/read.d.ts +1 -0
  330. package/vendor/opencli/dist/clis/codex/read.js +34 -0
  331. package/vendor/opencli/dist/clis/codex/screenshot.d.ts +1 -0
  332. package/vendor/opencli/dist/clis/codex/screenshot.js +2 -0
  333. package/vendor/opencli/dist/clis/codex/send.d.ts +1 -0
  334. package/vendor/opencli/dist/clis/codex/send.js +43 -0
  335. package/vendor/opencli/dist/clis/codex/status.d.ts +1 -0
  336. package/vendor/opencli/dist/clis/codex/status.js +2 -0
  337. package/vendor/opencli/dist/clis/coupang/add-to-cart.d.ts +1 -0
  338. package/vendor/opencli/dist/clis/coupang/add-to-cart.js +140 -0
  339. package/vendor/opencli/dist/clis/coupang/search.d.ts +1 -0
  340. package/vendor/opencli/dist/clis/coupang/search.js +451 -0
  341. package/vendor/opencli/dist/clis/coupang/utils.d.ts +24 -0
  342. package/vendor/opencli/dist/clis/coupang/utils.js +262 -0
  343. package/vendor/opencli/dist/clis/coupang/utils.test.d.ts +1 -0
  344. package/vendor/opencli/dist/clis/coupang/utils.test.js +62 -0
  345. package/vendor/opencli/dist/clis/ctrip/search.d.ts +14 -0
  346. package/vendor/opencli/dist/clis/ctrip/search.js +86 -0
  347. package/vendor/opencli/dist/clis/ctrip/search.test.d.ts +1 -0
  348. package/vendor/opencli/dist/clis/ctrip/search.test.js +64 -0
  349. package/vendor/opencli/dist/clis/cursor/ask.d.ts +1 -0
  350. package/vendor/opencli/dist/clis/cursor/ask.js +70 -0
  351. package/vendor/opencli/dist/clis/cursor/composer.d.ts +1 -0
  352. package/vendor/opencli/dist/clis/cursor/composer.js +42 -0
  353. package/vendor/opencli/dist/clis/cursor/dump.d.ts +1 -0
  354. package/vendor/opencli/dist/clis/cursor/dump.js +2 -0
  355. package/vendor/opencli/dist/clis/cursor/export.d.ts +1 -0
  356. package/vendor/opencli/dist/clis/cursor/export.js +51 -0
  357. package/vendor/opencli/dist/clis/cursor/extract-code.d.ts +1 -0
  358. package/vendor/opencli/dist/clis/cursor/extract-code.js +35 -0
  359. package/vendor/opencli/dist/clis/cursor/history.d.ts +1 -0
  360. package/vendor/opencli/dist/clis/cursor/history.js +43 -0
  361. package/vendor/opencli/dist/clis/cursor/model.d.ts +1 -0
  362. package/vendor/opencli/dist/clis/cursor/model.js +53 -0
  363. package/vendor/opencli/dist/clis/cursor/new.d.ts +1 -0
  364. package/vendor/opencli/dist/clis/cursor/new.js +2 -0
  365. package/vendor/opencli/dist/clis/cursor/read.d.ts +1 -0
  366. package/vendor/opencli/dist/clis/cursor/read.js +44 -0
  367. package/vendor/opencli/dist/clis/cursor/screenshot.d.ts +1 -0
  368. package/vendor/opencli/dist/clis/cursor/screenshot.js +2 -0
  369. package/vendor/opencli/dist/clis/cursor/send.d.ts +1 -0
  370. package/vendor/opencli/dist/clis/cursor/send.js +40 -0
  371. package/vendor/opencli/dist/clis/cursor/status.d.ts +1 -0
  372. package/vendor/opencli/dist/clis/cursor/status.js +2 -0
  373. package/vendor/opencli/dist/clis/devto/tag.yaml +34 -0
  374. package/vendor/opencli/dist/clis/devto/top.yaml +29 -0
  375. package/vendor/opencli/dist/clis/devto/user.yaml +33 -0
  376. package/vendor/opencli/dist/clis/dictionary/examples.yaml +25 -0
  377. package/vendor/opencli/dist/clis/dictionary/search.yaml +27 -0
  378. package/vendor/opencli/dist/clis/dictionary/synonyms.yaml +25 -0
  379. package/vendor/opencli/dist/clis/discord-app/channels.d.ts +1 -0
  380. package/vendor/opencli/dist/clis/discord-app/channels.js +57 -0
  381. package/vendor/opencli/dist/clis/discord-app/members.d.ts +1 -0
  382. package/vendor/opencli/dist/clis/discord-app/members.js +38 -0
  383. package/vendor/opencli/dist/clis/discord-app/read.d.ts +1 -0
  384. package/vendor/opencli/dist/clis/discord-app/read.js +45 -0
  385. package/vendor/opencli/dist/clis/discord-app/search.d.ts +1 -0
  386. package/vendor/opencli/dist/clis/discord-app/search.js +56 -0
  387. package/vendor/opencli/dist/clis/discord-app/send.d.ts +1 -0
  388. package/vendor/opencli/dist/clis/discord-app/send.js +27 -0
  389. package/vendor/opencli/dist/clis/discord-app/servers.d.ts +1 -0
  390. package/vendor/opencli/dist/clis/discord-app/servers.js +36 -0
  391. package/vendor/opencli/dist/clis/discord-app/status.d.ts +1 -0
  392. package/vendor/opencli/dist/clis/discord-app/status.js +16 -0
  393. package/vendor/opencli/dist/clis/douban/book-hot.d.ts +1 -0
  394. package/vendor/opencli/dist/clis/douban/book-hot.js +14 -0
  395. package/vendor/opencli/dist/clis/douban/download.d.ts +1 -0
  396. package/vendor/opencli/dist/clis/douban/download.js +67 -0
  397. package/vendor/opencli/dist/clis/douban/download.test.d.ts +1 -0
  398. package/vendor/opencli/dist/clis/douban/download.test.js +170 -0
  399. package/vendor/opencli/dist/clis/douban/marks.d.ts +1 -0
  400. package/vendor/opencli/dist/clis/douban/marks.js +115 -0
  401. package/vendor/opencli/dist/clis/douban/movie-hot.d.ts +1 -0
  402. package/vendor/opencli/dist/clis/douban/movie-hot.js +14 -0
  403. package/vendor/opencli/dist/clis/douban/photos.d.ts +1 -0
  404. package/vendor/opencli/dist/clis/douban/photos.js +34 -0
  405. package/vendor/opencli/dist/clis/douban/reviews.d.ts +1 -0
  406. package/vendor/opencli/dist/clis/douban/reviews.js +106 -0
  407. package/vendor/opencli/dist/clis/douban/search.d.ts +1 -0
  408. package/vendor/opencli/dist/clis/douban/search.js +16 -0
  409. package/vendor/opencli/dist/clis/douban/subject.yaml +107 -0
  410. package/vendor/opencli/dist/clis/douban/top250.yaml +70 -0
  411. package/vendor/opencli/dist/clis/douban/utils.d.ts +63 -0
  412. package/vendor/opencli/dist/clis/douban/utils.js +389 -0
  413. package/vendor/opencli/dist/clis/douban/utils.test.d.ts +1 -0
  414. package/vendor/opencli/dist/clis/douban/utils.test.js +64 -0
  415. package/vendor/opencli/dist/clis/doubao/ask.d.ts +1 -0
  416. package/vendor/opencli/dist/clis/doubao/ask.js +35 -0
  417. package/vendor/opencli/dist/clis/doubao/detail.d.ts +1 -0
  418. package/vendor/opencli/dist/clis/doubao/detail.js +33 -0
  419. package/vendor/opencli/dist/clis/doubao/detail.test.d.ts +1 -0
  420. package/vendor/opencli/dist/clis/doubao/detail.test.js +42 -0
  421. package/vendor/opencli/dist/clis/doubao/history.d.ts +1 -0
  422. package/vendor/opencli/dist/clis/doubao/history.js +28 -0
  423. package/vendor/opencli/dist/clis/doubao/history.test.d.ts +1 -0
  424. package/vendor/opencli/dist/clis/doubao/history.test.js +37 -0
  425. package/vendor/opencli/dist/clis/doubao/meeting-summary.d.ts +1 -0
  426. package/vendor/opencli/dist/clis/doubao/meeting-summary.js +39 -0
  427. package/vendor/opencli/dist/clis/doubao/meeting-transcript.d.ts +1 -0
  428. package/vendor/opencli/dist/clis/doubao/meeting-transcript.js +36 -0
  429. package/vendor/opencli/dist/clis/doubao/new.d.ts +1 -0
  430. package/vendor/opencli/dist/clis/doubao/new.js +20 -0
  431. package/vendor/opencli/dist/clis/doubao/read.d.ts +1 -0
  432. package/vendor/opencli/dist/clis/doubao/read.js +19 -0
  433. package/vendor/opencli/dist/clis/doubao/send.d.ts +1 -0
  434. package/vendor/opencli/dist/clis/doubao/send.js +22 -0
  435. package/vendor/opencli/dist/clis/doubao/status.d.ts +1 -0
  436. package/vendor/opencli/dist/clis/doubao/status.js +24 -0
  437. package/vendor/opencli/dist/clis/doubao/utils.d.ts +50 -0
  438. package/vendor/opencli/dist/clis/doubao/utils.js +901 -0
  439. package/vendor/opencli/dist/clis/doubao/utils.test.d.ts +1 -0
  440. package/vendor/opencli/dist/clis/doubao/utils.test.js +24 -0
  441. package/vendor/opencli/dist/clis/doubao-app/ask.d.ts +1 -0
  442. package/vendor/opencli/dist/clis/doubao-app/ask.js +53 -0
  443. package/vendor/opencli/dist/clis/doubao-app/dump.d.ts +1 -0
  444. package/vendor/opencli/dist/clis/doubao-app/dump.js +24 -0
  445. package/vendor/opencli/dist/clis/doubao-app/new.d.ts +1 -0
  446. package/vendor/opencli/dist/clis/doubao-app/new.js +20 -0
  447. package/vendor/opencli/dist/clis/doubao-app/read.d.ts +1 -0
  448. package/vendor/opencli/dist/clis/doubao-app/read.js +18 -0
  449. package/vendor/opencli/dist/clis/doubao-app/screenshot.d.ts +1 -0
  450. package/vendor/opencli/dist/clis/doubao-app/screenshot.js +18 -0
  451. package/vendor/opencli/dist/clis/doubao-app/send.d.ts +1 -0
  452. package/vendor/opencli/dist/clis/doubao-app/send.js +27 -0
  453. package/vendor/opencli/dist/clis/doubao-app/status.d.ts +1 -0
  454. package/vendor/opencli/dist/clis/doubao-app/status.js +16 -0
  455. package/vendor/opencli/dist/clis/doubao-app/utils.d.ts +37 -0
  456. package/vendor/opencli/dist/clis/doubao-app/utils.js +110 -0
  457. package/vendor/opencli/dist/clis/douyin/_shared/browser-fetch.d.ts +10 -0
  458. package/vendor/opencli/dist/clis/douyin/_shared/browser-fetch.js +30 -0
  459. package/vendor/opencli/dist/clis/douyin/_shared/browser-fetch.test.d.ts +1 -0
  460. package/vendor/opencli/dist/clis/douyin/_shared/browser-fetch.test.js +30 -0
  461. package/vendor/opencli/dist/clis/douyin/_shared/creation-id.d.ts +1 -0
  462. package/vendor/opencli/dist/clis/douyin/_shared/creation-id.js +5 -0
  463. package/vendor/opencli/dist/clis/douyin/_shared/creation-id.test.d.ts +1 -0
  464. package/vendor/opencli/dist/clis/douyin/_shared/creation-id.test.js +22 -0
  465. package/vendor/opencli/dist/clis/douyin/_shared/imagex-upload.d.ts +20 -0
  466. package/vendor/opencli/dist/clis/douyin/_shared/imagex-upload.js +53 -0
  467. package/vendor/opencli/dist/clis/douyin/_shared/imagex-upload.test.d.ts +1 -0
  468. package/vendor/opencli/dist/clis/douyin/_shared/imagex-upload.test.js +87 -0
  469. package/vendor/opencli/dist/clis/douyin/_shared/public-api.d.ts +33 -0
  470. package/vendor/opencli/dist/clis/douyin/_shared/public-api.js +29 -0
  471. package/vendor/opencli/dist/clis/douyin/_shared/sts2.d.ts +8 -0
  472. package/vendor/opencli/dist/clis/douyin/_shared/sts2.js +21 -0
  473. package/vendor/opencli/dist/clis/douyin/_shared/sts2.test.d.ts +1 -0
  474. package/vendor/opencli/dist/clis/douyin/_shared/sts2.test.js +27 -0
  475. package/vendor/opencli/dist/clis/douyin/_shared/text-extra.d.ts +18 -0
  476. package/vendor/opencli/dist/clis/douyin/_shared/text-extra.js +15 -0
  477. package/vendor/opencli/dist/clis/douyin/_shared/text-extra.test.d.ts +1 -0
  478. package/vendor/opencli/dist/clis/douyin/_shared/text-extra.test.js +37 -0
  479. package/vendor/opencli/dist/clis/douyin/_shared/timing.d.ts +2 -0
  480. package/vendor/opencli/dist/clis/douyin/_shared/timing.js +22 -0
  481. package/vendor/opencli/dist/clis/douyin/_shared/timing.test.d.ts +1 -0
  482. package/vendor/opencli/dist/clis/douyin/_shared/timing.test.js +28 -0
  483. package/vendor/opencli/dist/clis/douyin/_shared/tos-upload-short-read.test.d.ts +11 -0
  484. package/vendor/opencli/dist/clis/douyin/_shared/tos-upload-short-read.test.js +83 -0
  485. package/vendor/opencli/dist/clis/douyin/_shared/tos-upload.d.ts +53 -0
  486. package/vendor/opencli/dist/clis/douyin/_shared/tos-upload.js +295 -0
  487. package/vendor/opencli/dist/clis/douyin/_shared/tos-upload.test.d.ts +1 -0
  488. package/vendor/opencli/dist/clis/douyin/_shared/tos-upload.test.js +229 -0
  489. package/vendor/opencli/dist/clis/douyin/_shared/transcode.d.ts +27 -0
  490. package/vendor/opencli/dist/clis/douyin/_shared/transcode.js +45 -0
  491. package/vendor/opencli/dist/clis/douyin/_shared/transcode.test.d.ts +1 -0
  492. package/vendor/opencli/dist/clis/douyin/_shared/transcode.test.js +91 -0
  493. package/vendor/opencli/dist/clis/douyin/_shared/types.d.ts +26 -0
  494. package/vendor/opencli/dist/clis/douyin/_shared/types.js +1 -0
  495. package/vendor/opencli/dist/clis/douyin/activities.d.ts +1 -0
  496. package/vendor/opencli/dist/clis/douyin/activities.js +22 -0
  497. package/vendor/opencli/dist/clis/douyin/activities.test.d.ts +1 -0
  498. package/vendor/opencli/dist/clis/douyin/activities.test.js +55 -0
  499. package/vendor/opencli/dist/clis/douyin/collections.d.ts +1 -0
  500. package/vendor/opencli/dist/clis/douyin/collections.js +22 -0
  501. package/vendor/opencli/dist/clis/douyin/collections.test.d.ts +1 -0
  502. package/vendor/opencli/dist/clis/douyin/collections.test.js +45 -0
  503. package/vendor/opencli/dist/clis/douyin/delete.d.ts +1 -0
  504. package/vendor/opencli/dist/clis/douyin/delete.js +18 -0
  505. package/vendor/opencli/dist/clis/douyin/delete.test.d.ts +1 -0
  506. package/vendor/opencli/dist/clis/douyin/delete.test.js +11 -0
  507. package/vendor/opencli/dist/clis/douyin/draft.d.ts +11 -0
  508. package/vendor/opencli/dist/clis/douyin/draft.js +354 -0
  509. package/vendor/opencli/dist/clis/douyin/draft.test.d.ts +1 -0
  510. package/vendor/opencli/dist/clis/douyin/draft.test.js +364 -0
  511. package/vendor/opencli/dist/clis/douyin/drafts.d.ts +1 -0
  512. package/vendor/opencli/dist/clis/douyin/drafts.js +23 -0
  513. package/vendor/opencli/dist/clis/douyin/drafts.test.d.ts +1 -0
  514. package/vendor/opencli/dist/clis/douyin/drafts.test.js +11 -0
  515. package/vendor/opencli/dist/clis/douyin/hashtag.d.ts +1 -0
  516. package/vendor/opencli/dist/clis/douyin/hashtag.js +52 -0
  517. package/vendor/opencli/dist/clis/douyin/hashtag.test.d.ts +1 -0
  518. package/vendor/opencli/dist/clis/douyin/hashtag.test.js +58 -0
  519. package/vendor/opencli/dist/clis/douyin/location.d.ts +1 -0
  520. package/vendor/opencli/dist/clis/douyin/location.js +24 -0
  521. package/vendor/opencli/dist/clis/douyin/location.test.d.ts +1 -0
  522. package/vendor/opencli/dist/clis/douyin/location.test.js +23 -0
  523. package/vendor/opencli/dist/clis/douyin/profile.d.ts +1 -0
  524. package/vendor/opencli/dist/clis/douyin/profile.js +28 -0
  525. package/vendor/opencli/dist/clis/douyin/profile.test.d.ts +1 -0
  526. package/vendor/opencli/dist/clis/douyin/profile.test.js +46 -0
  527. package/vendor/opencli/dist/clis/douyin/publish.d.ts +14 -0
  528. package/vendor/opencli/dist/clis/douyin/publish.js +288 -0
  529. package/vendor/opencli/dist/clis/douyin/publish.test.d.ts +1 -0
  530. package/vendor/opencli/dist/clis/douyin/publish.test.js +38 -0
  531. package/vendor/opencli/dist/clis/douyin/stats.d.ts +1 -0
  532. package/vendor/opencli/dist/clis/douyin/stats.js +27 -0
  533. package/vendor/opencli/dist/clis/douyin/stats.test.d.ts +1 -0
  534. package/vendor/opencli/dist/clis/douyin/stats.test.js +22 -0
  535. package/vendor/opencli/dist/clis/douyin/update.d.ts +1 -0
  536. package/vendor/opencli/dist/clis/douyin/update.js +31 -0
  537. package/vendor/opencli/dist/clis/douyin/update.test.d.ts +1 -0
  538. package/vendor/opencli/dist/clis/douyin/update.test.js +11 -0
  539. package/vendor/opencli/dist/clis/douyin/user-videos.d.ts +5 -0
  540. package/vendor/opencli/dist/clis/douyin/user-videos.js +74 -0
  541. package/vendor/opencli/dist/clis/douyin/user-videos.test.d.ts +1 -0
  542. package/vendor/opencli/dist/clis/douyin/user-videos.test.js +108 -0
  543. package/vendor/opencli/dist/clis/douyin/videos.d.ts +1 -0
  544. package/vendor/opencli/dist/clis/douyin/videos.js +51 -0
  545. package/vendor/opencli/dist/clis/douyin/videos.test.d.ts +1 -0
  546. package/vendor/opencli/dist/clis/douyin/videos.test.js +54 -0
  547. package/vendor/opencli/dist/clis/facebook/add-friend.yaml +43 -0
  548. package/vendor/opencli/dist/clis/facebook/events.yaml +44 -0
  549. package/vendor/opencli/dist/clis/facebook/feed.yaml +63 -0
  550. package/vendor/opencli/dist/clis/facebook/friends.yaml +42 -0
  551. package/vendor/opencli/dist/clis/facebook/groups.yaml +50 -0
  552. package/vendor/opencli/dist/clis/facebook/join-group.yaml +44 -0
  553. package/vendor/opencli/dist/clis/facebook/memories.yaml +39 -0
  554. package/vendor/opencli/dist/clis/facebook/notifications.yaml +40 -0
  555. package/vendor/opencli/dist/clis/facebook/profile.yaml +37 -0
  556. package/vendor/opencli/dist/clis/facebook/search.test.d.ts +5 -0
  557. package/vendor/opencli/dist/clis/facebook/search.test.js +58 -0
  558. package/vendor/opencli/dist/clis/facebook/search.yaml +47 -0
  559. package/vendor/opencli/dist/clis/gemini/ask.d.ts +1 -0
  560. package/vendor/opencli/dist/clis/gemini/ask.js +46 -0
  561. package/vendor/opencli/dist/clis/gemini/ask.test.d.ts +1 -0
  562. package/vendor/opencli/dist/clis/gemini/ask.test.js +100 -0
  563. package/vendor/opencli/dist/clis/gemini/image.d.ts +1 -0
  564. package/vendor/opencli/dist/clis/gemini/image.js +105 -0
  565. package/vendor/opencli/dist/clis/gemini/new.d.ts +1 -0
  566. package/vendor/opencli/dist/clis/gemini/new.js +20 -0
  567. package/vendor/opencli/dist/clis/gemini/reply-state.test.d.ts +1 -0
  568. package/vendor/opencli/dist/clis/gemini/reply-state.test.js +641 -0
  569. package/vendor/opencli/dist/clis/gemini/utils.d.ts +77 -0
  570. package/vendor/opencli/dist/clis/gemini/utils.js +930 -0
  571. package/vendor/opencli/dist/clis/gemini/utils.test.d.ts +1 -0
  572. package/vendor/opencli/dist/clis/gemini/utils.test.js +178 -0
  573. package/vendor/opencli/dist/clis/google/news.d.ts +5 -0
  574. package/vendor/opencli/dist/clis/google/news.js +58 -0
  575. package/vendor/opencli/dist/clis/google/search.d.ts +10 -0
  576. package/vendor/opencli/dist/clis/google/search.js +127 -0
  577. package/vendor/opencli/dist/clis/google/suggest.d.ts +5 -0
  578. package/vendor/opencli/dist/clis/google/suggest.js +34 -0
  579. package/vendor/opencli/dist/clis/google/trends.d.ts +5 -0
  580. package/vendor/opencli/dist/clis/google/trends.js +38 -0
  581. package/vendor/opencli/dist/clis/google/utils.d.ts +9 -0
  582. package/vendor/opencli/dist/clis/google/utils.js +23 -0
  583. package/vendor/opencli/dist/clis/google/utils.test.d.ts +1 -0
  584. package/vendor/opencli/dist/clis/google/utils.test.js +75 -0
  585. package/vendor/opencli/dist/clis/grok/ask.d.ts +19 -0
  586. package/vendor/opencli/dist/clis/grok/ask.js +292 -0
  587. package/vendor/opencli/dist/clis/grok/ask.test.d.ts +1 -0
  588. package/vendor/opencli/dist/clis/grok/ask.test.js +54 -0
  589. package/vendor/opencli/dist/clis/hackernews/ask.yaml +38 -0
  590. package/vendor/opencli/dist/clis/hackernews/best.yaml +38 -0
  591. package/vendor/opencli/dist/clis/hackernews/jobs.yaml +36 -0
  592. package/vendor/opencli/dist/clis/hackernews/new.yaml +38 -0
  593. package/vendor/opencli/dist/clis/hackernews/search.yaml +44 -0
  594. package/vendor/opencli/dist/clis/hackernews/show.yaml +38 -0
  595. package/vendor/opencli/dist/clis/hackernews/top.yaml +38 -0
  596. package/vendor/opencli/dist/clis/hackernews/user.yaml +25 -0
  597. package/vendor/opencli/dist/clis/hf/top.d.ts +1 -0
  598. package/vendor/opencli/dist/clis/hf/top.js +119 -0
  599. package/vendor/opencli/dist/clis/hupu/detail.d.ts +1 -0
  600. package/vendor/opencli/dist/clis/hupu/detail.js +72 -0
  601. package/vendor/opencli/dist/clis/hupu/hot.yaml +43 -0
  602. package/vendor/opencli/dist/clis/hupu/like.d.ts +1 -0
  603. package/vendor/opencli/dist/clis/hupu/like.js +75 -0
  604. package/vendor/opencli/dist/clis/hupu/reply.d.ts +1 -0
  605. package/vendor/opencli/dist/clis/hupu/reply.js +71 -0
  606. package/vendor/opencli/dist/clis/hupu/search.d.ts +1 -0
  607. package/vendor/opencli/dist/clis/hupu/search.js +59 -0
  608. package/vendor/opencli/dist/clis/hupu/unlike.d.ts +1 -0
  609. package/vendor/opencli/dist/clis/hupu/unlike.js +75 -0
  610. package/vendor/opencli/dist/clis/hupu/utils.d.ts +20 -0
  611. package/vendor/opencli/dist/clis/hupu/utils.js +319 -0
  612. package/vendor/opencli/dist/clis/imdb/person.d.ts +1 -0
  613. package/vendor/opencli/dist/clis/imdb/person.js +203 -0
  614. package/vendor/opencli/dist/clis/imdb/reviews.d.ts +1 -0
  615. package/vendor/opencli/dist/clis/imdb/reviews.js +88 -0
  616. package/vendor/opencli/dist/clis/imdb/search.d.ts +1 -0
  617. package/vendor/opencli/dist/clis/imdb/search.js +161 -0
  618. package/vendor/opencli/dist/clis/imdb/title.d.ts +1 -0
  619. package/vendor/opencli/dist/clis/imdb/title.js +93 -0
  620. package/vendor/opencli/dist/clis/imdb/top.d.ts +1 -0
  621. package/vendor/opencli/dist/clis/imdb/top.js +53 -0
  622. package/vendor/opencli/dist/clis/imdb/trending.d.ts +1 -0
  623. package/vendor/opencli/dist/clis/imdb/trending.js +52 -0
  624. package/vendor/opencli/dist/clis/imdb/utils.d.ts +46 -0
  625. package/vendor/opencli/dist/clis/imdb/utils.js +285 -0
  626. package/vendor/opencli/dist/clis/imdb/utils.test.d.ts +1 -0
  627. package/vendor/opencli/dist/clis/imdb/utils.test.js +88 -0
  628. package/vendor/opencli/dist/clis/instagram/_shared/private-publish.d.ts +138 -0
  629. package/vendor/opencli/dist/clis/instagram/_shared/private-publish.js +1030 -0
  630. package/vendor/opencli/dist/clis/instagram/_shared/private-publish.test.d.ts +1 -0
  631. package/vendor/opencli/dist/clis/instagram/_shared/private-publish.test.js +705 -0
  632. package/vendor/opencli/dist/clis/instagram/_shared/protocol-capture.d.ts +26 -0
  633. package/vendor/opencli/dist/clis/instagram/_shared/protocol-capture.js +282 -0
  634. package/vendor/opencli/dist/clis/instagram/_shared/protocol-capture.test.d.ts +1 -0
  635. package/vendor/opencli/dist/clis/instagram/_shared/protocol-capture.test.js +114 -0
  636. package/vendor/opencli/dist/clis/instagram/_shared/runtime-info.d.ts +9 -0
  637. package/vendor/opencli/dist/clis/instagram/_shared/runtime-info.js +81 -0
  638. package/vendor/opencli/dist/clis/instagram/comment.yaml +52 -0
  639. package/vendor/opencli/dist/clis/instagram/download.d.ts +16 -0
  640. package/vendor/opencli/dist/clis/instagram/download.js +225 -0
  641. package/vendor/opencli/dist/clis/instagram/download.test.d.ts +1 -0
  642. package/vendor/opencli/dist/clis/instagram/download.test.js +118 -0
  643. package/vendor/opencli/dist/clis/instagram/explore.yaml +43 -0
  644. package/vendor/opencli/dist/clis/instagram/follow.yaml +41 -0
  645. package/vendor/opencli/dist/clis/instagram/followers.yaml +51 -0
  646. package/vendor/opencli/dist/clis/instagram/following.yaml +51 -0
  647. package/vendor/opencli/dist/clis/instagram/like.yaml +46 -0
  648. package/vendor/opencli/dist/clis/instagram/note.d.ts +1 -0
  649. package/vendor/opencli/dist/clis/instagram/note.js +222 -0
  650. package/vendor/opencli/dist/clis/instagram/note.test.d.ts +1 -0
  651. package/vendor/opencli/dist/clis/instagram/note.test.js +81 -0
  652. package/vendor/opencli/dist/clis/instagram/post.d.ts +4 -0
  653. package/vendor/opencli/dist/clis/instagram/post.js +1496 -0
  654. package/vendor/opencli/dist/clis/instagram/post.test.d.ts +1 -0
  655. package/vendor/opencli/dist/clis/instagram/post.test.js +1647 -0
  656. package/vendor/opencli/dist/clis/instagram/profile.yaml +42 -0
  657. package/vendor/opencli/dist/clis/instagram/reel.d.ts +1 -0
  658. package/vendor/opencli/dist/clis/instagram/reel.js +826 -0
  659. package/vendor/opencli/dist/clis/instagram/reel.test.d.ts +1 -0
  660. package/vendor/opencli/dist/clis/instagram/reel.test.js +167 -0
  661. package/vendor/opencli/dist/clis/instagram/save.yaml +46 -0
  662. package/vendor/opencli/dist/clis/instagram/saved.yaml +40 -0
  663. package/vendor/opencli/dist/clis/instagram/search.yaml +44 -0
  664. package/vendor/opencli/dist/clis/instagram/story.d.ts +1 -0
  665. package/vendor/opencli/dist/clis/instagram/story.js +115 -0
  666. package/vendor/opencli/dist/clis/instagram/story.test.d.ts +1 -0
  667. package/vendor/opencli/dist/clis/instagram/story.test.js +167 -0
  668. package/vendor/opencli/dist/clis/instagram/unfollow.yaml +38 -0
  669. package/vendor/opencli/dist/clis/instagram/unlike.yaml +46 -0
  670. package/vendor/opencli/dist/clis/instagram/unsave.yaml +46 -0
  671. package/vendor/opencli/dist/clis/instagram/user.yaml +54 -0
  672. package/vendor/opencli/dist/clis/jd/item.d.ts +5 -0
  673. package/vendor/opencli/dist/clis/jd/item.js +97 -0
  674. package/vendor/opencli/dist/clis/jd/item.test.d.ts +1 -0
  675. package/vendor/opencli/dist/clis/jd/item.test.js +43 -0
  676. package/vendor/opencli/dist/clis/jike/comment.d.ts +1 -0
  677. package/vendor/opencli/dist/clis/jike/comment.js +106 -0
  678. package/vendor/opencli/dist/clis/jike/create.d.ts +1 -0
  679. package/vendor/opencli/dist/clis/jike/create.js +105 -0
  680. package/vendor/opencli/dist/clis/jike/feed.d.ts +1 -0
  681. package/vendor/opencli/dist/clis/jike/feed.js +66 -0
  682. package/vendor/opencli/dist/clis/jike/like.d.ts +1 -0
  683. package/vendor/opencli/dist/clis/jike/like.js +60 -0
  684. package/vendor/opencli/dist/clis/jike/notifications.d.ts +1 -0
  685. package/vendor/opencli/dist/clis/jike/notifications.js +168 -0
  686. package/vendor/opencli/dist/clis/jike/post.yaml +59 -0
  687. package/vendor/opencli/dist/clis/jike/repost.d.ts +1 -0
  688. package/vendor/opencli/dist/clis/jike/repost.js +102 -0
  689. package/vendor/opencli/dist/clis/jike/search.d.ts +1 -0
  690. package/vendor/opencli/dist/clis/jike/search.js +66 -0
  691. package/vendor/opencli/dist/clis/jike/topic.yaml +53 -0
  692. package/vendor/opencli/dist/clis/jike/user.yaml +52 -0
  693. package/vendor/opencli/dist/clis/jike/utils.d.ts +19 -0
  694. package/vendor/opencli/dist/clis/jike/utils.js +25 -0
  695. package/vendor/opencli/dist/clis/jimeng/generate.yaml +85 -0
  696. package/vendor/opencli/dist/clis/jimeng/history.yaml +46 -0
  697. package/vendor/opencli/dist/clis/linkedin/search.d.ts +1 -0
  698. package/vendor/opencli/dist/clis/linkedin/search.js +367 -0
  699. package/vendor/opencli/dist/clis/linkedin/timeline.d.ts +21 -0
  700. package/vendor/opencli/dist/clis/linkedin/timeline.js +503 -0
  701. package/vendor/opencli/dist/clis/linkedin/timeline.test.d.ts +1 -0
  702. package/vendor/opencli/dist/clis/linkedin/timeline.test.js +81 -0
  703. package/vendor/opencli/dist/clis/linux-do/categories.yaml +70 -0
  704. package/vendor/opencli/dist/clis/linux-do/category.d.ts +1 -0
  705. package/vendor/opencli/dist/clis/linux-do/category.js +36 -0
  706. package/vendor/opencli/dist/clis/linux-do/feed.d.ts +45 -0
  707. package/vendor/opencli/dist/clis/linux-do/feed.js +397 -0
  708. package/vendor/opencli/dist/clis/linux-do/feed.test.d.ts +1 -0
  709. package/vendor/opencli/dist/clis/linux-do/feed.test.js +118 -0
  710. package/vendor/opencli/dist/clis/linux-do/hot.d.ts +1 -0
  711. package/vendor/opencli/dist/clis/linux-do/hot.js +25 -0
  712. package/vendor/opencli/dist/clis/linux-do/latest.d.ts +1 -0
  713. package/vendor/opencli/dist/clis/linux-do/latest.js +18 -0
  714. package/vendor/opencli/dist/clis/linux-do/search.yaml +48 -0
  715. package/vendor/opencli/dist/clis/linux-do/tags.yaml +41 -0
  716. package/vendor/opencli/dist/clis/linux-do/topic.yaml +77 -0
  717. package/vendor/opencli/dist/clis/linux-do/user-posts.yaml +67 -0
  718. package/vendor/opencli/dist/clis/linux-do/user-topics.yaml +54 -0
  719. package/vendor/opencli/dist/clis/lobsters/active.yaml +29 -0
  720. package/vendor/opencli/dist/clis/lobsters/hot.yaml +29 -0
  721. package/vendor/opencli/dist/clis/lobsters/newest.yaml +29 -0
  722. package/vendor/opencli/dist/clis/lobsters/tag.yaml +34 -0
  723. package/vendor/opencli/dist/clis/medium/feed.d.ts +1 -0
  724. package/vendor/opencli/dist/clis/medium/feed.js +15 -0
  725. package/vendor/opencli/dist/clis/medium/search.d.ts +1 -0
  726. package/vendor/opencli/dist/clis/medium/search.js +15 -0
  727. package/vendor/opencli/dist/clis/medium/user.d.ts +1 -0
  728. package/vendor/opencli/dist/clis/medium/user.js +15 -0
  729. package/vendor/opencli/dist/clis/medium/utils.d.ts +5 -0
  730. package/vendor/opencli/dist/clis/medium/utils.js +79 -0
  731. package/vendor/opencli/dist/clis/notebooklm/compat.test.d.ts +3 -0
  732. package/vendor/opencli/dist/clis/notebooklm/compat.test.js +16 -0
  733. package/vendor/opencli/dist/clis/notebooklm/current.d.ts +1 -0
  734. package/vendor/opencli/dist/clis/notebooklm/current.js +27 -0
  735. package/vendor/opencli/dist/clis/notebooklm/get.d.ts +1 -0
  736. package/vendor/opencli/dist/clis/notebooklm/get.js +36 -0
  737. package/vendor/opencli/dist/clis/notebooklm/history.d.ts +1 -0
  738. package/vendor/opencli/dist/clis/notebooklm/history.js +24 -0
  739. package/vendor/opencli/dist/clis/notebooklm/history.test.d.ts +1 -0
  740. package/vendor/opencli/dist/clis/notebooklm/history.test.js +58 -0
  741. package/vendor/opencli/dist/clis/notebooklm/list.d.ts +1 -0
  742. package/vendor/opencli/dist/clis/notebooklm/list.js +35 -0
  743. package/vendor/opencli/dist/clis/notebooklm/note-list.d.ts +1 -0
  744. package/vendor/opencli/dist/clis/notebooklm/note-list.js +27 -0
  745. package/vendor/opencli/dist/clis/notebooklm/note-list.test.d.ts +1 -0
  746. package/vendor/opencli/dist/clis/notebooklm/note-list.test.js +56 -0
  747. package/vendor/opencli/dist/clis/notebooklm/notes-get.d.ts +1 -0
  748. package/vendor/opencli/dist/clis/notebooklm/notes-get.js +46 -0
  749. package/vendor/opencli/dist/clis/notebooklm/notes-get.test.d.ts +1 -0
  750. package/vendor/opencli/dist/clis/notebooklm/notes-get.test.js +72 -0
  751. package/vendor/opencli/dist/clis/notebooklm/open.d.ts +1 -0
  752. package/vendor/opencli/dist/clis/notebooklm/open.js +41 -0
  753. package/vendor/opencli/dist/clis/notebooklm/open.test.d.ts +1 -0
  754. package/vendor/opencli/dist/clis/notebooklm/open.test.js +63 -0
  755. package/vendor/opencli/dist/clis/notebooklm/rpc.d.ts +36 -0
  756. package/vendor/opencli/dist/clis/notebooklm/rpc.js +189 -0
  757. package/vendor/opencli/dist/clis/notebooklm/rpc.test.d.ts +1 -0
  758. package/vendor/opencli/dist/clis/notebooklm/rpc.test.js +105 -0
  759. package/vendor/opencli/dist/clis/notebooklm/shared.d.ts +87 -0
  760. package/vendor/opencli/dist/clis/notebooklm/shared.js +3 -0
  761. package/vendor/opencli/dist/clis/notebooklm/source-fulltext.d.ts +1 -0
  762. package/vendor/opencli/dist/clis/notebooklm/source-fulltext.js +43 -0
  763. package/vendor/opencli/dist/clis/notebooklm/source-fulltext.test.d.ts +1 -0
  764. package/vendor/opencli/dist/clis/notebooklm/source-fulltext.test.js +106 -0
  765. package/vendor/opencli/dist/clis/notebooklm/source-get.d.ts +1 -0
  766. package/vendor/opencli/dist/clis/notebooklm/source-get.js +39 -0
  767. package/vendor/opencli/dist/clis/notebooklm/source-get.test.d.ts +1 -0
  768. package/vendor/opencli/dist/clis/notebooklm/source-get.test.js +84 -0
  769. package/vendor/opencli/dist/clis/notebooklm/source-guide.d.ts +1 -0
  770. package/vendor/opencli/dist/clis/notebooklm/source-guide.js +43 -0
  771. package/vendor/opencli/dist/clis/notebooklm/source-guide.test.d.ts +1 -0
  772. package/vendor/opencli/dist/clis/notebooklm/source-guide.test.js +104 -0
  773. package/vendor/opencli/dist/clis/notebooklm/source-list.d.ts +1 -0
  774. package/vendor/opencli/dist/clis/notebooklm/source-list.js +29 -0
  775. package/vendor/opencli/dist/clis/notebooklm/status.d.ts +1 -0
  776. package/vendor/opencli/dist/clis/notebooklm/status.js +30 -0
  777. package/vendor/opencli/dist/clis/notebooklm/summary.d.ts +1 -0
  778. package/vendor/opencli/dist/clis/notebooklm/summary.js +29 -0
  779. package/vendor/opencli/dist/clis/notebooklm/summary.test.d.ts +1 -0
  780. package/vendor/opencli/dist/clis/notebooklm/summary.test.js +78 -0
  781. package/vendor/opencli/dist/clis/notebooklm/utils.d.ts +38 -0
  782. package/vendor/opencli/dist/clis/notebooklm/utils.js +738 -0
  783. package/vendor/opencli/dist/clis/notebooklm/utils.test.d.ts +1 -0
  784. package/vendor/opencli/dist/clis/notebooklm/utils.test.js +390 -0
  785. package/vendor/opencli/dist/clis/notion/export.d.ts +1 -0
  786. package/vendor/opencli/dist/clis/notion/export.js +31 -0
  787. package/vendor/opencli/dist/clis/notion/favorites.d.ts +1 -0
  788. package/vendor/opencli/dist/clis/notion/favorites.js +84 -0
  789. package/vendor/opencli/dist/clis/notion/new.d.ts +1 -0
  790. package/vendor/opencli/dist/clis/notion/new.js +34 -0
  791. package/vendor/opencli/dist/clis/notion/read.d.ts +1 -0
  792. package/vendor/opencli/dist/clis/notion/read.js +30 -0
  793. package/vendor/opencli/dist/clis/notion/search.d.ts +1 -0
  794. package/vendor/opencli/dist/clis/notion/search.js +46 -0
  795. package/vendor/opencli/dist/clis/notion/sidebar.d.ts +1 -0
  796. package/vendor/opencli/dist/clis/notion/sidebar.js +41 -0
  797. package/vendor/opencli/dist/clis/notion/status.d.ts +1 -0
  798. package/vendor/opencli/dist/clis/notion/status.js +16 -0
  799. package/vendor/opencli/dist/clis/notion/write.d.ts +1 -0
  800. package/vendor/opencli/dist/clis/notion/write.js +40 -0
  801. package/vendor/opencli/dist/clis/ones/common.d.ts +32 -0
  802. package/vendor/opencli/dist/clis/ones/common.js +144 -0
  803. package/vendor/opencli/dist/clis/ones/enrich-tasks.d.ts +5 -0
  804. package/vendor/opencli/dist/clis/ones/enrich-tasks.js +37 -0
  805. package/vendor/opencli/dist/clis/ones/login.d.ts +1 -0
  806. package/vendor/opencli/dist/clis/ones/login.js +80 -0
  807. package/vendor/opencli/dist/clis/ones/logout.d.ts +1 -0
  808. package/vendor/opencli/dist/clis/ones/logout.js +17 -0
  809. package/vendor/opencli/dist/clis/ones/me.d.ts +1 -0
  810. package/vendor/opencli/dist/clis/ones/me.js +30 -0
  811. package/vendor/opencli/dist/clis/ones/my-tasks.d.ts +1 -0
  812. package/vendor/opencli/dist/clis/ones/my-tasks.js +120 -0
  813. package/vendor/opencli/dist/clis/ones/resolve-labels.d.ts +10 -0
  814. package/vendor/opencli/dist/clis/ones/resolve-labels.js +64 -0
  815. package/vendor/opencli/dist/clis/ones/task-helpers.d.ts +29 -0
  816. package/vendor/opencli/dist/clis/ones/task-helpers.js +212 -0
  817. package/vendor/opencli/dist/clis/ones/task-helpers.test.d.ts +1 -0
  818. package/vendor/opencli/dist/clis/ones/task-helpers.test.js +12 -0
  819. package/vendor/opencli/dist/clis/ones/task.d.ts +1 -0
  820. package/vendor/opencli/dist/clis/ones/task.js +66 -0
  821. package/vendor/opencli/dist/clis/ones/tasks.d.ts +1 -0
  822. package/vendor/opencli/dist/clis/ones/tasks.js +79 -0
  823. package/vendor/opencli/dist/clis/ones/token-info.d.ts +1 -0
  824. package/vendor/opencli/dist/clis/ones/token-info.js +42 -0
  825. package/vendor/opencli/dist/clis/ones/worklog.d.ts +11 -0
  826. package/vendor/opencli/dist/clis/ones/worklog.js +267 -0
  827. package/vendor/opencli/dist/clis/ones/worklog.test.d.ts +1 -0
  828. package/vendor/opencli/dist/clis/ones/worklog.test.js +20 -0
  829. package/vendor/opencli/dist/clis/paperreview/commands.test.d.ts +3 -0
  830. package/vendor/opencli/dist/clis/paperreview/commands.test.js +243 -0
  831. package/vendor/opencli/dist/clis/paperreview/feedback.d.ts +1 -0
  832. package/vendor/opencli/dist/clis/paperreview/feedback.js +52 -0
  833. package/vendor/opencli/dist/clis/paperreview/review.d.ts +1 -0
  834. package/vendor/opencli/dist/clis/paperreview/review.js +37 -0
  835. package/vendor/opencli/dist/clis/paperreview/submit.d.ts +1 -0
  836. package/vendor/opencli/dist/clis/paperreview/submit.js +85 -0
  837. package/vendor/opencli/dist/clis/paperreview/utils.d.ts +46 -0
  838. package/vendor/opencli/dist/clis/paperreview/utils.js +197 -0
  839. package/vendor/opencli/dist/clis/paperreview/utils.test.d.ts +1 -0
  840. package/vendor/opencli/dist/clis/paperreview/utils.test.js +49 -0
  841. package/vendor/opencli/dist/clis/pixiv/detail.yaml +49 -0
  842. package/vendor/opencli/dist/clis/pixiv/download.d.ts +7 -0
  843. package/vendor/opencli/dist/clis/pixiv/download.js +78 -0
  844. package/vendor/opencli/dist/clis/pixiv/download.test.d.ts +1 -0
  845. package/vendor/opencli/dist/clis/pixiv/download.test.js +87 -0
  846. package/vendor/opencli/dist/clis/pixiv/illusts.d.ts +8 -0
  847. package/vendor/opencli/dist/clis/pixiv/illusts.js +65 -0
  848. package/vendor/opencli/dist/clis/pixiv/illusts.test.d.ts +1 -0
  849. package/vendor/opencli/dist/clis/pixiv/illusts.test.js +99 -0
  850. package/vendor/opencli/dist/clis/pixiv/ranking.yaml +53 -0
  851. package/vendor/opencli/dist/clis/pixiv/search.d.ts +6 -0
  852. package/vendor/opencli/dist/clis/pixiv/search.js +43 -0
  853. package/vendor/opencli/dist/clis/pixiv/search.test.d.ts +1 -0
  854. package/vendor/opencli/dist/clis/pixiv/search.test.js +83 -0
  855. package/vendor/opencli/dist/clis/pixiv/test-utils.d.ts +12 -0
  856. package/vendor/opencli/dist/clis/pixiv/test-utils.js +23 -0
  857. package/vendor/opencli/dist/clis/pixiv/user.yaml +46 -0
  858. package/vendor/opencli/dist/clis/pixiv/utils.d.ts +27 -0
  859. package/vendor/opencli/dist/clis/pixiv/utils.js +49 -0
  860. package/vendor/opencli/dist/clis/producthunt/browse.d.ts +1 -0
  861. package/vendor/opencli/dist/clis/producthunt/browse.js +99 -0
  862. package/vendor/opencli/dist/clis/producthunt/hot.d.ts +1 -0
  863. package/vendor/opencli/dist/clis/producthunt/hot.js +110 -0
  864. package/vendor/opencli/dist/clis/producthunt/posts.d.ts +1 -0
  865. package/vendor/opencli/dist/clis/producthunt/posts.js +28 -0
  866. package/vendor/opencli/dist/clis/producthunt/today.d.ts +1 -0
  867. package/vendor/opencli/dist/clis/producthunt/today.js +35 -0
  868. package/vendor/opencli/dist/clis/producthunt/utils.d.ts +29 -0
  869. package/vendor/opencli/dist/clis/producthunt/utils.js +99 -0
  870. package/vendor/opencli/dist/clis/producthunt/utils.test.d.ts +1 -0
  871. package/vendor/opencli/dist/clis/producthunt/utils.test.js +64 -0
  872. package/vendor/opencli/dist/clis/reddit/comment.d.ts +1 -0
  873. package/vendor/opencli/dist/clis/reddit/comment.js +57 -0
  874. package/vendor/opencli/dist/clis/reddit/frontpage.yaml +30 -0
  875. package/vendor/opencli/dist/clis/reddit/hot.yaml +47 -0
  876. package/vendor/opencli/dist/clis/reddit/popular.yaml +40 -0
  877. package/vendor/opencli/dist/clis/reddit/read.d.ts +1 -0
  878. package/vendor/opencli/dist/clis/reddit/read.js +184 -0
  879. package/vendor/opencli/dist/clis/reddit/read.test.d.ts +1 -0
  880. package/vendor/opencli/dist/clis/reddit/read.test.js +28 -0
  881. package/vendor/opencli/dist/clis/reddit/save.d.ts +1 -0
  882. package/vendor/opencli/dist/clis/reddit/save.js +51 -0
  883. package/vendor/opencli/dist/clis/reddit/saved.d.ts +1 -0
  884. package/vendor/opencli/dist/clis/reddit/saved.js +49 -0
  885. package/vendor/opencli/dist/clis/reddit/search.yaml +61 -0
  886. package/vendor/opencli/dist/clis/reddit/subreddit.yaml +50 -0
  887. package/vendor/opencli/dist/clis/reddit/subscribe.d.ts +1 -0
  888. package/vendor/opencli/dist/clis/reddit/subscribe.js +50 -0
  889. package/vendor/opencli/dist/clis/reddit/upvote.d.ts +1 -0
  890. package/vendor/opencli/dist/clis/reddit/upvote.js +64 -0
  891. package/vendor/opencli/dist/clis/reddit/upvoted.d.ts +1 -0
  892. package/vendor/opencli/dist/clis/reddit/upvoted.js +49 -0
  893. package/vendor/opencli/dist/clis/reddit/user-comments.yaml +46 -0
  894. package/vendor/opencli/dist/clis/reddit/user-posts.yaml +44 -0
  895. package/vendor/opencli/dist/clis/reddit/user.yaml +40 -0
  896. package/vendor/opencli/dist/clis/reuters/search.d.ts +1 -0
  897. package/vendor/opencli/dist/clis/reuters/search.js +51 -0
  898. package/vendor/opencli/dist/clis/sinablog/article.d.ts +1 -0
  899. package/vendor/opencli/dist/clis/sinablog/article.js +14 -0
  900. package/vendor/opencli/dist/clis/sinablog/hot.d.ts +1 -0
  901. package/vendor/opencli/dist/clis/sinablog/hot.js +14 -0
  902. package/vendor/opencli/dist/clis/sinablog/search.d.ts +1 -0
  903. package/vendor/opencli/dist/clis/sinablog/search.js +51 -0
  904. package/vendor/opencli/dist/clis/sinablog/user.d.ts +1 -0
  905. package/vendor/opencli/dist/clis/sinablog/user.js +15 -0
  906. package/vendor/opencli/dist/clis/sinablog/utils.d.ts +7 -0
  907. package/vendor/opencli/dist/clis/sinablog/utils.js +186 -0
  908. package/vendor/opencli/dist/clis/sinafinance/news.d.ts +7 -0
  909. package/vendor/opencli/dist/clis/sinafinance/news.js +61 -0
  910. package/vendor/opencli/dist/clis/sinafinance/rolling-news.d.ts +4 -0
  911. package/vendor/opencli/dist/clis/sinafinance/rolling-news.js +40 -0
  912. package/vendor/opencli/dist/clis/sinafinance/stock-rank.d.ts +4 -0
  913. package/vendor/opencli/dist/clis/sinafinance/stock-rank.js +65 -0
  914. package/vendor/opencli/dist/clis/sinafinance/stock.d.ts +8 -0
  915. package/vendor/opencli/dist/clis/sinafinance/stock.js +117 -0
  916. package/vendor/opencli/dist/clis/smzdm/search.d.ts +1 -0
  917. package/vendor/opencli/dist/clis/smzdm/search.js +54 -0
  918. package/vendor/opencli/dist/clis/spotify/spotify.d.ts +1 -0
  919. package/vendor/opencli/dist/clis/spotify/spotify.js +316 -0
  920. package/vendor/opencli/dist/clis/spotify/utils.d.ts +21 -0
  921. package/vendor/opencli/dist/clis/spotify/utils.js +66 -0
  922. package/vendor/opencli/dist/clis/spotify/utils.test.d.ts +1 -0
  923. package/vendor/opencli/dist/clis/spotify/utils.test.js +67 -0
  924. package/vendor/opencli/dist/clis/stackoverflow/bounties.yaml +29 -0
  925. package/vendor/opencli/dist/clis/stackoverflow/hot.yaml +28 -0
  926. package/vendor/opencli/dist/clis/stackoverflow/search.yaml +33 -0
  927. package/vendor/opencli/dist/clis/stackoverflow/unanswered.yaml +28 -0
  928. package/vendor/opencli/dist/clis/steam/top-sellers.yaml +29 -0
  929. package/vendor/opencli/dist/clis/substack/feed.d.ts +1 -0
  930. package/vendor/opencli/dist/clis/substack/feed.js +15 -0
  931. package/vendor/opencli/dist/clis/substack/publication.d.ts +1 -0
  932. package/vendor/opencli/dist/clis/substack/publication.js +15 -0
  933. package/vendor/opencli/dist/clis/substack/search.d.ts +1 -0
  934. package/vendor/opencli/dist/clis/substack/search.js +78 -0
  935. package/vendor/opencli/dist/clis/substack/utils.d.ts +8 -0
  936. package/vendor/opencli/dist/clis/substack/utils.js +136 -0
  937. package/vendor/opencli/dist/clis/substack/utils.test.d.ts +1 -0
  938. package/vendor/opencli/dist/clis/substack/utils.test.js +44 -0
  939. package/vendor/opencli/dist/clis/tieba/commands.test.d.ts +4 -0
  940. package/vendor/opencli/dist/clis/tieba/commands.test.js +79 -0
  941. package/vendor/opencli/dist/clis/tieba/hot.d.ts +1 -0
  942. package/vendor/opencli/dist/clis/tieba/hot.js +48 -0
  943. package/vendor/opencli/dist/clis/tieba/posts.d.ts +1 -0
  944. package/vendor/opencli/dist/clis/tieba/posts.js +85 -0
  945. package/vendor/opencli/dist/clis/tieba/read.d.ts +1 -0
  946. package/vendor/opencli/dist/clis/tieba/read.js +140 -0
  947. package/vendor/opencli/dist/clis/tieba/search.d.ts +1 -0
  948. package/vendor/opencli/dist/clis/tieba/search.js +108 -0
  949. package/vendor/opencli/dist/clis/tieba/utils.d.ts +101 -0
  950. package/vendor/opencli/dist/clis/tieba/utils.js +240 -0
  951. package/vendor/opencli/dist/clis/tieba/utils.test.d.ts +1 -0
  952. package/vendor/opencli/dist/clis/tieba/utils.test.js +290 -0
  953. package/vendor/opencli/dist/clis/tiktok/comment.yaml +66 -0
  954. package/vendor/opencli/dist/clis/tiktok/explore.yaml +39 -0
  955. package/vendor/opencli/dist/clis/tiktok/follow.yaml +39 -0
  956. package/vendor/opencli/dist/clis/tiktok/following.yaml +46 -0
  957. package/vendor/opencli/dist/clis/tiktok/friends.yaml +47 -0
  958. package/vendor/opencli/dist/clis/tiktok/like.yaml +38 -0
  959. package/vendor/opencli/dist/clis/tiktok/live.yaml +51 -0
  960. package/vendor/opencli/dist/clis/tiktok/notifications.yaml +52 -0
  961. package/vendor/opencli/dist/clis/tiktok/profile.yaml +45 -0
  962. package/vendor/opencli/dist/clis/tiktok/save.yaml +34 -0
  963. package/vendor/opencli/dist/clis/tiktok/search.yaml +47 -0
  964. package/vendor/opencli/dist/clis/tiktok/unfollow.yaml +44 -0
  965. package/vendor/opencli/dist/clis/tiktok/unlike.yaml +38 -0
  966. package/vendor/opencli/dist/clis/tiktok/unsave.yaml +36 -0
  967. package/vendor/opencli/dist/clis/tiktok/user.yaml +44 -0
  968. package/vendor/opencli/dist/clis/twitter/accept.d.ts +1 -0
  969. package/vendor/opencli/dist/clis/twitter/accept.js +203 -0
  970. package/vendor/opencli/dist/clis/twitter/article.d.ts +1 -0
  971. package/vendor/opencli/dist/clis/twitter/article.js +163 -0
  972. package/vendor/opencli/dist/clis/twitter/block.d.ts +1 -0
  973. package/vendor/opencli/dist/clis/twitter/block.js +89 -0
  974. package/vendor/opencli/dist/clis/twitter/bookmark.d.ts +1 -0
  975. package/vendor/opencli/dist/clis/twitter/bookmark.js +64 -0
  976. package/vendor/opencli/dist/clis/twitter/bookmarks.d.ts +1 -0
  977. package/vendor/opencli/dist/clis/twitter/bookmarks.js +172 -0
  978. package/vendor/opencli/dist/clis/twitter/delete.d.ts +1 -0
  979. package/vendor/opencli/dist/clis/twitter/delete.js +73 -0
  980. package/vendor/opencli/dist/clis/twitter/download.d.ts +8 -0
  981. package/vendor/opencli/dist/clis/twitter/download.js +110 -0
  982. package/vendor/opencli/dist/clis/twitter/follow.d.ts +1 -0
  983. package/vendor/opencli/dist/clis/twitter/follow.js +66 -0
  984. package/vendor/opencli/dist/clis/twitter/followers.d.ts +1 -0
  985. package/vendor/opencli/dist/clis/twitter/followers.js +102 -0
  986. package/vendor/opencli/dist/clis/twitter/following.d.ts +1 -0
  987. package/vendor/opencli/dist/clis/twitter/following.js +95 -0
  988. package/vendor/opencli/dist/clis/twitter/hide-reply.d.ts +1 -0
  989. package/vendor/opencli/dist/clis/twitter/hide-reply.js +67 -0
  990. package/vendor/opencli/dist/clis/twitter/like.d.ts +1 -0
  991. package/vendor/opencli/dist/clis/twitter/like.js +69 -0
  992. package/vendor/opencli/dist/clis/twitter/likes.d.ts +24 -0
  993. package/vendor/opencli/dist/clis/twitter/likes.js +217 -0
  994. package/vendor/opencli/dist/clis/twitter/likes.test.d.ts +1 -0
  995. package/vendor/opencli/dist/clis/twitter/likes.test.js +85 -0
  996. package/vendor/opencli/dist/clis/twitter/notifications.d.ts +1 -0
  997. package/vendor/opencli/dist/clis/twitter/notifications.js +127 -0
  998. package/vendor/opencli/dist/clis/twitter/post.d.ts +1 -0
  999. package/vendor/opencli/dist/clis/twitter/post.js +98 -0
  1000. package/vendor/opencli/dist/clis/twitter/post.test.d.ts +1 -0
  1001. package/vendor/opencli/dist/clis/twitter/post.test.js +116 -0
  1002. package/vendor/opencli/dist/clis/twitter/profile.d.ts +1 -0
  1003. package/vendor/opencli/dist/clis/twitter/profile.js +103 -0
  1004. package/vendor/opencli/dist/clis/twitter/reply-dm.d.ts +1 -0
  1005. package/vendor/opencli/dist/clis/twitter/reply-dm.js +182 -0
  1006. package/vendor/opencli/dist/clis/twitter/reply.d.ts +13 -0
  1007. package/vendor/opencli/dist/clis/twitter/reply.js +280 -0
  1008. package/vendor/opencli/dist/clis/twitter/reply.test.d.ts +1 -0
  1009. package/vendor/opencli/dist/clis/twitter/reply.test.js +151 -0
  1010. package/vendor/opencli/dist/clis/twitter/search.d.ts +1 -0
  1011. package/vendor/opencli/dist/clis/twitter/search.js +169 -0
  1012. package/vendor/opencli/dist/clis/twitter/search.test.d.ts +1 -0
  1013. package/vendor/opencli/dist/clis/twitter/search.test.js +236 -0
  1014. package/vendor/opencli/dist/clis/twitter/shared.d.ts +6 -0
  1015. package/vendor/opencli/dist/clis/twitter/shared.js +35 -0
  1016. package/vendor/opencli/dist/clis/twitter/thread.d.ts +1 -0
  1017. package/vendor/opencli/dist/clis/twitter/thread.js +151 -0
  1018. package/vendor/opencli/dist/clis/twitter/timeline.d.ts +24 -0
  1019. package/vendor/opencli/dist/clis/twitter/timeline.js +204 -0
  1020. package/vendor/opencli/dist/clis/twitter/timeline.test.d.ts +1 -0
  1021. package/vendor/opencli/dist/clis/twitter/timeline.test.js +102 -0
  1022. package/vendor/opencli/dist/clis/twitter/trending.d.ts +1 -0
  1023. package/vendor/opencli/dist/clis/twitter/trending.js +60 -0
  1024. package/vendor/opencli/dist/clis/twitter/unblock.d.ts +1 -0
  1025. package/vendor/opencli/dist/clis/twitter/unblock.js +72 -0
  1026. package/vendor/opencli/dist/clis/twitter/unbookmark.d.ts +1 -0
  1027. package/vendor/opencli/dist/clis/twitter/unbookmark.js +63 -0
  1028. package/vendor/opencli/dist/clis/twitter/unfollow.d.ts +1 -0
  1029. package/vendor/opencli/dist/clis/twitter/unfollow.js +72 -0
  1030. package/vendor/opencli/dist/clis/v2ex/daily.d.ts +1 -0
  1031. package/vendor/opencli/dist/clis/v2ex/daily.js +98 -0
  1032. package/vendor/opencli/dist/clis/v2ex/hot.yaml +28 -0
  1033. package/vendor/opencli/dist/clis/v2ex/latest.yaml +28 -0
  1034. package/vendor/opencli/dist/clis/v2ex/me.d.ts +1 -0
  1035. package/vendor/opencli/dist/clis/v2ex/me.js +99 -0
  1036. package/vendor/opencli/dist/clis/v2ex/member.yaml +29 -0
  1037. package/vendor/opencli/dist/clis/v2ex/node.yaml +34 -0
  1038. package/vendor/opencli/dist/clis/v2ex/nodes.yaml +31 -0
  1039. package/vendor/opencli/dist/clis/v2ex/notifications.d.ts +1 -0
  1040. package/vendor/opencli/dist/clis/v2ex/notifications.js +71 -0
  1041. package/vendor/opencli/dist/clis/v2ex/replies.yaml +32 -0
  1042. package/vendor/opencli/dist/clis/v2ex/topic.yaml +33 -0
  1043. package/vendor/opencli/dist/clis/v2ex/user.yaml +34 -0
  1044. package/vendor/opencli/dist/clis/web/read.d.ts +16 -0
  1045. package/vendor/opencli/dist/clis/web/read.js +202 -0
  1046. package/vendor/opencli/dist/clis/weibo/comments.d.ts +1 -0
  1047. package/vendor/opencli/dist/clis/weibo/comments.js +53 -0
  1048. package/vendor/opencli/dist/clis/weibo/feed.d.ts +1 -0
  1049. package/vendor/opencli/dist/clis/weibo/feed.js +56 -0
  1050. package/vendor/opencli/dist/clis/weibo/hot.d.ts +1 -0
  1051. package/vendor/opencli/dist/clis/weibo/hot.js +39 -0
  1052. package/vendor/opencli/dist/clis/weibo/me.d.ts +1 -0
  1053. package/vendor/opencli/dist/clis/weibo/me.js +76 -0
  1054. package/vendor/opencli/dist/clis/weibo/post.d.ts +1 -0
  1055. package/vendor/opencli/dist/clis/weibo/post.js +75 -0
  1056. package/vendor/opencli/dist/clis/weibo/search.d.ts +1 -0
  1057. package/vendor/opencli/dist/clis/weibo/search.js +73 -0
  1058. package/vendor/opencli/dist/clis/weibo/user.d.ts +1 -0
  1059. package/vendor/opencli/dist/clis/weibo/user.js +63 -0
  1060. package/vendor/opencli/dist/clis/weibo/utils.d.ts +6 -0
  1061. package/vendor/opencli/dist/clis/weibo/utils.js +30 -0
  1062. package/vendor/opencli/dist/clis/weixin/download.d.ts +38 -0
  1063. package/vendor/opencli/dist/clis/weixin/download.js +321 -0
  1064. package/vendor/opencli/dist/clis/weread/book.d.ts +1 -0
  1065. package/vendor/opencli/dist/clis/weread/book.js +219 -0
  1066. package/vendor/opencli/dist/clis/weread/commands.test.d.ts +3 -0
  1067. package/vendor/opencli/dist/clis/weread/commands.test.js +374 -0
  1068. package/vendor/opencli/dist/clis/weread/highlights.d.ts +1 -0
  1069. package/vendor/opencli/dist/clis/weread/highlights.js +23 -0
  1070. package/vendor/opencli/dist/clis/weread/notebooks.d.ts +1 -0
  1071. package/vendor/opencli/dist/clis/weread/notebooks.js +21 -0
  1072. package/vendor/opencli/dist/clis/weread/notes.d.ts +1 -0
  1073. package/vendor/opencli/dist/clis/weread/notes.js +29 -0
  1074. package/vendor/opencli/dist/clis/weread/private-api-regression.test.d.ts +1 -0
  1075. package/vendor/opencli/dist/clis/weread/private-api-regression.test.js +369 -0
  1076. package/vendor/opencli/dist/clis/weread/ranking.d.ts +1 -0
  1077. package/vendor/opencli/dist/clis/weread/ranking.js +28 -0
  1078. package/vendor/opencli/dist/clis/weread/search-regression.test.d.ts +1 -0
  1079. package/vendor/opencli/dist/clis/weread/search-regression.test.js +407 -0
  1080. package/vendor/opencli/dist/clis/weread/search.d.ts +1 -0
  1081. package/vendor/opencli/dist/clis/weread/search.js +162 -0
  1082. package/vendor/opencli/dist/clis/weread/shelf.d.ts +1 -0
  1083. package/vendor/opencli/dist/clis/weread/shelf.js +65 -0
  1084. package/vendor/opencli/dist/clis/weread/utils.d.ts +76 -0
  1085. package/vendor/opencli/dist/clis/weread/utils.js +321 -0
  1086. package/vendor/opencli/dist/clis/weread/utils.test.d.ts +1 -0
  1087. package/vendor/opencli/dist/clis/weread/utils.test.js +128 -0
  1088. package/vendor/opencli/dist/clis/wikipedia/random.d.ts +1 -0
  1089. package/vendor/opencli/dist/clis/wikipedia/random.js +19 -0
  1090. package/vendor/opencli/dist/clis/wikipedia/search.d.ts +1 -0
  1091. package/vendor/opencli/dist/clis/wikipedia/search.js +30 -0
  1092. package/vendor/opencli/dist/clis/wikipedia/summary.d.ts +1 -0
  1093. package/vendor/opencli/dist/clis/wikipedia/summary.js +23 -0
  1094. package/vendor/opencli/dist/clis/wikipedia/trending.d.ts +1 -0
  1095. package/vendor/opencli/dist/clis/wikipedia/trending.js +35 -0
  1096. package/vendor/opencli/dist/clis/wikipedia/utils.d.ts +36 -0
  1097. package/vendor/opencli/dist/clis/wikipedia/utils.js +31 -0
  1098. package/vendor/opencli/dist/clis/xianyu/chat.d.ts +7 -0
  1099. package/vendor/opencli/dist/clis/xianyu/chat.js +146 -0
  1100. package/vendor/opencli/dist/clis/xianyu/chat.test.d.ts +1 -0
  1101. package/vendor/opencli/dist/clis/xianyu/chat.test.js +15 -0
  1102. package/vendor/opencli/dist/clis/xianyu/item.d.ts +7 -0
  1103. package/vendor/opencli/dist/clis/xianyu/item.js +152 -0
  1104. package/vendor/opencli/dist/clis/xianyu/item.test.d.ts +1 -0
  1105. package/vendor/opencli/dist/clis/xianyu/item.test.js +56 -0
  1106. package/vendor/opencli/dist/clis/xianyu/search.d.ts +10 -0
  1107. package/vendor/opencli/dist/clis/xianyu/search.js +134 -0
  1108. package/vendor/opencli/dist/clis/xianyu/search.test.d.ts +1 -0
  1109. package/vendor/opencli/dist/clis/xianyu/search.test.js +17 -0
  1110. package/vendor/opencli/dist/clis/xianyu/utils.d.ts +1 -0
  1111. package/vendor/opencli/dist/clis/xianyu/utils.js +8 -0
  1112. package/vendor/opencli/dist/clis/xiaoe/catalog.yaml +129 -0
  1113. package/vendor/opencli/dist/clis/xiaoe/content.yaml +43 -0
  1114. package/vendor/opencli/dist/clis/xiaoe/courses.yaml +73 -0
  1115. package/vendor/opencli/dist/clis/xiaoe/detail.yaml +39 -0
  1116. package/vendor/opencli/dist/clis/xiaoe/play-url.yaml +124 -0
  1117. package/vendor/opencli/dist/clis/xiaohongshu/comments.d.ts +8 -0
  1118. package/vendor/opencli/dist/clis/xiaohongshu/comments.js +133 -0
  1119. package/vendor/opencli/dist/clis/xiaohongshu/comments.test.d.ts +1 -0
  1120. package/vendor/opencli/dist/clis/xiaohongshu/comments.test.js +139 -0
  1121. package/vendor/opencli/dist/clis/xiaohongshu/creator-note-detail.d.ts +84 -0
  1122. package/vendor/opencli/dist/clis/xiaohongshu/creator-note-detail.js +341 -0
  1123. package/vendor/opencli/dist/clis/xiaohongshu/creator-note-detail.test.d.ts +1 -0
  1124. package/vendor/opencli/dist/clis/xiaohongshu/creator-note-detail.test.js +259 -0
  1125. package/vendor/opencli/dist/clis/xiaohongshu/creator-notes-summary.d.ts +28 -0
  1126. package/vendor/opencli/dist/clis/xiaohongshu/creator-notes-summary.js +92 -0
  1127. package/vendor/opencli/dist/clis/xiaohongshu/creator-notes-summary.test.d.ts +1 -0
  1128. package/vendor/opencli/dist/clis/xiaohongshu/creator-notes-summary.test.js +49 -0
  1129. package/vendor/opencli/dist/clis/xiaohongshu/creator-notes.d.ts +24 -0
  1130. package/vendor/opencli/dist/clis/xiaohongshu/creator-notes.js +227 -0
  1131. package/vendor/opencli/dist/clis/xiaohongshu/creator-notes.test.d.ts +1 -0
  1132. package/vendor/opencli/dist/clis/xiaohongshu/creator-notes.test.js +192 -0
  1133. package/vendor/opencli/dist/clis/xiaohongshu/creator-profile.d.ts +10 -0
  1134. package/vendor/opencli/dist/clis/xiaohongshu/creator-profile.js +53 -0
  1135. package/vendor/opencli/dist/clis/xiaohongshu/creator-stats.d.ts +10 -0
  1136. package/vendor/opencli/dist/clis/xiaohongshu/creator-stats.js +73 -0
  1137. package/vendor/opencli/dist/clis/xiaohongshu/download.d.ts +10 -0
  1138. package/vendor/opencli/dist/clis/xiaohongshu/download.js +167 -0
  1139. package/vendor/opencli/dist/clis/xiaohongshu/download.test.d.ts +1 -0
  1140. package/vendor/opencli/dist/clis/xiaohongshu/download.test.js +73 -0
  1141. package/vendor/opencli/dist/clis/xiaohongshu/feed.yaml +31 -0
  1142. package/vendor/opencli/dist/clis/xiaohongshu/note-helpers.d.ts +12 -0
  1143. package/vendor/opencli/dist/clis/xiaohongshu/note-helpers.js +23 -0
  1144. package/vendor/opencli/dist/clis/xiaohongshu/note.d.ts +7 -0
  1145. package/vendor/opencli/dist/clis/xiaohongshu/note.js +87 -0
  1146. package/vendor/opencli/dist/clis/xiaohongshu/note.test.d.ts +1 -0
  1147. package/vendor/opencli/dist/clis/xiaohongshu/note.test.js +183 -0
  1148. package/vendor/opencli/dist/clis/xiaohongshu/notifications.yaml +37 -0
  1149. package/vendor/opencli/dist/clis/xiaohongshu/publish.d.ts +18 -0
  1150. package/vendor/opencli/dist/clis/xiaohongshu/publish.js +531 -0
  1151. package/vendor/opencli/dist/clis/xiaohongshu/publish.test.d.ts +1 -0
  1152. package/vendor/opencli/dist/clis/xiaohongshu/publish.test.js +195 -0
  1153. package/vendor/opencli/dist/clis/xiaohongshu/search.d.ts +15 -0
  1154. package/vendor/opencli/dist/clis/xiaohongshu/search.js +131 -0
  1155. package/vendor/opencli/dist/clis/xiaohongshu/search.test.d.ts +1 -0
  1156. package/vendor/opencli/dist/clis/xiaohongshu/search.test.js +160 -0
  1157. package/vendor/opencli/dist/clis/xiaohongshu/user-helpers.d.ts +16 -0
  1158. package/vendor/opencli/dist/clis/xiaohongshu/user-helpers.js +69 -0
  1159. package/vendor/opencli/dist/clis/xiaohongshu/user-helpers.test.d.ts +1 -0
  1160. package/vendor/opencli/dist/clis/xiaohongshu/user-helpers.test.js +99 -0
  1161. package/vendor/opencli/dist/clis/xiaohongshu/user.d.ts +1 -0
  1162. package/vendor/opencli/dist/clis/xiaohongshu/user.js +56 -0
  1163. package/vendor/opencli/dist/clis/xiaoyuzhou/episode.d.ts +1 -0
  1164. package/vendor/opencli/dist/clis/xiaoyuzhou/episode.js +28 -0
  1165. package/vendor/opencli/dist/clis/xiaoyuzhou/podcast-episodes.d.ts +1 -0
  1166. package/vendor/opencli/dist/clis/xiaoyuzhou/podcast-episodes.js +36 -0
  1167. package/vendor/opencli/dist/clis/xiaoyuzhou/podcast.d.ts +1 -0
  1168. package/vendor/opencli/dist/clis/xiaoyuzhou/podcast.js +27 -0
  1169. package/vendor/opencli/dist/clis/xiaoyuzhou/utils.d.ts +16 -0
  1170. package/vendor/opencli/dist/clis/xiaoyuzhou/utils.js +55 -0
  1171. package/vendor/opencli/dist/clis/xiaoyuzhou/utils.test.d.ts +1 -0
  1172. package/vendor/opencli/dist/clis/xiaoyuzhou/utils.test.js +99 -0
  1173. package/vendor/opencli/dist/clis/xueqiu/comments.d.ts +118 -0
  1174. package/vendor/opencli/dist/clis/xueqiu/comments.js +354 -0
  1175. package/vendor/opencli/dist/clis/xueqiu/comments.test.d.ts +1 -0
  1176. package/vendor/opencli/dist/clis/xueqiu/comments.test.js +696 -0
  1177. package/vendor/opencli/dist/clis/xueqiu/danjuan-utils.d.ts +55 -0
  1178. package/vendor/opencli/dist/clis/xueqiu/danjuan-utils.js +126 -0
  1179. package/vendor/opencli/dist/clis/xueqiu/danjuan-utils.test.d.ts +1 -0
  1180. package/vendor/opencli/dist/clis/xueqiu/danjuan-utils.test.js +41 -0
  1181. package/vendor/opencli/dist/clis/xueqiu/earnings-date.yaml +69 -0
  1182. package/vendor/opencli/dist/clis/xueqiu/feed.yaml +53 -0
  1183. package/vendor/opencli/dist/clis/xueqiu/fund-holdings.d.ts +1 -0
  1184. package/vendor/opencli/dist/clis/xueqiu/fund-holdings.js +28 -0
  1185. package/vendor/opencli/dist/clis/xueqiu/fund-snapshot.d.ts +1 -0
  1186. package/vendor/opencli/dist/clis/xueqiu/fund-snapshot.js +25 -0
  1187. package/vendor/opencli/dist/clis/xueqiu/hot-stock.yaml +49 -0
  1188. package/vendor/opencli/dist/clis/xueqiu/hot.yaml +46 -0
  1189. package/vendor/opencli/dist/clis/xueqiu/search.yaml +55 -0
  1190. package/vendor/opencli/dist/clis/xueqiu/stock.yaml +69 -0
  1191. package/vendor/opencli/dist/clis/xueqiu/watchlist.yaml +46 -0
  1192. package/vendor/opencli/dist/clis/yahoo-finance/quote.d.ts +1 -0
  1193. package/vendor/opencli/dist/clis/yahoo-finance/quote.js +72 -0
  1194. package/vendor/opencli/dist/clis/yollomi/background.d.ts +4 -0
  1195. package/vendor/opencli/dist/clis/yollomi/background.js +45 -0
  1196. package/vendor/opencli/dist/clis/yollomi/edit.d.ts +5 -0
  1197. package/vendor/opencli/dist/clis/yollomi/edit.js +56 -0
  1198. package/vendor/opencli/dist/clis/yollomi/face-swap.d.ts +5 -0
  1199. package/vendor/opencli/dist/clis/yollomi/face-swap.js +43 -0
  1200. package/vendor/opencli/dist/clis/yollomi/generate.d.ts +9 -0
  1201. package/vendor/opencli/dist/clis/yollomi/generate.js +100 -0
  1202. package/vendor/opencli/dist/clis/yollomi/models.d.ts +1 -0
  1203. package/vendor/opencli/dist/clis/yollomi/models.js +33 -0
  1204. package/vendor/opencli/dist/clis/yollomi/object-remover.d.ts +4 -0
  1205. package/vendor/opencli/dist/clis/yollomi/object-remover.js +42 -0
  1206. package/vendor/opencli/dist/clis/yollomi/remove-bg.d.ts +4 -0
  1207. package/vendor/opencli/dist/clis/yollomi/remove-bg.js +38 -0
  1208. package/vendor/opencli/dist/clis/yollomi/restore.d.ts +4 -0
  1209. package/vendor/opencli/dist/clis/yollomi/restore.js +38 -0
  1210. package/vendor/opencli/dist/clis/yollomi/try-on.d.ts +4 -0
  1211. package/vendor/opencli/dist/clis/yollomi/try-on.js +46 -0
  1212. package/vendor/opencli/dist/clis/yollomi/upload.d.ts +7 -0
  1213. package/vendor/opencli/dist/clis/yollomi/upload.js +71 -0
  1214. package/vendor/opencli/dist/clis/yollomi/upscale.d.ts +4 -0
  1215. package/vendor/opencli/dist/clis/yollomi/upscale.js +53 -0
  1216. package/vendor/opencli/dist/clis/yollomi/utils.d.ts +45 -0
  1217. package/vendor/opencli/dist/clis/yollomi/utils.js +180 -0
  1218. package/vendor/opencli/dist/clis/yollomi/video.d.ts +5 -0
  1219. package/vendor/opencli/dist/clis/yollomi/video.js +56 -0
  1220. package/vendor/opencli/dist/clis/youtube/channel.d.ts +1 -0
  1221. package/vendor/opencli/dist/clis/youtube/channel.js +150 -0
  1222. package/vendor/opencli/dist/clis/youtube/comments.d.ts +1 -0
  1223. package/vendor/opencli/dist/clis/youtube/comments.js +95 -0
  1224. package/vendor/opencli/dist/clis/youtube/search.d.ts +1 -0
  1225. package/vendor/opencli/dist/clis/youtube/search.js +99 -0
  1226. package/vendor/opencli/dist/clis/youtube/transcript-group.d.ts +44 -0
  1227. package/vendor/opencli/dist/clis/youtube/transcript-group.js +226 -0
  1228. package/vendor/opencli/dist/clis/youtube/transcript-group.test.d.ts +1 -0
  1229. package/vendor/opencli/dist/clis/youtube/transcript-group.test.js +99 -0
  1230. package/vendor/opencli/dist/clis/youtube/transcript.d.ts +1 -0
  1231. package/vendor/opencli/dist/clis/youtube/transcript.js +263 -0
  1232. package/vendor/opencli/dist/clis/youtube/utils.d.ts +17 -0
  1233. package/vendor/opencli/dist/clis/youtube/utils.js +92 -0
  1234. package/vendor/opencli/dist/clis/youtube/utils.test.d.ts +1 -0
  1235. package/vendor/opencli/dist/clis/youtube/utils.test.js +37 -0
  1236. package/vendor/opencli/dist/clis/youtube/video.d.ts +1 -0
  1237. package/vendor/opencli/dist/clis/youtube/video.js +116 -0
  1238. package/vendor/opencli/dist/clis/yuanbao/ask.d.ts +21 -0
  1239. package/vendor/opencli/dist/clis/yuanbao/ask.js +427 -0
  1240. package/vendor/opencli/dist/clis/yuanbao/ask.test.d.ts +1 -0
  1241. package/vendor/opencli/dist/clis/yuanbao/ask.test.js +124 -0
  1242. package/vendor/opencli/dist/clis/yuanbao/new.d.ts +1 -0
  1243. package/vendor/opencli/dist/clis/yuanbao/new.js +70 -0
  1244. package/vendor/opencli/dist/clis/yuanbao/new.test.d.ts +1 -0
  1245. package/vendor/opencli/dist/clis/yuanbao/new.test.js +30 -0
  1246. package/vendor/opencli/dist/clis/yuanbao/shared.d.ts +13 -0
  1247. package/vendor/opencli/dist/clis/yuanbao/shared.js +49 -0
  1248. package/vendor/opencli/dist/clis/zhihu/download.d.ts +7 -0
  1249. package/vendor/opencli/dist/clis/zhihu/download.js +79 -0
  1250. package/vendor/opencli/dist/clis/zhihu/download.test.d.ts +1 -0
  1251. package/vendor/opencli/dist/clis/zhihu/download.test.js +12 -0
  1252. package/vendor/opencli/dist/clis/zhihu/hot.yaml +46 -0
  1253. package/vendor/opencli/dist/clis/zhihu/question.d.ts +1 -0
  1254. package/vendor/opencli/dist/clis/zhihu/question.js +53 -0
  1255. package/vendor/opencli/dist/clis/zhihu/question.test.d.ts +1 -0
  1256. package/vendor/opencli/dist/clis/zhihu/question.test.js +72 -0
  1257. package/vendor/opencli/dist/clis/zhihu/search.yaml +59 -0
  1258. package/vendor/opencli/dist/clis/zsxq/dynamics.d.ts +1 -0
  1259. package/vendor/opencli/dist/clis/zsxq/dynamics.js +47 -0
  1260. package/vendor/opencli/dist/clis/zsxq/groups.d.ts +1 -0
  1261. package/vendor/opencli/dist/clis/zsxq/groups.js +32 -0
  1262. package/vendor/opencli/dist/clis/zsxq/search.d.ts +1 -0
  1263. package/vendor/opencli/dist/clis/zsxq/search.js +43 -0
  1264. package/vendor/opencli/dist/clis/zsxq/search.test.d.ts +1 -0
  1265. package/vendor/opencli/dist/clis/zsxq/search.test.js +24 -0
  1266. package/vendor/opencli/dist/clis/zsxq/topic.d.ts +1 -0
  1267. package/vendor/opencli/dist/clis/zsxq/topic.js +47 -0
  1268. package/vendor/opencli/dist/clis/zsxq/topic.test.d.ts +1 -0
  1269. package/vendor/opencli/dist/clis/zsxq/topic.test.js +29 -0
  1270. package/vendor/opencli/dist/clis/zsxq/topics.d.ts +1 -0
  1271. package/vendor/opencli/dist/clis/zsxq/topics.js +25 -0
  1272. package/vendor/opencli/dist/clis/zsxq/topics.test.d.ts +1 -0
  1273. package/vendor/opencli/dist/clis/zsxq/topics.test.js +24 -0
  1274. package/vendor/opencli/dist/clis/zsxq/utils.d.ts +97 -0
  1275. package/vendor/opencli/dist/clis/zsxq/utils.js +230 -0
  1276. package/vendor/opencli/dist/commanderAdapter.d.ts +22 -0
  1277. package/vendor/opencli/dist/commanderAdapter.js +301 -0
  1278. package/vendor/opencli/dist/commanderAdapter.test.d.ts +1 -0
  1279. package/vendor/opencli/dist/commanderAdapter.test.js +244 -0
  1280. package/vendor/opencli/dist/commands/daemon.d.ts +9 -0
  1281. package/vendor/opencli/dist/commands/daemon.js +85 -0
  1282. package/vendor/opencli/dist/commands/daemon.test.d.ts +1 -0
  1283. package/vendor/opencli/dist/commands/daemon.test.js +160 -0
  1284. package/vendor/opencli/dist/completion.d.ts +21 -0
  1285. package/vendor/opencli/dist/completion.js +120 -0
  1286. package/vendor/opencli/dist/completion.test.d.ts +1 -0
  1287. package/vendor/opencli/dist/completion.test.js +23 -0
  1288. package/vendor/opencli/dist/constants.d.ts +17 -0
  1289. package/vendor/opencli/dist/constants.js +34 -0
  1290. package/vendor/opencli/dist/daemon.d.ts +21 -0
  1291. package/vendor/opencli/dist/daemon.js +303 -0
  1292. package/vendor/opencli/dist/daemon.test.d.ts +1 -0
  1293. package/vendor/opencli/dist/daemon.test.js +65 -0
  1294. package/vendor/opencli/dist/discovery.d.ts +31 -0
  1295. package/vendor/opencli/dist/discovery.js +330 -0
  1296. package/vendor/opencli/dist/doctor.d.ts +38 -0
  1297. package/vendor/opencli/dist/doctor.js +126 -0
  1298. package/vendor/opencli/dist/doctor.test.d.ts +1 -0
  1299. package/vendor/opencli/dist/doctor.test.js +91 -0
  1300. package/vendor/opencli/dist/download/article-download.d.ts +59 -0
  1301. package/vendor/opencli/dist/download/article-download.js +178 -0
  1302. package/vendor/opencli/dist/download/index.d.ts +71 -0
  1303. package/vendor/opencli/dist/download/index.js +345 -0
  1304. package/vendor/opencli/dist/download/index.test.d.ts +1 -0
  1305. package/vendor/opencli/dist/download/index.test.js +118 -0
  1306. package/vendor/opencli/dist/download/media-download.d.ts +49 -0
  1307. package/vendor/opencli/dist/download/media-download.js +114 -0
  1308. package/vendor/opencli/dist/download/progress.d.ts +36 -0
  1309. package/vendor/opencli/dist/download/progress.js +111 -0
  1310. package/vendor/opencli/dist/electron-apps.d.ts +31 -0
  1311. package/vendor/opencli/dist/electron-apps.js +71 -0
  1312. package/vendor/opencli/dist/electron-apps.test.d.ts +1 -0
  1313. package/vendor/opencli/dist/electron-apps.test.js +43 -0
  1314. package/vendor/opencli/dist/engine.test.d.ts +1 -0
  1315. package/vendor/opencli/dist/engine.test.js +297 -0
  1316. package/vendor/opencli/dist/errors.d.ts +76 -0
  1317. package/vendor/opencli/dist/errors.js +119 -0
  1318. package/vendor/opencli/dist/errors.test.d.ts +1 -0
  1319. package/vendor/opencli/dist/errors.test.js +59 -0
  1320. package/vendor/opencli/dist/execution.d.ts +14 -0
  1321. package/vendor/opencli/dist/execution.js +209 -0
  1322. package/vendor/opencli/dist/execution.test.d.ts +1 -0
  1323. package/vendor/opencli/dist/execution.test.js +40 -0
  1324. package/vendor/opencli/dist/explore.d.ts +101 -0
  1325. package/vendor/opencli/dist/explore.js +379 -0
  1326. package/vendor/opencli/dist/extension-manifest-regression.test.d.ts +1 -0
  1327. package/vendor/opencli/dist/extension-manifest-regression.test.js +13 -0
  1328. package/vendor/opencli/dist/external-clis.yaml +56 -0
  1329. package/vendor/opencli/dist/external.d.ts +40 -0
  1330. package/vendor/opencli/dist/external.js +209 -0
  1331. package/vendor/opencli/dist/external.test.d.ts +1 -0
  1332. package/vendor/opencli/dist/external.test.js +68 -0
  1333. package/vendor/opencli/dist/generate.d.ts +41 -0
  1334. package/vendor/opencli/dist/generate.js +121 -0
  1335. package/vendor/opencli/dist/hooks.d.ts +46 -0
  1336. package/vendor/opencli/dist/hooks.js +58 -0
  1337. package/vendor/opencli/dist/hooks.test.d.ts +4 -0
  1338. package/vendor/opencli/dist/hooks.test.js +92 -0
  1339. package/vendor/opencli/dist/idle-manager.d.ts +19 -0
  1340. package/vendor/opencli/dist/idle-manager.js +54 -0
  1341. package/vendor/opencli/dist/interceptor.d.ts +42 -0
  1342. package/vendor/opencli/dist/interceptor.js +186 -0
  1343. package/vendor/opencli/dist/interceptor.test.d.ts +4 -0
  1344. package/vendor/opencli/dist/interceptor.test.js +81 -0
  1345. package/vendor/opencli/dist/launcher.d.ts +40 -0
  1346. package/vendor/opencli/dist/launcher.js +208 -0
  1347. package/vendor/opencli/dist/launcher.test.d.ts +1 -0
  1348. package/vendor/opencli/dist/launcher.test.js +138 -0
  1349. package/vendor/opencli/dist/logger.d.ts +22 -0
  1350. package/vendor/opencli/dist/logger.js +47 -0
  1351. package/vendor/opencli/dist/main.d.ts +5 -0
  1352. package/vendor/opencli/dist/main.js +60 -0
  1353. package/vendor/opencli/dist/node-network.d.ts +10 -0
  1354. package/vendor/opencli/dist/node-network.js +174 -0
  1355. package/vendor/opencli/dist/node-network.test.d.ts +1 -0
  1356. package/vendor/opencli/dist/node-network.test.js +55 -0
  1357. package/vendor/opencli/dist/output.d.ts +14 -0
  1358. package/vendor/opencli/dist/output.js +147 -0
  1359. package/vendor/opencli/dist/output.test.d.ts +1 -0
  1360. package/vendor/opencli/dist/output.test.js +62 -0
  1361. package/vendor/opencli/dist/pipeline/executor.d.ts +11 -0
  1362. package/vendor/opencli/dist/pipeline/executor.js +93 -0
  1363. package/vendor/opencli/dist/pipeline/executor.test.d.ts +4 -0
  1364. package/vendor/opencli/dist/pipeline/executor.test.js +173 -0
  1365. package/vendor/opencli/dist/pipeline/index.d.ts +5 -0
  1366. package/vendor/opencli/dist/pipeline/index.js +5 -0
  1367. package/vendor/opencli/dist/pipeline/registry.d.ts +19 -0
  1368. package/vendor/opencli/dist/pipeline/registry.js +43 -0
  1369. package/vendor/opencli/dist/pipeline/steps/browser.d.ts +12 -0
  1370. package/vendor/opencli/dist/pipeline/steps/browser.js +76 -0
  1371. package/vendor/opencli/dist/pipeline/steps/download.d.ts +34 -0
  1372. package/vendor/opencli/dist/pipeline/steps/download.js +263 -0
  1373. package/vendor/opencli/dist/pipeline/steps/download.test.d.ts +1 -0
  1374. package/vendor/opencli/dist/pipeline/steps/download.test.js +100 -0
  1375. package/vendor/opencli/dist/pipeline/steps/fetch.d.ts +5 -0
  1376. package/vendor/opencli/dist/pipeline/steps/fetch.js +142 -0
  1377. package/vendor/opencli/dist/pipeline/steps/fetch.test.d.ts +1 -0
  1378. package/vendor/opencli/dist/pipeline/steps/fetch.test.js +123 -0
  1379. package/vendor/opencli/dist/pipeline/steps/intercept.d.ts +5 -0
  1380. package/vendor/opencli/dist/pipeline/steps/intercept.js +50 -0
  1381. package/vendor/opencli/dist/pipeline/steps/tap.d.ts +12 -0
  1382. package/vendor/opencli/dist/pipeline/steps/tap.js +92 -0
  1383. package/vendor/opencli/dist/pipeline/steps/transform.d.ts +9 -0
  1384. package/vendor/opencli/dist/pipeline/steps/transform.js +70 -0
  1385. package/vendor/opencli/dist/pipeline/template.d.ts +16 -0
  1386. package/vendor/opencli/dist/pipeline/template.js +276 -0
  1387. package/vendor/opencli/dist/pipeline/template.test.d.ts +4 -0
  1388. package/vendor/opencli/dist/pipeline/template.test.js +172 -0
  1389. package/vendor/opencli/dist/pipeline/transform.test.d.ts +4 -0
  1390. package/vendor/opencli/dist/pipeline/transform.test.js +119 -0
  1391. package/vendor/opencli/dist/plugin-manifest.d.ts +70 -0
  1392. package/vendor/opencli/dist/plugin-manifest.js +160 -0
  1393. package/vendor/opencli/dist/plugin-manifest.test.d.ts +4 -0
  1394. package/vendor/opencli/dist/plugin-manifest.test.js +179 -0
  1395. package/vendor/opencli/dist/plugin-scaffold.d.ts +28 -0
  1396. package/vendor/opencli/dist/plugin-scaffold.js +142 -0
  1397. package/vendor/opencli/dist/plugin-scaffold.test.d.ts +4 -0
  1398. package/vendor/opencli/dist/plugin-scaffold.test.js +83 -0
  1399. package/vendor/opencli/dist/plugin.d.ts +145 -0
  1400. package/vendor/opencli/dist/plugin.js +1221 -0
  1401. package/vendor/opencli/dist/plugin.test.d.ts +4 -0
  1402. package/vendor/opencli/dist/plugin.test.js +1312 -0
  1403. package/vendor/opencli/dist/record.d.ts +97 -0
  1404. package/vendor/opencli/dist/record.js +694 -0
  1405. package/vendor/opencli/dist/record.test.d.ts +1 -0
  1406. package/vendor/opencli/dist/record.test.js +293 -0
  1407. package/vendor/opencli/dist/registry-api.d.ts +13 -0
  1408. package/vendor/opencli/dist/registry-api.js +10 -0
  1409. package/vendor/opencli/dist/registry.d.ts +81 -0
  1410. package/vendor/opencli/dist/registry.js +78 -0
  1411. package/vendor/opencli/dist/registry.test.d.ts +4 -0
  1412. package/vendor/opencli/dist/registry.test.js +113 -0
  1413. package/vendor/opencli/dist/runtime-detect.d.ts +21 -0
  1414. package/vendor/opencli/dist/runtime-detect.js +32 -0
  1415. package/vendor/opencli/dist/runtime-detect.test.d.ts +1 -0
  1416. package/vendor/opencli/dist/runtime-detect.test.js +27 -0
  1417. package/vendor/opencli/dist/runtime.d.ts +36 -0
  1418. package/vendor/opencli/dist/runtime.js +61 -0
  1419. package/vendor/opencli/dist/scripts/framework.d.ts +4 -0
  1420. package/vendor/opencli/dist/scripts/framework.js +21 -0
  1421. package/vendor/opencli/dist/scripts/interact.d.ts +4 -0
  1422. package/vendor/opencli/dist/scripts/interact.js +20 -0
  1423. package/vendor/opencli/dist/scripts/store.d.ts +9 -0
  1424. package/vendor/opencli/dist/scripts/store.js +44 -0
  1425. package/vendor/opencli/dist/serialization.d.ts +38 -0
  1426. package/vendor/opencli/dist/serialization.js +78 -0
  1427. package/vendor/opencli/dist/serialization.test.d.ts +1 -0
  1428. package/vendor/opencli/dist/serialization.test.js +39 -0
  1429. package/vendor/opencli/dist/snapshotFormatter.d.ts +11 -0
  1430. package/vendor/opencli/dist/snapshotFormatter.js +338 -0
  1431. package/vendor/opencli/dist/snapshotFormatter.test.d.ts +7 -0
  1432. package/vendor/opencli/dist/snapshotFormatter.test.js +521 -0
  1433. package/vendor/opencli/dist/synthesize.d.ts +103 -0
  1434. package/vendor/opencli/dist/synthesize.js +216 -0
  1435. package/vendor/opencli/dist/tui.d.ts +29 -0
  1436. package/vendor/opencli/dist/tui.js +192 -0
  1437. package/vendor/opencli/dist/tui.test.d.ts +1 -0
  1438. package/vendor/opencli/dist/tui.test.js +19 -0
  1439. package/vendor/opencli/dist/types.d.ts +98 -0
  1440. package/vendor/opencli/dist/types.js +7 -0
  1441. package/vendor/opencli/dist/update-check.d.ts +22 -0
  1442. package/vendor/opencli/dist/update-check.js +112 -0
  1443. package/vendor/opencli/dist/utils.d.ts +11 -0
  1444. package/vendor/opencli/dist/utils.js +33 -0
  1445. package/vendor/opencli/dist/validate.d.ts +14 -0
  1446. package/vendor/opencli/dist/validate.js +96 -0
  1447. package/vendor/opencli/dist/verify.d.ts +26 -0
  1448. package/vendor/opencli/dist/verify.js +67 -0
  1449. package/vendor/opencli/dist/version.d.ts +4 -0
  1450. package/vendor/opencli/dist/version.js +16 -0
  1451. package/vendor/opencli/dist/weixin-download.test.d.ts +1 -0
  1452. package/vendor/opencli/dist/weixin-download.test.js +44 -0
  1453. package/vendor/opencli/dist/yaml-schema.d.ts +29 -0
  1454. package/vendor/opencli/dist/yaml-schema.js +22 -0
@@ -0,0 +1,1647 @@
1
+ import * as fs from 'node:fs';
2
+ import * as os from 'node:os';
3
+ import * as path from 'node:path';
4
+ import { afterAll, afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
5
+ import { AuthRequiredError, CommandExecutionError } from '../../errors.js';
6
+ import { getRegistry } from '../../registry.js';
7
+ import * as privatePublish from './_shared/private-publish.js';
8
+ import { buildClickActionJs, buildEnsureComposerOpenJs, buildInspectUploadStageJs, buildPublishStatusProbeJs } from './post.js';
9
+ import './post.js';
10
+ const tempDirs = [];
11
+ function createTempImage(name = 'demo.jpg', bytes = Buffer.from([0xff, 0xd8, 0xff, 0xd9])) {
12
+ const dir = fs.mkdtempSync(path.join(os.tmpdir(), 'opencli-instagram-post-'));
13
+ tempDirs.push(dir);
14
+ const filePath = path.join(dir, name);
15
+ fs.writeFileSync(filePath, bytes);
16
+ return filePath;
17
+ }
18
+ function createTempVideo(name = 'demo.mp4', bytes = Buffer.from('video')) {
19
+ const dir = fs.mkdtempSync(path.join(os.tmpdir(), 'opencli-instagram-post-video-'));
20
+ tempDirs.push(dir);
21
+ const filePath = path.join(dir, name);
22
+ fs.writeFileSync(filePath, bytes);
23
+ return filePath;
24
+ }
25
+ function withInitialDialogDismiss(results) {
26
+ return [{ ok: false }, ...results];
27
+ }
28
+ function createPageMock(evaluateResults, overrides = {}) {
29
+ const evaluate = vi.fn();
30
+ for (const result of evaluateResults) {
31
+ evaluate.mockResolvedValueOnce(result);
32
+ }
33
+ return {
34
+ goto: vi.fn().mockResolvedValue(undefined),
35
+ evaluate,
36
+ getCookies: vi.fn().mockResolvedValue([]),
37
+ snapshot: vi.fn().mockResolvedValue(undefined),
38
+ click: vi.fn().mockResolvedValue(undefined),
39
+ typeText: vi.fn().mockResolvedValue(undefined),
40
+ pressKey: vi.fn().mockResolvedValue(undefined),
41
+ scrollTo: vi.fn().mockResolvedValue(undefined),
42
+ getFormState: vi.fn().mockResolvedValue({ forms: [], orphanFields: [] }),
43
+ wait: vi.fn().mockResolvedValue(undefined),
44
+ tabs: vi.fn().mockResolvedValue([]),
45
+ closeTab: vi.fn().mockResolvedValue(undefined),
46
+ newTab: vi.fn().mockResolvedValue(undefined),
47
+ selectTab: vi.fn().mockResolvedValue(undefined),
48
+ networkRequests: vi.fn().mockResolvedValue([]),
49
+ consoleMessages: vi.fn().mockResolvedValue([]),
50
+ scroll: vi.fn().mockResolvedValue(undefined),
51
+ autoScroll: vi.fn().mockResolvedValue(undefined),
52
+ installInterceptor: vi.fn().mockResolvedValue(undefined),
53
+ getInterceptedRequests: vi.fn().mockResolvedValue([]),
54
+ waitForCapture: vi.fn().mockResolvedValue(undefined),
55
+ screenshot: vi.fn().mockResolvedValue(''),
56
+ setFileInput: vi.fn().mockResolvedValue(undefined),
57
+ insertText: undefined,
58
+ getCurrentUrl: vi.fn().mockResolvedValue(null),
59
+ ...overrides,
60
+ };
61
+ }
62
+ afterAll(() => {
63
+ for (const dir of tempDirs) {
64
+ fs.rmSync(dir, { recursive: true, force: true });
65
+ }
66
+ delete process.env.OPENCLI_INSTAGRAM_CAPTURE;
67
+ });
68
+ describe('instagram auth detection', () => {
69
+ it('does not treat generic homepage text containing "log in" as an auth failure', () => {
70
+ const globalState = globalThis;
71
+ const originalDocument = globalState.document;
72
+ const originalWindow = globalState.window;
73
+ globalState.document = {
74
+ body: { innerText: 'Suggested for you Log in to see more content' },
75
+ querySelector: () => null,
76
+ querySelectorAll: () => [],
77
+ };
78
+ globalState.window = { location: { pathname: '/' } };
79
+ try {
80
+ expect(eval(buildEnsureComposerOpenJs())).toEqual({ ok: true });
81
+ }
82
+ finally {
83
+ globalState.document = originalDocument;
84
+ globalState.window = originalWindow;
85
+ }
86
+ });
87
+ });
88
+ describe('instagram publish status detection', () => {
89
+ it('does not treat unrelated page text as share failure while the sharing dialog is still visible', () => {
90
+ const globalState = globalThis;
91
+ class MockHTMLElement {
92
+ }
93
+ const visibleDialog = new MockHTMLElement();
94
+ visibleDialog.textContent = 'Sharing';
95
+ visibleDialog.querySelector = () => null;
96
+ visibleDialog.getBoundingClientRect = () => ({ width: 100, height: 100 });
97
+ const originalDocument = globalState.document;
98
+ const originalWindow = globalState.window;
99
+ const originalHTMLElement = globalState.HTMLElement;
100
+ globalState.HTMLElement = MockHTMLElement;
101
+ globalState.document = {
102
+ querySelectorAll: (selector) => selector === '[role="dialog"]' ? [visibleDialog] : [],
103
+ };
104
+ globalState.window = {
105
+ location: { href: 'https://www.instagram.com/' },
106
+ getComputedStyle: () => ({ display: 'block', visibility: 'visible' }),
107
+ };
108
+ try {
109
+ expect(eval(buildPublishStatusProbeJs())).toEqual({
110
+ ok: false,
111
+ failed: false,
112
+ settled: false,
113
+ url: '',
114
+ });
115
+ }
116
+ finally {
117
+ globalState.document = originalDocument;
118
+ globalState.window = originalWindow;
119
+ globalState.HTMLElement = originalHTMLElement;
120
+ }
121
+ });
122
+ it('does not treat a stale visible error dialog as share failure while sharing is still in progress', () => {
123
+ const globalState = globalThis;
124
+ class MockHTMLElement {
125
+ }
126
+ const sharingDialog = new MockHTMLElement();
127
+ sharingDialog.textContent = 'Sharing';
128
+ sharingDialog.querySelector = () => null;
129
+ sharingDialog.getBoundingClientRect = () => ({ width: 100, height: 100 });
130
+ const staleErrorDialog = new MockHTMLElement();
131
+ staleErrorDialog.textContent = 'Something went wrong. Please try again. Try again';
132
+ staleErrorDialog.querySelector = () => null;
133
+ staleErrorDialog.getBoundingClientRect = () => ({ width: 100, height: 100 });
134
+ const originalDocument = globalState.document;
135
+ const originalWindow = globalState.window;
136
+ const originalHTMLElement = globalState.HTMLElement;
137
+ globalState.HTMLElement = MockHTMLElement;
138
+ globalState.document = {
139
+ querySelectorAll: (selector) => selector === '[role="dialog"]' ? [sharingDialog, staleErrorDialog] : [],
140
+ };
141
+ globalState.window = {
142
+ location: { href: 'https://www.instagram.com/' },
143
+ getComputedStyle: () => ({ display: 'block', visibility: 'visible' }),
144
+ };
145
+ try {
146
+ expect(eval(buildPublishStatusProbeJs())).toEqual({
147
+ ok: false,
148
+ failed: false,
149
+ settled: false,
150
+ url: '',
151
+ });
152
+ }
153
+ finally {
154
+ globalState.document = originalDocument;
155
+ globalState.window = originalWindow;
156
+ globalState.HTMLElement = originalHTMLElement;
157
+ }
158
+ });
159
+ it('prefers explicit post-shared success over stale visible error text', () => {
160
+ const globalState = globalThis;
161
+ class MockHTMLElement {
162
+ }
163
+ const sharedDialog = new MockHTMLElement();
164
+ sharedDialog.textContent = 'Post shared Your post has been shared.';
165
+ sharedDialog.querySelector = () => null;
166
+ sharedDialog.getBoundingClientRect = () => ({ width: 100, height: 100 });
167
+ const staleErrorDialog = new MockHTMLElement();
168
+ staleErrorDialog.textContent = 'Something went wrong. Please try again. Try again';
169
+ staleErrorDialog.querySelector = () => null;
170
+ staleErrorDialog.getBoundingClientRect = () => ({ width: 100, height: 100 });
171
+ const originalDocument = globalState.document;
172
+ const originalWindow = globalState.window;
173
+ const originalHTMLElement = globalState.HTMLElement;
174
+ globalState.HTMLElement = MockHTMLElement;
175
+ globalState.document = {
176
+ querySelectorAll: (selector) => selector === '[role="dialog"]' ? [sharedDialog, staleErrorDialog] : [],
177
+ };
178
+ globalState.window = {
179
+ location: { href: 'https://www.instagram.com/' },
180
+ getComputedStyle: () => ({ display: 'block', visibility: 'visible' }),
181
+ };
182
+ try {
183
+ expect(eval(buildPublishStatusProbeJs())).toEqual({
184
+ ok: true,
185
+ failed: false,
186
+ settled: false,
187
+ url: '',
188
+ });
189
+ }
190
+ finally {
191
+ globalState.document = originalDocument;
192
+ globalState.window = originalWindow;
193
+ globalState.HTMLElement = originalHTMLElement;
194
+ }
195
+ });
196
+ });
197
+ describe('instagram click action detection', () => {
198
+ it('matches aria-label-only Next buttons in the media dialog', () => {
199
+ const globalState = globalThis;
200
+ class MockHTMLElement {
201
+ textContent = '';
202
+ ariaLabel = '';
203
+ clicked = false;
204
+ querySelectorAll = (_selector) => [];
205
+ querySelector = (_selector) => null;
206
+ getAttribute(name) {
207
+ if (name === 'aria-label')
208
+ return this.ariaLabel || null;
209
+ return null;
210
+ }
211
+ getBoundingClientRect() {
212
+ return { width: 100, height: 40 };
213
+ }
214
+ click() {
215
+ this.clicked = true;
216
+ }
217
+ }
218
+ const nextButton = new MockHTMLElement();
219
+ nextButton.ariaLabel = 'Next';
220
+ const dialog = new MockHTMLElement();
221
+ dialog.textContent = 'Crop Back Select crop Open media gallery';
222
+ dialog.querySelector = (selector) => selector === 'input[type="file"]' ? {} : null;
223
+ dialog.querySelectorAll = (selector) => selector === 'button, div[role="button"]' ? [nextButton] : [];
224
+ const body = new MockHTMLElement();
225
+ const originalDocument = globalState.document;
226
+ const originalWindow = globalState.window;
227
+ const originalHTMLElement = globalState.HTMLElement;
228
+ globalState.HTMLElement = MockHTMLElement;
229
+ globalState.document = {
230
+ body,
231
+ querySelectorAll: (selector) => selector === '[role="dialog"]' ? [dialog] : [],
232
+ };
233
+ globalState.window = {
234
+ getComputedStyle: () => ({ display: 'block', visibility: 'visible' }),
235
+ };
236
+ try {
237
+ expect(eval(buildClickActionJs(['Next', '下一步'], 'media'))).toEqual({
238
+ ok: true,
239
+ label: 'Next',
240
+ });
241
+ expect(nextButton.clicked).toBe(true);
242
+ }
243
+ finally {
244
+ globalState.document = originalDocument;
245
+ globalState.window = originalWindow;
246
+ globalState.HTMLElement = originalHTMLElement;
247
+ }
248
+ });
249
+ it('does not click a body-level Next button when media scope has no matching dialog controls', () => {
250
+ const globalState = globalThis;
251
+ class MockHTMLElement {
252
+ textContent = '';
253
+ ariaLabel = '';
254
+ clicked = false;
255
+ children = [];
256
+ querySelectorAll = (_selector) => this.children;
257
+ querySelector = (_selector) => null;
258
+ getAttribute(name) {
259
+ if (name === 'aria-label')
260
+ return this.ariaLabel || null;
261
+ return null;
262
+ }
263
+ getBoundingClientRect() {
264
+ return { width: 100, height: 40 };
265
+ }
266
+ click() {
267
+ this.clicked = true;
268
+ }
269
+ }
270
+ const bodyNext = new MockHTMLElement();
271
+ bodyNext.ariaLabel = 'Next';
272
+ const errorDialog = new MockHTMLElement();
273
+ errorDialog.textContent = 'Something went wrong Try again';
274
+ errorDialog.children = [];
275
+ const body = new MockHTMLElement();
276
+ body.children = [bodyNext];
277
+ const originalDocument = globalState.document;
278
+ const originalWindow = globalState.window;
279
+ const originalHTMLElement = globalState.HTMLElement;
280
+ globalState.HTMLElement = MockHTMLElement;
281
+ globalState.document = {
282
+ body,
283
+ querySelectorAll: (selector) => selector === '[role="dialog"]' ? [errorDialog] : [],
284
+ };
285
+ globalState.window = {
286
+ getComputedStyle: () => ({ display: 'block', visibility: 'visible' }),
287
+ };
288
+ try {
289
+ expect(eval(buildClickActionJs(['Next', '下一步'], 'media'))).toEqual({ ok: false });
290
+ expect(bodyNext.clicked).toBe(false);
291
+ }
292
+ finally {
293
+ globalState.document = originalDocument;
294
+ globalState.window = originalWindow;
295
+ globalState.HTMLElement = originalHTMLElement;
296
+ }
297
+ });
298
+ });
299
+ describe('instagram upload stage detection', () => {
300
+ it('does not treat a body-level Next button as upload preview when the visible dialog is an error', () => {
301
+ const globalState = globalThis;
302
+ class MockHTMLElement {
303
+ textContent = '';
304
+ ariaLabel = '';
305
+ children = [];
306
+ querySelectorAll = (_selector) => this.children;
307
+ querySelector = (_selector) => null;
308
+ getAttribute(name) {
309
+ if (name === 'aria-label')
310
+ return this.ariaLabel || null;
311
+ return null;
312
+ }
313
+ getBoundingClientRect() {
314
+ return { width: 100, height: 40 };
315
+ }
316
+ }
317
+ const bodyNext = new MockHTMLElement();
318
+ bodyNext.ariaLabel = 'Next';
319
+ const errorDialog = new MockHTMLElement();
320
+ errorDialog.textContent = 'Something went wrong. Please try again. Try again';
321
+ const body = new MockHTMLElement();
322
+ body.children = [bodyNext];
323
+ const originalDocument = globalState.document;
324
+ const originalWindow = globalState.window;
325
+ const originalHTMLElement = globalState.HTMLElement;
326
+ globalState.HTMLElement = MockHTMLElement;
327
+ globalState.document = {
328
+ body,
329
+ querySelectorAll: (selector) => {
330
+ if (selector === '[role="dialog"]')
331
+ return [errorDialog];
332
+ return [];
333
+ },
334
+ };
335
+ globalState.window = {
336
+ getComputedStyle: () => ({ display: 'block', visibility: 'visible' }),
337
+ };
338
+ try {
339
+ expect(eval(buildInspectUploadStageJs())).toEqual({
340
+ state: 'failed',
341
+ detail: 'Something went wrong. Please try again. Try again',
342
+ });
343
+ }
344
+ finally {
345
+ globalState.document = originalDocument;
346
+ globalState.window = originalWindow;
347
+ globalState.HTMLElement = originalHTMLElement;
348
+ }
349
+ });
350
+ });
351
+ describe('instagram post registration', () => {
352
+ beforeEach(() => {
353
+ vi.spyOn(privatePublish, 'resolveInstagramPrivatePublishConfig').mockResolvedValue({
354
+ apiContext: {
355
+ asbdId: '',
356
+ csrfToken: 'csrf-token',
357
+ igAppId: '936619743392459',
358
+ igWwwClaim: '',
359
+ instagramAjax: '1036523242',
360
+ webSessionId: '',
361
+ },
362
+ jazoest: '22047',
363
+ });
364
+ vi.spyOn(privatePublish, 'publishImagesViaPrivateApi').mockRejectedValue(new CommandExecutionError('Instagram private publish configure failed: 400 {"message":"fallback to ui"}'));
365
+ });
366
+ afterEach(() => {
367
+ vi.restoreAllMocks();
368
+ });
369
+ it('registers the post command with a required-value media arg', () => {
370
+ const cmd = getRegistry().get('instagram/post');
371
+ expect(cmd).toBeDefined();
372
+ expect(cmd?.browser).toBe(true);
373
+ expect(cmd?.timeoutSeconds).toBe(300);
374
+ expect(cmd?.args.some((arg) => arg.name === 'media' && !arg.required && arg.valueRequired)).toBe(true);
375
+ expect(cmd?.args.some((arg) => arg.name === 'content' && !arg.required && arg.positional)).toBe(true);
376
+ });
377
+ it('prefers the private route by default and returns without touching UI upload steps when private publish succeeds', async () => {
378
+ const imagePath = createTempImage('private-default.jpg');
379
+ const privateSpy = vi.spyOn(privatePublish, 'publishImagesViaPrivateApi').mockResolvedValueOnce({
380
+ code: 'PRIVATEDEFAULT123',
381
+ uploadIds: ['111'],
382
+ });
383
+ const evaluate = vi.fn(async (js) => {
384
+ if (js.includes('sharing') && js.includes('create new post'))
385
+ return { ok: false };
386
+ if (js.includes('window.location?.pathname'))
387
+ return { ok: true };
388
+ if (js.includes('const data = Array.isArray(window[') && js.includes('__opencli_ig_protocol_capture'))
389
+ return { data: [], errors: [] };
390
+ return { ok: true };
391
+ });
392
+ const page = createPageMock([], {
393
+ evaluate,
394
+ getCookies: vi.fn().mockResolvedValue([{ name: 'csrftoken', value: 'csrf-token', domain: 'instagram.com' }]),
395
+ });
396
+ const cmd = getRegistry().get('instagram/post');
397
+ const result = await cmd.func(page, { media: imagePath, content: 'private default' });
398
+ expect(privateSpy).toHaveBeenCalledTimes(1);
399
+ expect(page.setFileInput).not.toHaveBeenCalled();
400
+ expect(result).toEqual([
401
+ {
402
+ status: '✅ Posted',
403
+ detail: 'Single image post shared successfully',
404
+ url: 'https://www.instagram.com/p/PRIVATEDEFAULT123/',
405
+ },
406
+ ]);
407
+ privateSpy.mockRestore();
408
+ });
409
+ it('falls back to the UI route when the default private route fails safely before publishing', async () => {
410
+ const imagePath = createTempImage('private-fallback-ui.jpg');
411
+ const privateSpy = vi.spyOn(privatePublish, 'publishImagesViaPrivateApi').mockRejectedValueOnce(new CommandExecutionError('Instagram private publish configure_sidecar failed: 400 {"message":"Uploaded image is invalid"}'));
412
+ const evaluate = vi.fn(async (js) => {
413
+ if (js.includes('sharing') && js.includes('create new post'))
414
+ return { ok: false };
415
+ if (js.includes('window.location?.pathname'))
416
+ return { ok: true };
417
+ if (js.includes('data-opencli-ig-upload-index'))
418
+ return { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] };
419
+ if (js.includes("dispatchEvent(new Event('input'"))
420
+ return { ok: true };
421
+ if (js.includes('const hasPreviewUi ='))
422
+ return { ok: true, state: 'preview' };
423
+ if (js.includes("scope === 'media'"))
424
+ return { ok: true, label: 'Next' };
425
+ if (js.includes("scope === 'caption'"))
426
+ return { ok: true, label: 'Share' };
427
+ if (js.includes('post shared') && js.includes('your post has been shared'))
428
+ return { ok: true, url: 'https://www.instagram.com/p/PRIVATEFALLBACK123/' };
429
+ return { ok: true };
430
+ });
431
+ const page = createPageMock([], {
432
+ evaluate,
433
+ getCookies: vi.fn().mockResolvedValue([{ name: 'csrftoken', value: 'csrf-token', domain: 'instagram.com' }]),
434
+ });
435
+ const cmd = getRegistry().get('instagram/post');
436
+ const result = await cmd.func(page, { media: imagePath, content: 'private fallback' });
437
+ expect(privateSpy).toHaveBeenCalledTimes(1);
438
+ expect(page.setFileInput).toHaveBeenCalledWith([imagePath], '[data-opencli-ig-upload-index="0"]');
439
+ expect(result).toEqual([
440
+ {
441
+ status: '✅ Posted',
442
+ detail: 'Single image post shared successfully',
443
+ url: 'https://www.instagram.com/p/PRIVATEFALLBACK123/',
444
+ },
445
+ ]);
446
+ privateSpy.mockRestore();
447
+ });
448
+ it('falls back to the UI route for mixed-media posts when the private route fails safely before publishing', async () => {
449
+ const imagePath = createTempImage('mixed-fallback-image.jpg');
450
+ const videoPath = createTempVideo('mixed-fallback-video.mp4');
451
+ const privateSpy = vi.spyOn(privatePublish, 'publishMediaViaPrivateApi').mockRejectedValueOnce(new CommandExecutionError('Instagram private publish configure_sidecar failed: 400 {"message":"fallback to ui"}'));
452
+ const evaluate = vi.fn(async (js) => {
453
+ if (js.includes('sharing') && js.includes('create new post'))
454
+ return { ok: false };
455
+ if (js.includes('window.location?.pathname'))
456
+ return { ok: true };
457
+ if (js.includes('data-opencli-ig-upload-index'))
458
+ return { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] };
459
+ if (js.includes("dispatchEvent(new Event('input'"))
460
+ return { ok: true };
461
+ if (js.includes('const hasPreviewUi ='))
462
+ return { ok: true, state: 'preview' };
463
+ if (js.includes("scope === 'media'"))
464
+ return { ok: true, label: 'Next' };
465
+ if (js.includes("scope === 'caption'"))
466
+ return { ok: true, label: 'Share' };
467
+ if (js.includes('post shared') && js.includes('your post has been shared'))
468
+ return { ok: true, url: 'https://www.instagram.com/p/MIXEDFALLBACK123/' };
469
+ return { ok: true };
470
+ });
471
+ const page = createPageMock([], {
472
+ evaluate,
473
+ getCookies: vi.fn().mockResolvedValue([{ name: 'csrftoken', value: 'csrf-token', domain: 'instagram.com' }]),
474
+ });
475
+ const cmd = getRegistry().get('instagram/post');
476
+ const result = await cmd.func(page, {
477
+ media: `${imagePath},${videoPath}`,
478
+ content: 'mixed ui fallback',
479
+ });
480
+ expect(privateSpy).toHaveBeenCalledTimes(1);
481
+ expect(page.setFileInput).toHaveBeenCalledWith([imagePath, videoPath], '[data-opencli-ig-upload-index="0"]');
482
+ expect(result).toEqual([
483
+ {
484
+ status: '✅ Posted',
485
+ detail: '2-item mixed-media carousel post shared successfully',
486
+ url: 'https://www.instagram.com/p/MIXEDFALLBACK123/',
487
+ },
488
+ ]);
489
+ privateSpy.mockRestore();
490
+ });
491
+ it('prefers the private route by default for mixed-media posts and preserves input order', async () => {
492
+ const imagePath = createTempImage('mixed-default.jpg');
493
+ const videoPath = createTempVideo('mixed-default.mp4');
494
+ const privateSpy = vi.spyOn(privatePublish, 'publishMediaViaPrivateApi').mockResolvedValueOnce({
495
+ code: 'MIXEDPRIVATE123',
496
+ uploadIds: ['111', '222'],
497
+ });
498
+ const page = createPageMock([], {
499
+ evaluate: vi.fn(async () => ({ ok: true })),
500
+ getCookies: vi.fn().mockResolvedValue([{ name: 'csrftoken', value: 'csrf-token', domain: 'instagram.com' }]),
501
+ });
502
+ const cmd = getRegistry().get('instagram/post');
503
+ const result = await cmd.func(page, {
504
+ media: `${imagePath},${videoPath}`,
505
+ content: 'mixed private default',
506
+ });
507
+ expect(privateSpy).toHaveBeenCalledWith(expect.objectContaining({
508
+ mediaItems: [
509
+ { type: 'image', filePath: imagePath },
510
+ { type: 'video', filePath: videoPath },
511
+ ],
512
+ caption: 'mixed private default',
513
+ }));
514
+ expect(page.setFileInput).not.toHaveBeenCalled();
515
+ expect(result).toEqual([
516
+ {
517
+ status: '✅ Posted',
518
+ detail: '2-item mixed-media carousel post shared successfully',
519
+ url: 'https://www.instagram.com/p/MIXEDPRIVATE123/',
520
+ },
521
+ ]);
522
+ privateSpy.mockRestore();
523
+ });
524
+ it('rejects missing --media before browser work', async () => {
525
+ const page = createPageMock([]);
526
+ const cmd = getRegistry().get('instagram/post');
527
+ await expect(cmd.func(page, {
528
+ content: 'missing media',
529
+ })).rejects.toThrow('Argument "media" is required.');
530
+ });
531
+ it('rejects empty or invalid --media inputs', async () => {
532
+ const imagePath = createTempImage('invalid-media-image.jpg');
533
+ const page = createPageMock([]);
534
+ const cmd = getRegistry().get('instagram/post');
535
+ await expect(cmd.func(page, {
536
+ media: '',
537
+ })).rejects.toThrow('Argument "media" is required.');
538
+ await expect(cmd.func(page, {
539
+ media: `${imagePath},/tmp/does-not-exist.mp4`,
540
+ })).rejects.toThrow('Media file not found');
541
+ });
542
+ it('uploads a single image, fills caption, and shares the post', async () => {
543
+ const imagePath = createTempImage();
544
+ const page = createPageMock(withInitialDialogDismiss([
545
+ { ok: true },
546
+ { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] },
547
+ { ok: true },
548
+ { ok: true },
549
+ { ok: false },
550
+ { ok: true, label: 'Next' },
551
+ { ok: true },
552
+ { ok: true },
553
+ { ok: true },
554
+ { ok: true, label: 'Share' },
555
+ { ok: true, url: 'https://www.instagram.com/p/ABC123xyz/' },
556
+ ]));
557
+ const cmd = getRegistry().get('instagram/post');
558
+ const result = await cmd.func(page, {
559
+ media: imagePath,
560
+ content: 'hello from opencli',
561
+ });
562
+ expect(page.goto).toHaveBeenCalledWith('https://www.instagram.com/');
563
+ expect(page.setFileInput).toHaveBeenCalledWith([imagePath], '[data-opencli-ig-upload-index="0"]');
564
+ expect(page.evaluate.mock.calls.some((args) => String(args[0]).includes("dispatchEvent(new Event('change'"))).toBe(true);
565
+ expect(result).toEqual([
566
+ {
567
+ status: '✅ Posted',
568
+ detail: 'Single image post shared successfully',
569
+ url: 'https://www.instagram.com/p/ABC123xyz/',
570
+ },
571
+ ]);
572
+ });
573
+ it('uploads multiple images as a carousel and shares the post', async () => {
574
+ const firstImagePath = createTempImage('carousel-1.jpg');
575
+ const secondImagePath = createTempImage('carousel-2.jpg');
576
+ const page = createPageMock(withInitialDialogDismiss([
577
+ { ok: true },
578
+ { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] },
579
+ { ok: true },
580
+ { ok: true },
581
+ { ok: false },
582
+ { ok: true, label: 'Next' },
583
+ { ok: true },
584
+ { ok: true },
585
+ { ok: true },
586
+ { ok: true, label: 'Share' },
587
+ { ok: true, url: 'https://www.instagram.com/p/CAROUSEL123/' },
588
+ ]));
589
+ const cmd = getRegistry().get('instagram/post');
590
+ const result = await cmd.func(page, {
591
+ media: `${firstImagePath},${secondImagePath}`,
592
+ content: 'hello carousel',
593
+ });
594
+ expect(page.setFileInput).toHaveBeenCalledWith([firstImagePath, secondImagePath], '[data-opencli-ig-upload-index="0"]');
595
+ expect(result).toEqual([
596
+ {
597
+ status: '✅ Posted',
598
+ detail: '2-image carousel post shared successfully',
599
+ url: 'https://www.instagram.com/p/CAROUSEL123/',
600
+ },
601
+ ]);
602
+ });
603
+ it('installs and dumps protocol capture when OPENCLI_INSTAGRAM_CAPTURE is enabled', async () => {
604
+ process.env.OPENCLI_INSTAGRAM_CAPTURE = '1';
605
+ const imagePath = createTempImage('capture-enabled.jpg');
606
+ const evaluate = vi.fn(async (js) => {
607
+ if (js.includes('__opencli_ig_protocol_capture') && js.includes('PATCH_GUARD'))
608
+ return { ok: true };
609
+ if (js.includes('const data = Array.isArray(window[') && js.includes('__opencli_ig_protocol_capture')) {
610
+ return { data: [], errors: [] };
611
+ }
612
+ if (js.includes('sharing') && js.includes('create new post'))
613
+ return { ok: false };
614
+ if (js.includes('window.location?.pathname'))
615
+ return { ok: true };
616
+ if (js.includes('data-opencli-ig-upload-index'))
617
+ return { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] };
618
+ if (js.includes("dispatchEvent(new Event('input'"))
619
+ return { ok: true };
620
+ if (js.includes('const hasPreviewUi ='))
621
+ return { ok: true, state: 'preview' };
622
+ if (js.includes("scope === 'media'"))
623
+ return { ok: true, label: 'Next' };
624
+ if (js.includes("scope === 'caption'"))
625
+ return { ok: true, label: 'Share' };
626
+ if (js.includes('post shared') && js.includes('your post has been shared'))
627
+ return { ok: true, url: 'https://www.instagram.com/p/CAPTURE123/' };
628
+ return { ok: true };
629
+ });
630
+ const page = createPageMock([], { evaluate });
631
+ const cmd = getRegistry().get('instagram/post');
632
+ const result = await cmd.func(page, {
633
+ media: imagePath,
634
+ content: 'capture enabled',
635
+ });
636
+ const evaluateCalls = evaluate.mock.calls.map((args) => String(args[0]));
637
+ expect(evaluateCalls.some((js) => js.includes('__opencli_ig_protocol_capture') && js.includes('PATCH_GUARD'))).toBe(true);
638
+ expect(evaluateCalls.some((js) => js.includes('const data = Array.isArray(window[') && js.includes('__opencli_ig_protocol_capture'))).toBe(true);
639
+ expect(result).toEqual([
640
+ {
641
+ status: '✅ Posted',
642
+ detail: 'Single image post shared successfully',
643
+ url: 'https://www.instagram.com/p/CAPTURE123/',
644
+ },
645
+ ]);
646
+ delete process.env.OPENCLI_INSTAGRAM_CAPTURE;
647
+ });
648
+ it('retries media Next when preview is visible before the button becomes clickable', async () => {
649
+ const firstImagePath = createTempImage('carousel-delay-1.jpg');
650
+ const secondImagePath = createTempImage('carousel-delay-2.jpg');
651
+ let nextAttempts = 0;
652
+ const evaluate = vi.fn(async (js) => {
653
+ if (js.includes('sharing') && js.includes('create new post'))
654
+ return { ok: false };
655
+ if (js.includes('window.location?.pathname'))
656
+ return { ok: true };
657
+ if (js.includes('data-opencli-ig-upload-index'))
658
+ return { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] };
659
+ if (js.includes("dispatchEvent(new Event('input'"))
660
+ return { ok: true };
661
+ if (js.includes('const hasVisibleButtonInDialogs'))
662
+ return { state: 'preview', detail: 'Crop Back Next Select crop' };
663
+ if (js.includes("dialogText.includes('write a caption')") || js.includes("const editable = document.querySelector('textarea, [contenteditable=\"true\"]');")) {
664
+ return { ok: nextAttempts >= 2 };
665
+ }
666
+ if (js.includes("!labels.includes(text) && !labels.includes(aria)")) {
667
+ nextAttempts += 1;
668
+ if (nextAttempts === 1)
669
+ return { ok: false };
670
+ return { ok: true, label: 'Next' };
671
+ }
672
+ if (js.includes('ClipboardEvent') && js.includes('textarea'))
673
+ return { ok: true, mode: 'textarea' };
674
+ if (js.includes('readLexicalText'))
675
+ return { ok: true };
676
+ if (js.includes('post shared') && js.includes('your post has been shared'))
677
+ return { ok: true, url: 'https://www.instagram.com/p/CAROUSELRETRY123/' };
678
+ return { ok: true };
679
+ });
680
+ const page = createPageMock([], { evaluate });
681
+ const cmd = getRegistry().get('instagram/post');
682
+ const result = await cmd.func(page, {
683
+ media: `${firstImagePath},${secondImagePath}`,
684
+ content: 'hello delayed carousel',
685
+ });
686
+ expect(result).toEqual([
687
+ {
688
+ status: '✅ Posted',
689
+ detail: '2-image carousel post shared successfully',
690
+ url: 'https://www.instagram.com/p/CAROUSELRETRY123/',
691
+ },
692
+ ]);
693
+ });
694
+ it('retries the whole carousel flow when preview briefly appears and then degrades into an upload error before Next is usable', async () => {
695
+ const firstImagePath = createTempImage('carousel-race-1.jpg');
696
+ const secondImagePath = createTempImage('carousel-race-2.jpg');
697
+ let composerRuns = 0;
698
+ let uploadStageChecks = 0;
699
+ let secondAttemptAdvanced = false;
700
+ const evaluate = vi.fn(async (js) => {
701
+ if (js.includes('sharing') && js.includes('create new post'))
702
+ return { ok: false };
703
+ if (js.includes('window.location?.pathname')) {
704
+ composerRuns += 1;
705
+ return { ok: true };
706
+ }
707
+ if (js.includes('data-opencli-ig-upload-index'))
708
+ return { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] };
709
+ if (js.includes("dispatchEvent(new Event('input'"))
710
+ return { ok: true };
711
+ if (js.includes('const hasVisibleButtonInDialogs')) {
712
+ uploadStageChecks += 1;
713
+ if (composerRuns === 1 && uploadStageChecks === 1) {
714
+ return { state: 'preview', detail: 'Crop Back Next Select crop' };
715
+ }
716
+ if (composerRuns === 1) {
717
+ return { state: 'failed', detail: 'Something went wrong. Please try again.' };
718
+ }
719
+ return { state: 'preview', detail: 'Crop Back Next Select crop' };
720
+ }
721
+ if (js.includes("dialogText.includes('write a caption')") || js.includes("const editable = document.querySelector('textarea, [contenteditable=\"true\"]');")) {
722
+ return { ok: composerRuns >= 2 && secondAttemptAdvanced };
723
+ }
724
+ if (js.includes("!labels.includes(text) && !labels.includes(aria)")) {
725
+ if (composerRuns === 1)
726
+ return { ok: false };
727
+ secondAttemptAdvanced = true;
728
+ return { ok: true, label: 'Next' };
729
+ }
730
+ if (js.includes('button[aria-label="Close"]'))
731
+ return { ok: true };
732
+ if (js.includes('ClipboardEvent') && js.includes('textarea'))
733
+ return { ok: true, mode: 'textarea' };
734
+ if (js.includes('readLexicalText'))
735
+ return { ok: true };
736
+ if (js.includes('post shared') && js.includes('your post has been shared'))
737
+ return { ok: true, url: 'https://www.instagram.com/p/CAROUSELFRESH123/' };
738
+ return { ok: true };
739
+ });
740
+ const page = createPageMock([], { evaluate });
741
+ const cmd = getRegistry().get('instagram/post');
742
+ const result = await cmd.func(page, {
743
+ media: `${firstImagePath},${secondImagePath}`,
744
+ content: 'hello recovered carousel',
745
+ });
746
+ expect(result).toEqual([
747
+ {
748
+ status: '✅ Posted',
749
+ detail: '2-image carousel post shared successfully',
750
+ url: 'https://www.instagram.com/p/CAROUSELFRESH123/',
751
+ },
752
+ ]);
753
+ });
754
+ it('uploads a single image and shares it without a caption when content is omitted', async () => {
755
+ const imagePath = createTempImage('no-caption.jpg');
756
+ const evaluate = vi.fn(async (js) => {
757
+ if (js.includes('sharing') && js.includes('create new post'))
758
+ return { ok: false };
759
+ if (js.includes('window.location?.pathname'))
760
+ return { ok: true };
761
+ if (js.includes('data-opencli-ig-upload-index'))
762
+ return { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] };
763
+ if (js.includes("dispatchEvent(new Event('input'"))
764
+ return { ok: true };
765
+ if (js.includes('const hasPreviewUi ='))
766
+ return { ok: true, state: 'preview' };
767
+ if (js.includes("scope === 'media'"))
768
+ return { ok: true, label: 'Next' };
769
+ if (js.includes("scope === 'caption'"))
770
+ return { ok: true, label: 'Share' };
771
+ if (js.includes('const editable = document.querySelector(\'textarea, [contenteditable="true"]\');'))
772
+ return { ok: true };
773
+ if (js.includes('post shared') && js.includes('your post has been shared'))
774
+ return { ok: true, url: 'https://www.instagram.com/p/NOCAPTION123/' };
775
+ return { ok: false };
776
+ });
777
+ const page = createPageMock([], { evaluate });
778
+ const cmd = getRegistry().get('instagram/post');
779
+ const result = await cmd.func(page, {
780
+ media: imagePath,
781
+ });
782
+ const evaluateCalls = page.evaluate.mock.calls.map((args) => String(args[0]));
783
+ expect(evaluateCalls.some((js) => js.includes('Write a caption'))).toBe(false);
784
+ expect(result).toEqual([
785
+ {
786
+ status: '✅ Posted',
787
+ detail: 'Single image post shared successfully',
788
+ url: 'https://www.instagram.com/p/NOCAPTION123/',
789
+ },
790
+ ]);
791
+ });
792
+ it('falls back to browser-side file injection when the extension does not support set-file-input', async () => {
793
+ const imagePath = createTempImage('legacy-extension.jpg');
794
+ const evaluate = vi.fn(async (js) => {
795
+ if (js.includes('sharing') && js.includes('create new post'))
796
+ return { ok: false };
797
+ if (js.includes('window.location?.pathname'))
798
+ return { ok: true };
799
+ if (js.includes('data-opencli-ig-upload-index'))
800
+ return { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] };
801
+ if (js.includes('__opencliInstagramUpload_') && js.includes('] = [];'))
802
+ return { ok: true };
803
+ if (js.includes('parts.push(chunk)'))
804
+ return { ok: true, count: 1 };
805
+ if (js.includes('File input not found for fallback injection'))
806
+ return { ok: true, count: 1 };
807
+ if (js.includes('const hasPreviewUi ='))
808
+ return { ok: true, state: 'preview' };
809
+ if (js.includes("scope === 'caption'"))
810
+ return { ok: true, label: 'Share' };
811
+ if (js.includes("scope === 'media'"))
812
+ return { ok: true, label: 'Next' };
813
+ if (js.includes('labels.includes(text)'))
814
+ return { ok: false };
815
+ if (js.includes('ClipboardEvent') && js.includes('textarea'))
816
+ return { ok: true, mode: 'textarea' };
817
+ if (js.includes('readLexicalText'))
818
+ return { ok: true };
819
+ if (js.includes('couldn') && js.includes('your post has been shared'))
820
+ return { ok: true, url: 'https://www.instagram.com/p/LEGACY123/' };
821
+ return { ok: true };
822
+ });
823
+ const page = createPageMock([], {
824
+ evaluate,
825
+ setFileInput: vi.fn().mockRejectedValue(new Error('Unknown action: set-file-input')),
826
+ });
827
+ const cmd = getRegistry().get('instagram/post');
828
+ const result = await cmd.func(page, {
829
+ media: imagePath,
830
+ content: 'legacy bridge fallback',
831
+ });
832
+ expect(page.setFileInput).toHaveBeenCalledWith([imagePath], '[data-opencli-ig-upload-index="0"]');
833
+ expect(result).toEqual([
834
+ {
835
+ status: '✅ Posted',
836
+ detail: 'Single image post shared successfully',
837
+ url: 'https://www.instagram.com/p/LEGACY123/',
838
+ },
839
+ ]);
840
+ });
841
+ it('chunks large legacy fallback uploads instead of embedding the whole image in one evaluate payload', async () => {
842
+ const imagePath = createTempImage('legacy-large.jpg', Buffer.alloc(900 * 1024, 1));
843
+ const evaluate = vi.fn(async (js) => {
844
+ if (js.includes('sharing') && js.includes('create new post'))
845
+ return { ok: false };
846
+ if (js.includes('window.location?.pathname'))
847
+ return { ok: true };
848
+ if (js.includes('data-opencli-ig-upload-index'))
849
+ return { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] };
850
+ if (js.includes('window[') && js.includes('] = [];'))
851
+ return { ok: true };
852
+ if (js.includes('parts.push(chunk)'))
853
+ return { ok: true, count: 1 };
854
+ if (js.includes('File input not found for fallback injection'))
855
+ return { ok: true, count: 1 };
856
+ if (js.includes('const hasPreviewUi ='))
857
+ return { ok: true, state: 'preview' };
858
+ if (js.includes("scope === 'caption'"))
859
+ return { ok: true, label: 'Share' };
860
+ if (js.includes("scope === 'media'"))
861
+ return { ok: true, label: 'Next' };
862
+ if (js.includes('labels.includes(text)'))
863
+ return { ok: false };
864
+ if (js.includes('ClipboardEvent') && js.includes('textarea'))
865
+ return { ok: true, mode: 'textarea' };
866
+ if (js.includes('readLexicalText'))
867
+ return { ok: true };
868
+ if (js.includes('couldn') && js.includes('your post has been shared'))
869
+ return { ok: true, url: 'https://www.instagram.com/p/LARGELEGACY123/' };
870
+ return { ok: true };
871
+ });
872
+ const page = createPageMock([], {
873
+ evaluate,
874
+ setFileInput: vi.fn().mockRejectedValue(new Error('Unknown action: set-file-input')),
875
+ });
876
+ const cmd = getRegistry().get('instagram/post');
877
+ const result = await cmd.func(page, {
878
+ media: imagePath,
879
+ content: 'legacy large bridge fallback',
880
+ });
881
+ const chunkCalls = evaluate.mock.calls.filter((args) => String(args[0]).includes('parts.push(chunk)'));
882
+ expect(chunkCalls.length).toBeGreaterThan(1);
883
+ expect(result).toEqual([
884
+ {
885
+ status: '✅ Posted',
886
+ detail: 'Single image post shared successfully',
887
+ url: 'https://www.instagram.com/p/LARGELEGACY123/',
888
+ },
889
+ ]);
890
+ });
891
+ it('fails clearly when Browser Bridge file upload support is unavailable', async () => {
892
+ const imagePath = createTempImage('missing-bridge.jpg');
893
+ const page = createPageMock([], { setFileInput: undefined });
894
+ const cmd = getRegistry().get('instagram/post');
895
+ await expect(cmd.func(page, {
896
+ media: imagePath,
897
+ content: 'hello from opencli',
898
+ })).rejects.toThrow(CommandExecutionError);
899
+ });
900
+ it('maps login-gated composer access to AuthRequiredError', async () => {
901
+ const imagePath = createTempImage('auth.jpg');
902
+ const page = createPageMock(withInitialDialogDismiss([
903
+ { ok: false, reason: 'auth' },
904
+ ]));
905
+ const cmd = getRegistry().get('instagram/post');
906
+ await expect(cmd.func(page, {
907
+ media: imagePath,
908
+ content: 'login required',
909
+ })).rejects.toThrow(AuthRequiredError);
910
+ });
911
+ it('captures a debug screenshot when the upload preview never appears', async () => {
912
+ const imagePath = createTempImage('no-preview.jpg');
913
+ const page = createPageMock(withInitialDialogDismiss([
914
+ { ok: true },
915
+ { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] },
916
+ { ok: true },
917
+ { ok: false },
918
+ { ok: false },
919
+ { ok: false },
920
+ { ok: false },
921
+ { ok: false },
922
+ { ok: false },
923
+ { ok: false },
924
+ { ok: false },
925
+ { ok: false },
926
+ { ok: false },
927
+ { ok: false },
928
+ { ok: false },
929
+ { ok: false },
930
+ ]));
931
+ const cmd = getRegistry().get('instagram/post');
932
+ await expect(cmd.func(page, {
933
+ media: imagePath,
934
+ content: 'preview missing',
935
+ })).rejects.toThrow('Instagram image preview did not appear after upload');
936
+ expect(page.screenshot).toHaveBeenCalledWith({ path: '/tmp/instagram_post_preview_debug.png' });
937
+ });
938
+ it('fails clearly when Instagram shows an upload-stage error dialog', async () => {
939
+ const imagePath = createTempImage('upload-error.jpg');
940
+ const page = createPageMock(withInitialDialogDismiss([
941
+ { ok: true },
942
+ { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] },
943
+ { ok: true },
944
+ { ok: false, state: 'failed', detail: 'Something went wrong. Please try again.' },
945
+ ]));
946
+ const cmd = getRegistry().get('instagram/post');
947
+ await expect(cmd.func(page, {
948
+ media: imagePath,
949
+ content: 'upload should fail clearly',
950
+ })).rejects.toThrow('Instagram image upload failed');
951
+ });
952
+ it('treats crop/next preview UI as success even if stale error text is still visible', async () => {
953
+ const imagePath = createTempImage('upload-preview-wins.jpg');
954
+ const page = createPageMock(withInitialDialogDismiss([
955
+ { ok: true },
956
+ { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] },
957
+ { ok: true },
958
+ {
959
+ ok: false,
960
+ state: 'preview',
961
+ detail: 'Something went wrong. Please try again. Crop Back Next Select crop Select zoom Open media gallery',
962
+ },
963
+ { ok: false },
964
+ { ok: true, label: 'Next' },
965
+ { ok: true },
966
+ { ok: true },
967
+ { ok: true },
968
+ { ok: true, label: 'Share' },
969
+ { ok: true, url: 'https://www.instagram.com/p/PREVIEWWINS123/' },
970
+ ]));
971
+ const cmd = getRegistry().get('instagram/post');
972
+ const result = await cmd.func(page, {
973
+ media: imagePath,
974
+ content: 'preview state wins over stale error text',
975
+ });
976
+ expect(result).toEqual([
977
+ {
978
+ status: '✅ Posted',
979
+ detail: 'Single image post shared successfully',
980
+ url: 'https://www.instagram.com/p/PREVIEWWINS123/',
981
+ },
982
+ ]);
983
+ });
984
+ it('retries the same upload selector once after an upload-stage error and can still succeed', async () => {
985
+ const imagePath = createTempImage('upload-retry.jpg');
986
+ const setFileInput = vi.fn().mockResolvedValue(undefined);
987
+ let uploadProbeCount = 0;
988
+ const evaluate = vi.fn(async (js) => {
989
+ if (js.includes('sharing') && js.includes('create new post'))
990
+ return { ok: false };
991
+ if (js.includes('window.location?.pathname'))
992
+ return { ok: true };
993
+ if (js.includes('data-opencli-ig-upload-index'))
994
+ return { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] };
995
+ if (js.includes("dispatchEvent(new Event('input'"))
996
+ return { ok: true };
997
+ if (js.includes('const failed =') && js.includes('const hasCaption =')) {
998
+ uploadProbeCount += 1;
999
+ return uploadProbeCount === 1
1000
+ ? { ok: false, state: 'failed', detail: 'Something went wrong. Please try again.' }
1001
+ : { ok: true, state: 'preview' };
1002
+ }
1003
+ if (js.includes('button[aria-label="Close"]'))
1004
+ return { ok: true };
1005
+ if (js.includes("scope === 'media'"))
1006
+ return { ok: true, label: 'Next' };
1007
+ if (js.includes('ClipboardEvent') && js.includes('textarea'))
1008
+ return { ok: true, mode: 'textarea' };
1009
+ if (js.includes('readLexicalText'))
1010
+ return { ok: true };
1011
+ if (js.includes("scope === 'caption'"))
1012
+ return { ok: true, label: 'Share' };
1013
+ if (js.includes('post shared') && js.includes('your post has been shared'))
1014
+ return { ok: true, url: 'https://www.instagram.com/p/UPLOADRETRY123/' };
1015
+ return { ok: true };
1016
+ });
1017
+ const page = createPageMock([], { setFileInput, evaluate });
1018
+ const cmd = getRegistry().get('instagram/post');
1019
+ const result = await cmd.func(page, {
1020
+ media: imagePath,
1021
+ content: 'upload retry succeeds',
1022
+ });
1023
+ expect(setFileInput).toHaveBeenCalledTimes(1);
1024
+ expect(result).toEqual([
1025
+ {
1026
+ status: '✅ Posted',
1027
+ detail: 'Single image post shared successfully',
1028
+ url: 'https://www.instagram.com/p/UPLOADRETRY123/',
1029
+ },
1030
+ ]);
1031
+ });
1032
+ it('clicks upload Try again in-place before resetting the whole flow when Instagram shows an upload error dialog', async () => {
1033
+ const imagePath = createTempImage('upload-inline-retry.jpg');
1034
+ let uploadProbeCount = 0;
1035
+ const evaluate = vi.fn(async (js) => {
1036
+ if (js.includes('sharing') && js.includes('create new post'))
1037
+ return { ok: false };
1038
+ if (js.includes('window.location?.pathname'))
1039
+ return { ok: true };
1040
+ if (js.includes('data-opencli-ig-upload-index'))
1041
+ return { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] };
1042
+ if (js.includes("dispatchEvent(new Event('input'"))
1043
+ return { ok: true };
1044
+ if (js.includes('const hasVisibleButtonInDialogs')) {
1045
+ uploadProbeCount += 1;
1046
+ return uploadProbeCount === 1
1047
+ ? { state: 'failed', detail: 'Something went wrong. Please try again.' }
1048
+ : { state: 'preview', detail: 'Crop Back Next Select crop' };
1049
+ }
1050
+ if (js.includes('something went wrong') && js.includes('label === \'try again\''))
1051
+ return { ok: true };
1052
+ if (js.includes("dialogText.includes('write a caption')") || js.includes("const editable = document.querySelector('textarea, [contenteditable=\"true\"]');")) {
1053
+ return { ok: true };
1054
+ }
1055
+ if (js.includes("!labels.includes(text) && !labels.includes(aria)")) {
1056
+ if (js.includes('"Share"'))
1057
+ return { ok: true, label: 'Share' };
1058
+ return { ok: true, label: 'Next' };
1059
+ }
1060
+ if (js.includes('ClipboardEvent') && js.includes('textarea'))
1061
+ return { ok: true, mode: 'textarea' };
1062
+ if (js.includes('readLexicalText'))
1063
+ return { ok: true };
1064
+ if (js.includes('post shared') && js.includes('your post has been shared'))
1065
+ return { ok: true, url: 'https://www.instagram.com/p/UPLOADINLINERETRY123/' };
1066
+ return { ok: true };
1067
+ });
1068
+ const page = createPageMock([], { evaluate });
1069
+ const cmd = getRegistry().get('instagram/post');
1070
+ const result = await cmd.func(page, {
1071
+ media: imagePath,
1072
+ content: 'upload inline retry succeeds',
1073
+ });
1074
+ expect(result).toEqual([
1075
+ {
1076
+ status: '✅ Posted',
1077
+ detail: 'Single image post shared successfully',
1078
+ url: 'https://www.instagram.com/p/UPLOADINLINERETRY123/',
1079
+ },
1080
+ ]);
1081
+ });
1082
+ it('retries max-size carousel upload failures beyond the expanded large-carousel budget before succeeding', async () => {
1083
+ const paths = [
1084
+ createTempImage('carousel-10-1.jpg'),
1085
+ createTempImage('carousel-10-2.jpg'),
1086
+ createTempImage('carousel-10-3.jpg'),
1087
+ createTempImage('carousel-10-4.jpg'),
1088
+ createTempImage('carousel-10-5.jpg'),
1089
+ createTempImage('carousel-10-6.jpg'),
1090
+ createTempImage('carousel-10-7.jpg'),
1091
+ createTempImage('carousel-10-8.jpg'),
1092
+ createTempImage('carousel-10-9.jpg'),
1093
+ createTempImage('carousel-10-10.jpg'),
1094
+ ];
1095
+ const setFileInput = vi.fn().mockResolvedValue(undefined);
1096
+ let uploadProbeCount = 0;
1097
+ const evaluate = vi.fn(async (js) => {
1098
+ if (js.includes('sharing') && js.includes('create new post'))
1099
+ return { ok: false };
1100
+ if (js.includes('window.location?.pathname'))
1101
+ return { ok: true };
1102
+ if (js.includes('data-opencli-ig-upload-index'))
1103
+ return { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] };
1104
+ if (js.includes("dispatchEvent(new Event('input'"))
1105
+ return { ok: true };
1106
+ if (js.includes('const hasVisibleButtonInDialogs')) {
1107
+ uploadProbeCount += 1;
1108
+ if (uploadProbeCount <= 16) {
1109
+ return { state: 'failed', detail: 'Something went wrong. Please try again.' };
1110
+ }
1111
+ return { state: 'preview', detail: 'Crop Back Next Select crop' };
1112
+ }
1113
+ if (js.includes('button[aria-label="Close"]'))
1114
+ return { ok: true };
1115
+ if (js.includes("dialogText.includes('write a caption')") || js.includes("const editable = document.querySelector('textarea, [contenteditable=\"true\"]');")) {
1116
+ return { ok: true };
1117
+ }
1118
+ if (js.includes("!labels.includes(text) && !labels.includes(aria)")) {
1119
+ if (js.includes('"Share"'))
1120
+ return { ok: true, label: 'Share' };
1121
+ return { ok: true, label: 'Next' };
1122
+ }
1123
+ if (js.includes('post shared') && js.includes('your post has been shared'))
1124
+ return { ok: true, url: 'https://www.instagram.com/p/CAROUSEL10RETRY123/' };
1125
+ return { ok: true };
1126
+ });
1127
+ const page = createPageMock([], { setFileInput, evaluate });
1128
+ const cmd = getRegistry().get('instagram/post');
1129
+ const result = await cmd.func(page, {
1130
+ media: paths.join(','),
1131
+ });
1132
+ expect(setFileInput).toHaveBeenCalledTimes(5);
1133
+ expect(result).toEqual([
1134
+ {
1135
+ status: '✅ Posted',
1136
+ detail: '10-image carousel post shared successfully',
1137
+ url: 'https://www.instagram.com/p/CAROUSEL10RETRY123/',
1138
+ },
1139
+ ]);
1140
+ });
1141
+ it('forces a fresh home reload before retrying after an upload-stage error', async () => {
1142
+ const imagePath = createTempImage('upload-fresh-reload.jpg');
1143
+ const gotoUrls = [];
1144
+ const goto = vi.fn(async (url) => {
1145
+ gotoUrls.push(String(url));
1146
+ });
1147
+ let uploadProbeCount = 0;
1148
+ let advancedToCaption = false;
1149
+ const evaluate = vi.fn(async (js) => {
1150
+ if (js.includes('window.location?.pathname'))
1151
+ return { ok: true };
1152
+ if (js.includes('data-opencli-ig-upload-index'))
1153
+ return { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] };
1154
+ if (js.includes("dispatchEvent(new Event('input'"))
1155
+ return { ok: true };
1156
+ if (js.includes("dialogText.includes('write a caption')") || js.includes("const editable = document.querySelector('textarea, [contenteditable=\"true\"]');")) {
1157
+ return { ok: advancedToCaption };
1158
+ }
1159
+ if (js.includes('const hasPreviewUi =')) {
1160
+ uploadProbeCount += 1;
1161
+ if (uploadProbeCount === 1) {
1162
+ return { ok: false, state: 'failed', detail: 'Something went wrong. Please try again.' };
1163
+ }
1164
+ return gotoUrls.some((url) => url.includes('__opencli_reset='))
1165
+ ? { ok: true, state: 'preview' }
1166
+ : { ok: false, state: 'failed', detail: 'Something went wrong. Please try again.' };
1167
+ }
1168
+ if (js.includes('button[aria-label="Close"]'))
1169
+ return { ok: false };
1170
+ if (js.includes("scope === 'media'")) {
1171
+ advancedToCaption = true;
1172
+ return { ok: true, label: 'Next' };
1173
+ }
1174
+ if (js.includes('ClipboardEvent') && js.includes('textarea'))
1175
+ return { ok: true, mode: 'textarea' };
1176
+ if (js.includes('readLexicalText'))
1177
+ return { ok: true };
1178
+ if (js.includes("scope === 'caption'"))
1179
+ return { ok: true, label: 'Share' };
1180
+ if (js.includes('post shared') && js.includes('your post has been shared'))
1181
+ return { ok: true, url: 'https://www.instagram.com/p/FRESHRELOAD123/' };
1182
+ return { ok: false };
1183
+ });
1184
+ const page = createPageMock([], {
1185
+ goto,
1186
+ evaluate,
1187
+ setFileInput: vi.fn().mockResolvedValue(undefined),
1188
+ });
1189
+ const cmd = getRegistry().get('instagram/post');
1190
+ const result = await cmd.func(page, {
1191
+ media: imagePath,
1192
+ content: 'fresh reload after upload failure',
1193
+ });
1194
+ expect(gotoUrls.some((url) => url.includes('__opencli_reset='))).toBe(true);
1195
+ expect(result).toEqual([
1196
+ {
1197
+ status: '✅ Posted',
1198
+ detail: 'Single image post shared successfully',
1199
+ url: 'https://www.instagram.com/p/FRESHRELOAD123/',
1200
+ },
1201
+ ]);
1202
+ });
1203
+ it('retries the share action in-place when Instagram shows a visible try-again share failure dialog', async () => {
1204
+ const imagePath = createTempImage('share-retry.jpg');
1205
+ let shareStatusChecks = 0;
1206
+ const evaluate = vi.fn(async (js) => {
1207
+ if (js.includes('sharing') && js.includes('create new post'))
1208
+ return { ok: false };
1209
+ if (js.includes('window.location?.pathname'))
1210
+ return { ok: true };
1211
+ if (js.includes('data-opencli-ig-upload-index'))
1212
+ return { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] };
1213
+ if (js.includes("dispatchEvent(new Event('input'"))
1214
+ return { ok: true };
1215
+ if (js.includes('const hasVisibleButtonInDialogs'))
1216
+ return { state: 'preview', detail: 'Crop Back Next Select crop' };
1217
+ if (js.includes("dialogText.includes('write a caption')") || js.includes("const editable = document.querySelector('textarea, [contenteditable=\"true\"]');")) {
1218
+ return { ok: true };
1219
+ }
1220
+ if (js.includes("!labels.includes(text) && !labels.includes(aria)")) {
1221
+ if (js.includes('"Share"'))
1222
+ return { ok: true, label: 'Share' };
1223
+ return { ok: true, label: 'Next' };
1224
+ }
1225
+ if (js.includes('ClipboardEvent') && js.includes('textarea'))
1226
+ return { ok: true, mode: 'textarea' };
1227
+ if (js.includes('readLexicalText'))
1228
+ return { ok: true };
1229
+ if (js.includes('post shared') && js.includes('your post has been shared')) {
1230
+ shareStatusChecks += 1;
1231
+ return shareStatusChecks === 1
1232
+ ? { ok: false, failed: true, settled: false, url: '' }
1233
+ : { ok: true, failed: false, settled: false, url: 'https://www.instagram.com/p/SHARERETRY123/' };
1234
+ }
1235
+ if (js.includes('post couldn') && js.includes('try again'))
1236
+ return { ok: true };
1237
+ return { ok: true };
1238
+ });
1239
+ const page = createPageMock([], { evaluate });
1240
+ const cmd = getRegistry().get('instagram/post');
1241
+ const result = await cmd.func(page, {
1242
+ media: imagePath,
1243
+ content: 'share retry succeeds',
1244
+ });
1245
+ expect(result).toEqual([
1246
+ {
1247
+ status: '✅ Posted',
1248
+ detail: 'Single image post shared successfully',
1249
+ url: 'https://www.instagram.com/p/SHARERETRY123/',
1250
+ },
1251
+ ]);
1252
+ });
1253
+ it('re-resolves the upload input when the tagged selector goes stale before setFileInput runs', async () => {
1254
+ const imagePath = createTempImage('stale-selector.jpg');
1255
+ const setFileInput = vi.fn()
1256
+ .mockRejectedValueOnce(new Error('No element found matching selector: [data-opencli-ig-upload-index="0"]'))
1257
+ .mockResolvedValueOnce(undefined);
1258
+ const page = createPageMock(withInitialDialogDismiss([
1259
+ { ok: true },
1260
+ { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] },
1261
+ { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] },
1262
+ { ok: true },
1263
+ { ok: true },
1264
+ { ok: false },
1265
+ { ok: true, label: 'Next' },
1266
+ { ok: true },
1267
+ { ok: true },
1268
+ { ok: true },
1269
+ { ok: true, label: 'Share' },
1270
+ { ok: true, url: 'https://www.instagram.com/p/STALE123/' },
1271
+ ]), { setFileInput });
1272
+ const cmd = getRegistry().get('instagram/post');
1273
+ const result = await cmd.func(page, {
1274
+ media: imagePath,
1275
+ content: 'stale selector recovery',
1276
+ });
1277
+ expect(setFileInput).toHaveBeenCalledTimes(2);
1278
+ expect(result).toEqual([
1279
+ {
1280
+ status: '✅ Posted',
1281
+ detail: 'Single image post shared successfully',
1282
+ url: 'https://www.instagram.com/p/STALE123/',
1283
+ },
1284
+ ]);
1285
+ });
1286
+ it('re-resolves the upload input when CDP loses the matched file-input node before setFileInput runs', async () => {
1287
+ const imagePath = createTempImage('stale-node-id.jpg');
1288
+ const setFileInput = vi.fn()
1289
+ .mockRejectedValueOnce(new Error('{"code":-32000,"message":"Could not find node with given id"}'))
1290
+ .mockResolvedValueOnce(undefined);
1291
+ const page = createPageMock(withInitialDialogDismiss([
1292
+ { ok: true },
1293
+ { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] },
1294
+ { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] },
1295
+ { ok: true },
1296
+ { ok: true },
1297
+ { ok: false },
1298
+ { ok: true, label: 'Next' },
1299
+ { ok: true },
1300
+ { ok: true },
1301
+ { ok: true },
1302
+ { ok: true, label: 'Share' },
1303
+ { ok: true, url: 'https://www.instagram.com/p/STALEID123/' },
1304
+ ]), { setFileInput });
1305
+ const cmd = getRegistry().get('instagram/post');
1306
+ const result = await cmd.func(page, {
1307
+ media: imagePath,
1308
+ content: 'stale node id recovery',
1309
+ });
1310
+ expect(setFileInput).toHaveBeenCalledTimes(2);
1311
+ expect(result).toEqual([
1312
+ {
1313
+ status: '✅ Posted',
1314
+ detail: 'Single image post shared successfully',
1315
+ url: 'https://www.instagram.com/p/STALEID123/',
1316
+ },
1317
+ ]);
1318
+ });
1319
+ it('retries opening the home composer instead of navigating to the broken /create/select route', async () => {
1320
+ const imagePath = createTempImage('retry-composer.jpg');
1321
+ const page = createPageMock(withInitialDialogDismiss([
1322
+ { ok: true },
1323
+ { ok: false },
1324
+ { ok: true },
1325
+ { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] },
1326
+ { ok: true },
1327
+ { ok: true },
1328
+ { ok: false },
1329
+ { ok: true, label: 'Next' },
1330
+ { ok: true },
1331
+ { ok: true },
1332
+ { ok: true },
1333
+ { ok: true, label: 'Share' },
1334
+ { ok: true, url: 'https://www.instagram.com/p/FALLBACK123/' },
1335
+ ]));
1336
+ const cmd = getRegistry().get('instagram/post');
1337
+ const result = await cmd.func(page, {
1338
+ media: imagePath,
1339
+ content: 'retry composer',
1340
+ });
1341
+ const gotoCalls = page.goto.mock.calls.map((args) => String(args[0]));
1342
+ expect(gotoCalls.every((url) => !url.includes('/create/select'))).toBe(true);
1343
+ expect(gotoCalls.some((url) => url === 'https://www.instagram.com/')).toBe(true);
1344
+ expect(result).toEqual([
1345
+ {
1346
+ status: '✅ Posted',
1347
+ detail: 'Single image post shared successfully',
1348
+ url: 'https://www.instagram.com/p/FALLBACK123/',
1349
+ },
1350
+ ]);
1351
+ });
1352
+ it('clicks Next twice when Instagram shows an intermediate preview step before the caption editor', async () => {
1353
+ const imagePath = createTempImage('double-next.jpg');
1354
+ let nextClicks = 0;
1355
+ const evaluate = vi.fn(async (js) => {
1356
+ if (js.includes('sharing') && js.includes('create new post'))
1357
+ return { ok: false };
1358
+ if (js.includes('window.location?.pathname'))
1359
+ return { ok: true };
1360
+ if (js.includes('data-opencli-ig-upload-index'))
1361
+ return { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] };
1362
+ if (js.includes("dispatchEvent(new Event('input'"))
1363
+ return { ok: true };
1364
+ if (js.includes('const hasVisibleButtonInDialogs'))
1365
+ return { state: 'preview', detail: 'Crop Back Next Select crop' };
1366
+ if (js.includes("dialogText.includes('write a caption')") || js.includes("const editable = document.querySelector('textarea, [contenteditable=\"true\"]');")) {
1367
+ return { ok: nextClicks >= 2 };
1368
+ }
1369
+ if (js.includes("!labels.includes(text) && !labels.includes(aria)")) {
1370
+ if (js.includes('"Share"'))
1371
+ return { ok: true, label: 'Share' };
1372
+ nextClicks += 1;
1373
+ return { ok: true, label: 'Next' };
1374
+ }
1375
+ if (js.includes('ClipboardEvent') && js.includes('textarea'))
1376
+ return { ok: true, mode: 'textarea' };
1377
+ if (js.includes('readLexicalText'))
1378
+ return { ok: true };
1379
+ if (js.includes('post shared') && js.includes('your post has been shared'))
1380
+ return { ok: true, url: 'https://www.instagram.com/p/DOUBLE123/' };
1381
+ return { ok: true };
1382
+ });
1383
+ const page = createPageMock([], { evaluate });
1384
+ const cmd = getRegistry().get('instagram/post');
1385
+ const result = await cmd.func(page, {
1386
+ media: imagePath,
1387
+ content: 'double next flow',
1388
+ });
1389
+ expect(result).toEqual([
1390
+ {
1391
+ status: '✅ Posted',
1392
+ detail: 'Single image post shared successfully',
1393
+ url: 'https://www.instagram.com/p/DOUBLE123/',
1394
+ },
1395
+ ]);
1396
+ });
1397
+ it('tries the next upload input when the first candidate never opens the preview', async () => {
1398
+ const imagePath = createTempImage('second-input.jpg');
1399
+ const setFileInput = vi.fn()
1400
+ .mockResolvedValueOnce(undefined)
1401
+ .mockResolvedValueOnce(undefined);
1402
+ const page = createPageMock(withInitialDialogDismiss([
1403
+ { ok: true },
1404
+ { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]', '[data-opencli-ig-upload-index="1"]'] },
1405
+ { ok: true },
1406
+ { ok: false },
1407
+ { ok: false },
1408
+ { ok: false },
1409
+ { ok: false },
1410
+ { ok: false },
1411
+ { ok: false },
1412
+ { ok: false },
1413
+ { ok: false },
1414
+ { ok: true },
1415
+ { ok: true },
1416
+ { ok: false },
1417
+ { ok: true, label: 'Next' },
1418
+ { ok: true },
1419
+ { ok: true },
1420
+ { ok: true },
1421
+ { ok: true, label: 'Share' },
1422
+ { ok: true, url: 'https://www.instagram.com/p/SECOND123/' },
1423
+ ]), { setFileInput });
1424
+ const cmd = getRegistry().get('instagram/post');
1425
+ const result = await cmd.func(page, {
1426
+ media: imagePath,
1427
+ content: 'second input works',
1428
+ });
1429
+ expect(setFileInput).toHaveBeenNthCalledWith(1, [imagePath], '[data-opencli-ig-upload-index="0"]');
1430
+ expect(setFileInput).toHaveBeenNthCalledWith(2, [imagePath], '[data-opencli-ig-upload-index="1"]');
1431
+ expect(result).toEqual([
1432
+ {
1433
+ status: '✅ Posted',
1434
+ detail: 'Single image post shared successfully',
1435
+ url: 'https://www.instagram.com/p/SECOND123/',
1436
+ },
1437
+ ]);
1438
+ });
1439
+ it('fails fast when Instagram reports that the post could not be shared', async () => {
1440
+ const imagePath = createTempImage('share-failed.jpg');
1441
+ const page = createPageMock(withInitialDialogDismiss([
1442
+ { ok: true },
1443
+ { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] },
1444
+ { ok: true },
1445
+ { ok: true },
1446
+ { ok: false },
1447
+ { ok: true, label: 'Next' },
1448
+ { ok: true },
1449
+ { ok: true },
1450
+ { ok: true },
1451
+ { ok: true, label: 'Share' },
1452
+ { ok: false, failed: true, url: '' },
1453
+ ]));
1454
+ const cmd = getRegistry().get('instagram/post');
1455
+ await expect(cmd.func(page, {
1456
+ media: imagePath,
1457
+ content: 'share should fail',
1458
+ })).rejects.toThrow('Instagram post share failed');
1459
+ });
1460
+ it('keeps waiting across the full publish timeout window instead of fast-forwarding after 30 polls', async () => {
1461
+ const imagePath = createTempImage('slow-share.jpg');
1462
+ const page = createPageMock(withInitialDialogDismiss([
1463
+ { ok: true },
1464
+ { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] },
1465
+ { ok: true },
1466
+ { ok: true },
1467
+ { ok: false },
1468
+ { ok: true, label: 'Next' },
1469
+ { ok: true },
1470
+ { ok: true },
1471
+ { ok: true },
1472
+ { ok: true, label: 'Share' },
1473
+ ...Array.from({ length: 35 }, () => ({ ok: false, failed: false, settled: false, url: '' })),
1474
+ { ok: true, url: 'https://www.instagram.com/p/SLOWSHARE123/' },
1475
+ ]));
1476
+ const cmd = getRegistry().get('instagram/post');
1477
+ const result = await cmd.func(page, {
1478
+ media: imagePath,
1479
+ content: 'slow share eventually succeeds',
1480
+ });
1481
+ const waitCalls = page.wait.mock.calls.filter((args) => args[0]?.time === 1);
1482
+ expect(waitCalls.length).toBeGreaterThanOrEqual(35);
1483
+ expect(result).toEqual([
1484
+ {
1485
+ status: '✅ Posted',
1486
+ detail: 'Single image post shared successfully',
1487
+ url: 'https://www.instagram.com/p/SLOWSHARE123/',
1488
+ },
1489
+ ]);
1490
+ });
1491
+ it('does not retry the upload flow after Share has already been clicked', async () => {
1492
+ const imagePath = createTempImage('no-duplicate-retry.jpg');
1493
+ const setFileInput = vi.fn().mockResolvedValue(undefined);
1494
+ const page = createPageMock(withInitialDialogDismiss([
1495
+ { ok: true },
1496
+ { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] },
1497
+ { ok: true },
1498
+ { ok: true },
1499
+ { ok: false },
1500
+ { ok: true, label: 'Next' },
1501
+ { ok: true },
1502
+ { ok: true },
1503
+ { ok: true },
1504
+ { ok: true, label: 'Share' },
1505
+ ...Array.from({ length: 30 }, () => ({ ok: false, failed: false, url: '' })),
1506
+ ]), { setFileInput });
1507
+ const cmd = getRegistry().get('instagram/post');
1508
+ await expect(cmd.func(page, {
1509
+ media: imagePath,
1510
+ content: 'share observation stalled',
1511
+ })).rejects.toThrow('Instagram post share confirmation did not appear');
1512
+ expect(setFileInput).toHaveBeenCalledTimes(1);
1513
+ });
1514
+ it('recovers the latest post URL from the current logged-in profile when success does not navigate to /p/', async () => {
1515
+ const imagePath = createTempImage('url-recovery.jpg');
1516
+ const evaluate = vi.fn(async (js) => {
1517
+ if (js.includes('const data = Array.isArray(window[') && js.includes('__opencli_ig_protocol_capture')) {
1518
+ return { data: [], errors: [] };
1519
+ }
1520
+ if (js.includes('fetch(') && js.includes('/api/v1/users/') && js.includes('X-IG-App-ID')) {
1521
+ return js.includes('dynamic-runtime-app-id')
1522
+ ? { ok: true, username: 'tsezi_ray' }
1523
+ : { ok: false };
1524
+ }
1525
+ if (js.includes('window.location?.pathname'))
1526
+ return { ok: true };
1527
+ if (js.includes('data-opencli-ig-upload-index'))
1528
+ return { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] };
1529
+ if (js.includes("dispatchEvent(new Event('input'"))
1530
+ return { ok: true };
1531
+ if (js.includes('const hasPreviewUi ='))
1532
+ return { ok: true, state: 'preview' };
1533
+ if (js.includes("scope === 'media'"))
1534
+ return { ok: true, label: 'Next' };
1535
+ if (js.includes("scope === 'caption'"))
1536
+ return { ok: true, label: 'Share' };
1537
+ if (js.includes('post shared') && js.includes('your post has been shared'))
1538
+ return { ok: true, url: '' };
1539
+ if (js.includes('const hrefs = Array.from(document.querySelectorAll(\'a[href*="/p/"]\'))')) {
1540
+ const calls = evaluate.mock.calls.filter(([script]) => typeof script === 'string' && script.includes('const hrefs = Array.from(document.querySelectorAll(\'a[href*="/p/"]\'))')).length;
1541
+ return calls === 1
1542
+ ? { ok: true, hrefs: ['/tsezi_ray/p/PINNED111/', '/tsezi_ray/p/OLD222/'] }
1543
+ : { ok: true, hrefs: ['/tsezi_ray/p/PINNED111/', '/tsezi_ray/p/OLD222/', '/tsezi_ray/p/RECOVER123/'] };
1544
+ }
1545
+ if (js.includes('document.documentElement?.outerHTML')) {
1546
+ return {
1547
+ appId: 'dynamic-runtime-app-id',
1548
+ csrfToken: 'csrf-token',
1549
+ instagramAjax: 'dynamic-rollout',
1550
+ };
1551
+ }
1552
+ return { ok: true };
1553
+ });
1554
+ const page = createPageMock([], {
1555
+ evaluate,
1556
+ getCookies: vi.fn().mockResolvedValue([{ name: 'ds_user_id', value: '61236465677', domain: 'instagram.com' }]),
1557
+ });
1558
+ const cmd = getRegistry().get('instagram/post');
1559
+ const result = await cmd.func(page, {
1560
+ media: imagePath,
1561
+ content: 'url recovery',
1562
+ });
1563
+ expect(result).toEqual([
1564
+ {
1565
+ status: '✅ Posted',
1566
+ detail: 'Single image post shared successfully',
1567
+ url: 'https://www.instagram.com/tsezi_ray/p/RECOVER123/',
1568
+ },
1569
+ ]);
1570
+ });
1571
+ it('treats a closed composer as a successful share and falls back to URL recovery', async () => {
1572
+ const imagePath = createTempImage('share-settled.jpg');
1573
+ const page = createPageMock([
1574
+ { appId: 'dynamic-runtime-app-id', csrfToken: 'csrf-token', instagramAjax: 'dynamic-rollout' },
1575
+ { ok: true, username: 'tsezi_ray' },
1576
+ { ok: true, hrefs: ['/p/OLD111/'] },
1577
+ { ok: false },
1578
+ { ok: true },
1579
+ { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] },
1580
+ { ok: true },
1581
+ { ok: true },
1582
+ { ok: false },
1583
+ { ok: true, label: 'Next' },
1584
+ { ok: true },
1585
+ { ok: true },
1586
+ { ok: true },
1587
+ { ok: true, label: 'Share' },
1588
+ { ok: false, failed: false, settled: true, url: '' },
1589
+ { ok: false, failed: false, settled: true, url: '' },
1590
+ { ok: false, failed: false, settled: true, url: '' },
1591
+ { appId: 'dynamic-runtime-app-id', csrfToken: 'csrf-token', instagramAjax: 'dynamic-rollout' },
1592
+ { ok: true, username: 'tsezi_ray' },
1593
+ { ok: true, hrefs: ['/p/OLD111/', '/p/RECOVER789/'] },
1594
+ ], {
1595
+ getCookies: vi.fn().mockResolvedValue([{ name: 'ds_user_id', value: '61236465677', domain: 'instagram.com' }]),
1596
+ });
1597
+ const cmd = getRegistry().get('instagram/post');
1598
+ const result = await cmd.func(page, {
1599
+ media: imagePath,
1600
+ content: 'share settled recovery',
1601
+ });
1602
+ expect(result).toEqual([
1603
+ {
1604
+ status: '✅ Posted',
1605
+ detail: 'Single image post shared successfully',
1606
+ url: 'https://www.instagram.com/p/RECOVER789/',
1607
+ },
1608
+ ]);
1609
+ });
1610
+ it('accepts standard /p/... profile links during URL recovery', async () => {
1611
+ const imagePath = createTempImage('url-recovery-standard-shape.jpg');
1612
+ const page = createPageMock([
1613
+ { appId: 'dynamic-runtime-app-id', csrfToken: 'csrf-token', instagramAjax: 'dynamic-rollout' },
1614
+ { ok: true, username: 'tsezi_ray' },
1615
+ { ok: true, hrefs: ['/p/PINNED111/', '/p/OLD222/'] },
1616
+ { ok: false },
1617
+ { ok: true },
1618
+ { ok: true, selectors: ['[data-opencli-ig-upload-index="0"]'] },
1619
+ { ok: true },
1620
+ { ok: true },
1621
+ { ok: false },
1622
+ { ok: true, label: 'Next' },
1623
+ { ok: true },
1624
+ { ok: true },
1625
+ { ok: true },
1626
+ { ok: true, label: 'Share' },
1627
+ { ok: true, url: '' },
1628
+ { appId: 'dynamic-runtime-app-id', csrfToken: 'csrf-token', instagramAjax: 'dynamic-rollout' },
1629
+ { ok: true, username: 'tsezi_ray' },
1630
+ { ok: true, hrefs: ['/p/PINNED111/', '/p/OLD222/', '/p/RECOVER456/'] },
1631
+ ], {
1632
+ getCookies: vi.fn().mockResolvedValue([{ name: 'ds_user_id', value: '61236465677', domain: 'instagram.com' }]),
1633
+ });
1634
+ const cmd = getRegistry().get('instagram/post');
1635
+ const result = await cmd.func(page, {
1636
+ media: imagePath,
1637
+ content: 'url recovery standard shape',
1638
+ });
1639
+ expect(result).toEqual([
1640
+ {
1641
+ status: '✅ Posted',
1642
+ detail: 'Single image post shared successfully',
1643
+ url: 'https://www.instagram.com/p/RECOVER456/',
1644
+ },
1645
+ ]);
1646
+ });
1647
+ });